@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
}

.responsive-table {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin-bottom: 2rem
}

.responsive-table table {
    width: 100%;
    border-collapse: collapse;
    font-family: Arial, sans-serif;
    text-align: center;
    min-width: 600px
}

.responsive-table caption {
    font-weight: 700;
    padding: 8px 0
}

.responsive-table th,
.responsive-table td {
    border: 1px solid #000;
    padding: 8px;
    vertical-align: middle;
    word-break: break-word
}

.responsive-table thead th {
    background-color: #145739 !important;
    color: #fff
}

@media (max-width: 768px) {
    .responsive-table table {
        font-size: 14px;
        min-width: 500px
    }

    .responsive-table caption {
        font-size: 15px
    }
}

.legales table td {
    border-right: #E6E6E6 solid 1px;
    vertical-align: middle
}

.legales table td tr td {
    border-right: none
}

.legales table td table {
    margin-bottom: 0
}

.legales {
    overflow-y: hidden;
    overflow-x: visible
}

.legales p {
    font-size: 16px;
    margin-bottom: 15px
}

.legales thead th {
    background-color: #145739 !important;
    color: #fff
}

.iconly-green {
    color: #145739
}

.gray-title {
    background: #eff0f4;
    padding: 9px 9px 5px;
    font-weight: 700
}

.bullets {
    list-style-type: disc;
    list-style-position: inside
}

.bullets-number {
    list-style-type: decimal;
    list-style-position: inside
}

.bullets-letter {
    list-style-type: upper-latin;
    list-style-position: inside
}

.text-xl {
    font-size: 24px;
    margin-bottom: 0;
    font-weight: 600
}

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-size: cover;
    background-position: center bottom;
    background-repeat: no-repeat;
    display: grid;
    grid-template-rows: auto 1fr auto;
    place-items: start;
    text-align: center;
    color: #fff;
    padding: 7% 50px;
    margin-inline: auto;
    max-width: 1400px;
    position: relative
}

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

.teaser-h1 {
    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;
    color: #9be34c;
    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) {
    .code-container {
        padding: 110px 30px 80px
    }
}

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

    .logo-visa-hero {
        display: none
    }

    .home-wrap {
        height: 1060px
    }

    .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
    }

    .home-wrap {
        height: 1170px
    }

    .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
    }

    .home-wrap {
        height: 1270px
    }

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

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

    .home-wrap {
        padding: 0% 50px 12%
    }

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

h1 {
    font-size: clamp(2rem, 1.5vw + 1.6rem, 2.5rem);
    font-family: Azteca;
    font-weight: 700;
    font-style: italic;
    font-stretch: condensed
}

h2 {
    font-size: clamp(1.25rem, 1vw + 1.1rem, 1.5rem);
    font-family: Azteca;
    font-weight: 700;
    font-style: italic;
    font-stretch: condensed
}