@font-face {
    font-family: Azteca;
    src: url(/fonts/azteca/Azteca-Regular.woff2) format("woff2"), url(/fonts/azteca/Azteca-Regular.woff) format("woff"), url(/fonts/azteca/Azteca-Regular.otf) format("opentype");
    font-weight: 400;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: Azteca;
    src: url(/fonts/azteca/Azteca-Cd_Bold_It.woff2) format("woff2"), url(/fonts/azteca/Azteca-Cd_Bold_It.woff) format("woff"), url(/fonts/azteca/Azteca-Cd_Bold_It.otf) format("opentype");
    font-weight: 700;
    font-style: italic;
    font-stretch: condensed;
    font-display: swap
}

.score-title {
    font-stretch: condensed;
    color: #179d4a;
    text-shadow: 0 0 3px #CDFC9A, 0 0 3px rgba(205, 252, 154, .77), 0 0 7px #CDFC9A;
    -webkit-text-stroke-width: 1px;
    -webkit-text-stroke-color: rgba(255, 255, 255, .4);
    font-size: clamp(3rem, .8vw + 1.1rem, 3rem);
    margin-bottom: 20px
}

.validate-btn {
    border-radius: 30px;
    color: #fff;
    padding: 15px 30px 12px;
    background-color: #179d4a
}

.validate-btn:hover {
    background: #145739 !important;
    color: #fff !important
}

.grass-texture {
    background: var(--1a7c6abd) left center no-repeat, var(--db9e8772) right center no-repeat, var(--7e9342d0) center top no-repeat;
    background-size: 200px auto, 200px auto, cover;
    background-position: left center, right center, center top;
    color: #fff;
    position: relative
}

.grass-texture .container {
    max-width: 600px;
    margin-inline: auto
}

.grass-texture .code-container {
    padding: 2% 0
}

body {
    font-family: Azteca;
    margin: 0;
    padding: 0
}

.visa-inline {
    display: inline-block;
    vertical-align: baseline;
    transform: translateY(2px);
    width: clamp(120px, 10vw, 148px);
    height: auto;
    margin-left: .1ch;
    margin-bottom: .1ch
}

.home-wrap {
    margin-top: 64px;
    background: var(--7e9342d0) center top no-repeat;
    background-size: cover;
    background-position: center top
}

.home-wrap img {
    max-width: 1400px;
    margin-inline: auto
}

.teaser-logo {
    width: clamp(300px, 14vw, 350px);
    height: auto;
    display: block
}

h1 {
    font-size: clamp(2rem, 1.5vw + 1.5rem, 2.5rem);
    line-height: normal
}

.teaser-h1 {
    font-style: italic;
    font-stretch: condensed;
    font-weight: 900;
    line-height: 1.06;
    letter-spacing: .5px;
    text-transform: uppercase;
    font-size: clamp(48px, 5.2vw, 64px);
    margin-bottom: 30px
}

.teaser-strong {
    color: #9be34c
}

.teaser-sub {
    margin: 0;
    font-size: clamp(24px, 3.2vw, 36px);
    font-family: Azteca;
    font-style: italic;
    font-weight: 400;
    line-height: 44px !important
}

.teaser-ital {
    margin: 0;
    font-style: italic;
    font-weight: 800;
    font-stretch: condensed;
    color: #9be34c;
    font-size: clamp(24px, 3.6vw, 32px);
    font-size: 48px
}

.teaser-center {
    margin-top: clamp(2vh, 0vh, 24vh);
    text-align: start
}

.teaser-center .hero-txt {
    max-width: 540px
}

.logo-visa-hero {
    position: absolute;
    right: -1px;
    bottom: 60px;
    max-width: 270px
}

.logo-visa-mobile {
    display: none;
    position: relative
}

@media (min-width: 320px) and (max-width: 749px) {
    .grass-texture {
        background: var(--0fe43430) top center no-repeat, var(--95376ff8) bottom center no-repeat, var(--055bfab4) center top no-repeat;
        background-size: 200px auto, 200px auto, cover;
        background-position: top center, bottom center, center top;
        color: #fff;
        position: relative
    }

    .code-container {
        padding: 50px 30px
    }
}

@media (min-width: 320px) and (max-width: 549px) {
    .teaser-center {
        padding-top: 0 !important;
        margin-top: 0 !important
    }

    .logo-visa-hero {
        display: none
    }

    .logo-visa-mobile {
        display: block;
        width: 100%
    }
}

@media (min-width: 550px) and (max-width: 649px) {
    .teaser-center {
        padding-top: 0 !important;
        margin-top: 0 !important
    }

    .logo-visa-hero {
        display: none
    }

    .logo-visa-mobile {
        display: block;
        width: 100%
    }
}

@media (min-width: 650px) and (max-width: 749px) {
    .teaser-center {
        padding-top: 0 !important;
        margin-top: 0 !important
    }

    .logo-visa-hero {
        display: none
    }

    .logo-visa-mobile {
        display: block;
        width: 100%
    }
}

@media (min-width: 750px) and (max-width: 1038px) {
    .teaser-center .hero-txt {
        max-width: 370px
    }

    .logo-visa-hero {
        max-width: 180px
    }
}