/*  ====================================
    Fonts
====================================  */


/*  Myriad Pro
------------------------------------  */

/*  Regular  */
@font-face {
    font-display: block;
    font-family: "Myriad Pro";
    font-style: normal;
    font-weight: 400;
    src: url("../fonts/MYRIADPRO-REGULAR.woff") format("woff");
}


/*  Semi-Bold  */
@font-face {
    font-display: block;
    font-family: "Myriad Pro";
    font-style: normal;
    font-weight: 600;
    src: url("../fonts/MYRIADPRO-SEMIBOLD.woff") format("woff");
}


/*  Bold  */
@font-face {
    font-display: block;
    font-family: "Myriad Pro";
    font-style: normal;
    font-weight: 700;
    src: url("../fonts/MYRIADPRO-BOLD.woff") format("woff");
}




/*  ====================================
    Styles
====================================  */


/*  Pseudo Elements
------------------------------------  */

::placeholder {
    color: #55555580;
}


::-moz-placeholder {
    opacity: 1;
}




/*  Tags
------------------------------------  */

a {
    color: inherit;
    text-decoration: none;
}


body {
    background: url("../images/background.png") fixed;
    font-family: "Myriad Pro", sans-serif;
    margin: 0;
}


h1, h2, h3 {
    margin-top: 0;
}


p {
    margin-top: 0;
}


strong {
    font-weight: 600;
}


svg {
    display: block;
    fill: currentColor;
    pointer-events: none;
}


ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}




/*  Shared Classses
------------------------------------  */

.container {
    margin: 0 auto;
    max-width: 1366px;
    padding: 0 40px;
}


/*  Screen Reader  */
.screen-reader {
    position: absolute;
    transform: scale(0);
}




/*  Header
------------------------------------  */

.header {
    background-color: #FFF;
    box-shadow: 0px 0px 50px rgba(0, 110, 88, 0.1);
    height: 107px;
    margin-bottom: 69px;
    position: sticky;
    top: 0;
    width: 100%;
    z-index: 1;
}

.header::before {
    background-color: #2a6654;
    content: "";
    display: block;
    height: 4px;
    left: 40px;
    position: absolute;
    top: 20px;
    width: calc(100% - 80px);
}

.header .container {
    display: flex;
}


.hr-logo {
    background-color: #FFF;;
    content: url("../images/logo.png");
    padding: 16px 40px 20px;
    position: relative;
}


.hr-navigation {
    align-self: center;
    margin: 24px 40px 0 auto;
}

.hr-navigation ul {
    color: #555555;
    display: flex;
    font-size: 18px;
    font-weight: 600;
}

.hr-navigation li:not(:last-child) {
    margin-right: 24px;
}

.hr-navigation .cookies {
    display: none;
}


.hr-navigation a:not(.button) {
    transition: color 0.10s ease-in;
}

.hr-navigation a:not(.button):hover {
    color: #F15D2A;
}


.hr-navigation .button {
    background-color: #F15D2A;
    border-radius: 5px;
    box-shadow: 0px 0px 15px rgba(241, 93, 42, 0.5);
    color: #FFF;
    padding: 11px 16px;
    transition: box-shadow 0.10s ease-in;
}

.hr-navigation .button:hover {
    box-shadow: 0px 0px 20px rgba(241, 93, 42, 0.75);
}




/*  Main
------------------------------------  */

.mn-offer--details {
    display: grid;
    grid-column-gap: 40px;
    grid-template-columns: 1fr 1fr;
    margin-bottom: 80px;
    padding: 0 40px;
    position: relative;
}

.mn-offer--details__text {
    font-size: 18px;
    position: relative;
}

.mn-offer--details__text h1 {
    color: #006E58;
    font-size: 36px;
    line-height: 45px;
    margin: 0 0 27px;
}

.mn-offer--details__text p {
    color: #555555;
    line-height: 27px;
    margin: 0 0 26px;
}

.mn-offer--details__text a {
    align-items: center;
    border-radius: 5px;
    display: flex;
    font-weight: 600;
    justify-content: space-between;
    padding: 16px 17px 16px 24px;
    transition: box-shadow 0.10s ease-in;
}

.mn-offer--details__text a::after {
    font-size: 0;
    margin-left: 24px;
}

.mn-offer--details__text a:first-of-type {
    background-color: #F15D2A;
    box-shadow: 0px 0px 15px rgba(241, 93, 42, 0.5);
    color: #FFF;
    margin-bottom: 12px;
}

.mn-offer--details__text a:first-of-type::after {
    content: url("../svgs/file-edit.svg");
}

.mn-offer--details__text a:first-of-type:hover {
    box-shadow: 0px 0px 20px rgba(241, 93, 42, 0.75);
}

.mn-offer--details__text a:last-of-type {
    background-color: #FFFF;
    box-shadow: 0px 0px 15px rgba(0, 110, 88, 0.05);
    color: #006E58;
}

.mn-offer--details__text a:last-of-type::after {
    content: url("../svgs/external-link.svg");
}

.mn-offer--details__text a:last-of-type:hover {
    box-shadow: 0px 0px 20px rgba(0, 110, 88, 0.25);
}

.mn-offer--details__images:not(.mobile) {
    bottom: -140px;
    padding-top: 35px;
    position: absolute;
    right: 40px;
}

.mn-offer--details__images.mobile {
    display: none;
}

.mn-offer--details__images.mixta {
    content: url("../images/mixta.png");
}

.mn-offer--details__images.junior {
    content: url("../images/junior.png");
}



.mn-offer--benefits {
    background-color: #006E58;
    border-radius: 3px;
    box-shadow: 0px 0px 25px rgba(0, 110, 88, 0.5);
    color: #FFF;
    margin-bottom: 76px;
    padding: 44px 40px 41px;
}

.mn-offer--benefits h2 {
    font-size: 24px;
    line-height: 24px;
    margin-bottom: 43px;
}

.mn-offer--benefits__inner {
    display: grid;
    grid-column-gap: 40px;
    grid-template-columns: 1fr 1fr;
}

.mn-offer--benefits section {
    padding: 0 0 0 24px;
    position: relative;
}

.mn-offer--benefits section::before {
    border-radius: 3px;
    content: "";
    height: calc(100% - 6px);
    background-color: #BED730;
    left: 0;
    position: absolute;
    top: 5px;
    width: 8px;
}

.mn-offer--benefits section:first-child:not(:only-child),
.mn-offer--benefits section:nth-child(2) {
    margin-bottom: 34px;
}

.mn-offer--benefits section .title {
    align-items: center;
    color: #BED730;
    display: flex;
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 10px;
}

.mn-offer--benefits section .title::before {
    margin: 6px 10px 0 0;
}

.mn-offer--benefits section .title.lock::before {
    content: url("../svgs/lock.svg");
}

.mn-offer--benefits section .title.extension::before {
    content: url("../svgs/extension.svg");
}

.mn-offer--benefits section .title.protect::before {
    content: url("../svgs/protect.svg");
}

.mn-offer--benefits section .description {
    font-size: 16px;
    line-height: 24px;
}

.mn-offer--benefits section .description p {
    margin-bottom: 9px;
}

.mn-offer--benefits section .description p:last-child {
    margin-bottom: 0;
}

.mn-offer--benefits li {
    padding-left: 24px;
    position: relative;
}

.mn-offer--benefits li:not(:last-child) {
    margin-bottom: 9px;
}

.mn-offer--benefits li::before {
    content: url("../svgs/check.svg");
    left: 0;
    position: absolute;
    top: 2px;
}



.mn-offer--why {
    margin-bottom: 72px;
}

.mn-offer--why h2 {
    color: #006E58;
    font-size: 24px;
    line-height: 24px;
    margin-bottom: 33px;
}

.mn-offer--why ul {
    color: #555555;
    display: grid;
    font-size: 16px;
    font-weight: 600;
    grid-column-gap: 40px;
    grid-row-gap: 24px;
    grid-template-columns: 1fr 1fr;
}

.mn-offer--why li {
    background-color: #BED730;
    border-radius: 3px;
    content: "";
    width: calc(100% - 8px);
}

.mn-offer--why li:hover div {
    transform: translate(-4px, -4px);
}

.mn-offer--why li div {
    align-items: center;
    background-color: #FFF;
    border-radius: 3px;
    box-sizing: border-box;
    box-shadow: 0px 0px 25px rgba(190, 215, 48, 0.5);
    display: flex;
    left: 8px;
    padding: 22px 24px;
    position: relative;
    top: 8px;
    transition: transform 0.10s ease-in;
}

.mn-offer--why li div::before {
    margin-right: 24px;
}

.mn-offer--why li:nth-child(1) div::before {
    content: url("../svgs/reason-1.svg");
}

.mn-offer--why li:nth-child(2) div::before {
    content: url("../svgs/reason-2.svg");
}

.mn-offer--why li:nth-child(3) div::before {
    content: url("../svgs/reason-3.svg");
}

.mn-offer--why li:nth-child(4) div::before {
    content: url("../svgs/reason-4.svg");
}



.mn-offer--contact-voucher {
    display: grid;
    grid-column-gap: 40px;
    grid-template-columns: calc(50% + 20px) auto;
    margin-bottom: 40px;
}


.mn-offer--contact {
    background-color: #FFF;
    border-radius: 3px;
    box-shadow: 0px 0px 25px rgba(26, 26, 26, 0.25);
    box-sizing: border-box;
    margin: 40px;
    padding: 34px 40px 40px;
    position: relative;
}

.mn-offer--contact::after {
    background-color: #F15D2A;
    border-radius: 3px;
    box-shadow: 0px 0px 25px rgba(241, 93, 42, 0.5);
    content: "";
    height: 100%;
    left: -40px;
    position: absolute;
    top: -40px;
    width: calc(100% + 80px);
    z-index: -1;
}

.mn-offer--contact h3 {
    color: #F15D2A;
    font-size: 32px;
    line-height: 48px;
    margin-bottom: 38px;
}

.mn-offer--contact form div {
    display: grid;
    grid-column-gap: 24px;
    grid-row-gap: 35px;
    grid-template-columns: 1fr 1fr;
    margin-bottom: 32px;
}

.mn-offer--contact label:not(.checkbox) span {
    align-items: center;
    color: #555555;
    display: flex;
    font-size: 16px;
    margin-bottom: 10px;
}

.mn-offer--contact label:not(.checkbox) span {
    font-weight: 600;
}

.mn-offer--contact label span::before {
    font-size: 0;
    margin-right: 6px;
}

.mn-offer--contact label .name::before {
    content: url("../svgs/person.svg");
}

.mn-offer--contact label .email::before {
    content: url("../svgs/envelope.svg");
}

.mn-offer--contact label .county::before {
    content: url("../svgs/location.svg");
}

.mn-offer--contact label .tel::before {
    content: url("../svgs/phone.svg");
}

.mn-offer--contact input[type=email],
.mn-offer--contact input[type=tel],
.mn-offer--contact input[type=text],
.mn-offer--contact select {
    background-color: #FFF;
    border: none;
    border-radius: 3px;
    box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);
    box-sizing: border-box;
    font-family: inherit;
    font-size: 16px;
    max-width: 100%;
    padding: 13px 12px;
    width: 100%;
}

.mn-offer--contact input {
    color: #555555;
}

.mn-offer--contact input[type=checkbox] {
	opacity: 0;
	pointer-events: none;
	position: absolute;
	transform: scale(0.05);
}

.mn-offer--contact select {
    appearance: none;
    background-image: url("../svgs/chevron-down.svg");
    background-position-x: calc(100% - 10px);
    background-position-y: 14px;
    background-repeat: no-repeat;
    color: #55555580;
}

.mn-offer--contact option {
    color: #555555;
}

.mn-offer--contact .checkbox {
    color: #555555;
	cursor: pointer;
	display: inline-flex;
    font-size: 16px;
	position: relative;
}

.mn-offer--contact .checkbox:focus-within {
    outline: 2px solid #101010;
}

.mn-offer--contact .checkbox:not(:last-child) {
    margin-bottom: 12px;
}

.mn-offer--contact .checkbox:last-of-type {
    margin-bottom: 16px;
}

.mn-offer--contact .checkbox input:checked + span {
	background-color: #555555;
}

.mn-offer--contact .checkbox input:checked + span svg {
	transform: scale(1);
}

.mn-offer--contact .checkbox a {
    transition: color 0.10s ease-in;
}

.mn-offer--contact .checkbox a:hover {
    color: #F15D2A;
}


.mn-offer--contact .checkbox span:first-of-type {
	border: 1px solid #555555;
	border-radius: 2px;
	display: block;
	flex-shrink: 0;
	height: 10px;
	margin-right: 10px;
	position: relative;
	top: 4px;
	width: 10px;
}

.mn-offer--contact .checkbox svg {
	transform: scale(0);
}

.mn-offer--contact button {
    align-items: center;
    background-color: #F15D2A;
    border: none;
    border-radius: 5px;
    box-shadow: 0px 0px 15px rgba(241, 93, 42, 0.5);
    color: #FFF;
    cursor: pointer;
    display: flex;
    font-family: inherit;
    font-size: 18px;
    font-weight: 700;
    justify-content: space-between;
    padding: 16px 17px 16px 24px;
    transition: box-shadow 0.10s ease-in;
    width: 100%;
}

.mn-offer--contact button::after {
    content: url("../svgs/send.svg");
    font-size: 0;
}

.mn-offer--contact button:hover {
    box-shadow: 0px 0px 20px rgba(241, 93, 42, 0.75);
}


.mn-offer--voucher {
    box-sizing: border-box;
    height: 100%;
    padding: 92px 80px 0;
    position: relative;
    width: 100%;
}

.mn-offer--voucher::before {
    background-color: #BED730;
    border-radius: 3px;
    box-shadow: 0px 0px 25px rgba(190, 215, 48, 0.5);
    content: "";
    height: calc(100% - 172px);
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: -1;
}

.mn-offer--voucher h3 {
    color: #FFF;
    font-size: 20px;
    line-height: 30px;
    margin-bottom: 0;
    text-align: center;
}

.mn-offer--voucher div {
    border-radius: 22px;
    bottom: 40px;
    box-shadow: 0px 0px 25px rgba(0, 110, 88, 0.5);
    content: url("../images/voucher.png");
    font-size: 0;
    position: absolute;
    width: calc(100% - 160px);
}



/*  Cookies
------------------------------------  */

.mn-cookies {
    margin-bottom: 80px;
    padding: 0 40px;
}

.mn-cookies h1 {
    color: #006E58;
    font-size: 36px;
    line-height: 45px;
    margin: 0 0 27px;
}

.mn-cookies {
    color: #555555;
    line-height: 27px;
}

.mn-cookies p {
    margin: 0 0 26px;
}



/*  Footer
------------------------------------  */

.footer {
    color: #555555;
}

.fr-inner {
    padding: 0 40px;
}

.fr-inner.v1 {
    display: grid;
    grid-column-gap: 40px;
    grid-template-columns: 1fr 1fr 1fr;
}

.fr-inner.v2 {
    display: flex;
}

.footer > div:first-of-type {
    background-color: #E5E5E5;
    padding: 22px 0 23px;
}

.footer > div:first-of-type span {
    display: block;
}

.footer > div:last-of-type {
    background-color: #FFF;
    padding: 22px 0 21px;
    position: relative;
}

.footer > div:last-of-type::before {
    background-color: #E5E5E5;
    content: "";
    display: block;
    height: 4px;
    left: 0;
    position: absolute;
    top: 30px;
    width: 100%;
}

.footer a {
    transition: color 0.10s ease-in;
}

.footer a:hover {
    color: #006E58;
}

.footer .title:not(.v3) {
    font-size: 14px;
    margin-bottom: 10px;
}

.footer .title.v2 span {
    background-color: #FFF;
    display: inline-block;
    padding: 0 24px;
    position: relative;
    transform: translateX(-24px);
}

.footer .title.v3 span {
    background-color: #FFF;
    border-bottom: 4px solid #E5E5E5;
    border-left: 4px solid #E5E5E5;
    border-right: 4px solid #E5E5E5;
    display: inline-block;
    font-size: 16px;
    padding: 10px 24px 17px;
    position: relative;
}

.footer .title.v3 span::before {
    background-color: #FFF;
    content: "";
    display: block;
    height: 9px;
    left: -4px;
    position: absolute;
    top: -1px;
    width: 4px;
}

.footer .title.v3 span::after {
    background-color: #FFF;
    content: "";
    display: block;
    height: 9px;
    right: -4px;
    position: absolute;
    top: -1px;
    width: 4px;
}

.footer .item {
    font-size: 12px;
}

.footer .item:not(.v2) {
    margin-bottom: 9px;
}

.footer .item:last-child {
    margin-bottom: 0;
}

.footer .item.v2 {
    margin-bottom: 5px;
}

.footer .divider {
    font-size: 10px;
    position: relative;
    top: -1px;
}

.fr-slogan {
    margin-left: auto;
    text-align: right;
}
