/* Base */

    @font-face {
        font-family: 'Futura';
        font-style: normal;
        font-weight: 500;
        font-display: swap;
        src: url(../fonts/futura-medium.woff2) format('woff2');
    }

    @font-face {
        font-family: 'Futura';
        font-style: normal;
        font-weight: 700;
        font-display: swap;
        src: url(../fonts/futura-heavy.woff2) format('woff2');
    }

    @font-face {
        font-family: 'Futura-Cond';
        font-style: normal;
        font-weight: 500;
        font-display: swap;
        src: url(../fonts/futura-cond-medium.woff2) format('woff2');
    }
    
    @font-face {
        font-family: 'Futura-Cond';
        font-style: normal;
        font-weight: 700;
        font-display: swap;
        src: url(../fonts/futura-cond-bold.woff2) format('woff2');
    }

    @font-face {
        font-family: 'Creighton';
        font-style: normal;
        font-weight: 700;
        font-display: swap;
        src: url(../fonts/creighton.woff2) format('woff2');
    }

html,
body {
    font-family: 'Futura', sans-serif, arial, verdana;
    font-weight:500;
    font-size: 100%;
    line-height: 1.625rem;
    color: #000000;
    margin: 0;
    padding: 0 !important;
    overflow-x: hidden;
    transition: all .2s;
}

input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0px 1000px white inset
}

::selection {
    background-color: rgba(255, 238, 0, 0.25);
    text-shadow: none
}

a {
    color: #000;
    text-decoration: none;
    transition: all .2s;
}

a:hover,
a:focus {
    color: #653584;
    transition: all .2s;
    text-decoration: underline;
}

a:focus {
    outline: none;
}

input,
button {
    outline: none
}

select {
    /*-webkit-appearance: none;
  -moz-appearance: none;*/
    text-indent: 1px;
    text-overflow: '';
}

select::-ms-expand {
    display: none;
}


/* Cookie Consent modifications */

#cm {
    box-shadow: none;
}

#cm:before {
    content: "";
    display: block;
    width: 1000%;
    height: 1000%;
    position: absolute;
    left: -500%;
    top: -500%;
    background-color: rgb(0 0 0 / 65%);
}

#cc_div #cm {
    overflow: visible;
}

.cc_div .cloud #c-inr {
    background-color: #fff;
    position: relative;
    padding: 3em 3em 2em;
    border-bottom: 10px solid #e82227;
}

#cm,
#s-inr,
.cc_div .c-bl,
.cc_div .b-tl,
#s-bl .act .b-acc {
    border-radius: 0;
}

.cc_div *,
.cc_div :hover,
.cc_div :before,
.cc_div :after {
    text-shadow: none;
    color: #131313;
}

.cc_div .cc-link {
    color: #e82227;
    border-bottom: 1px solid #e82227;
    border-color: #e82227;
}

.cc_div .c-bn {
    border-radius: 4px;
    background-color: #dfdfdf;
    color: #000;
    font-weight: bold;
    font-size: .875em;
    padding: 0.9em 1.2em;
}

.cc_div .c-bn:active,
.cc_div .c-bn:hover {
    background-color: #000;
    color: #dfdfdf;
}

#cm .c_link:hover,
#cm .c_link:active,
#s-cnt button+button:hover,
#s-cnt button+button:active,
#s-c-bn:active,
#s-c-bn:hover {
    background-color: #131313;
    color: #dfdfdf;
}

#c-bns button:first-child,
#s-bns button:first-child {
    color: #fff;
    background-color: #e82227;
}

#c-bns button:first-child:active,
#c-bns button:first-child:hover,
#s-bns button:first-child:active,
#s-bns button:first-child:hover {
    background-color: #fff;
    color: #e82227;
}

#c-bns.swap button:last-child:active,
#c-bns.swap button:last-child:hover {
    background-color: #6e6e6e;
    color: #fff;
}

.cc_div .cloud #c-txt button {
    display: none;
}

#cm.cloud {
    padding: 0;
}

.cc_div .cloud #c-bns {
    top: -0.5rem;
    position: relative;
}

.cc_div .b-tg .c-tg {
    background-color: #9c9d9d;
}

.cc_div .b-tg .c-tgl:checked~.c-tg {
    background-color: #fecc00;
}

#s-c-bn {
    position: absolute;
    top: 16px;
    background-color: transparent;
    right: 16px;
}

#s-c-bn::before,
#s-c-bn::after {
    background-color: #131313;
}

#s-c-bn:hover::before,
#s-c-bn:hover::after {
    background-color: #dfdfdf;
}

#cm-ov,
#cs-ov {
    background-color: none;
}

#s-inr {
    border-bottom: 10px solid #fecc00;
}


/* Bootstrap modifications */

.container {
    max-width: 1174px;
}

.btn {
    font-family: 'Creighton', Arial, Helvetica, sans-serif;
    font-size: 28px;
    line-height: 54px;
    border-radius: 200px;
    border: 0;
    padding: 0 2.5rem 0;
    transition: all .2s;
    font-weight: 600;
    height: 56px;
    text-transform: none;
}

.btn:hover {
    transition: all .2s;
    text-decoration: none;
    opacity: .9;
}

.btn-primary {
    background-color: #fff200;
    border-color: #fff200;
    color: #162d5b;
}

.btn-primary:first-child:hover,
:not(.btn-check)+.btn-primary:hover,
.btn-primary:hover {
    background-color: #fff200;
    border-color: #fff200;
    color: #162d5b;
}

.btn-primary.focus,
.btn-primary:focus,
.btn-primary:not(:disabled):not(.disabled).active,
.btn-primary:not(:disabled):not(.disabled):active,
.show>.btn-primary.dropdown-toggle {
    background-color: #fff200;
    border-color: #fff200;
    color: #162d5b;
    box-shadow: none;
    text-decoration: none;
}

.btn-secondary {
    background-color: #00d8be;
    border-color: #00d8be;
    color: #162d5b;
}

.btn-secondary:first-child:hover,
:not(.btn-check)+.btn-secondary:hover,
.btn-secondary:hover {
    background-color: #00d8be;
    border-color: #00d8be;
    color: #162d5b;
}

.btn-secondary.focus,
.btn-secondary:focus,
.btn-secondary:not(:disabled):not(.disabled).active,
.btn-secondary:not(:disabled):not(.disabled):active,
.show>.btn-secondary.dropdown-toggle {
    background-color: #00d8be;
    border-color: #00d8be;
    color: #162d5b;
    box-shadow: none;
    text-decoration: none;
}

.btn-third {
    background-color: #fff;
    border-color: #fff;
    color: #162d5b;
}

.btn-third:first-child:hover,
:not(.btn-check)+.btn-third:hover,
.btn-third:hover {
    background-color: #fff;
    border-color: #fff;
    color: #162d5b;
}

.btn-third.focus,
.btn-third:focus,
.btn-third:not(:disabled):not(.disabled).active,
.btn-third:not(:disabled):not(.disabled):active,
.show>.btn-third.dropdown-toggle {
    background-color: #fff;
    border-color: #fff;
    color: #162d5b;
    box-shadow: none;
    text-decoration: none;
}

.btn-forth {
    background-color: #172f5b;
    border-color: #172f5b;
    color: #fff200;
}

.btn-forth:first-child:hover,
:not(.btn-check)+.btn-forth:hover,
.btn-forth:hover {
    background-color: #172f5b;
    border-color: #172f5b;
    color: #fff200;
}

.btn-forth.focus,
.btn-forth:focus,
.btn-forth:not(:disabled):not(.disabled).active,
.btn-forth:not(:disabled):not(.disabled):active,
.show>.btn-forth.dropdown-toggle {
    background-color: #172f5b;
    border-color: #172f5b;
    color: #fff200;
    box-shadow: none;
    text-decoration: none;
}

.btn-alt {
    background-color: transparent;
    border-color: transparent;
    color: #fff;
    transition: all .2s;
    background-image: url(../images/btn-alt.png);
    background-repeat: no-repeat;
    background-size: 100%;
    width: 286px;
    font-size: 16px;
}

.btn-alt:first-child:hover,
:not(.btn-check)+.btn-alt:hover,
.btn-alt:hover {
    background-color: transparent;
    border-color: transparent;
    color: #fff;
}

.btn-alt.focus,
.btn-alt:focus,
.btn-alt:not(:disabled):not(.disabled).active,
.btn-alt:not(:disabled):not(.disabled):active,
.show>.btn-alt.dropdown-toggle {
    background-color: transparent;
    border-color: transparent;
    color: #fff;
    transition: all .2s;
    box-shadow: none;
    text-decoration: none;
}

.navbar {
    padding: 0;
    background: #0E6BBC;
    background: linear-gradient(90deg, rgba(14, 107, 188, 1) 0%, rgba(45, 152, 224, 1) 100%);
}

.nav-link {
    font-family: 'Creighton', Arial, Helvetica, sans-serif;
    line-height: 90px;
    padding-top: 0;
    padding-bottom: 0;
    color: #fff;
    transition: all .2s;
    font-weight: 600;
    font-size: 24px;
    text-transform: uppercase;
}

.nav-link:focus,
.nav-link:hover {
    background-color: #fef500;
    color: #0076d1;
    text-decoration: none;
    text-shadow: none;
}

.navbar-expand-lg .navbar-nav .nav-link {
    padding-left: .75rem;
    padding-right: .75rem;
}

.navbar-nav .nav-link.active,
.navbar-nav .show>.nav-link {
    background-color: #fff;
    color: #e82227;
    text-decoration: none;
}

.navbar-nav .nav-link.active:hover,
.navbar-nav .show>.nav-link:hover {
    cursor: default;
}

.form-group {
    position: relative;
}

.form-group label {
    display: none;
}

.form-group .form-check-label {
    display: block;
    font-size: 18px;
    margin: 4px 1rem 0 .5rem;
}

.form-group .placeholder {
    position: absolute;
    font-size: 19px;
    color: #808080;
    left:5px;
    top: 1px;
    pointer-events: none;
    transition: all .2s;
    z-index: 2;
    background-color: #ffffff;
    opacity: 1;
    padding: 0 0 0 12px;
    line-height: 48px;
    width: calc(100% - 20px);
}

.form-group-select .placeholder {
    width: calc(100% - 40px);
    max-height: 46px;
    overflow: hidden;
}

.form-group .placeholder.active {
    font-size: 12px;
    line-height: 16px;
    transition: all .2s;
    left: 16px;
    top: 6px;
    padding: 0;
    z-index: 10;
    background-color: transparent;
}

.form-group input[type=file] + .placeholder {
    padding: 0px 20px 0px 16px;
    left: 2px;
    top: 1px;
    width: calc(100% - 4px);
}

.form-group input[type=file] + .placeholder.active {
    padding: 0;
    left: 16px;
    top: 4px;
    width: auto;
}

.form-group.textarea .placeholder {
    left: 16px;
    top: 5px;
    padding: 0;
}

.form-group.textarea .placeholder.active {
    top: 10px;
}

.form-group.has-error .placeholder {
    background-color: #feebeb;
}

.form-group button {
    position: absolute;
    width: 20px;
    height: 20px;
    right: 12px;
    z-index: 10;
    top: 50%;
    transform: translateY(-50%);
    border: 0;
    background-color: transparent;
    background-repeat: no-repeat;
    background-size: 20px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000000' viewBox='0 0 512 512'%3E %3Cpath d='M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM216 336h24V272H216c-13.3 0-24-10.7-24-24s10.7-24 24-24h48c13.3 0 24 10.7 24 24v88h8c13.3 0 24 10.7 24 24s-10.7 24-24 24H216c-13.3 0-24-10.7-24-24s10.7-24 24-24zm40-208a32 32 0 1 1 0 64 32 32 0 1 1 0-64z'/%3E%3C/svg%3E");
} 

.form-control:disabled + .placeholder {
    background-color: #e9ecef;
}

.input-group:not(.has-validation)>:not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.form-check-input:checked[type=radio] {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='2' fill='%23172f5b'/%3e%3c/svg%3e");
}

.input-group-text {
    background-color: #fff;
    padding-left: 15px;
    padding-top: 18px;
    padding-bottom: 0;
    border-color: #bdbdbd;
    border-radius: 0;
}

.form-check {
    position: relative;
}

form .error {
    position: absolute;
    font-size: 12px;
    left: 0;
    width: 100%;
    padding-left: 17px;
    bottom: -14px;
    color: #e82227;
    opacity: 0;
    line-height: 15px;
}

form .form-check .error {
    left: 43px;
    bottom: -14px;
    width: auto;
    padding: 0 .5rem;
}

.has-error .error {
    opacity: 1;
    color: #fff;
    background-color: #e82227;
}

.has-error .form-control {
    border-color: rgb(247 30 19);
    background-color: rgb(255 233 233);
}

.form-check.has-error .form-check-input {
    border-color: rgb(255 167 169);
    background-color: rgb(255 233 233);
}

.has-error .input-group-text {
    border-color: rgb(255 167 169);
    background-color: rgb(255 233 233);
}

.form-check.has-error .form-check-input:checked {
    border-color: #e82227;
    background-color: #e82227;
}

.form-control {
    background-color: #fff;
    border-radius: 0;
    border: 1px solid #c9c9c9;
    padding: 21px 1rem 4px;
    height: 50px;
    font-size: 19px;
}

input.form-control[type=password] {
    letter-spacing: -8px;
}

textarea.form-control {
    line-height: 24px;
    padding-top: 1.5rem;
}

select.form-control {
    padding-left: 14px;
    -webkit-appearance: none;
    position: relative;
    background-color: transparent;
}

select.form-control:focus {
    background-color: transparent;
}

.form-group-select {
    background-color: #fff;
    border-radius: 0;
    background-size: 16px;
    background-repeat: no-repeat;
    background-position: right 11px center;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512'%3E%3Cpath d='M201.4 406.6c12.5 12.5 32.8 12.5 45.3 0l192-192c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L224 338.7 54.6 169.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l192 192z'/%3E%3C/svg%3E");
}

.form-group-select {
    background-color: #fff;
    border-radius: 4px;
    background-size: 16px;
    background-repeat: no-repeat;
    background-position: right 11px center;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512'%3E%3Cpath d='M201.4 406.6c12.5 12.5 32.8 12.5 45.3 0l192-192c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L224 338.7 54.6 169.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l192 192z'/%3E%3C/svg%3E");
}

/*
.form-group-select:before {
    width: 16px;
    height: 16px;
    content: "";
    display: block;
    position: absolute;
    right: 12px;
    z-index: 1;
    top: 16px;
    background-repeat: no-repeat;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512'%3E%3Cpath d='M201.4 406.6c12.5 12.5 32.8 12.5 45.3 0l192-192c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L224 338.7 54.6 169.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l192 192z'/%3E%3C/svg%3E");
}
*/

.form-check-input:checked[type=checkbox] {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23162d5b' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e");
}

.form-control:focus {
    color: #131313;
    border-color: #182f5b;
    box-shadow: none;
    transition: all .2s;
}

.form-check-label {
    font-size: 16px;
    margin-top: 0.3rem;
    margin-left: 1rem;
}

.form-check-input {
    width: 25px;
    height: 25px;
    border-color: #c9c9c9;
}

.form-check-input[type=checkbox] {
    border-radius: 0;
}

.form-check-input:checked,
.form-check.has-error .form-check-input:checked {
    background-color: #fff204;
    border-color: #fff204;
}

.form-check-input:focus {
    box-shadow: none;
    border-color: #fff204;
}

.modal {
    padding-right: 0 !important;
}

.modal-content {
    border-radius: 0;
    border: 0;
}

.modal-body {
    padding: 2rem 1rem;
}

.modal h3 {
    text-align: left;
    margin-bottom: 1rem;
    font-weight: 600;
}

.modal-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1050;
    width: 100vw;
    height: 100vh;
    background-color: #000;
}

.modal-backdrop.show {
    opacity: 0.5;
}

.btn-close {
    position: absolute !important;
    right: -1rem;
    top: -1rem;
    background-color: #fff;
    opacity: 1;
    border-radius: 0;
    background-size: 14px;
    padding: 8px;
    width: 1rem;
    height: 1rem;
}

.btn-close:hover {
    opacity: 1;
}

.btn-close:focus {
    box-shadow: none;
}

.pagination .page-link svg {
    width: 24px;
    height: 24px;
}

.pagination .page-link svg path {
    fill:#e82227;
}

.pagination .page-link {
    color: #e82227;
    border: 0;
    padding: 0.5rem 1rem;
}

.pagination .active>.page-link, .page-link.active {
    background-color: #e82227;
    color: #fff;
    border-radius: 0;
}

.custom-tooltip .tooltip-inner {
    max-width: 300px;
}

/* Slick modifications */

.slick-list {
    max-width: 75%;
    margin: 0 auto;
    padding: 0 0 3rem;
    text-align: center;
}

.slick-slide img {
    margin: 0 auto;
}

.slick-prev,
.slick-next {
    background-size: 86%;
    background-position: center;
    position: absolute;
    right: 0;
    top: 50%;
    z-index: 10000;
    transform: translateY(-50%);
    font-size: 0;
    width: 32px;
    height: 32px;
    border: 0;
    background-color: #172f5b;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23ffffff' viewBox='0 0 512 512'%3E%3Cpath d='M0 256a256 256 0 1 0 512 0A256 256 0 1 0 0 256zM281 385c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l71-71L136 280c-13.3 0-24-10.7-24-24s10.7-24 24-24l182.1 0-71-71c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0L393 239c9.4 9.4 9.4 24.6 0 33.9L281 385z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    border-radius: 100%;
}

.slick-prev {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23ffffff' viewBox='0 0 512 512'%3E%3Cpath d='M512 256A256 256 0 1 0 0 256a256 256 0 1 0 512 0zM231 127c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-71 71L376 232c13.3 0 24 10.7 24 24s-10.7 24-24 24l-182.1 0 71 71c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0L119 273c-9.4-9.4-9.4-24.6 0-33.9L231 127z'/%3E%3C/svg%3E");
    left: 0;
    right: auto;
}

.slick-dots {
    list-style: none;
    position: absolute;
    left: 0;
    right: 0;
    text-align: center;
    bottom: -1rem;
    padding: 0;
}

.slick-dots li {
    display: inline-block;
    margin: 0 1rem;
}

.slick-dots button {
    border: 0;
    background-color: #131313;
    opacity: .65;
    font-size: 0;
    width: 12px;
    height: 12px;
    border-radius: 100%;
    padding: 0;
}

.slick-active button {
    opacity: 1;
    background-color: #154a91;
}

.slick-disabled {
    opacity: .25;
}

.slick-disabled:hover {
    cursor: default;
}

.slick-products .slick-list {
    max-width: 90%;
    padding: 2rem 0 1rem;
}

.slick-products p {
    margin: 1rem auto;
    font-weight: 600;
    color: #172f5b;
    height: 104px;
    font-size: 21px;
}

/* Animated hamburger menu */

.navbar-toggler {
    border: 0;
    position: fixed;
    margin: 0;
    padding: 0;
    width: auto;
    opacity: .85;
    transition: all .2s;
    z-index: 103;
    right: 6px;
    top: 12px;
}

.scrolled .navbar-toggler {
    opacity: 1;
}

.navbar-toggler .inline-svg,
.navbar-toggler .inline-svg rect {
    width: 40px;
    height: auto;
    position: relative;
}

.navbar-toggler .inline-svg path {
    fill: #fff;
    transition: all .2s;
}

.navbar-toggler:focus,
.navbar-toggler:active {
    outline: none;
    box-shadow: none;
}

.svg-menu-toggle {
    fill: #fff;
    pointer-events: all;
    cursor: pointer;
    opacity: 1;
}

.svg-menu-toggle .bar {
    transform: rotate(0) translateY(0) translateX(0);
    opacity: 1;
    transform-origin: 20px 10px;
    transition: transform 0.4s ease-in-out, opacity 0.2s ease-in-out;
}

.svg-menu-toggle .bar:nth-of-type(1) {
    transform-origin: 20px 10px;
}

.svg-menu-toggle .bar:nth-of-type(3) {
    transform-origin: 20px 20px;
}

.svg-menu-toggle.active path {
    fill: #fff;
    opacity: 1;
    transition: all .2s;
}

.svg-menu-toggle.active .bar:nth-of-type(1) {
    transform: rotate(-45deg) translateY(0) translateX(0);
}

.svg-menu-toggle.active .bar:nth-of-type(2) {
    opacity: 0;
}

.svg-menu-toggle.active .bar:nth-of-type(3) {
    transform: rotate(45deg) translateY(0em) translateX(0em);
}


/* Site */

.svg path {
    transition: all .2s;
}

p {
    margin-bottom: 1.8rem;
}

b {
    font-weight: 600;
}

small {
    font-weight: 500;
    font-size: 100%;
}

.highlight {
    color: #000;
}

.highlight2 {
    color: #172f5b;
}

.site {
    font-size: 1.125em;
}

.content-padding {
    padding-top: 3rem;
    padding-bottom: 3rem;
}

.anchor {
    display: block;
    position: relative;
    top: -7rem;
    visibility: hidden;
}

#system-msg:before,
.system-msg:before {
    content: "";
    display: block;
    position: fixed;
    left:0;
    right:0;
    top:0;
    bottom:0;
    background-color: #000;
    opacity: .25;
    z-index: 11;
}

.system-msg-content {
    position: fixed !important;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    z-index: 11;
    background-color: #fff;
    padding: 1.4rem;
    font-size: 1.4rem;
    line-height: 3rem;
    text-align: center;
    border-radius: 4px;
    box-shadow: 0 0 30px rgb(0 0 0 / 25%);
}

#passw_errors .system-msg-content,
#reg_errors .system-msg-content,
#comp_errors .system-msg-content {
    font-size: 1rem;
    text-align: left;
    color: #e82227;
    line-height: 1.6em;
    /*text-indent: -1.4rem;*/
    padding-left: 2.4rem;
}

header {
    background-color: #172f5b;
    color: #fff;
    height: 90px;
    position: fixed;
    transition: all .2s;
    z-index: 30;
    top: 0;
    left: 0;
    right: 0;
}

.navbar:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    display: block;
    background: #0E6BBC;
    background: linear-gradient(90deg, rgba(14, 107, 188, 1) 0%, rgba(45, 152, 224, 1) 100%);
    width: 100%;
    height: 0;
    transition: all .05s;
}

header.scrolled .navbar {
    box-shadow: 0 0 20px rgb(0 0 0 / 20%);
}

header.scrolled .navbar:before {
    height: 100%;
    transition: all .05s;
}

header .container {
    position: relative;
}

footer {
    background-color: #162d5b;
    color: #fff;
    padding: 22px 0;
    height: 70px;
    overflow: hidden;
    font-size: 16px;
    line-height: 28px;
    font-family: 'Futura', Arial, Helvetica, sans-serif;
    font-weight: 600;
}

footer a {
    color: #fff;
    text-decoration: none;
}

footer a:hover {
    color: #fff;
    text-decoration: underline;
}

footer a:focus {
    color: #fff;
}

.top {
    display: inline-block;
    font-size: 0;
    width: 36px;
    height: 36px;
    transform: rotate(-90deg);
    margin-left: 16px;
    position: relative;
    border-radius: 0;
    top: -12px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%230678d0' viewBox='0 0 384 512'%3E%3Cpath d='M342.6 233.4c12.5 12.5 12.5 32.8 0 45.3l-192 192c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L274.7 256 105.4 86.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l192 192z'/%3E%3C/svg%3E");
    background-size: 50%;
    background-position: 8px center;
    background-color: #fef500;
    background-repeat: no-repeat;
}

.logo-primary {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
}

.logo-primary img,
.logo-primary svg {
    width: auto;
    height: 90px;
    transition: all .2s;
}

.logo-secondary {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
}

.logo-secondary img, 
.logo-secondary svg {
    width: auto;
    height: 61px;
    transition: all .2s;
}

header.scrolled {
    transition: all .2s;
    height: 70px;
}

header.scrolled .nav-link {
    line-height: 70px;
}

header.scrolled .logo-primary img,
header.scrolled .logo-primary svg {
    height: 70px;
    transition: all .2s;
}

header.scrolled .logo-secondary img,
header.scrolled .logo-secondary svg{
    height: 50px;
    transition: all .2s;
}

h1 {
    font-size: 56px;
    line-height: 48px;
    color: #981915;
    position: absolute;
    font-family: 'Futura', Arial, Helvetica, sans-serif;
}

h1.subpage {
    font-size: 64px;
    line-height: 1;
    font-weight: bold;
    color: #981915;
    font-family: 'Futura', Arial, Helvetica, sans-serif;
    margin: 5rem 0 1rem;
    text-indent: 0;
    position: relative;
    text-align: center;
}

h2 {
    font-size: 64px;
    font-weight: 600;
    line-height: 1;
    color: #fff;
    font-family: 'Creighton', Arial, Helvetica, sans-serif;
    margin-bottom: 2rem;
    text-align: center;
    text-transform: uppercase;
}

h3 {
    font-size: 38px;
    line-height: 42px;
    color: #fff;
    font-family: 'Futura', Arial, Helvetica, sans-serif;
    margin-bottom: 0;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: -1px;
}

.top-auchan {
    margin-top: 90px;
    background-color: #e10019;
    color: #fff;
}

.top-auchan .container {
    position: relative;
}

.top-auchan a {
    color: #fff;
    text-decoration: underline;
}

.top-auchan a:hover {
    text-decoration: none;
}

.top-auchan p {
    margin: 0;
    line-height: 90px;
    font-size: 20px;
    padding-left: 3rem;
}

.top-auchan .svg {
    width:139px;
    height:45px;
    position: absolute;
    right: calc(3rem + 12px);
    top:50%;
    transform: translateY(-50%);
}

.top-auchan .svg path {
    fill:#fff;
}

.intro {
    background: transparent url(../images/intro-bg.jpg) center top no-repeat;
    position: relative;
    margin-top: 90px;
    height: 492px;
}

.intro .intro-content>p {
    position: absolute;
    left: 12px;
    bottom: 0;
    color: #fff200;
    text-align: center;
    font-size: 26px;
    font-weight: 500;
    margin: 0;
    text-transform: uppercase;
    background-color: #172f5b;
    line-height: 56px;
    padding-right: 2rem;
    transform: skewX(45deg);
    font-family: 'Futura-Cond', sans-serif, arial, verdana;
}

.intro .intro-content>p::before {
    position: absolute;
    left: -100%;
    bottom: 0;
    top:0;
    display: block;
    width: 100%;
    background-color: #172f5b;
    content: "";
}

.intro .intro-content>p span {
    transform: skewX(-45deg);
    display: block;
}

.intro .container>span {
    font-size: 13px;
    color: #fff;
    font-weight: 500;
    position: absolute;
    right: 12px;
    bottom: 4px;
    z-index: 3;
}

.intro h1 {
    color: #fff;
    position: relative;
    font-family: 'Creighton', Arial, Helvetica, sans-serif;
    font-size: 96px;
    font-weight: 400;
    line-height: .95;
    margin: 0;
    padding: 0;
    text-transform: uppercase;
    text-shadow: 4.092px 4.388px 8px rgba(7, 21, 46, 0.46);
    padding: 85px 0 32px;
}

.intro h2 {
    font-size: 28px;
    color: #fff;
    margin: 0;
    text-align: left;
    text-transform: none;
    max-width: 498px;
    line-height: 1.2;
    text-shadow: 4.092px 4.388px 8px rgba(7, 21, 46, 0.46);
    font-family: 'Futura-Cond', sans-serif, arial, verdana;
}

.intro h2 span {
    font-size: 48px;
    color: #5c9f2e;
    text-transform: uppercase;
    display: block;
}

.intro>p {
    color: #fff;
    font-size: 22px;
    line-height: 1;
    font-family: 'Futura', Arial, Helvetica, sans-serif;
    margin: 11rem 0 6.5rem;
    font-weight: 900;
}

.intro-btn {
    /*
    position: absolute;
    bottom: 1rem;
    left: 50%;
    transform: translateX(-50%);
    display: none;
    */
}

.intro .btn {
    margin-right: 2rem;
}

.intro-content-plus {
    height: 131px;
    background: transparent url(../images/intro-bg2.png) center no-repeat;
    margin-bottom:-131px;
    position: relative;
    z-index: 2;
}

.dowin {
    text-align: center;
    background-color: #fff200;
    color: #0073d5;
    font-size: 2rem;
    padding: 2rem 0;
    line-height: 36px;
}

.steps {
    position: relative;
    z-index: 1;
    background: transparent url(../images/steps-bg.jpg) center no-repeat;
    background-size: cover;
    color: #fff;
}

.steps h2 {
    color: #fff200;
}

.steps .container * {
    position: relative;
    z-index: 1;
}

.step-item {
    height: 100%;
    margin: 0;
    font-size: 22px;
    padding: 0;
}

.steps img {
    margin-bottom: 2rem;
}

.steps a:not(.btn){
    text-decoration: underline;
    color: #fff;
}

.steps a:not(.btn):hover{
    text-decoration: none;
    color: #00d8be;
}

.steps p {
    margin-bottom: 0;
    font-size: 22px;
    letter-spacing: -.5px;
    padding: 0 0 2rem;
}

.steps b {
    color: #00d8be;
}

.steps h3 {
    margin: 2rem 0 2rem;
    color: #fff200;
    font-size: 48px;
    font-weight: 600;
    text-transform: none;
}

.steps span {
    color: #fff200;
}

.steps img,
.steps svg {
    width: auto;
    height: 70px;
}

.steps img + b,
.steps svg + b {
    font-family: 'Creighton', Arial, Helvetica, sans-serif;
    display: block;
    margin: 1.5rem 0;
    font-size: 48px;
    text-align: center;
    color: #fff200;
    font-weight: 600;
}

.steps svg path {
    fill: #fff;
}

.steps .col-12>p {
    font-size: 21px;
    margin:2rem 0 0;
}

.steps b span {
    color: #5c9f2e;
}

.prizes {
    color: #fff;
    position: relative;
}

.prizes .container {
    position: absolute;
    top: 0;
    z-index: 1;
    height: 100%;
    left: 0;
    right: 0;
    text-align: left;
}

.prizes .container>div {
    position: absolute;
    left: 12px;
    top: 2rem;
    overflow: hidden;
    padding-right: 100px;
}

.prizes h2 {
    transform: skew(45deg);
    background-color: #fff;
    padding: .5rem 2.5rem .5rem 4.5rem;
    margin-left: -3rem;
}

.prizes h2 span {
    font-size: 56px;
    color: #152d5b;
    transform: skew(-45deg);
    display: block;
}

.prizes .row>div:nth-child(1),
.prizes .row>div:nth-child(3) {
    padding-top: 2rem;
}

.prizes p {
    text-align: center;
    font-size: 14px;
    padding: 0;
    margin: 0;
    position: absolute;
    right: 12px;
    bottom: 12px;
}

.prizes small {
    font-size: 14px;
    display: block;
    text-align: center;
}

.registration {
    background-color: #172f5b;
    color: #fff;
    position: relative;
    font-size: 21px;
}

.registration a:not(.btn) {
    text-decoration: underline;
    color: #fff;
}

.registration a:not(.btn):hover {
    text-decoration: none;
}

.registration h2 {
    color: #fff200;
    text-align: left;
    margin-bottom: 1rem;
    line-height: 1;
    position: relative;
    display: inline-block;
}

.registration h2::after {
    content: "";
    display: block;
    width:121px;
    height:40px;
    position: absolute;
    right:-142px;
    background: transparent url(../images/arrows.png) center no-repeat;
    top:50%;
    transform: translateY(-50%);
}

.registration h3 {
    color: #fff;
    margin-bottom: 1rem;
    text-align: left;
    font-weight: 600;
}

.registration h3 + p {
    color: #fff;
}

.registration p {
    max-width: 460px;
}

.registration a.wannabe:not(.btn) {
    text-decoration: underline;
    color: #fff200;
    margin: -1.5rem 0 0;
    position: absolute;
}

.registration a.wannabe:not(.btn):hover {
    text-decoration: underline;
    color: #00d8be;
}

#reg_phone_error input[type=text]:focus {
    border-left-color: #fff;
}

.registration .btn-primary {
    position: relative;
}

.registration .btn-primary::after {
    content: "";
    display: block;
    width:121px;
    height:40px;
    position: absolute;
    right:-142px;
    background: transparent url(../images/arrows.png) center no-repeat;
    top:50%;
    transform: translateY(-50%) rotate(180deg);
}

.lostpass-sent{
    color: #e82227;
    font-weight: bold;
}

.new-password {
    position: absolute;
    left: 2rem;
    right: 2rem;
    top: 50%;
    transform: translateY(-50%);
    background-color: #fff;
    z-index: 100;
    border-radius: 4px;
    box-shadow: 0 0 50px #969696;
    max-width: 992px;
    margin: 0 auto;
}

.competition * {
    position: relative;
}

.competition {
    color: #fff;
    position: relative;
    z-index: 1;
    background-color: #fff
}

.competition h2 {
    color: #fff204;
}

.competition p {
    max-width: 740px;
    margin: 0 auto 1.8rem;
}

.competition a:not(.btn) {
    color: #fff;
    text-decoration: underline;
}

.competition a:not(.btn):hover {
    text-decoration: none;
}

.competition-item {
    max-width: 776px;
    padding: 2rem;
    margin: 0 auto;
    background-color: #172f5b;
    color: #fff;
    text-align: left;
    border-radius: 0;
    font-size: 19px;
}

.competition-item h3 {
    color: #653584;
}

.competition-item svg {
    width: 20px;
    height: 20px;
    margin-left: 0.5rem;
    position: relative;
    top: -3px;
}

.competition-item svg path {
    fill: #e82227;
}

.form-upload input[type=file] {
    color: #fff;
    border-radius: 40px;
    border: 1px solid black;
    width: calc(100% - 4px);
    margin: 0 0 0 1px;
}

.form-upload input[type=file] + .placeholder {
    background: #653584;
    color: #fff;
    border-radius: 40px;
}

.form-upload input[type=file] + .placeholder .svg {
    width: auto;
    height: 32px;
    margin: 0;
    top: -1px;
}

.form-upload input[type=file] + .placeholder .svg path {
    fill: #fff;
}

.form-group.form-upload input[type=file] + .placeholder.active {
    padding: 0px 20px 0px 16px;
    left: 2px;
    top: 1px;
    width: calc(100% - 4px);
    line-height: 48px;
    font-size: 18px;
}

.form-upload input[type=file] + .placeholder.active .svg {
    height: 32px;
}

#competition_files_cont {
    margin: 2.9rem 0 1rem 0;
    font-size: 16px;
}

#competition_files_cont p:nth-of-type(1) {
    position: relative;
}

#competition_files_cont p:nth-of-type(1):before {
    content: "Feltöltött fájlok";
    position: absolute;
    left: 0;
    top: -26px;
    font-weight: bold;
    color: #653584;
}

#competition_files_cont a {
    text-indent: -9999px;
    display: inline-block;
    background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGhlaWdodD0iMjRweCIgdmlld0JveD0iMCAtOTYwIDk2MCA5NjAiIHdpZHRoPSIyNHB4IiBmaWxsPSIjZTgyMjI3Ij48cGF0aCBkPSJtMjU2LTIwMC01Ni01NiAyMjQtMjI0LTIyNC0yMjQgNTYtNTYgMjI0IDIyNCAyMjQtMjI0IDU2IDU2LTIyNCAyMjQgMjI0IDIyNC01NiA1Ni0yMjQtMjI0LTIyNCAyMjRaIi8+PC9zdmc+);
    width: 24px;
    height: 24px;
    background-position: center 1px;
}

#competition_files_cont p {
    margin: 0;
}

.case-person,
.case-online {
    display: none;
}

.case-person.active,
.case-online.active {
    display: flex;
}

.case-person-image,
.case-online-image{
    display: none;
}

@media (max-width:767.98px) {
    .case-person-image.active,
    .case-online-image.active{
        display: block;
    }
}

.validation {
    min-height: calc(100vh - 70px);
}

.competition-success .svg path {
    fill:#5c9f2e;
}

.competition-success .svg circle {
    stroke:#5c9f2e;
}

.competition-success, .validation-success {
    display: none;
    opacity: 0;
    transition: all .2s;
}

.competition.success .competition-success,
.validation.success .validation-success {
    display: block;
    opacity: 1;
    transition: all .2s;
    color: #4b4b4b;
    font-size: 24px;
    text-align: center;
}

.competition.success .competition-success h3,
.validation.success .validation-success h3 {
    color: #5c9f2e;
    font-size: 64px;
    line-height: 1;
    margin: 4rem 0 1rem;
    font-weight: 600;
}

.competition.success .competition-intro>h2,
.competition.success .competition-item,
.validation.success .validation-intro>h1,
.validation.success .validation-intro>h2,
.validation.success .validation-item {
    display: none;
}

#competition-menu .table-hover>tbody>tr:hover>* {
    background-color: #fff;
    --bs-table-accent-bg: none;
    color: #4b4b4b;
}

#competition-menu .table>:not(caption)>*>* {
    color: #182f5b;
}

#competition-menu {
    position: relative;
    padding: 3rem 0 2rem;
    color: #182f5b;
    margin: 1rem 0 -2rem;
}

#competition-menu:before {
    content: "";
    display: block;
    width: 1000%;
    height: 100%;
    position: absolute;
    left: -100%;
    right: -100%;
    top: 0;
    bottom: 0;
    z-index: 0;
    background-color: #fff;
}

.tab-content>.tab-pane {
    padding: 2rem 2rem 0;
}

.tab-pane h3 {
    text-align: center;
    color: #182f5b;
    margin-bottom: 1rem;
    font-family: 'Creighton', Arial, Helvetica, sans-serif;
    font-size: 48px;
}

.tab-pane ul,
.tab-pane form {
    max-width: 740px;
    margin: 0 auto 1.8rem;
}

.tab-pane a:not(.btn) {
    color: #182f5b;
}

p.send-success {
    margin: 1rem 0 0;
    padding: 0.5rem 1rem;
    width: auto;
    display: inline-block;
    border-radius: 200px;
    color: #e82227;
}

.winners {
    background-color: #fff;
    color: #162d5b;
    position: relative;
    font-size: 21px;
    overflow: hidden;
}

.winners .container {
    position: relative;
    padding-top: 17px;
    padding-bottom: 17px;
}

.winners img {
    margin: 0 auto 2rem;
}

.winners h2 {
    text-align: left;
    color: #162d5b;
}

.winners span {
    font-size: 40px;
    font-family: 'Creighton', Arial, Helvetica, sans-serif;
    display: block;
    margin: 0rem 0 -1rem 0;
    color: #00d8be;
}

.winners .note {
    display: block;
    text-align: center;
    font-size: 16px;
    text-transform: none;
    margin: -1rem 0 2rem;
    color: #172f5b;
}

.winners .btn {
    width: 256px;
    display: block;
    margin: 0 auto;
}

.modal-winners {
    text-align: center;
}

.products {
    background-color: #fff;
    text-align: center;
    position: relative;
    font-size: 21px;
    color: #2a2623;
}

.products h2 {
    color: #172f5b;
    line-height: 1.2;
}

.products a:not(.btn){
    text-decoration: underline;
    color: #000;
}

.products a:not(.btn):hover{
    text-decoration: none;
}

.products .note {
    margin: 0 0 2rem;
    font-size: 16px;
    text-transform: none;
    text-align: center;
    display: block;
    color: #2a2623;
}

.products img {
    margin: -3rem auto -1rem;
}

.products .container>p {
    max-width: 992px;
    margin: 0 auto;
}

.shop {
    background-color: #172f5b;
    padding: 3rem 0;
}

.shop img {
    margin-left: 1rem;
    transform: rotate(180deg);
}

.faq {
    text-align: center;
    background-color: #fef500;
    padding: 2rem 0;
    color: #172f5b;
    font-size: 22px;
}

.faq h2 {
    color: #0678d0;
}

.contact {
    background-color: #fff;
    color: #172f5b;
    font-size: 21px;
}

.contact h2 {
    margin-bottom: 2rem;
    color: #172f5b;
    text-align: left;
    line-height: 1;
}

.contact p {
    max-width: 460px;
}

.contact textarea {
    height: 220px;
}

.contact a {
    text-decoration: underline;
    color: #172f5b;
}

.contact a:hover {
    text-decoration: none;
}

.administrator header{
    background-color: #e82227;
}

.admin {
    padding: 9rem 0 2rem 0;
    background-color: #fff;
    color: #4b4b4b;
}

.admin .container {
    max-width: 1540px;
}

.admin h3 {
    color: #172f5b;
    margin: 0 0 2rem;
    font-weight: 600;
}

.admin .btn {
    transform: scale(.8);
}

.admin .table {
    font-size: 1rem;
}

.admin .table>:not(caption)>*>* {
    padding: 0.5rem;
}

.admin .win textarea {
    height: 480px;
    padding: 1rem;
}

.admin .table .highlighted {
    background-color: rgb(255 201 44 / 30%);
}

.admin .table .btn-sm {
    display: inline-block;
    background-color: #e82227;
    padding: 0 .5rem;
    color: #fff;
    border-radius: 8px;
    line-height: 30px;
}

.admin .table .btn-sm:hover {
    text-decoration: none;
    opacity: .75;
}

.modify {
    display: inline-block;
    width:24px;
    height:24px;
    margin: 0 auto;
    background-size: 16px;
    background-position: center;
    background-repeat: no-repeat;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512' fill='%23000000'%3E%3C!--! Font Awesome Pro 6.2.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license (Commercial License) Copyright 2022 Fonticons, Inc. --%3E%3Cpath d='M495.9 166.6c3.2 8.7 .5 18.4-6.4 24.6l-43.3 39.4c1.1 8.3 1.7 16.8 1.7 25.4s-.6 17.1-1.7 25.4l43.3 39.4c6.9 6.2 9.6 15.9 6.4 24.6c-4.4 11.9-9.7 23.3-15.8 34.3l-4.7 8.1c-6.6 11-14 21.4-22.1 31.2c-5.9 7.2-15.7 9.6-24.5 6.8l-55.7-17.7c-13.4 10.3-28.2 18.9-44 25.4l-12.5 57.1c-2 9.1-9 16.3-18.2 17.8c-13.8 2.3-28 3.5-42.5 3.5s-28.7-1.2-42.5-3.5c-9.2-1.5-16.2-8.7-18.2-17.8l-12.5-57.1c-15.8-6.5-30.6-15.1-44-25.4L83.1 425.9c-8.8 2.8-18.6 .3-24.5-6.8c-8.1-9.8-15.5-20.2-22.1-31.2l-4.7-8.1c-6.1-11-11.4-22.4-15.8-34.3c-3.2-8.7-.5-18.4 6.4-24.6l43.3-39.4C64.6 273.1 64 264.6 64 256s.6-17.1 1.7-25.4L22.4 191.2c-6.9-6.2-9.6-15.9-6.4-24.6c4.4-11.9 9.7-23.3 15.8-34.3l4.7-8.1c6.6-11 14-21.4 22.1-31.2c5.9-7.2 15.7-9.6 24.5-6.8l55.7 17.7c13.4-10.3 28.2-18.9 44-25.4l12.5-57.1c2-9.1 9-16.3 18.2-17.8C227.3 1.2 241.5 0 256 0s28.7 1.2 42.5 3.5c9.2 1.5 16.2 8.7 18.2 17.8l12.5 57.1c15.8 6.5 30.6 15.1 44 25.4l55.7-17.7c8.8-2.8 18.6-.3 24.5 6.8c8.1 9.8 15.5 20.2 22.1 31.2l4.7 8.1c6.1 11 11.4 22.4 15.8 34.3zM256 336c44.2 0 80-35.8 80-80s-35.8-80-80-80s-80 35.8-80 80s35.8 80 80 80z'/%3E%3C/svg%3E");
}

@media (max-width: 767.98px) {
    .admin {
        padding-top: 6rem;
    }
}

form {
    position: relative;
}

.registration .form-success,
.contact .form-success {
    display: none;
    z-index: 10;
    text-align: center;
    padding: 0;
    opacity: 0;
    transition: all .2s;
    visibility: hidden;
}

.registration.success .form-success,
.contact.success .form-success {
    opacity: 1;
    display: block;
    transition: all .2s;
    visibility: visible;
}

.registration.success .container form>*:not(.form-success),
.contact.success .container form>*:not(.form-success) {
    display: none;
}

.registration .form-success svg,
.contact .form-success svg {
    margin: 0 0 2rem;
}

.registration .form-success svg path {
    fill:#00d8be;
}

.registration .form-success svg circle {
    stroke:#00d8be;
}

.registration .form-success h3 {
    max-width: 400px;
    margin: 0 auto 1rem;
    color: #fff200;
    text-align: center;
    font-weight: 900;
}

.registration .form-success p {
    max-width: 320px;
    margin: 0 auto;
    color: #fff;
}

.contact .form-success h3 {
    max-width: 400px;
    margin: 0 auto 1rem;
    color: #00d8be;
    text-align: center;
    font-weight: 900;
}

.contact .form-success p {
    max-width: 320px;
    margin: 0 auto;
    color: #00d8be;
}

.contact .form-success .svg path {
    fill: #00d8be;
}

.contact .form-success .svg circle {
    stroke: #00d8be;
}

/* Responsive CSS */

@media (max-width:409.98px) {
    .intro {
        background-size: cover !important;
    }
}

@media (min-width:410px) and (max-width:767.98px) {
    .intro {
        background-size: contain !important;
    }
}

@media (max-width:767.98px) {
    .btn-close {
        right: 0;
    }
    .form-check-label {
        width: calc(100% - 20px);
        font-size: 16px;
    }
    form {
        margin-top: 2rem;
    }
    form .btn {
        margin: 2rem auto 0;
        display: block;
    }
    .form-group {
        margin-bottom: .5rem;
    }
    footer {
        height: auto;
        line-height: 1.4;
        padding: 1rem 0 4rem;
        position: relative;
    }
    .content-padding {
        padding-top: 2rem;
        padding-bottom: 2rem;
    }    
    .top {
        position: absolute;
        bottom: 1rem;
        top: auto;
        left: 0;
        right: 0;
        margin: 0 auto;
    }
    .site {
        font-size: 1rem;
    }
    h1.subpage {
        font-size: 40px;
        line-height: 38px;
        margin: 4rem 0 -2rem;
    }
    h2 {
        font-size: 32px;
        line-height: 32px;
        margin-bottom: 1rem;
    }
    h3 {
        font-size: 1.8rem;
        margin: 0 0 1rem;
    }

    .top-auchan {
        margin: 4rem 0 0 0;
        padding-bottom: 1rem;
    }
    
    .top-auchan p {
        line-height: 1.4rem;
        text-align: center;
        padding: .5rem 0;
        font-size: 16px;
    }

    .top-auchan .svg {
        position: relative;
        right: auto;
        top: auto;
        transform: none;
        margin: 0 auto;
        display: block;
        width: auto;
        height: 30px;
    }

    .intro {
        margin: 64px 0 0;
        padding: 0 0 1rem;
        text-align: center;
        height: auto;
        background: linear-gradient(90deg, rgba(14, 107, 188, 1) 0%, rgba(45, 152, 224, 1) 100%);
    }

    .intro span {
        left: auto;
        top: auto;
        font-size: 3vw;
        right: .5rem;
        bottom: .2rem;
    }

    .intro h1 {
        font-size: 15vw;
        margin: 0;
        padding: 1rem .5rem;
    }

    .intro h1>span {
        font-size: 6vw;
    }

    .intro img {
        margin: 0 -12px;
        max-width: calc(100% + 24px);
        z-index: 2;
        position: relative;
    }

    .intro .intro-content>p {
        position: relative;
        top: auto;
        width: 100%;
        max-width: none;
        right: auto;
        font-size: 3vw;
    }

    .intro .container>span {
        right: 20px;
        left: auto;
        bottom: 23vw;
        position: absolute;
        font-size: 3vw;
    }

    .intro .container>img:first-of-type {
        max-width: 50%;
    }

    .intro .container>span {
        position: relative;
        left: 0;
        margin: 0 0 1rem;
        display: none;
    }

    .intro h2 {
        text-align: center;
        font-size: 7vw;
        margin: .5rem 0 0 0;
        max-width: none;
    }

    .intro h2 span {
        font-size: 9vw;
    }

    .intro .intro-content>p {
        font-size: 5vw !important;
        margin: 0 0 .5rem;
        line-height: 1.2;
        display: none;
    }

    .intro p b {
        display: block;
    }

    .intro p span {
        display: block;
    }

    .intro .btn {
        margin: 0 0 -6px -7%;
        display: block;
        width: 75%;
        transform: scale(70%);
    }

    .dowin {
        text-align: center;
        background-color: #fff200;
        color: #0073d5;
        font-size: 20px;
        padding: 1rem 0;
        line-height: 22px;
    }

    .dowin b {
        font-size: 12vw;
        line-height: 1;
    }

    .steps {
        background: linear-gradient(98deg, rgba(14, 107, 188, 1) 0%, rgba(45, 152, 224, 1) 100%);
    }

    .steps h3 {
        margin-top: 3rem;
        font-size: 32px;
    }

    .steps img, .steps svg {
        height: 60px;
    }

    .steps img + b, .steps svg + b {
        font-size: 24px;
        margin-bottom: 1rem;
    }

    .steps img, .steps svg {
        margin: 0rem 0 -1rem;
    }

    .steps p {
        font-size: 18px;
    }

    .steps .btn {
        margin: 0 auto;
        display: block;
        width: 256px;
    }

    .step-item {
        margin: 1rem 0 0;
        padding: 1rem;
    }

    .registration {
        font-size: 17px;
    }

    .registration .btn {
        margin: 0 auto;
        display: block;
        width: 256px;
    }

    .registration h2::after {
        width: 65px;
        height: 20px;
        right: -77px;
        background-size: contain;
    }

    .registration .col-lg-6 p {
        margin: 0;
        max-width: none;
    }

    .registration .btn-primary::after {
        display: none;
    }

    .shop img {
        display: none;
    }

    .faq {
        padding: 2rem 1rem;
    }

    .winners {
        font-size: 17px;
        padding: 2rem 1rem;
        background-size: auto;
        background-repeat: repeat;
    }

    .winners .container {
        padding: 0;
    }

    .winners span {
        font-size: 1.7rem;
        margin: 0 0 -2.5rem;
    }

    .winners .btn {
        margin: 0 auto 1rem;
        display: block;
        width: 256px;
    }

    .winners img {
        margin: 2rem auto 1rem;
    }

    .winners .container>span {
        top: auto;
        bottom: 22%;
        left: 0;
        right: 0;
        display: block;
        text-align: center;
        font-size: 2.1vw;
        margin-left: -7px;
    }

    .winners .note {
        margin: 0 0 2rem;
    }

    .products {
        font-size: 16px;
    }

    .products img {
        margin: -1rem auto;
    }

    .prizes p + img {
        margin-bottom: 2rem;
    }

    .prizes .container {
        padding: 0;
    }

    .prizes .container>div {
        left: 0;
        top: 1rem;
    }

    .prizes h2 {
        padding: .35rem 1.5rem .35rem 2.5rem;
        margin: 0 0 0 -1.75rem;
        line-height: 9vw;
    }

    .prizes h2 span {
        font-size: 9.5vw;
    }

    .competition-item {
        margin: 0 -12px;
        padding: 2rem 1rem 1rem;
        border-radius: 0;
    }
    #competition-menu {
        padding: 0;
    }
    #competition-menu .nav {
        display: block;
        text-align: center;
    }
    #competition-menu .nav li {
        display: block;
        margin-bottom: 1rem;
    }

    .tab-content>.tab-pane {
        padding: 2rem 0;
    }
    
    .contact {
        padding: 2rem 0;
        font-size: 17px;
    }

    .contact p {
        margin: 0;
    }

    #competition-menu .btn {
        margin: 0 auto;
        display: block;
        width: 256px;
    }

    .system-msg-content {
        transform: translateY(-50%);
        left: 1rem;
        right: 1rem;
    }
    .competition.success .competition-success h3,
    .validation.success .validation-success h3 {
        font-size: 2.2rem;
        line-height: 40px;
    }
    .validation {
        min-height: calc(100vh - 170px);
    }    
}

@media (min-width:768px) and (max-width:991.98px) {
    .system-msg-content {
        transform: translateY(-50%);
        left: 10%;
        right: 10%;
    }

    h2 {
        font-size: 48px;
    }

    .top-auchan {
        margin-top: 64px;
    }

    .top-auchan p {
        line-height: 60px;
        font-size: 16px;
        padding-left: 1rem;
        padding-top: 4px;
    }

    .intro {
        background-size: 1600px;
        height: 410px;
        background-position: center left 60%;
        margin-top: 64px;
    }

    .intro h1 {
        font-size: 6.5vw;
        padding: 60px 0 24px;
    }

    .intro h1 span {
        font-size: 3.5vw;
    }

    .intro h2 {
        max-width: 35%;
        font-size: 2.5vw;
    }

    .intro h2 span {
        font-size: 6vw;
    }
    
    .intro .intro-content>p {
        bottom: 0;
        font-size: 16px;
        line-height: 40px;
    }

    .intro .container>span {
        bottom: 0;
        right: .5rem;
    }
    
    .steps img + b, .steps svg + b {
        font-size: 24px;
    }

    .winners img {
        max-height: 350px;
        right: -2.6rem;
    }

    .winners .container>span {
        right: 132px;
        top: 174px;
        font-size: 9px;
    }

}

@media (min-width:768px) {
    footer .text-md-start {
        position: relative;
    }

    footer .text-md-start p a:last-of-type {
        position: absolute;
        right: 9%;
    }
}

@media (max-width:991.98px) {
    header {
        height: 64px;
        margin-bottom: -64px;
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        z-index: 20;
    }

    .navbar {
        height: 64px;
    }

    header.scrolled {
        transition: all .2s;
        height: 64px;
        margin-bottom: -64px;
        box-shadow: 0 0 20px rgb(0 0 0 / 20%);
    }

    header.scrolled .nav-link {
        line-height: 40px;
    }

    .logo-primary img,
    .logo-primary svg,
    header.scrolled .logo-primary img,
    header.scrolled .logo-primary svg {
        height: 64px;
    }

    .logo-secondary img,
    .logo-secondary svg,
    header.scrolled .logo-secondary img,
    header.scrolled .logo-secondary svg {
        height: 45px;
    }

    .navbar-nav {
        z-index: 1;
        position: relative;
        padding: .8rem 0;
    }

    .nav-link {
        line-height: 52px;
        font-size: 21px;
        padding: 0;
    }

    .navbar-expand-lg .navbar-nav .nav-link {
        padding-left: 0;
        padding-right: 0;
        text-align: center;
    }

    .navbar-collapse {
        top: 32px;
        position: absolute;
        background-color: #0478d0;
        width: calc(100% + 1rem);
        margin: 0px 0px 0px -1rem;
        box-shadow: 0 10px 25px rgb(0 0 0 / 25%);
    }

    .registration h3 + p {
        text-align: center;
        max-width: none;
    }

    .intro>img {
        width: 100%;
    }

    .step-item {
        height: auto;
        padding: 0;
    }

}

@media (min-width:992px) and (max-width:1199.98px) {
    .navbar-expand-lg .navbar-nav .nav-link {
        padding-left: 12px;
        padding-right: 12px;
        font-size: 20px;
    }
    .navbar-expand-lg .navbar-nav .nav-item:first-child {
        display: none;
    }

    .system-msg-content {
        transform: translateY(-50%);
        left: 20%;
        right: 20%;
    }

    .form-group .placeholder {
        font-size: 14px;
    }

    h2 {
        font-size: 48px;
    }

    .intro {
        height: 492px;
        background-position: center left 60%;
    }

    .intro-content-plus {
        background-size: 1420px;
        height: 96px;
        margin-bottom: -96px;
    }

    .intro h1 {
        font-size: 7vw;
    }

    .intro h1 span {
        font-size: 2.4vw;
    }

    .intro .container>span {
        right: 1rem;
        bottom: .35rem;
    }

    .intro h2 {
        font-size: 2.3vw;
        width: 38%;
    }

    .intro h2 span {
        font-size: 3.5vw;
    }

    .intro .intro-content>p {
        font-size: 22px;
    }

    .intro .container>p {
        font-size: 20px;
        margin: 0;
        max-width: 300px;
    }

    .products .note {
        margin: 2rem 0 1rem;
    }
    
}

@media (min-width:1200px) {

    .intro .container {
        position: relative;
        height: 492px;
    }

    .products .note {
        padding-top: 1rem;
    }
}

.CookieDeclaration {
    display: none;
}