/* =========================================================
   CLEAN v2 — organizado
   - Mantém a estrutura visual atual
   - Remove duplicações
   - Mantém foco em legibilidade e manutenção
========================================================= */


/* =========================================================
   TOKENS GLOBAIS
========================================================= */
:root{
    /* Base */
    --bg: #EEF8F5;
    --surface: #ffffff;

    --brand: #5F7852;
    --brand-2: #4f6645;
    --ink: #163025;
    --muted: rgba(22,48,37,.74);
    --border: rgba(22,48,37,.12);

    --radius: 18px;
    --radius-lg: 22px;

    --shadow-offer: 0 22px 60px rgba(0,0,0,.12);

    --divider-h: 26px;
    --divider-opacity: .14;

    --band-pad: 64px;
    --band-pad-m: 52px;

    --container-pad: 18px;
    --container-pad-m: 12px;

    --list-gap: 8px;
    --list-item-gap: 10px;
    --ic: 28px;

    --anchor-offset: 96px;

    /* Escola (es-) */
    --es-bg: rgba(255,255,255,.95);
    --es-border: rgba(22,48,37,.10);
    --es-border-soft: rgba(22,48,37,.08);
    --es-shadow: 0 10px 30px rgba(0,0,0,.05);
    --es-shadow-lg: 0 24px 60px rgba(0,0,0,.16);
    --es-radius: 18px;
    --es-radius-lg: 22px;
    --es-ink: #163025;
    --es-text: rgba(22,48,37,.82);
    --es-muted: rgba(22,48,37,.62);
    --es-brand: #5F7852;
    --es-brand-2: #4f6645;
    --es-accent: #E07A3F;
    --es-soft: rgba(191,230,214,.22);

    /* Ebooks (eb-) */
    --eb-bg: rgba(255,255,255,.95);
    --eb-border: rgba(22,48,37,.10);
    --eb-border-soft: rgba(22,48,37,.08);
    --eb-shadow: 0 10px 30px rgba(0,0,0,.05);
    --eb-shadow-lg: 0 24px 60px rgba(0,0,0,.16);
    --eb-radius: 18px;
    --eb-radius-lg: 22px;
    --eb-ink: #163025;
    --eb-text: rgba(22,48,37,.82);
    --eb-muted: rgba(22,48,37,.62);
    --eb-brand: #5F7852;
    --eb-brand-2: #4f6645;
    --eb-accent: #E07A3F;
    --eb-soft: rgba(191,230,214,.22);
}


/* =========================================================
   BASE
========================================================= */
html{ scroll-behavior: smooth; }

body{
    background: var(--bg);
    color: var(--ink);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

.display-none{
    display: none;
}

/* Âncoras */
[id]{ scroll-margin-top: var(--anchor-offset); }

.anchor-target{
    display: block;
    height: 0;
    scroll-margin-top: var(--anchor-offset);
}


/* =========================================================
   TOPBAR
========================================================= */
.topbar{
    background: rgba(191,230,214,.45);
    border-bottom: 2px solid rgba(22,48,37,.08);
    backdrop-filter: blur(8px);
    font-size: clamp(14px, 5.1vw, 25px);
}

.topbar .msg{
    font-weight: 950;
    letter-spacing: .2px;
    color: #1f3a2d;
}

.topbar b{
    color: #E07A3F;
}


/* =========================================================
   HERO
========================================================= */
.hero{
    position: relative;
    overflow: hidden;
    padding: 36px 0 10px;
    background:
        radial-gradient(980px 560px at 10% 10%, rgba(191,230,214,.55), rgba(238,248,245,0) 60%),
        radial-gradient(980px 620px at 92% 18%, rgba(95,120,82,.14), rgba(238,248,245,0) 62%),
        linear-gradient(180deg, rgba(255,255,255,.88), rgba(238,248,245,.92));
}

.hero::after{
    content:"";
    position:absolute;
    inset:0;
    background: radial-gradient(1100px 520px at 50% 90%, rgba(0,0,0,.06), rgba(0,0,0,0) 62%);
    pointer-events:none;
}

.logo img{
    max-height: 46px;
    width:auto;
    height:auto;
    display:block;
}

.h1{
    font-family: Georgia, "Times New Roman", Times, serif;
    font-weight: 900;
    letter-spacing: -.35px;
    line-height: 1.06;
    margin: 16px 0 12px;
    font-size: clamp(20px, 4.2vw, 40px);
    color: #0f2a20;
    text-wrap: balance;
}

.h1 .accent{
    color: var(--brand);
}

.sub{
    font-size: clamp(15px, 1.55vw, 19px);
    color: rgba(22,48,37,.82);
    line-height: 1.52;
    font-weight: 650;
    max-width: 62ch;
}

.hero-media{
    position: relative;
    display: inline-block;
    width: 100%;
}

.hero-badge{
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 2;
    display: inline-block;
    background: #E07A3F;
    color: #fff;
    padding: 7px 12px;
    border-radius: 10px;
    font-size: .85rem;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: .2px;
    box-shadow: 0 6px 16px rgba(0,0,0,.12);
}

.hero-img{
    display: block;
    width: 100%;
    height: auto;
    border-radius: var(--radius);
}

.hero-benefits{
    list-style:none;
    padding:0;
    margin:16px 0;
}

.hero-benefits li{
    display:flex;
    align-items:flex-start;
    gap:8px;
    margin-bottom:8px;
    font-size:0.95rem;
    padding-left: 20px;
}

.hero-benefits i{
    color:#00AE57;
    margin-top:2px;
}


/* =========================================================
   SOCIAL PROOF
========================================================= */
.social-proof{
    display: flex;
    align-items: center;
    gap: 10px;
}

.avatars{
    display: flex;
}

.avatars img{
    width: 42px;
    height: 42px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid #fff;
    margin-left: -12px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.08);
}

.avatars img:first-child{
    margin-left: 0;
}

.social-text{
    font-size: 16px;
    color: #163025;
    line-height: 1.2;
}

.social-text strong{
    color: #E07A3F;
    font-size: 17px;
    font-weight: 700;
}


/* =========================================================
   BOTÕES
========================================================= */
.btn-cta{
    border: 1px solid rgba(22,48,37,.16);
    background: rgba(255,255,255,.92);
    color: #0f2a20;
    padding: 12px 18px;
    border-radius: 14px;
    font-weight: 950;
}

.btn-cta:hover{
    background: rgba(255,255,255,1);
    color: #0f2a20;
    border-color: rgba(22,48,37,.22);
}

.btn-checkout{
    border: 0;
    background: var(--brand);
    color: #fff;
    padding: 14px 18px;
    border-radius: 14px;
    box-shadow: 0 14px 28px rgba(95,120,82,.24);
    font-weight: 1000;
}

.btn-checkout:hover{
    background: var(--brand-2);
    color:#fff;
}

.btn-checkout-cta{
    background: #00AE57;
    border: 0;
    border-radius: 22px;
    padding: 18px 22px;
    font-weight: 1000;
    font-size: 22px;
    letter-spacing: .2px;
    color: #ffffff;
    box-shadow:
        0 14px 30px rgba(0,174,87,.35),
        0 6px 0 rgba(0,140,70,1);
    transition: all .18s ease;
}

.btn-checkout-cta:hover{
    background: #00994D;
    transform: translateY(-2px);
    box-shadow:
        0 20px 40px rgba(0,174,87,.40),
        0 8px 0 rgba(0,120,60,1);
    color: #fff;
}

.btn-checkout-cta:active{
    transform: translateY(2px);
    box-shadow:
        0 8px 18px rgba(0,174,87,.30),
        0 2px 0 rgba(0,120,60,1);
}

.mini{
    font-size: 13px;
    color: rgba(22,48,37,.72);
    font-weight: 850;
}


/* =========================================================
   SEÇÕES
========================================================= */
.band{
    position: relative;
    padding: var(--band-pad) 0;
    isolation: isolate;
}

.band::before{
    content:"";
    position:absolute;
    left:0;
    right:0;
    top:0;
    height: var(--divider-h);
    background:
        radial-gradient(
        1200px 24px at 50% 100%,
        rgba(22,48,37,var(--divider-opacity)) 0%,
        rgba(22,48,37,0) 72%
        );
    pointer-events:none;
    z-index:0;
    opacity:.95;
}

.band .container{
    position:relative;
    z-index:1;
    padding-left: var(--container-pad) !important;
    padding-right: var(--container-pad) !important;
}

.band-a{
    background:
        linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.78)),
        linear-gradient(180deg, rgba(238,248,245,.96), rgba(238,248,245,1));
}

.band-b{
    background:
        linear-gradient(180deg, rgba(191,230,214,.18), rgba(255,255,255,.84)),
        linear-gradient(180deg, rgba(255,255,255,.82), rgba(238,248,245,1));
}

.band-c{
    background:
        linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.76)),
        radial-gradient(980px 640px at 85% 20%, rgba(95,120,82,.08), rgba(238,248,245,0) 62%),
        linear-gradient(180deg, rgba(238,248,245,1), rgba(238,248,245,.96));
}


/* =========================================================
   TÍTULOS
========================================================= */
.section-title{
    font-family: Georgia, "Times New Roman", Times, serif;
    font-weight: 900;
    letter-spacing: -.2px;
    color: #0f2a20;
    font-size: clamp(22px, 3vw, 34px);
    margin: 0 0 10px;
    text-wrap: balance;
}

.section-title b{
    color: #E07A3F;
}

.section-sub{
    color: rgba(22,48,37,.72);
    font-weight: 650;
    margin: 0 0 22px;
    max-width: 78ch;
}

.section-sub b{
    color: #E07A3F;
}

/* =========================================================
   SOFT CARD
========================================================= */
.soft-card{
    background: transparent;
    border: 0;
    box-shadow: none;
    border-radius: 0;
}

.soft-card.p-4{
    padding: 0 !important;
}

.soft-card.h-100{
    padding: 14px 0 !important;
    border-top: 1px solid rgba(22,48,37,.10);
}

.row.g-3 .col-lg-4:first-child .soft-card.h-100{
    border-top: 0;
}


/* =========================================================
   LISTAS
========================================================= */
.ic{
    width: var(--ic);
    height: var(--ic);
    border-radius: 999px;
    background: rgba(191,230,214,.45);
    border: 1px solid rgba(95,120,82,.20);
    display:flex;
    align-items:center;
    justify-content:center;
    color: var(--brand);
    flex: 0 0 var(--ic);
}

.ic i{
    font-size: 14px;
    line-height: 1;
}

.list-clean{
    list-style:none;
    margin:0;
    padding:0;
    display:flex;
    flex-direction: column;
    gap: var(--list-gap);
}

.list-clean li{
    display:flex;
    align-items:flex-start;
    gap: var(--list-item-gap);
    padding: 8px 0;
    border-bottom: 1px solid rgba(22,48,37,.08);
    font-size: 15.5px;
    line-height: 1.48;
    font-weight: 720;
    color: rgba(22,48,37,.88);
}

.list-clean li:last-child{
    border-bottom:0;
}

.list-clean li span:last-child{
    flex:1;
    display:block;
}


/* =========================================================
   GALERIAS / IMAGENS
========================================================= */
.band .full-bleed{
    margin-left: 0 !important;
    margin-right: 0 !important;
}

.gallery-img{
    width:100%;
    height:auto;
    display:block;
    border-radius: var(--radius);
    border: 1px solid rgba(22,48,37,.12);
    background:#fff;
}

.testi-img{
    width:100%;
    height:auto;
    border-radius: var(--radius);
    border: 1px solid rgba(22,48,37,.10);
    background:#fff;
    display:block;
}


/* =========================================================
   EBOOK FRAME
========================================================= */
.ebook-frame{
    aspect-ratio: 9 / 16;
    width: 100%;
    border-radius: var(--radius);
    border: 1px solid rgba(22,48,37,.12);
    background: rgba(255,255,255,.92);
    display: grid;
    place-items: center;
    overflow: hidden;
    padding: 10px;
}

.ebook-img{
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.ebook-frame .gallery-img,
.ebook-frame .ebook-img{
    border: 0 !important;
    background: transparent !important;
    border-radius: calc(var(--radius) - 2px) !important;
}


/* =========================================================
   OFERTA
========================================================= */
.offer{
    background: rgba(255,255,255,.96);
    border: 1px solid rgba(22,48,37,.14);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-offer);
    overflow:hidden;
}

.offer-inner{
    padding: 22px;
}

.offer-head{
    display:flex;
    align-items:center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}

.offer-kicker{
    font-weight: 950;
    color: rgba(15,42,32,.88);
}

.offer-kicker i{
    color: rgba(95,120,82,.70);
}

.offer-table{
    list-style:none;
    margin: 0;
    padding: 0;
    border-top: 1px solid rgba(22,48,37,.10);
}

.offer-row{
    display:flex;
    align-items:flex-start;
    justify-content: space-between;
    gap: 14px;
    padding: 12px 0;
    border-bottom: 1px solid rgba(22,48,37,.10);
}

.offer-left{
    display:flex;
    align-items:flex-start;
    gap: 10px;
    flex: 1;
    min-width: 0;
}

.offer-check{
    width: 26px;
    height: 26px;
    border-radius: 999px;
    display:flex;
    align-items:center;
    justify-content:center;
    background: rgba(191,230,214,.38);
    border: 1px solid rgba(95,120,82,.18);
    color: var(--brand);
    flex: 0 0 26px;
    margin-top: 1px;
}

.offer-check i{
    font-size: 16px;
}

.offer-text{
    font-weight: 750;
    color: rgba(22,48,37,.90);
    line-height: 1.38;
    overflow-wrap: anywhere;
}

.offer-price{
    font-weight: 1000;
    color: #E07A3F;
    white-space: nowrap;
    text-align: right;
    min-width: 74px;
}

.offer-total{
    display:flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 12px;
    padding-top: 12px;
    margin-top: 6px;
}

.offer-total .tlabel{
    font-weight: 1000;
    color: rgba(22,48,37,.78);
}

.offer-total .tvalue{
    font-weight: 1000;
    white-space: nowrap;
}

.offer-total .tvalue s{
    color: #E07A3F;
    text-decoration-thickness: 2px;
    font-size: clamp(17px, 4.1vw, 22px);
}

.offer-final{
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid rgba(22,48,37,.12);
}

.final-grid{
    display:grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 18px;
    align-items: start;
}

.final-price-box{
    background: rgba(255,255,255,.92);
    border: 1px solid rgba(22,48,37,.10);
    border-radius: var(--radius-lg);
    padding: 16px 16px 12px;
}

.final-price-box .de{
    color: rgba(22,48,37,.90);
    font-weight: 950;
    font-size: 18px;
    margin-bottom: 8px;
}

.final-price-box .de s{
    color: #E07A3F;
}

.final-price-box .parcelado{
    font-size: 18px;
    font-weight: 900;
    color: rgba(22,48,37,.90);
}

.final-price-box .parcelado strong{
    font-weight: 1000;
}

.final-price-line{
    display:flex;
    align-items: baseline;
    gap: 10px;
    flex-wrap: wrap;
    margin: 0;
}

.final-price-line .value{
    display:flex;
    align-items: baseline;
    gap: 6px;
}

.final-price-line .value .rs{
    font-size: 20px;
    font-weight: 900;
    color: #00AE57;
    margin-right: 4px;
}

.final-price-line .value .num{
    font-size: clamp(72px, 7vw, 102px);
    font-weight: 1000;
    line-height: 1;
    letter-spacing: -1.5px;
    color: #00AE57;
    font-variant-numeric: tabular-nums;
}

.final-price-line .value .num b{
    font-size: clamp(24px, 2vw, 35px);
}

.value-2{
    float: left;
    width: 100%;
    font-size: 20px;
    color: #00AE57;
}

.countdown-inline{
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid rgba(22,48,37,.10);
    display:flex;
    align-items:center;
    justify-content: space-between;
    gap: 12px;
}

.countdown-inline .label{
    font-size: 13px;
    font-weight: 900;
    color: rgba(22,48,37,.62);
    letter-spacing: .2px;
}

.countdown-inline .time{
    font-weight: 1000;
    font-size: 15px;
    letter-spacing: .8px;
    font-variant-numeric: tabular-nums;
    padding: 6px 10px;
    border-radius: 999px;
    background: transparent;
    border: 1px solid rgba(47,94,78,.18);
    color: #E07A3F;
}

.seals{
    margin-top: 14px;
    display:flex;
    flex-wrap: wrap;
    gap: 14px;
}

.seal{
    background: transparent;
    border: 0;
    padding: 0;
    border-radius: 0;
    display:flex;
    align-items:center;
    gap: 6px;
    font-weight: 800;
    font-size: 13px;
    color: rgba(22,48,37,.68);
}

.seal i{
    color: rgba(47,94,78,.65);
    font-size: 16px;
}


/* =========================================================
   FAQ
========================================================= */
#faqAcc .accordion-button{
    background: rgba(255,255,255,.92) !important;
    color: #0f2a20 !important;
    font-weight: 950;
}

#faqAcc .accordion-button:not(.collapsed){
    background: rgba(191,230,214,.22) !important;
    color: #0f2a20 !important;
    box-shadow: none !important;
}

#faqAcc .accordion-button:focus{
    box-shadow: 0 0 0 .2rem rgba(95,120,82,.22) !important;
    border-color: rgba(95,120,82,.30) !important;
}

#faqAcc .accordion-item{
    border: 1px solid rgba(22,48,37,.10) !important;
    border-radius: 16px;
    overflow:hidden;
    background: transparent !important;
}

#faqAcc .accordion-item + .accordion-item{
    margin-top: 12px;
}

#faqAcc .accordion-body{
    background: rgba(255,255,255,.86) !important;
    color: rgba(22,48,37,.82) !important;
    font-weight: 500 !important;
}

#faqAcc .accordion-button::after{
    background-image: var(--bs-accordion-btn-icon);
    opacity: .85;
    filter: brightness(0) saturate(100%)
        invert(27%) sepia(18%)
        saturate(465%)
        hue-rotate(88deg)
        brightness(95%) contrast(90%);
}

#faqAcc .accordion-button:not(.collapsed)::after{
    transform: rotate(180deg);
    opacity: 1;
}


/* =========================================================
   FOOTER
========================================================= */
footer{
    padding: 40px 0 24px;
    color: rgba(22,48,37,.74);
    font-weight: 650;
}

.footer-links a,
.footer-links span{
    text-decoration:none;
    border-bottom: 1px dashed rgba(22,48,37,.35);
    color: inherit;
    cursor: pointer;
}

.footer-links a:hover,
.footer-links span:hover{
    border-bottom-color: rgba(22,48,37,.62);
}


/* =========================================================
   ESCOLA — CAPAS / PROJETOS / MODAL
========================================================= */
.es-school-showcase{
    overflow: hidden;
}

.es-section-head{
    margin-bottom: 18px;
}

.es-projects-head{
    margin-top: 42px;
}

.es-covers-grid{
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

.es-cover-card{
    background: var(--es-bg);
    border: 1px solid var(--es-border);
    border-radius: var(--es-radius);
    box-shadow: var(--es-shadow);
    overflow: hidden;
}

.es-cover-media{
    aspect-ratio: 900 / 736;
    background: #fff;
    overflow: hidden;
}

.es-cover-media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.es-cover-body{
    padding: 10px 10px 12px;
}

.es-cover-title{
    margin: 0 0 4px;
    color: var(--es-ink);
    font-size: 14px;
    line-height: 1.25;
    font-weight: 900;
}

.es-cover-mini{
    font-size: 12px;
    line-height: 1.35;
    color: var(--es-muted);
    font-weight: 700;
}

.es-featured-grid{
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

.es-project-card{
    background: var(--es-bg);
    border: 1px solid var(--es-border);
    border-radius: var(--es-radius);
    box-shadow: var(--es-shadow);
    overflow: hidden;
}

.es-project-media{
    background: #fff;
    overflow: hidden;
}

.es-project-media.is-portrait{
    aspect-ratio: 800 / 1000;
}

.es-project-media.is-square{
    aspect-ratio: 800 / 800;
}

.es-project-media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.es-open-gallery{
    min-width: min(100%, 340px);
}

.es-modal{
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
}

.es-modal.is-open{
    display: block;
}

.es-modal-backdrop{
    position: absolute;
    inset: 0;
    background: rgba(10,20,16,.56);
    backdrop-filter: blur(4px);
}

.es-modal-dialog{
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: min(1080px, calc(100vw - 12px));
    max-height: calc(100vh - 12px);
    background: #fff;
    border-radius: var(--es-radius-lg);
    border: 1px solid var(--es-border);
    box-shadow: var(--es-shadow-lg);
    overflow: auto;
    -webkit-overflow-scrolling: touch;
}

.es-modal-close{
    position: sticky;
    top: 10px;
    float: right;
    z-index: 5;
    margin: 10px 10px 0 0;
    width: 42px;
    height: 42px;
    border: 1px solid var(--es-border);
    border-radius: 999px;
    background: rgba(255,255,255,.94);
    color: var(--es-ink);
}

.es-modal-top{
    padding: 16px 16px 8px;
}

.es-modal-kicker{
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--es-accent);
    margin-bottom: 6px;
}

.es-modal-title{
    margin: 0 0 8px;
    color: var(--es-ink);
    font-size: clamp(22px, 5vw, 30px);
    line-height: 1.15;
    font-weight: 900;
}

.es-modal-desc{
    margin: 0;
    color: var(--es-text);
    font-size: 14px;
    line-height: 1.5;
}

.es-modal-meta{
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 0 16px 14px;
}

.es-modal-pill{
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--es-soft);
    color: var(--es-ink);
    border: 1px solid rgba(95,120,82,.14);
    border-radius: 999px;
    padding: 7px 10px;
    font-size: 12px;
    font-weight: 800;
}

.es-modal-pill i{
    color: #00AE57;
}

.es-modal-grid{
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 0 16px;
}

.es-modal-card{
    background: var(--es-bg);
    border: 1px solid var(--es-border-soft);
    border-radius: 16px;
    overflow: hidden;
}

.es-modal-media{
    width:100%;
    background:#EEF8F5;
    border-radius:16px;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
}

.es-modal-media.is-square{
    aspect-ratio:1/1;
}

.es-modal-media.is-portrait{
    aspect-ratio:4/5;
}

.es-modal-media img{
    max-width:100%;
    max-height:100%;
    width:auto;
    height:auto;
}

.es-modal-loading{
    display: none;
    justify-content: center;
    gap: 8px;
    padding: 18px 16px 12px;
}

.es-modal-loading.is-visible{
    display: flex;
}

.es-loading-dot{
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--es-brand);
    animation: esPulse 1s infinite ease-in-out;
}

.es-loading-dot:nth-child(2){ animation-delay: .15s; }
.es-loading-dot:nth-child(3){ animation-delay: .30s; }

@keyframes esPulse{
    0%,100%{ transform: scale(.7); opacity:.45; }
    50%{ transform: scale(1); opacity:1; }
}

.es-modal-sentinel{
    height: 16px;
}

.es-modal-bottom{
    position: sticky;
    bottom: 0;
    background: linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,.95) 16%, #fff 100%);
    padding: 12px 16px 16px;
}


/* =========================================================
   EBOOKS — GALERIA / MODAL
========================================================= */
.eb-ebooks-showcase{
    overflow: hidden;
}

.eb-section-head{
    margin-bottom: 18px;
}

.eb-grid{
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

.eb-card{
    background: var(--eb-bg);
    border: 1px solid var(--eb-border);
    border-radius: var(--eb-radius);
    box-shadow: var(--eb-shadow);
    overflow: hidden;
}

.eb-media{
    aspect-ratio: 9 / 16;
    background: rgba(255,255,255,.92);
    display: grid;
    place-items: center;
    overflow: hidden;
    padding: 10px;
}

.eb-img{
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.eb-open-gallery{
    min-width: min(100%, 340px);
}

.eb-modal{
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
}

.eb-modal.is-open{
    display: block;
}

.eb-modal-backdrop{
    position: absolute;
    inset: 0;
    background: rgba(10,20,16,.56);
    backdrop-filter: blur(4px);
}

.eb-modal-dialog{
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: min(1080px, calc(100vw - 12px));
    max-height: calc(100vh - 12px);
    background: #fff;
    border-radius: var(--eb-radius-lg);
    border: 1px solid var(--eb-border);
    box-shadow: var(--eb-shadow-lg);
    overflow: auto;
    -webkit-overflow-scrolling: touch;
}

.eb-modal-close{
    position: sticky;
    top: 10px;
    float: right;
    z-index: 5;
    margin: 10px 10px 0 0;
    width: 42px;
    height: 42px;
    border: 1px solid var(--eb-border);
    border-radius: 999px;
    background: rgba(255,255,255,.94);
    color: var(--eb-ink);
}

.eb-modal-top{
    padding: 16px 16px 8px;
}

.eb-modal-kicker{
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--eb-accent);
    margin-bottom: 6px;
}

.eb-modal-title{
    margin: 0 0 8px;
    color: var(--eb-ink);
    font-size: clamp(22px, 5vw, 30px);
    line-height: 1.15;
    font-weight: 900;
}

.eb-modal-desc{
    margin: 0;
    color: var(--eb-text);
    font-size: 14px;
    line-height: 1.5;
}

.eb-modal-meta{
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 0 16px 14px;
}

.eb-modal-pill{
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--eb-soft);
    color: var(--eb-ink);
    border: 1px solid rgba(95,120,82,.14);
    border-radius: 999px;
    padding: 7px 10px;
    font-size: 12px;
    font-weight: 800;
}

.eb-modal-pill i{
    color: #00AE57;
}

.eb-modal-grid{
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 0 16px;
}

.eb-modal-card{
    background: var(--eb-bg);
    border: 1px solid var(--eb-border-soft);
    border-radius: 16px;
    overflow: hidden;
}

.eb-modal-media{
    aspect-ratio: 9 / 16;
    background: rgba(255,255,255,.92);
    display: grid;
    place-items: center;
    overflow: hidden;
    padding: 10px;
}

.eb-modal-media img{
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.eb-modal-loading{
    display: none;
    justify-content: center;
    gap: 8px;
    padding: 18px 16px 12px;
}

.eb-modal-loading.is-visible{
    display: flex;
}

.eb-loading-dot{
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--eb-brand);
    animation: ebPulse 1s infinite ease-in-out;
}

.eb-loading-dot:nth-child(2){ animation-delay: .15s; }
.eb-loading-dot:nth-child(3){ animation-delay: .30s; }

@keyframes ebPulse{
    0%,100%{ transform: scale(.7); opacity:.45; }
    50%{ transform: scale(1); opacity:1; }
}

.eb-modal-sentinel{
    height: 16px;
}

.eb-modal-bottom{
    position: sticky;
    bottom: 0;
    background: linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,.95) 16%, #fff 100%);
    padding: 12px 16px 16px;
}


/* =========================================================
   COMPARAÇÃO
========================================================= */
.school-comparison{
    background: #fff;
}

.comparison-card{
    border-radius: 24px;
    padding: 28px 22px;
    height: 100%;
    box-shadow: 0 10px 30px rgba(0,0,0,.06);
}

.comparison-pain{
    background: #fff8f8;
    border: 1px solid #f2d6d6;
}

.comparison-solution{
    background: #f4fbf7;
    border: 1px solid #d7eadf;
}

.comparison-title{
    font-size: 1.35rem;
    line-height: 1.3;
}

.comparison-list li{
    display: flex;
    align-items: flex-start;
    font-size: 1rem;
    line-height: 1.5;
    margin-bottom: 14px;
}

.comparison-list li i{
    margin-top: 3px;
    flex: 0 0 auto;
}

.comparison-pain .bi{
    color: #dc3545;
}

.comparison-solution .bi{
    color: #00AE57;
}

.comparison-highlight{
    font-size: 1.1rem;
    line-height: 1.6;
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
}

.anchor-price{
    font-size: 2.4rem;
    font-weight: 700;
    color: #E07A3F;
    text-decoration: line-through;
    line-height: 1.2;
}

.anchor-break{
    font-size: 1.1rem;
    font-weight: 600;
    color: #00AE57;
}


/* =========================================================
   PLANOS DA ESCOLA
========================================================= */
.school-plans-section .school-plans-text{
    color:#5f6b66;
    max-width:700px;
}

.school-plans-section .school-plan-card{
    position:relative;
    background:#fff;
    border:1px solid #e6ece8;
    border-radius:24px;
    padding:28px 22px;
    height:100%;
    box-shadow:0 10px 30px rgba(0,0,0,.05);
}

.school-plans-section .school-plan-card--featured{
    border:2px solid #00AE57;
    background:#f8fffb;
}

.school-plans-section .school-plan-badge{
    display:inline-block;
    margin-bottom:14px;
    padding:6px 12px;
    border-radius:999px;
    background:#00AE57;
    color:#fff;
    font-size:.9rem;
    font-weight:600;
}

.school-plans-section .school-plan-title{
    font-size:1.6rem;
    font-weight:700;
    color:#0f2a20;
    margin-bottom:6px;
}

.school-plans-section .school-plan-access{
    font-size:1rem;
    color:#5f6b66;
    margin-bottom:18px;
}

.school-plans-section .school-plan-price-wrap{
    margin-bottom:18px;
}

.school-plans-section .school-plan-installments{
    font-size:2rem;
    font-weight:700;
    line-height:1.15;
    color:#0f2a20;
}

.school-plans-section .school-plan-cash{
    margin-top:4px;
    font-size:1rem;
    color:#5f6b66;
}

.school-plans-section .school-plan-list{
    list-style:none;
    padding:0;
    margin:0;
}

.school-plans-section .school-plan-list li{
    display:flex;
    align-items:flex-start;
    gap:10px;
    margin-bottom:12px;
    color:#33403b;
    line-height:1.45;
}

.school-plans-section .school-plan-list i{
    color:#00AE57;
    margin-top:3px;
    flex:0 0 auto;
}

.school-plans-section .school-plan-note{
    margin:8px 0 0;
    color:#5f6b66;
    font-size:.98rem;
}

.school-plans-section .school-plan-btn-primary,
.school-plan-btn-primary{
    background:#00AE57;
    border:none;
    color:#fff;
    font-weight:700;
    font-size:1.15rem;
    padding:16px 20px;
    border-radius:14px;
    box-shadow:0 6px 18px rgba(0,174,87,0.25);
    animation:schoolPulseBtn 2s ease-in-out infinite;
}

.school-plans-section .school-plan-btn-primary:hover,
.school-plan-btn-primary:hover{
    background:#00994c;
    color:#fff;
    transform:translateY(-1px);
}

.school-plans-section .school-plan-btn-primary:active,
.school-plan-btn-primary:active{
    transform:scale(0.97);
}

.school-plans-section .school-plan-btn-secondary{
    background:#fff;
    border:2px solid #dfe7e2;
    color:#0f2a20;
    font-weight:600;
    font-size:1.05rem;
    padding:14px 18px;
    border-radius:12px;
    transition:all .2s ease;
}

.school-plans-section .school-plan-btn-secondary:hover{
    border-color:#00AE57;
    color:#00AE57;
}

.school-seal{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    font-size:.95rem;
    color:#5f6b66;
}

.school-seal span{
    display:flex;
    align-items:center;
    gap:6px;
}

.school-seal i{
    color:#00AE57;
}

@keyframes schoolPulseBtn {
    0% {
        transform: scale(1);
        box-shadow: 0 6px 18px rgba(0,174,87,0.25);
    }
    50% {
        transform: scale(1.025);
        box-shadow: 0 10px 26px rgba(0,174,87,0.35);
    }
    100% {
        transform: scale(1);
        box-shadow: 0 6px 18px rgba(0,174,87,0.25);
    }
}


/* =========================================================
   OFFER COMBO
========================================================= */
.offer-combo-section .section-sub{
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
    text-align: left;
}

.combo-offer-wrap{
    display: grid;
    gap: 14px;
    margin-top: 18px;
}

.combo-card{
    background: #fff;
    border: 1px solid rgba(22,48,37,.10);
    border-radius: 18px;
    padding: 18px 18px 16px;
    box-shadow: 0 10px 30px rgba(0,0,0,.04);
}

.combo-card-bonus{
    background: linear-gradient(180deg, #ffffff 0%, #fcfdfb 100%);
}

.combo-card-head{
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(22,48,37,.08);
}

.combo-card-title{
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.combo-icon{
    width: 42px;
    height: 42px;
    min-width: 42px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(95,120,82,.10);
    color: #5F7852;
    font-size: 18px;
}

.combo-eyebrow{
    font-size: .78rem;
    line-height: 1.1;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: rgba(22,48,37,.62);
    margin-bottom: 4px;
}

.combo-card-title h3{
    margin: 0;
    font-size: 1.08rem;
    line-height: 1.25;
    font-weight: 800;
    color: #163025;
}

.combo-card-price{
    flex-shrink: 0;
    white-space: nowrap;
    font-size: 1.08rem;
    font-weight: 800;
    color: #5F7852;
    background: rgba(95,120,82,.08);
    border: 1px solid rgba(95,120,82,.14);
    border-radius: 999px;
    padding: 8px 12px;
}

.combo-list{
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 10px;
}

.combo-list li{
    position: relative;
    padding-left: 28px;
    color: rgba(22,48,37,.82);
    line-height: 1.5;
    font-size: .98rem;
}

.combo-list li::before{
    content: "\F633";
    font-family: "bootstrap-icons";
    position: absolute;
    left: 0;
    top: 0;
    color: #5F7852;
    font-size: 16px;
    line-height: 1.4;
}

.combo-total-box{
    margin-top: 18px;
    border-top: 1px dashed rgba(22,48,37,.12);
    padding-top: 16px;
}

.combo-total-box .tlabel{
    color: rgba(22,48,37,.68);
    font-weight: 700;
}

.combo-total-box .tvalue{
    font-weight: 800;
    color: #b94b4b;
    font-size: 1.15rem;
}

.combo-price-box{
    border: 1px solid rgba(22,48,37,.08);
    border-radius: 20px;
    background: linear-gradient(180deg, #ffffff 0%, #fbfcfb 100%);
    box-shadow: 0 12px 40px rgba(0,0,0,.05);
}

.combo-highlight{
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(95,120,82,.10);
    color: #163025;
    border: 1px solid rgba(95,120,82,.14);
    border-radius: 999px;
    padding: 8px 12px;
    font-weight: 700;
    font-size: .93rem;
    margin-bottom: 12px;
}

.combo-price-box .de{
    color: rgba(22,48,37,.80);
    font-size: 1rem;
    line-height: 1.5;
    margin-bottom: 12px;
}

.combo-price-box .de s{
    color: #E07A3F;
    font-weight: 700;
}

.combo-mini-note{
    text-align: center;
    font-size: .92rem;
    color: rgba(22,48,37,.74);
    margin-top: 10px;
    font-weight: 600;
}

.offer-combo-section .final-grid{
    align-items: stretch;
    gap: 18px;
}

.offer-combo-section .final-left,
.offer-combo-section .final-right{
    display: flex;
}

.offer-combo-section .final-price-box{
    width: 100%;
}

.offer-combo-section .final-right{
    flex-direction: column;
    justify-content: center;
}

.offer-combo-section .btn-checkout-cta{
    min-height: 58px;
    font-weight: 800;
    font-size: 22px;
    border-radius: 22px;
}

.offer-combo-section .countdown-inline{
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px dashed rgba(22,48,37,.10);
}

.offer-combo-section .countdown-inline .label{
    color: rgba(22,48,37,.68);
    font-size: .92rem;
    margin-bottom: 4px;
}

.offer-combo-section .countdown-inline .time{
    font-weight: 800;
    font-size: 1.1rem;
    letter-spacing: .02em;
    color: #E07A3F;
}

.offer-combo-section .seals{
    margin-top: 14px;
}

.offer-combo-section .seal{
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 2px;
    text-align: center;
    font-weight: 600;
    color: rgba(22,48,37,.76);
    background: rgba(255,255,255,.6);
    border: 1px solid rgba(22,48,37,.08);
    border-radius: 14px;
    padding: 10px 12px;
}


/* =========================================================
   BOTÃO WHATSAPP FIXO
========================================================= */
.btnwh{
    position: fixed;
    bottom: 20px;
    right: 20px;
    max-width: 55px;
    cursor: pointer;
}


/* =========================================================
   RESPONSIVO
========================================================= */
@media (min-width: 576px){
    .es-modal-grid{
        grid-template-columns: repeat(2, minmax(0,1fr));
    }

    .eb-modal-grid{
        grid-template-columns: repeat(2, minmax(0,1fr));
    }
}

@media (min-width: 768px){
    .es-covers-grid{
        grid-template-columns: repeat(2, minmax(0,1fr));
        gap: 14px;
    }

    .es-featured-grid{
        grid-template-columns: repeat(3, minmax(0,1fr));
        gap: 14px;
    }

    .es-modal-top{
        padding: 20px 20px 10px;
    }

    .es-modal-meta{
        padding: 0 20px 16px;
    }

    .es-modal-grid{
        grid-template-columns: repeat(4, minmax(0,1fr));
        gap: 12px;
        padding: 0 20px;
    }

    .es-modal-bottom{
        padding: 14px 20px 20px;
    }

    .es-cover-title{
        font-size: 15px;
    }

    .eb-grid{
        grid-template-columns: repeat(3, minmax(0,1fr));
        gap: 14px;
    }

    .eb-modal-top{
        padding: 20px 20px 10px;
    }

    .eb-modal-meta{
        padding: 0 20px 16px;
    }

    .eb-modal-grid{
        grid-template-columns: repeat(4, minmax(0,1fr));
        gap: 12px;
        padding: 0 20px;
    }

    .eb-modal-bottom{
        padding: 14px 20px 20px;
    }
}

@media (max-width: 991.98px){
    .band{
        padding: var(--band-pad-m) 0;
    }

    .logo img{
        max-height: 42px;
    }

    .hero{
        padding-top: 18px !important;
        padding-bottom: 10px !important;
    }

    .logo{
        display: block !important;
        width: 100%;
        text-align: center;
        margin-top: 0;
        margin-bottom: 25px;
    }

    .logo img{
        margin-left: auto;
        margin-right: auto;
    }

    .h1{
        margin-top: 6px !important;
        margin-bottom: 10px !important;
        line-height: 1.10;
        letter-spacing: -0.25px;
        font-size: clamp(20px, 5.6vw, 34px) !important;
        text-wrap: pretty;
    }

    .h1 > span{
        display: inline;
        white-space: normal;
    }

    .final-grid{
        grid-template-columns: 1fr;
        gap: 14px;
    }

    .combo-card-head{
        flex-direction: column;
        align-items: flex-start;
    }

    .combo-card-price{
        align-self: flex-start;
    }
}

@media (max-width: 767.98px){
    .hero-badge{
        top: 10px;
        left: 10px;
        padding: 6px 10px;
        font-size: .78rem;
        border-radius: 8px;
    }

    .school-plans-section .school-plan-installments{
        font-size:1.75rem;
    }

    .school-plans-section .school-plan-title{
        font-size:1.4rem;
    }

    .combo-card{
        padding: 16px 14px 14px;
        border-radius: 16px;
    }

    .combo-card-title h3{
        font-size: 1rem;
    }

    .combo-card-price{
        font-size: 1rem;
        padding: 7px 11px;
    }

    .combo-list li{
        font-size: .95rem;
        padding-left: 24px;
    }

    .combo-highlight{
        font-size: .88rem;
        line-height: 1.35;
        padding: 7px 10px;
    }

    .combo-price-box .de{
        font-size: .95rem;
    }

    .combo-mini-note{
        font-size: .88rem;
    }

    .offer-combo-section .seal{
        font-size: .9rem;
        line-height: 1.45;
    }
}

@media (max-width: 575.98px){
    :root{
        --list-gap: 7px;
        --list-item-gap: 9px;
        --ic: 26px;
    }

    .band .container{
        padding-left: var(--container-pad-m) !important;
        padding-right: var(--container-pad-m) !important;
    }

    .band{
        padding-top: 46px;
        padding-bottom: 46px;
    }

    .band::before{
        height: 10px;
        opacity: .55;
    }

    .band::after{
        content:"";
        position:absolute;
        left:0;
        right:0;
        top:0;
        height: 1px;
        background: rgba(22,48,37,.06);
        pointer-events:none;
        z-index:0;
    }

    .band-a,
    .band-b,
    .band-c{
        background-blend-mode: normal;
    }

    .list-clean li{
        font-size: 15px;
    }

    .offer-inner{
        padding: 16px;
    }

    .countdown-inline{
        flex-direction: column;
        align-items:flex-start;
        text-align:center;
        align-items:center;
        justify-content:center;
    }

    .countdown-inline .label{
        text-align:center;
        width:100%;
        margin-bottom: 6px;
    }

    .countdown-inline .time{
        border: none;
        margin-top: -10px;
        justify-content:center;
        text-align:center;
        width:100%;
    }

    .final-price-line{
        display:flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 6px;
    }

    .final-price-line .value,
    .final-price-line .value-2{
        display:flex;
        justify-content:center;
        align-items: baseline;
        gap: 4px;
    }

    .final-price-line .rs{
        font-size: 14px;
        opacity: .85;
    }

    .final-price-line .num{
        font-size: 44px;
        font-weight: 900;
        line-height: 1;
    }

    .final-price-line .num b{
        font-size: 22px;
        font-weight: 800;
    }

    .final-price-line .value-2{
        font-size: 16px;
        font-weight: 700;
        margin-top: 2px;
    }

    .band .full-bleed .gallery-img{
        border-radius: var(--radius) !important;
        border-left: 1px solid rgba(22,48,37,.12) !important;
        border-right: 1px solid rgba(22,48,37,.12) !important;
    }

    .ebook-frame .gallery-img,
    .ebook-frame .ebook-img{
        border-left: 0 !important;
        border-right: 0 !important;
    }

    .es-projects-head{
        margin-top: 34px;
    }

    .es-covers-grid,
    .es-featured-grid{
        gap: 10px;
    }

    .es-cover-body{
        padding: 9px 9px 11px;
    }

    .es-cover-title{
        font-size: 13px;
    }

    .es-cover-mini{
        font-size: 11px;
    }

    .es-modal-dialog{
        width: calc(100vw - 10px);
        max-height: calc(100vh - 10px);
        border-radius: 18px;
    }

    .es-modal-top{
        padding: 14px 14px 8px;
    }

    .es-modal-meta{
        padding: 0 14px 12px;
    }

    .es-modal-grid{
        padding: 0 14px;
        gap: 10px;
    }

    .es-modal-bottom{
        padding: 10px 14px 14px;
    }

    .eb-grid{
        gap: 10px;
    }

    .eb-modal-dialog{
        width: calc(100vw - 10px);
        max-height: calc(100vh - 10px);
        border-radius: 18px;
    }

    .eb-modal-top{
        padding: 14px 14px 8px;
    }

    .eb-modal-meta{
        padding: 0 14px 12px;
    }

    .eb-modal-grid{
        padding: 0 14px;
        gap: 10px;
    }

    .eb-modal-bottom{
        padding: 10px 14px 14px;
    }

    .btn-checkout-cta{
        font-size: 20px;
        padding: 18px 18px;
        border-radius: 24
    }
}

.es-modal-dialog,
.eb-modal-dialog{
    position: absolute;
    left: 50%;
    top: 8px;
    bottom: 8px;
    transform: translateX(-50%);
    width: min(1080px, calc(100vw - 12px));
    max-height: calc(100vh - 16px);
    overflow-y: auto;
    overflow-x: hidden;
    padding: 0;
    -webkit-overflow-scrolling: touch;                
    overscroll-behavior: contain;
}


.eb-modal-close,
.es-modal-close{
    position: sticky;
    top: 10px;
    float: right;
    z-index: 10;

    width: 44px;
    height: 44px;

    border-radius: 999px;

    background: #163025;
    color: #fff;

    display: flex;
    align-items: center;
    justify-content: center;

    box-shadow: 0 8px 20px rgba(0,0,0,.18);
}

.eb-modal-close i,
.es-modal-close{
    font-size: 22px;
}

/*@media (max-width: 768px){
    .topbar{
        display: none;
    }

    .logo, 
    .hero-media{
        margin-top: -25px;
    }
    .hero-benefits{margin-top: -5px;}
}*/

.courses-band-intro {
    display: inline-flex;
    align-items: center;
    gap: 6px;

    padding: 6px 12px;

    border-radius: 999px;

    background: rgba(191, 230, 214, 0.35);
    border: 1px solid rgba(22, 48, 37, 0.12);

    font-size: 12px;
    font-weight: 800;
    letter-spacing: .3px;

    color: #163025;

    margin-bottom: 12px;
}
.courses-band-intro {
    background: #fff;
    border: 1px solid rgba(22, 48, 37, 0.18);

    box-shadow: 0 6px 18px rgba(0,0,0,0.06);
}
.offer-combo-section .section-sub{
    text-align: left;
    margin-left: 0;
    margin-right: 0;     
}

@media (max-width: 991.98px){
    .combo-card-head{
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }

    .combo-card-title{
        flex: 1;
        min-width: 0;
    }

    .combo-card-price{
        flex-shrink: 0;
        margin-left: 10px;
    }

    .combo-card-title h3{
        font-size: 0.95rem;
    }
    .combo-mini-note{display: none;}
}

@keyframes pulseCTA {
    0% {
        transform: scale(1);
        box-shadow: 0 14px 30px rgba(0,174,87,.35),
                    0 6px 0 rgba(0,140,70,1);
    }
    50% {
        transform: scale(1.04);
        box-shadow: 0 20px 40px rgba(0,174,87,.45),
                    0 8px 0 rgba(0,120,60,1);
    }
    100% {
        transform: scale(1);
        box-shadow: 0 14px 30px rgba(0,174,87,.35),
                    0 6px 0 rgba(0,140,70,1);
    }
}

.btn-checkout-cta{
    animation: pulseCTA 1.8s ease-in-out infinite;
}

.btn-checkout-cta:hover,
.btn-checkout-cta:active{
    animation: none;
}
.btn-checkout-cta{
    position: relative;
    overflow: hidden;
}

.btn-checkout-cta::after{
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(120deg, transparent, rgba(255,255,255,.25), transparent);
    transition: all .6s ease;
}

.btn-checkout-cta:hover::after{
    left: 100%;
}
.mini-list{
    list-style: none;
    padding: 0;
    margin: 12px 0 0 0;
    display: grid;
    gap: 8px;
}

.mini-list li{
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.95rem;
    color: #2b2b2b;
    font-weight: 500;
}

.mini-list li::before{
    content: "✔";
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    font-size: 12px;
    color: #fff;
    background: #00AE57;
    border-radius: 50%;
    flex-shrink: 0;
}