/* scroll gerenciado via JS customizado (easing + offset) — NÃO usar scroll-behavior CSS */

/* ── Barra de progresso de rolagem ────────────────────────────────── */
.scroll-progress-bar {
    position: fixed;
    top: 0;
    left: 0;
    width: 0%;
    height: 3px;
    background: linear-gradient(90deg, var(--cbic-red, #ee404a) 0%, var(--cbic-blue, #0c4da2) 100%);
    z-index: 99999;
    border-radius: 0 2px 2px 0;
    pointer-events: none;
    will-change: width;
    transition: opacity .3s ease;
}
.scroll-progress-bar.is-hidden { opacity: 0; }

/* â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• 
       CBIC DESIGN SYSTEM — identidade visual cbic.org.br
    â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â• â•  */
    :root {
        /* Cores CBIC */
        --cbic-red:      #ee404a;
        --cbic-blue:     #0c4da2;
        --cbic-blue-dk:  #083782;
        --cbic-yellow:   #fac900;
        --cbic-navy:     #27323f;
        --cbic-navy-lt:  #344150;

        /* Superfícies */
        --white:   #ffffff;
        --gray-50: #f8f8f8;
        --gray-100:#f1f4f8;
        --gray-200:#e4eaf3;
        --gray-400:#9ba8b9;
        --gray-600:#595f6e;
        --gray-800:#374151;
        --ink:     #27323f;

        /* Tokens */
        --border:     rgba(12,77,162,.14);
        --radius-lg:  1.25rem;
        --radius-md:  .75rem;
        --radius-sm:  .45rem;
        --shadow-sm:  0 2px 12px rgba(39,50,63,.07);
        --shadow-md:  0 8px 32px rgba(39,50,63,.10);
        --shadow-lg:  0 20px 56px rgba(39,50,63,.14);
        --tr:         .22s cubic-bezier(.4,0,.2,1);
    }

    *, *::before, *::after { box-sizing: border-box; }
    html {
        /* scroll-behavior gerenciado via JS para offset correto do topbar */
        scroll-padding-top: 80px;
    }
    body {
        font-family: 'Montserrat', system-ui, sans-serif;
        background: var(--gray-50);
        color: var(--ink);
        margin: 0;
        overflow-x: hidden;
    }
    img { max-width: 100%; display: block; }

    /*  TOPBAR  */
    .topbar {
        position: sticky;
        top: 0;
        z-index: 200;
        background: rgba(255,255,255,.97);
        backdrop-filter: blur(16px);
        -webkit-backdrop-filter: blur(16px);
        border-bottom: 2px solid var(--cbic-red);
        padding: 0;
    }
    .topbar-inner {
        max-width: 1200px;
        margin: 0 auto;
        padding: 0 2rem;
        height: 68px;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1.5rem;
    }
    .topbar-logo { height: 48px; }
    .topbar-nav  { display: flex; align-items: center; gap: .25rem; }
    .mobile-menu-toggle {
        display: none;
        border: 1px solid var(--gray-200);
        background: var(--white);
        color: var(--cbic-blue);
        width: 42px;
        height: 42px;
        border-radius: .75rem;
        align-items: center;
        justify-content: center;
        font-size: 1.35rem;
        line-height: 1;
        box-shadow: 0 4px 14px rgba(39,50,63,.07);
    }
    .mobile-menu-toggle:focus-visible {
        outline: 3px solid rgba(12,77,162,.2);
        outline-offset: 2px;
    }
    .nav-link {
        font-size: .8rem;
        font-weight: 600;
        letter-spacing: .04em;
        text-transform: uppercase;
        color: var(--gray-600);
        text-decoration: none;
        padding: .5rem .85rem;
        border-radius: var(--radius-sm);
        transition: color var(--tr), background var(--tr);
    }
    .nav-link:hover { color: var(--cbic-blue); background: var(--gray-100); }
    .btn-nav-cta {
        background: var(--cbic-red);
        color: #fff;
        font-weight: 700;
        font-size: .8rem;
        letter-spacing: .04em;
        text-transform: uppercase;
        padding: .6rem 1.4rem;
        border-radius: var(--radius-sm);
        text-decoration: none;
        display: inline-flex;
        align-items: center;
        gap: .4rem;
        transition: all var(--tr);
        border: 0;
        margin-left: .5rem;
    }
    .btn-nav-cta:hover {
        background: #d12d37;
        color: #fff;
        transform: translateY(-1px);
        box-shadow: 0 6px 18px rgba(238,64,74,.35);
    }
    .nav-user-menu {
        position: relative;
        margin-left: .5rem;
        flex-shrink: 0;
    }
    .nav-user-trigger {
        display: inline-flex;
        align-items: center;
        gap: .55rem;
        min-height: 42px;
        max-width: 220px;
        background: var(--cbic-navy);
        border: 2px solid rgba(255,255,255,.12);
        border-radius: 999px;
        padding: .35rem .85rem .35rem .35rem;
        cursor: pointer;
        color: #fff;
        transition: background var(--tr), border-color var(--tr), box-shadow var(--tr);
        outline: none;
    }
    .nav-user-trigger:hover,
    .nav-user-trigger[aria-expanded="true"] {
        background: var(--cbic-navy-lt);
        border-color: rgba(255,255,255,.28);
        box-shadow: 0 4px 18px rgba(39,50,63,.22);
    }
    .nav-user-avatar,
    .nav-user-panel-avatar {
        border-radius: 50%;
        background: var(--cbic-red);
        color: #fff;
        font-weight: 800;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        letter-spacing: 0;
    }
    .nav-user-avatar {
        width: 32px;
        height: 32px;
        font-size: .75rem;
    }
    .nav-user-label {
        min-width: 0;
        max-width: 120px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        font-size: .8rem;
        font-weight: 800;
        letter-spacing: .04em;
        text-transform: uppercase;
        color: #fff;
    }
    .nav-user-chevron {
        font-size: .75rem;
        color: rgba(255,255,255,.68);
        transition: transform var(--tr);
        flex-shrink: 0;
    }
    .nav-user-trigger[aria-expanded="true"] .nav-user-chevron {
        transform: rotate(180deg);
    }
    .nav-user-panel {
        display: none;
        position: absolute;
        top: calc(100% + .6rem);
        right: 0;
        min-width: 280px;
        max-width: min(340px, calc(100vw - 2rem));
        background: #fff;
        border: 1px solid var(--gray-200);
        border-radius: var(--radius-md);
        box-shadow: 0 16px 48px rgba(39,50,63,.16), 0 2px 8px rgba(39,50,63,.08);
        overflow: hidden;
        z-index: 500;
    }
    .nav-user-panel.is-open {
        display: block;
    }
    .nav-user-panel-header {
        display: grid;
        grid-template-columns: 40px minmax(0, 1fr);
        align-items: center;
        gap: .75rem;
        padding: .9rem 1rem;
        background: var(--gray-50);
    }
    .nav-user-panel-avatar {
        width: 40px;
        height: 40px;
        font-size: .85rem;
    }
    .nav-user-panel-name,
    .nav-user-panel-email {
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    .nav-user-panel-name {
        font-size: .86rem;
        font-weight: 800;
        color: var(--ink);
    }
    .nav-user-panel-email {
        margin-top: .15rem;
        font-size: .74rem;
        font-weight: 600;
        color: var(--gray-600);
        text-transform: none;
        letter-spacing: 0;
    }
    .nav-user-panel-divider {
        height: 1px;
        background: var(--gray-200);
    }
    .nav-user-panel-item {
        display: flex;
        align-items: center;
        gap: .55rem;
        padding: .78rem 1rem;
        color: var(--ink);
        text-decoration: none;
        font-size: .82rem;
        font-weight: 700;
        transition: background var(--tr), color var(--tr);
    }
    .nav-user-panel-item:hover {
        background: var(--gray-100);
        color: var(--cbic-blue);
    }
    .nav-user-panel-item-primary {
        color: var(--cbic-blue);
    }
    .nav-user-panel-item-danger {
        color: var(--cbic-red);
    }

    /*  HERO  */
    .hero {
        background: var(--cbic-navy);
        position: relative;
        overflow: hidden;
        padding: 5.5rem 2rem 4rem;
    }
    /* Padrão de pontos decorativos */
    .hero::before {
        content: '';
        position: absolute;
        inset: 0;
        background-image:
            radial-gradient(circle 1px at 1px 1px, rgba(255,255,255,.09) 1px, transparent 0);
        background-size: 32px 32px;
        pointer-events: none;
    }
    /* Gradiente lateral esquerdo com azul */
    .hero::after {
        content: '';
        position: absolute;
        left: -200px;
        top: -100px;
        width: 600px;
        height: 600px;
        background: radial-gradient(circle, rgba(12,77,162,.55) 0%, transparent 70%);
        pointer-events: none;
    }
    /* Acento vermelho direito */
    .hero-accent-red {
        position: absolute;
        right: -100px;
        bottom: -80px;
        width: 400px;
        height: 400px;
        background: radial-gradient(circle, rgba(238,64,74,.35) 0%, transparent 70%);
        pointer-events: none;
    }
    .hero-stripe {
        position: absolute;
        left: 0;
        bottom: 0;
        width: 100%;
        height: 4px;
        background: var(--cbic-red);
    }
    .hero-inner {
        max-width: 1200px;
        margin: 0 auto;
        position: relative;
        z-index: 2;
        display: grid;
        grid-template-columns: 1fr auto;
        gap: 3rem;
        align-items: center;
    }
    .hero-eyebrow {
        display: inline-flex;
        align-items: center;
        gap: .5rem;
        border: 1px solid rgba(238,64,74,.4);
        color: rgba(255,255,255,.85);
        font-size: .72rem;
        font-weight: 700;
        letter-spacing: .12em;
        text-transform: uppercase;
        padding: .4rem 1rem;
        border-radius: 999px;
        margin-bottom: 1.25rem;
        background: rgba(238,64,74,.12);
    }
    .hero-title {
        font-size: clamp(2.2rem, 4.5vw, 3.6rem);
        font-weight: 900;
        line-height: 1.05;
        letter-spacing: -.03em;
        color: #fff;
        margin: 0 0 1.1rem;
    }
    .hero-title em {
        font-style: italic;
        color: #fff;
    }
    .hero-subtitle {
        font-size: 1.05rem;
        color: rgba(255,255,255,.72);
        max-width: 560px;
        line-height: 1.7;
        font-weight: 400;
        margin: 0 0 2.25rem;
    }
    .hero-ctas {
        display: flex;
        flex-wrap: wrap;
        gap: .85rem;
    }
    .btn-hero-primary {
        background: var(--cbic-red);
        color: #fff;
        font-weight: 800;
        font-size: .9rem;
        letter-spacing: .04em;
        text-transform: uppercase;
        padding: .95rem 2rem;
        border-radius: var(--radius-sm);
        text-decoration: none;
        display: inline-flex;
        align-items: center;
        gap: .5rem;
        transition: all var(--tr);
        border: 0;
    }
    .btn-hero-primary:hover {
        background: #c8282f;
        color: #fff;
        transform: translateY(-2px);
        box-shadow: 0 10px 28px rgba(238,64,74,.4);
    }
    .btn-hero-secondary {
        background: transparent;
        color: #fff;
        font-weight: 700;
        font-size: .9rem;
        letter-spacing: .04em;
        text-transform: uppercase;
        padding: .93rem 2rem;
        border-radius: var(--radius-sm);
        text-decoration: none;
        display: inline-flex;
        align-items: center;
        gap: .5rem;
        border: 2px solid rgba(255,255,255,.35);
        transition: all var(--tr);
    }
    .btn-hero-secondary:hover {
        border-color: rgba(255,255,255,.8);
        background: rgba(255,255,255,.08);
        color: #fff;
    }
    /* Stats no hero */
    .hero-stats {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 1rem;
        flex-shrink: 0;
    }
    .hero-stat {
        background: rgba(255,255,255,.06);
        border: 1px solid rgba(255,255,255,.1);
        border-radius: var(--radius-md);
        padding: 1.25rem 1rem;
        text-align: center;
    }
    .hero-stat-num {
        font-size: 1.9rem;
        font-weight: 900;
        color: var(--cbic-yellow);
        line-height: 1;
        letter-spacing: -.04em;
    }
    .hero-stat-lbl {
        font-size: .72rem;
        color: rgba(255,255,255,.6);
        font-weight: 600;
        letter-spacing: .04em;
        text-transform: uppercase;
        margin-top: .35rem;
    }

    /*  SECTION WRAPPER  */
    .section {
        padding: 5rem 2rem;
    }
    .section-alt { background: var(--white); }
    #planos.section-alt {
        position: relative;
        overflow: hidden;
        background:
            linear-gradient(115deg, rgba(12,77,162,.07) 0 1px, transparent 1px 120px),
            linear-gradient(180deg, #fff 0%, #f6f9fe 100%);
        background-size: 180px 180px, 100% 100%;
        animation: plansBackgroundDrift 18s linear infinite;
    }
    #planos .section-inner {
        position: relative;
        z-index: 1;
    }
    .section-dark {
        background: var(--cbic-navy);
        color: #fff;
    }
    .section-inner { max-width: 1200px; margin: 0 auto; }

    /* Section header */
    .section-label {
        display: inline-flex;
        align-items: center;
        gap: .45rem;
        font-size: .7rem;
        font-weight: 800;
        letter-spacing: .14em;
        text-transform: uppercase;
        color: var(--cbic-red);
        margin-bottom: .75rem;
    }
    .section-label::before {
        content: '';
        display: block;
        width: 18px;
        height: 2px;
        background: var(--cbic-red);
        border-radius: 1px;
    }
    .section-title {
        font-size: clamp(1.75rem, 3vw, 2.6rem);
        font-weight: 900;
        letter-spacing: -.03em;
        line-height: 1.1;
        margin: 0 0 .6rem;
        color: var(--ink);
    }
    .section-dark .section-title { color: #fff; }
    .section-dark .section-label { color: var(--cbic-yellow); }
    .section-dark .section-label::before { background: var(--cbic-yellow); }
    .section-sub {
        font-size: .97rem;
        color: var(--gray-600);
        line-height: 1.7;
        max-width: 1040px;
        font-weight: 400;
        margin: 0 0 3rem;
    }
    .section-dark .section-sub { color: rgba(255,255,255,.65); }

    /*  PLAN CARDS  */
    .cards-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
        gap: 1.5rem;
        align-items: stretch;
    }
    .mobile-carousel-controls {
        display: none;
    }
    .plan-card {
        background: var(--white);
        border: 1.5px solid var(--gray-200);
        border-radius: var(--radius-lg);
        overflow: hidden;
        display: flex;
        flex-direction: column;
        min-width: 0;
        box-shadow: var(--shadow-sm);
        transition: transform var(--tr), box-shadow var(--tr), border-color var(--tr);
        position: relative;
    }
    .plan-card:hover {
        transform: translateY(-6px);
        box-shadow: var(--shadow-lg);
        border-color: var(--cbic-red);
    }
    .plan-card.is-featured {
        border-color: var(--cbic-red);
        box-shadow: 0 0 0 3px rgba(238,64,74,.12), var(--shadow-md);
    }
    /* Linha superior colorida nos cards */
    .plan-card::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        height: 3px;
        background: var(--cbic-red);
        opacity: 0;
        transition: opacity var(--tr);
    }
    .plan-card:hover::before,
    .plan-card.is-featured::before { opacity: 1; }

    .plan-audience {
        display: grid;
        grid-template-columns: 38px minmax(0, 1fr) auto;
        align-items: center;
        gap: .7rem;
        min-height: 56px;
        margin-bottom: 1rem;
        padding: .55rem .65rem;
        border: 1px solid var(--gray-200);
        border-radius: .9rem;
        background: linear-gradient(135deg, rgba(255,255,255,.98), rgba(247,250,255,.92));
        box-shadow: inset 0 1px 0 rgba(255,255,255,.9), 0 10px 24px rgba(28,37,46,.05);
    }
    .plan-audience-icon {
        width: 38px;
        height: 38px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: .75rem;
        color: #fff;
        background: var(--cbic-blue);
        box-shadow: 0 8px 18px rgba(12,77,162,.18);
    }
    .plan-audience-copy {
        min-width: 0;
        display: flex;
        flex-direction: column;
        line-height: 1.15;
    }
    .plan-audience-kicker {
        font-size: .62rem;
        font-weight: 800;
        letter-spacing: .08em;
        text-transform: uppercase;
        color: var(--gray-500);
        margin-bottom: .2rem;
    }
    .plan-audience-copy strong {
        color: var(--ink);
        font-size: .84rem;
        font-weight: 900;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .plan-audience-chip {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 58px;
        height: 30px;
        padding: 0 .65rem;
        border-radius: 999px;
        color: #fff;
        font-size: .7rem;
        font-weight: 900;
        letter-spacing: .04em;
        text-transform: uppercase;
        box-shadow: 0 8px 18px rgba(28,37,46,.12);
    }
    .plan-audience-cpf .plan-audience-icon,
    .plan-audience-cpf .plan-audience-chip { background: var(--cbic-blue); }
    .plan-audience-cnpj .plan-audience-icon,
    .plan-audience-cnpj .plan-audience-chip { background: var(--cbic-red); }
    .plan-audience-both .plan-audience-icon,
    .plan-audience-both .plan-audience-chip { background: linear-gradient(135deg, var(--cbic-blue), var(--cbic-red)); }

    /* Ribbon "DESTAQUE" */
    .ribbon {
        position: absolute;
        top: 18px;
        right: -28px;
        background: var(--cbic-red);
        color: #fff;
        font-size: .65rem;
        font-weight: 800;
        letter-spacing: .1em;
        text-transform: uppercase;
        padding: .3rem 2.2rem;
        transform: rotate(45deg);
        box-shadow: 0 2px 8px rgba(238,64,74,.4);
    }

    .plan-head {
        padding: 1.75rem 1.75rem 1.25rem;
        border-bottom: 1px solid var(--gray-200);
        display: flex;
        flex-direction: column;
        flex-grow: 1;
    }
    .plan-code {
        font-size: .68rem;
        font-weight: 800;
        letter-spacing: .12em;
        text-transform: uppercase;
        color: var(--cbic-red);
        margin-bottom: .35rem;
    }
    .plan-name {
        font-size: 1.2rem;
        font-weight: 800;
        letter-spacing: -.02em;
        color: var(--ink);
        margin: 0 0 .5rem;
    }
    .plan-desc {
        font-size: .85rem;
        color: var(--gray-800);
        line-height: 1.6;
        font-weight: 500;
        margin: 0;
        flex-grow: 1;
    }
    .plan-price-row {
        display: flex;
        align-items: flex-end;
        gap: .5rem;
        margin-top: 1.1rem;
    }
    .plan-currency {
        font-size: .95rem;
        font-weight: 800;
        color: var(--cbic-red);
        line-height: 1;
        padding-bottom: .35rem;
    }
    .plan-price {
        font-size: 2.8rem;
        font-weight: 900;
        color: var(--cbic-red);
        line-height: 1;
        letter-spacing: -.06em;
    }
    .plan-period {
        font-size: .78rem;
        font-weight: 600;
        color: var(--gray-400);
        padding-bottom: .4rem;
    }

    /* cycle badge */
    .cycle-badge {
        display: inline-block;
        font-size: .65rem;
        font-weight: 800;
        letter-spacing: .08em;
        text-transform: uppercase;
        padding: .25rem .65rem;
        border-radius: 999px;
        margin-left: .35rem;
    }
    .cycle-monthly { background: #e8f0fb; color: var(--cbic-blue); }
    .cycle-annual  { background: rgba(250,201,0,.15); color: #b08a00; border: 1px solid rgba(250,201,0,.4); }
    .cycle-once    { background: #f0fdf4; color: #15803d; border: 1px solid #bbf7d0; }

    .plan-body { padding: 1.5rem 1.75rem; flex: 1; display: flex; flex-direction: column; gap: 1.1rem; }

    /* Sites chips */
    .chip-row { display: flex; flex-wrap: wrap; gap: .4rem; }
    .site-chip {
        background: var(--gray-100);
        border: 1px solid var(--gray-200);
        color: var(--gray-600);
        font-size: .68rem;
        font-weight: 700;
        letter-spacing: .04em;
        text-transform: uppercase;
        padding: .22rem .7rem;
        border-radius: 999px;
    }

    /* Benefits list */
    .benefit-list { list-style: none; margin: 0; padding: 0; display: grid; gap: .55rem; }
    .benefit-list li {
        display: flex;
        align-items: flex-start;
        gap: .55rem;
        font-size: .83rem;
        color: var(--gray-600);
        font-weight: 500;
        line-height: 1.45;
    }
    .benefit-list li .bi {
        color: var(--cbic-red);
        font-size: .95rem;
        flex-shrink: 0;
        margin-top: 1px;
    }

    /* CTA Button */
    .plan-cta { margin-top: auto; }
    .btn-plan {
        width: 100%;
        padding: .9rem;
        border-radius: var(--radius-sm);
        font-family: 'Montserrat', sans-serif;
        font-size: .82rem;
        font-weight: 800;
        letter-spacing: .05em;
        text-transform: uppercase;
        border: 0;
        cursor: pointer;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: .5rem;
        text-decoration: none;
        transition: all var(--tr);
    }
    .btn-plan-primary {
        background: var(--cbic-red);
        color: #fff;
    }
    .btn-plan-primary:hover {
        background: #c8282f;
        color: #fff;
        transform: translateY(-1px);
        box-shadow: 0 8px 22px rgba(238,64,74,.32);
    }
    .btn-plan-outline {
        background: linear-gradient(135deg, var(--cbic-blue), var(--cbic-blue-dk));
        color: #fff;
        border: 2px solid transparent;
        box-shadow: 0 10px 24px rgba(12,77,162,.22);
    }
    .btn-plan-outline:hover {
        background: linear-gradient(135deg, var(--cbic-red), #c8282f);
        color: #fff;
        transform: translateY(-1px);
        box-shadow: 0 12px 28px rgba(238,64,74,.28);
    }
    .btn-plan-ghost {
        background: transparent;
        color: var(--cbic-red);
        border: 2px solid var(--cbic-red);
    }
    .btn-plan-ghost:hover {
        background: var(--cbic-red);
        color: #fff;
    }

    /*  SUBSCRIPTION (PERFIL) CARDS — estilo escuro  */
    .profile-card {
        background: var(--cbic-navy-lt);
        border-radius: var(--radius-lg);
        overflow: hidden;
        display: flex;
        flex-direction: column;
        min-width: 0;
        transition: transform var(--tr), box-shadow var(--tr);
        position: relative;
    }
    .profile-card:hover {
        transform: translateY(-5px);
        box-shadow: 0 20px 48px rgba(0,0,0,.4);
    }
    .profile-card::before {
        content: '';
        position: absolute;
        top: 0; left: 0; right: 0;
        height: 3px;
        background: linear-gradient(90deg, var(--cbic-red), var(--cbic-yellow));
    }
    .profile-head { padding: 1.75rem; border-bottom: 1px solid rgba(255,255,255,.08); }
    .profile-code {
        font-size: .68rem;
        font-weight: 800;
        letter-spacing: .12em;
        text-transform: uppercase;
        color: var(--cbic-yellow);
        margin-bottom: .35rem;
    }
    .profile-name {
        font-size: 1.2rem;
        font-weight: 800;
        letter-spacing: -.02em;
        color: #fff;
        margin: 0 0 .5rem;
    }
    .profile-desc {
        font-size: .82rem;
        color: rgba(255,255,255,.6);
        line-height: 1.6;
        font-weight: 400;
        margin: 0;
    }
    .profile-price {
        font-size: 1.1rem;
        font-weight: 800;
        color: var(--cbic-yellow);
        margin-top: .85rem;
    }
    .profile-saving {
        font-size: .78rem;
        font-weight: 700;
        color: rgba(255,255,255,.78);
        margin-top: .35rem;
    }
    .profile-body { padding: 1.5rem 1.75rem; flex: 1; display: flex; flex-direction: column; gap: 1rem; }
    .profile-benefit-list { list-style: none; margin: 0; padding: 0; display: grid; gap: .55rem; }
    .profile-benefit-list li {
        display: flex;
        align-items: flex-start;
        gap: .55rem;
        font-size: .83rem;
        color: rgba(255,255,255,.72);
        font-weight: 500;
        line-height: 1.45;
    }
    .profile-benefit-list li .bi { color: var(--cbic-yellow); flex-shrink: 0; margin-top: 1px; }
    .btn-plan-yellow {
        background: var(--cbic-yellow);
        color: var(--cbic-navy);
        font-weight: 800;
    }
    .btn-plan-yellow:hover {
        background: #e8b800;
        color: var(--cbic-navy);
        transform: translateY(-1px);
        box-shadow: 0 8px 22px rgba(250,201,0,.35);
    }
    .btn-plan-ghost-light {
        background: transparent;
        color: rgba(255,255,255,.8);
        border: 2px solid rgba(255,255,255,.25);
    }
    .btn-plan-ghost-light:hover {
        border-color: rgba(255,255,255,.7);
        color: #fff;
        background: rgba(255,255,255,.06);
    }

    /*  ABOUT — seção institucional  */
    .about-grid {
        display: grid;
        grid-template-columns: 5fr 4fr;
        gap: 4rem;
        align-items: start;
    }
    .about-text { font-size: .95rem; color: var(--gray-600); line-height: 1.8; font-weight: 400; margin: 0 0 1.25rem; }
    .about-item {
        display: flex;
        align-items: flex-start;
        gap: 1rem;
        margin-bottom: 1.1rem;
    }
    .about-icon {
        width: 44px; height: 44px;
        border: 2px solid var(--cbic-blue);
        border-radius: var(--radius-sm);
        display: flex; align-items: center; justify-content: center;
        color: var(--cbic-blue);
        font-size: 1.1rem;
        flex-shrink: 0;
    }
    .about-item-ttl { font-size: .9rem; font-weight: 700; color: var(--ink); margin: 0 0 .15rem; }
    .about-item-txt { font-size: .82rem; color: var(--gray-600); line-height: 1.55; font-weight: 400; margin: 0; }

    /* Numbers box */
    .numbers-box {
        background: var(--cbic-navy);
        border-radius: var(--radius-lg);
        padding: 2rem;
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 1.25rem;
    }
    .num-item { text-align: center; }
    .num-val {
        font-size: 2.2rem;
        font-weight: 900;
        color: var(--cbic-red);
        letter-spacing: -.05em;
        line-height: 1;
    }
    .num-lbl {
        font-size: .72rem;
        font-weight: 700;
        letter-spacing: .06em;
        text-transform: uppercase;
        color: rgba(255,255,255,.55);
        margin-top: .35rem;
    }

    /* Include box */
    .include-box {
        background: var(--gray-100);
        border-left: 3px solid var(--cbic-blue);
        border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
        padding: 1.25rem 1.5rem;
        margin-top: 1.5rem;
    }
    .include-box-title {
        font-size: .78rem;
        font-weight: 800;
        letter-spacing: .08em;
        text-transform: uppercase;
        color: var(--cbic-blue);
        margin: 0 0 .75rem;
    }
    .include-box ul {
        margin: 0; padding: 0 0 0 .5rem; list-style: none;
        display: grid; gap: .45rem;
    }
    .include-box li {
        font-size: .83rem; color: var(--gray-600); font-weight: 500;
        display: flex; align-items: center; gap: .5rem;
    }
    .include-box li::before {
        content: '';
        display: block;
        width: 5px; height: 5px;
        border-radius: 50%;
        background: var(--cbic-blue);
        flex-shrink: 0;
    }

    /*  VALUE PROPS  */
    .value-grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 1.25rem;
    }
    .value-card {
        background: rgba(255,255,255,.05);
        border: 1px solid rgba(255,255,255,.1);
        border-radius: var(--radius-md);
        padding: 1.75rem 1.5rem;
        min-width: 0;
        transition: all var(--tr);
    }
    .value-card:hover {
        background: rgba(255,255,255,.08);
        border-color: rgba(250,201,0,.3);
        transform: translateY(-3px);
    }
    .value-num {
        font-size: 2rem;
        font-weight: 900;
        color: var(--cbic-red);
        line-height: 1;
        letter-spacing: -.04em;
        margin-bottom: 1rem;
    }
    .value-title { font-size: .95rem; font-weight: 800; color: #fff; margin: 0 0 .5rem; }
    .value-desc  { font-size: .82rem; color: rgba(255,255,255,.6); line-height: 1.65; font-weight: 400; margin: 0; }

    /*  SHOWCASE  */
    .showcase-card {
        background: var(--white);
        border: 1.5px solid var(--gray-200);
        border-radius: var(--radius-md);
        padding: 1.5rem;
        height: 100%;
        min-width: 0;
        transition: all var(--tr);
    }
    .showcase-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--cbic-blue); }
    .showcase-badge {
        display: inline-block;
        background: var(--cbic-yellow);
        color: var(--cbic-navy);
        font-size: .65rem;
        font-weight: 800;
        padding: .2rem .6rem;
        border-radius: 4px;
        letter-spacing: .05em;
        text-transform: uppercase;
        margin-bottom: .75rem;
    }
    .showcase-title { font-size: .95rem; font-weight: 800; color: var(--ink); margin: 0 0 .45rem; letter-spacing: -.01em; }
    .showcase-sub   { font-size: .8rem; color: var(--gray-400); margin: 0 0 .75rem; }
    .showcase-desc  { font-size: .83rem; color: var(--gray-600); line-height: 1.6; margin: 0 0 1.25rem; font-weight: 400; }
    .btn-showcase {
        font-size: .78rem;
        font-weight: 800;
        letter-spacing: .05em;
        text-transform: uppercase;
        color: var(--cbic-blue);
        text-decoration: none;
        display: inline-flex;
        align-items: center;
        gap: .4rem;
        transition: gap var(--tr);
    }
    .btn-showcase:hover { gap: .7rem; color: var(--cbic-blue); }

    /*  FAQ  */
    .faq-wrap { max-width: 820px; margin: 0 auto; }
    .faq-item {
        border-bottom: 1px solid var(--gray-200);
    }
    .faq-btn {
        width: 100%;
        background: none;
        border: 0;
        text-align: left;
        padding: 1.25rem 0;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        font-family: 'Montserrat', sans-serif;
        font-weight: 700;
        font-size: .92rem;
        color: var(--ink);
        cursor: pointer;
        transition: color var(--tr);
    }
    .faq-btn:hover { color: var(--cbic-red); }
    .faq-btn:hover .faq-icon { border-color: var(--cbic-red); color: var(--cbic-red); }
    .faq-icon {
        width: 36px; height: 36px;
        border: 2px solid var(--gray-300);
        border-radius: 50%;
        display: flex; align-items: center; justify-content: center;
        color: var(--gray-400);
        font-size: 1rem;
        flex-shrink: 0;
        transition: all .32s cubic-bezier(.4,0,.2,1);
    }
    /* chevron aponta BAIXO quando fechado — indica que tem conteúdo abaixo */
    .faq-icon i {
        display: block;
        transition: transform .35s cubic-bezier(.4,0,.2,1);
        transform: rotate(0deg);
    }
    .faq-item.open .faq-icon {
        background: var(--cbic-red);
        border-color: var(--cbic-red);
        color: #fff;
    }
    /* quando aberto, chevron aponta para CIMA (180°) */
    .faq-item.open .faq-icon i {
        transform: rotate(180deg);
    }
    .faq-body {
        display: none;
        padding: 0 0 1.25rem 0;
        font-size: .88rem;
        color: var(--gray-600);
        line-height: 1.75;
        font-weight: 400;
        max-width: 680px;
    }
    .faq-item.open .faq-body { display: block; }

    /*  CTA FINAL  */
    .cta-final-section {
        background: linear-gradient(135deg, var(--cbic-navy) 0%, var(--cbic-blue-dk) 52%, var(--cbic-navy-lt) 100%);
        padding: 5rem 2rem;
        text-align: center;
        position: relative;
        overflow: hidden;
    }
    .cta-final-section::before {
        content: '';
        position: absolute;
        inset: 0;
        background-image: radial-gradient(circle 1px at 1px 1px, rgba(255,255,255,.07) 1px, transparent 0);
        background-size: 28px 28px;
        pointer-events: none;
    }
    .cta-stripe-bottom {
        position: absolute;
        bottom: 0; left: 0; right: 0;
        height: 4px;
        background: linear-gradient(90deg, var(--cbic-red), var(--cbic-yellow), var(--cbic-blue));
    }
    .cta-final-inner { position: relative; z-index: 1; max-width: 700px; margin: 0 auto; }
    .cta-final-title {
        font-size: clamp(1.8rem, 3.5vw, 2.6rem);
        font-weight: 900;
        color: #fff;
        letter-spacing: -.03em;
        line-height: 1.1;
        margin: 0 0 .85rem;
    }
    .cta-final-sub { font-size: 1rem; color: rgba(255,255,255,.68); margin: 0 0 2.25rem; font-weight: 400; }
    .cta-btns { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; }

    /*  FOOTER  */
    .footer {
        background: var(--cbic-navy);
        padding: 2.5rem 2rem;
    }
    .footer-inner {
        max-width: 1200px;
        margin: 0 auto;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1.5rem;
        flex-wrap: wrap;
    }
    .footer-logo  { height: 28px; filter: brightness(0) invert(1); opacity: .65; }
    .footer-copy  { font-size: .78rem; color: rgba(255,255,255,.4); font-weight: 500; }
    .footer-links { display: flex; gap: 1.25rem; }
    .footer-link  { font-size: .78rem; color: rgba(255,255,255,.35); text-decoration: none; font-weight: 600; transition: color var(--tr); }
    .footer-link:hover { color: rgba(255,255,255,.8); }

    /*  FLASH  */
    .flash-wrap { max-width: 1200px; margin: 1rem auto 0; padding: 0 2rem; }
    .flash {
        padding: .85rem 1.2rem;
        border-radius: var(--radius-sm);
        font-size: .85rem;
        font-weight: 600;
        display: flex;
        align-items: center;
        gap: .6rem;
    }
    .flash-success { background: #f0fdf4; color: #166534; border: 1px solid #bbf7d0; }
    .flash-danger  { background: #fff0f1; color: #9f1239; border: 1px solid #fecaca; }

    /*  SEPARATOR DECORATIVO  */
    .stripe-sep {
        height: 3px;
        background: var(--cbic-red);
        opacity: .35;
    }

    /*  ANIMATIONS  */
    @keyframes fadeUp {
        from { opacity: 0; transform: translateY(24px); }
        to   { opacity: 1; transform: translateY(0); }
    }
    @keyframes fadeIn {
        from { opacity: 0; }
        to   { opacity: 1; }
    }
    @keyframes plansBackgroundDrift {
        from { background-position: 0 0, 0 0; }
        to   { background-position: 180px 180px, 0 0; }
    }
    @keyframes floatA {
        0%,100% { transform: translateY(0) rotate(0deg); }
        50%      { transform: translateY(-22px) rotate(8deg); }
    }
    @keyframes floatB {
        0%,100% { transform: translateY(0) rotate(0deg); }
        50%      { transform: translateY(-16px) rotate(-6deg); }
    }
    @keyframes floatC {
        0%,100% { transform: translateY(0) scale(1); }
        50%      { transform: translateY(-12px) scale(1.06); }
    }
    @keyframes pulseDot {
        0%,100% { opacity: .55; transform: scale(1); }
        50%      { opacity: 1;   transform: scale(1.15); }
    }
    @keyframes stripeSlide {
        from { background-position: 0 0; }
        to   { background-position: 80px 0; }
    }
    @keyframes rippleOut {
        from { transform: scale(0); opacity: .35; }
        to   { transform: scale(2.8); opacity: 0; }
    }
    .fade-up { opacity: 0; }
    .fade-up.visible {
        animation: fadeUp .7s cubic-bezier(.22,.68,0,1.2) forwards;
    }
    .fade-up.d1 { animation-delay: .08s; }
    .fade-up.d2 { animation-delay: .18s; }
    .fade-up.d3 { animation-delay: .28s; }
    .fade-up.d4 { animation-delay: .38s; }

    /* Floating shapes no hero */
    .hero-shape {
        position: absolute;
        border-radius: 50%;
        pointer-events: none;
        z-index: 1;
    }
    .hs1 {
        width: 70px; height: 70px;
        border: 2px solid rgba(250,201,0,.25);
        top: 18%; right: 18%;
        animation: floatA 6s ease-in-out infinite;
    }
    .hs2 {
        width: 40px; height: 40px;
        background: rgba(238,64,74,.18);
        top: 55%; right: 30%;
        animation: floatB 4.5s ease-in-out infinite 1s;
    }
    .hs3 {
        width: 100px; height: 100px;
        border: 1.5px solid rgba(12,77,162,.2);
        bottom: 20%; left: 8%;
        animation: floatC 7s ease-in-out infinite .5s;
    }
    .hs4 {
        width: 16px; height: 16px;
        background: var(--cbic-yellow);
        opacity: .45;
        top: 30%; left: 18%;
        animation: pulseDot 3s ease-in-out infinite;
    }

    /* hero-stripe: linha vermelha sólida discreta — sem animação */

    /* Ripple em clique em botões CTA */
    .btn-ripple {
        position: relative;
        overflow: hidden;
    }
    .btn-ripple::after {
        content: '';
        position: absolute;
        inset: 0;
        border-radius: inherit;
        background: rgba(255,255,255,.25);
        transform: scale(0);
        opacity: 0;
    }
    .btn-ripple:active::after {
        animation: rippleOut .5s ease forwards;
    }

    /* Hover lift mais suave nos cards */
    .plan-card {
        will-change: transform;
    }
    .plan-card:hover {
        transition: transform .35s cubic-bezier(.22,.68,0,1.2),
                    box-shadow .35s ease,
                    border-color .22s ease;
    }
    .profile-card {
        will-change: transform;
    }
    .profile-card:hover {
        transition: transform .35s cubic-bezier(.22,.68,0,1.2),
                    box-shadow .35s ease;
    }

    /* Nav link indicador animado */
    .nav-link {
        position: relative;
    }
    .nav-link::after {
        content: '';
        position: absolute;
        bottom: 2px; left: .85rem; right: .85rem;
        height: 2px;
        background: var(--cbic-blue);
        border-radius: 1px;
        transform: scaleX(0);
        transform-origin: center;
        transition: transform .25s cubic-bezier(.4,0,.2,1);
    }
    .nav-link:hover::after,
    .nav-link.active::after { transform: scaleX(1); }
    .nav-link.active { color: var(--cbic-blue) !important; }

    /* 
       ANIMAÇÕES — vida em todo o sistema
     */

    /* Slide-in lateral para seções alternadas */
    @keyframes slideInLeft {
        from { opacity:0; transform: translateX(-40px); }
        to   { opacity:1; transform: translateX(0); }
    }
    @keyframes slideInRight {
        from { opacity:0; transform: translateX(40px); }
        to   { opacity:1; transform: translateX(0); }
    }
    @keyframes slideInUp {
        from { opacity:0; transform: translateY(30px); }
        to   { opacity:1; transform: translateY(0); }
    }
    /* Pulse suave em labels e ícones */
    @keyframes pulseRed {
        0%,100% { box-shadow: 0 0 0 0 rgba(238,64,74,0); }
        50%      { box-shadow: 0 0 0 6px rgba(238,64,74,.15); }
    }
    /* Shimmer em hover de cards */
    @keyframes shimmer {
        from { background-position: -200% center; }
        to   { background-position: 200% center; }
    }
    /* Flutuação contínua para elementos decorativos */
    @keyframes floatGently {
        0%,100% { transform: translateY(0); }
        50%      { transform: translateY(-8px); }
    }
    /* Entrada pulsada do CTA */
    @keyframes ctaPop {
        0%   { transform: scale(1); }
        50%  { transform: scale(1.045); }
        100% { transform: scale(1); }
    }
    /* Wipe de underline */
    @keyframes wipeIn {
        from { transform: scaleX(0); }
        to   { transform: scaleX(1); }
    }

    /*  slide-in classes controladas por IntersectionObserver  */
    .slide-left  { opacity:0; transform: translateX(-40px); transition: opacity .65s cubic-bezier(.22,.68,0,1.2), transform .65s cubic-bezier(.22,.68,0,1.2); }
    .slide-right { opacity:0; transform: translateX(40px);  transition: opacity .65s cubic-bezier(.22,.68,0,1.2), transform .65s cubic-bezier(.22,.68,0,1.2); }
    .slide-up    { opacity:0; transform: translateY(32px);  transition: opacity .6s cubic-bezier(.22,.68,0,1.2), transform .6s cubic-bezier(.22,.68,0,1.2); }
    .slide-left.in, .slide-right.in, .slide-up.in { opacity:1; transform: none; }
    .slide-left.in  { transition-delay: var(--sd, 0s); }
    .slide-right.in { transition-delay: var(--sd, 0s); }
    .slide-up.in    { transition-delay: var(--sd, 0s); }

    /*  Section label pulse  */
    .section-label:hover {
        animation: pulseRed 1s ease-in-out;
    }

    /*  Plan cards — hover 3D tilt + lift  */
    .plan-card {
        will-change: transform;
        transition: transform .35s cubic-bezier(.22,.68,0,1.2),
                    box-shadow .35s ease,
                    border-color .22s ease;
    }
    .plan-card:hover {
        transform: translateY(-6px) perspective(600px) rotateX(2deg);
        box-shadow: 0 20px 48px rgba(28,37,46,.16);
    }
    .plan-card.is-featured:hover {
        transform: translateY(-8px) perspective(600px) rotateX(2deg);
        box-shadow: 0 24px 56px rgba(12,77,162,.28);
    }

    /*  Profile cards — slide-up + glow  */
    .profile-card {
        will-change: transform;
        transition: transform .35s cubic-bezier(.22,.68,0,1.2),
                    box-shadow .35s ease;
    }
    .profile-card:hover {
        transform: translateY(-6px);
        box-shadow: 0 20px 48px rgba(12,77,162,.22);
    }

    /*  Value cards — shimmer strip on hover  */
    .value-card {
        overflow: hidden;
        position: relative;
        transition: transform .32s cubic-bezier(.22,.68,0,1.2),
                    box-shadow .32s ease,
                    border-color .22s ease,
                    background .22s ease;
    }
    .value-card::before {
        content: '';
        position: absolute;
        inset: 0;
        background: linear-gradient(105deg,
            transparent 35%,
            rgba(255,255,255,.08) 50%,
            transparent 65%);
        background-size: 200% auto;
        opacity: 0;
        transition: opacity .3s ease;
    }
    .value-card:hover::before {
        opacity: 1;
        animation: shimmer .7s linear forwards;
    }
    .value-card:hover {
        transform: translateY(-5px);
        border-color: rgba(238,64,74,.35);
        background: rgba(255,255,255,.09);
        box-shadow: 0 12px 32px rgba(0,0,0,.2);
    }
    .value-num {
        transition: transform .3s cubic-bezier(.22,.68,0,1.2);
    }
    .value-card:hover .value-num {
        transform: scale(1.12);
    }

    /*  Showcase cards — lift + border glow  */
    .showcase-card {
        transition: transform .35s cubic-bezier(.22,.68,0,1.2),
                    box-shadow .35s ease,
                    border-color .22s ease;
    }
    .showcase-card:hover {
        transform: translateY(-5px);
        box-shadow: 0 16px 40px rgba(12,77,162,.14);
        border-color: var(--cbic-red);
    }

    /*  Bento stat items (seção sobre) — hover lift  */
    [class*="fade-up"][style*="border-radius:var(--radius-lg)"],
    .fade-up[style*="border-radius:var(--radius-lg)"] {
        transition: transform .3s cubic-bezier(.22,.68,0,1.2), box-shadow .3s ease;
        cursor: default;
    }

    /*  FAQ items — slide indicator  */
    .faq-item {
        transition: background .22s ease;
        border-radius: var(--radius-sm);
        padding: 0 .5rem;
        margin: 0 -.5rem;
    }
    .faq-item:hover {
        background: rgba(238,64,74,.04);
    }
    .faq-item.open {
        background: rgba(238,64,74,.04);
    }

    /*  Billing Toggle Switch (Premium)  */
    .billing-toggle-container { margin-top: 1.5rem; margin-bottom: 0.75rem; }
    .billing-toggle {
        display: inline-flex;
        background: var(--gray-100);
        padding: 4px;
        border-radius: 10px;
        align-items: center;
        border: 1px solid rgba(12, 77, 162, 0.05);
    }
    .billing-toggle-btn {
        background: transparent;
        border: none;
        padding: 0.45rem 1.15rem;
        font-size: 0.78rem;
        font-weight: 600;
        color: var(--gray-600);
        border-radius: 8px;
        cursor: pointer;
        transition: all 0.35s cubic-bezier(0.22, 0.68, 0, 1.2);
        display: flex;
        align-items: center;
        letter-spacing: .02em;
    }
    .billing-toggle-btn:hover { color: var(--ink); }
    .billing-toggle-btn.active {
        background: var(--white);
        color: var(--cbic-blue);
        box-shadow: 0 4px 14px rgba(12, 77, 162, 0.1), 0 1px 2px rgba(12, 77, 162, 0.04);
        font-weight: 700;
    }
    .discount-badge {
        background: rgba(238,64,74,.08);
        color: var(--cbic-red);
        padding: 0.15rem 0.45rem;
        border-radius: 5px;
        font-size: 0.65rem;
        font-weight: 800;
        margin-left: 0.5rem;
        letter-spacing: 0.02em;
    }
    .plan-price-display {
        margin-top: 1.2rem;
        animation: fadePriceIn 0.4s cubic-bezier(.4, 0, .2, 1) forwards;
    }
    @keyframes fadePriceIn {
        from { opacity: 0; transform: translateY(6px); }
        to   { opacity: 1; transform: translateY(0); }
    }
    .plan-price-display .price-val {
        font-size: 2.3rem;
        font-weight: 900;
        letter-spacing: -0.04em;
        line-height: 1;
        color: var(--cbic-navy);
    }
    .plan-price-display .price-period {
        font-size: 0.9rem;
        font-weight: 600;
        color: var(--gray-600);
        margin-left: 0.2rem;
    }

    /* Override cores no Profile Card (Tema Escuro) */
    .profile-card .billing-toggle {
        background: rgba(255,255,255,.05);
        border-color: rgba(255,255,255,.08);
    }
    .profile-card .billing-toggle-btn { color: rgba(255,255,255,.6); }
    .profile-card .billing-toggle-btn:hover { color: #fff; }
    .profile-card .billing-toggle-btn.active {
        background: rgba(255,255,255,.1);
        color: var(--white);
        box-shadow: 0 4px 14px rgba(0,0,0,.2);
    }
    .profile-card .discount-badge {
        background: rgba(250,201,0,.15);
        color: var(--cbic-yellow);
    }
    .profile-card .plan-price-display .price-val { color: #fff; }
    .profile-card .plan-price-display .price-period { color: rgba(255,255,255,.6); }

    /*  CTA final — pulse periódico no botão principal  */
    @keyframes ctaPulse {
        0%,100% { box-shadow: 0 0 0 0 rgba(238,64,74,0); }
        50%      { box-shadow: 0 0 0 12px rgba(238,64,74,.2); }
    }
    .cta-final-section .btn-hero-primary {
        animation: ctaPulse 2.5s ease-in-out infinite;
    }
    .cta-final-section .btn-hero-primary:hover {
        animation: none;
    }

    /*  Topbar CTA button — subtle bounce on load  */
    @keyframes navCtaBounce {
        0%,100% { transform: translateY(0); }
        40%     { transform: translateY(-3px); }
        60%     { transform: translateY(-1px); }
    }
    .btn-nav-cta {
        animation: navCtaBounce 4s ease-in-out infinite 2s;
    }
    .btn-nav-cta:hover {
        animation: none;
    }

    /* Contador animado */
    .count-up { font-variant-numeric: tabular-nums; }

    /*  RESPONSIVE  */
    @media (max-width: 1024px) {
        .about-grid { grid-template-columns: 1fr; gap: 2.5rem; }
        .value-grid { grid-template-columns: 1fr 1fr; }
    }
    @media (max-width: 768px) {
        html { scroll-padding-top: 64px; }
        body { background: #f5f7fa; }
        .topbar-inner {
            height: auto;
            min-height: 58px;
            padding: .6rem 1rem;
            gap: .75rem;
            position: relative;
        }
        .topbar-logo { height: 38px; }
        .mobile-menu-toggle {
            display: inline-flex;
            margin-left: auto;
        }
        .mobile-menu-toggle.is-open {
            background: var(--cbic-blue);
            border-color: var(--cbic-blue);
            color: #fff;
        }
        .topbar-nav {
            position: absolute;
            top: calc(100% + .55rem);
            left: 1rem;
            right: 1rem;
            display: grid;
            grid-template-columns: 1fr;
            gap: .25rem;
            padding: .75rem;
            border: 1px solid var(--gray-200);
            border-radius: 1rem;
            background: rgba(255,255,255,.98);
            box-shadow: 0 18px 45px rgba(39,50,63,.18);
            opacity: 0;
            visibility: hidden;
            transform: translateY(-8px);
            pointer-events: none;
            transition: opacity var(--tr), transform var(--tr), visibility var(--tr);
        }
        .topbar-nav.is-open {
            opacity: 1;
            visibility: visible;
            transform: translateY(0);
            pointer-events: auto;
        }
        .topbar.menu-open {
            box-shadow: 0 16px 42px rgba(39,50,63,.12) !important;
        }
        .topbar-nav .nav-link {
            display: flex;
            align-items: center;
            min-height: 2.65rem;
            padding: .65rem .85rem;
            font-size: .74rem;
            color: var(--ink);
            background: var(--gray-50);
        }
        .topbar-nav .nav-link::after { display: none; }
        .topbar-nav .nav-link.active {
            color: var(--cbic-blue) !important;
            background: #eef4ff;
        }
        .btn-nav-cta {
            margin-left: 0;
            padding: .72rem .85rem;
            font-size: .72rem;
            line-height: 1.1;
            max-width: none;
            width: 100%;
            justify-content: center;
            text-align: center;
        }
        .hero { padding: 3rem 1rem 2.65rem; }
        .hero::after {
            left: -260px;
            top: -160px;
            width: 520px;
            height: 520px;
        }
        .hero-accent-red {
            right: -180px;
            bottom: -130px;
            width: 330px;
            height: 330px;
        }
        .hero-inner { grid-template-columns: 1fr; gap: 1.5rem; }
        .hero-stats { display: none; }
        .hero-eyebrow {
            font-size: .62rem;
            max-width: 100%;
            padding: .38rem .72rem;
        }
        .hero-title {
            font-size: clamp(2rem, 10vw, 2.55rem);
            line-height: 1.02;
            letter-spacing: -.025em;
        }
        .hero-subtitle {
            font-size: .9rem;
            line-height: 1.62;
            margin-bottom: 1.45rem;
        }
        .hero-ctas { display: grid; grid-template-columns: 1fr; gap: .65rem; }
        .btn-hero-primary,
        .btn-hero-secondary {
            width: 100%;
            min-height: 2.85rem;
            justify-content: center;
            padding: .82rem 1rem;
            font-size: .75rem;
            text-align: center;
        }
        .section { padding: 3.25rem 1rem; }
        .section-inner { max-width: 100%; }
        .section-label {
            font-size: .62rem;
            margin-bottom: .62rem;
        }
        .section-title {
            font-size: clamp(1.55rem, 8vw, 2.05rem);
            line-height: 1.08;
        }
        .section-sub {
            font-size: .86rem;
            line-height: 1.65;
            margin-bottom: 2rem;
        }
        .value-grid {
            display: grid;
            grid-auto-flow: column;
            grid-auto-columns: minmax(238px, 78vw);
            grid-template-columns: none;
            gap: .85rem;
            overflow-x: auto;
            overflow-y: hidden;
            margin-left: -1rem;
            margin-right: -1rem;
            padding: .1rem 1rem 1rem;
            scroll-snap-type: x mandatory;
            scroll-padding-inline: 1rem;
            -webkit-overflow-scrolling: touch;
            scrollbar-width: none;
        }
        .value-grid::-webkit-scrollbar { display: none; }
        .value-grid > * {
            scroll-snap-align: start;
            height: 100%;
        }
        .cards-grid {
            display: grid;
            grid-auto-flow: column;
            grid-auto-columns: minmax(262px, 78vw);
            grid-template-columns: none;
            gap: .85rem;
            overflow-x: auto;
            overflow-y: hidden;
            margin-left: -1rem;
            margin-right: -1rem;
            padding: .2rem 1rem .75rem;
            scroll-snap-type: x mandatory;
            scroll-padding-inline: 1rem;
            -webkit-overflow-scrolling: touch;
            scrollbar-width: none;
        }
        .cards-grid::-webkit-scrollbar { display: none; }
        .cards-grid::after {
            content: '';
            width: .15rem;
        }
        .cards-grid > * {
            scroll-snap-align: start;
            height: 100%;
        }
        .plan-card,
        .profile-card,
        .showcase-card,
        .value-card {
            border-radius: 1rem;
            box-shadow: 0 8px 26px rgba(39,50,63,.08);
        }
        .mobile-carousel-controls {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: .72rem;
            margin: .05rem auto 0;
            min-height: 2.25rem;
        }
        .carousel-arrow {
            width: 2rem;
            height: 2rem;
            border-radius: 999px;
            border: 1px solid #d6e2f2;
            background: #fff;
            color: var(--cbic-blue);
            display: inline-flex;
            align-items: center;
            justify-content: center;
            box-shadow: 0 7px 18px rgba(39,50,63,.08);
        }
        .carousel-arrow:active {
            transform: scale(.95);
        }
        .carousel-dots {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: .32rem;
            min-width: 2.7rem;
        }
        .carousel-dot {
            width: .42rem;
            height: .42rem;
            border: 0;
            border-radius: 999px;
            background: #cbd8ea;
            padding: 0;
            transition: width var(--tr), background var(--tr);
        }
        .carousel-dot.is-active {
            width: 1.1rem;
            background: var(--cbic-blue);
        }
        .mobile-carousel-controls-light .carousel-arrow {
            border-color: rgba(255,255,255,.22);
            background: rgba(255,255,255,.08);
            color: #fff;
            box-shadow: none;
        }
        .mobile-carousel-controls-light .carousel-dot {
            background: rgba(255,255,255,.32);
        }
        .mobile-carousel-controls-light .carousel-dot.is-active {
            background: var(--cbic-yellow);
        }
        .plan-card:hover,
        .plan-card.is-featured:hover,
        .profile-card:hover,
        .showcase-card:hover,
        .value-card:hover {
            transform: none;
        }
        .plan-head,
        .profile-head {
            padding: 1.25rem 1.1rem 1rem;
        }
        .plan-body,
        .profile-body {
            padding: 1.1rem;
            gap: .85rem;
        }
        .plan-name,
        .profile-name {
            font-size: 1.02rem;
            line-height: 1.25;
        }
        .plan-desc,
        .profile-desc {
            font-size: .78rem;
            line-height: 1.55;
        }
        .billing-toggle-container { margin-top: 1rem; }
        .billing-toggle {
            width: 100%;
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }
        .billing-toggle-btn {
            justify-content: center;
            padding: .48rem .45rem;
            font-size: .72rem;
            min-width: 0;
        }
        .discount-badge {
            margin-left: .25rem;
            font-size: .58rem;
            padding: .12rem .3rem;
        }
        .plan-price-display { margin-top: .95rem; }
        .plan-price-display .price-val {
            font-size: clamp(1.8rem, 11vw, 2.25rem);
            letter-spacing: -.035em;
            overflow-wrap: anywhere;
        }
        .plan-price-display .price-period {
            font-size: .76rem;
        }
        .chip-row { gap: .3rem; }
        .site-chip {
            font-size: .58rem;
            padding: .2rem .5rem;
        }
        .benefit-list,
        .profile-benefit-list {
            gap: .48rem;
        }
        .benefit-list li,
        .profile-benefit-list li {
            font-size: .76rem;
            line-height: 1.45;
        }
        .btn-plan {
            min-height: 2.75rem;
            padding: .78rem .7rem;
            font-size: .72rem;
            white-space: normal;
            line-height: 1.15;
        }
        .about-grid { gap: 1.6rem; }
        .about-text { font-size: .86rem; line-height: 1.65; }
        .about-item {
            gap: .75rem;
            margin-bottom: .9rem;
        }
        .about-icon {
            width: 38px;
            height: 38px;
            font-size: 1rem;
        }
        .numbers-box {
            grid-template-columns: 1fr 1fr;
            padding: 1rem;
            gap: .75rem;
            border-radius: 1rem;
        }
        #sobre .section-sub {
            margin-bottom: 1.45rem !important;
        }
        #sobre .cbic-stats-grid {
            display: grid !important;
            grid-auto-flow: column !important;
            grid-auto-columns: minmax(192px, 62vw) !important;
            grid-template-columns: none !important;
            gap: .85rem !important;
            overflow-x: auto;
            overflow-y: hidden;
            margin-left: -1rem !important;
            margin-right: -1rem !important;
            padding: .2rem 1rem .75rem !important;
            scroll-snap-type: x mandatory;
            scroll-padding-inline: 1rem;
            -webkit-overflow-scrolling: touch;
            scrollbar-width: none;
        }
        #sobre .cbic-stats-grid::-webkit-scrollbar { display: none; }
        #sobre .cbic-stats-grid > div {
            padding: 1.15rem 1rem !important;
            border-radius: 1.05rem !important;
            min-width: 0;
            scroll-snap-align: start;
            height: 100%;
            min-height: 152px;
            display: flex;
            flex-direction: column;
            justify-content: space-between;
        }
        .cards-grid::-webkit-scrollbar,
        .value-grid::-webkit-scrollbar,
        #sobre .cbic-stats-grid::-webkit-scrollbar {
            height: 4px;
        }
        .cards-grid::-webkit-scrollbar-thumb,
        .value-grid::-webkit-scrollbar-thumb,
        #sobre .cbic-stats-grid::-webkit-scrollbar-thumb {
            background: rgba(12,77,162,.25);
            border-radius: 999px;
        }
        #sobre .num-val,
        #sobre .cbic-stats-grid [style*="font-size:3rem"],
        #sobre .cbic-stats-grid [style*="font-size:2.4rem"] {
            font-size: clamp(2.05rem, 12vw, 2.7rem) !important;
            line-height: .9 !important;
            letter-spacing: -.035em !important;
        }
        #sobre .cbic-stats-grid [style*="font-size:.65rem"] {
            font-size: .58rem !important;
            letter-spacing: .14em !important;
        }
        #sobre .cbic-stats-grid [style*="font-size:.78rem"],
        #sobre .cbic-stats-grid [style*="font-size:.8rem"] {
            font-size: .72rem !important;
            line-height: 1.25 !important;
        }
        .value-card {
            padding: 1.2rem 1rem;
        }
        .value-num {
            font-size: 1.65rem;
            margin-bottom: .7rem;
        }
        .value-title {
            font-size: .86rem;
        }
        .value-desc {
            font-size: .76rem;
            line-height: 1.55;
        }
        .faq-wrap { max-width: 100%; }
        .faq-item {
            margin: 0;
            padding: 0;
        }
        .faq-btn {
            padding: 1rem 0;
            font-size: .78rem;
            line-height: 1.4;
            gap: .75rem;
        }
        .faq-icon {
            width: 30px;
            height: 30px;
            font-size: .85rem;
        }
        .faq-body {
            font-size: .78rem;
            line-height: 1.6;
            padding-bottom: 1rem;
        }
        .cta-final-section { padding: 3.6rem 1rem; }
        .cta-final-title {
            font-size: clamp(1.6rem, 8vw, 2rem);
        }
        .cta-final-sub {
            font-size: .86rem;
            line-height: 1.58;
            margin-bottom: 1.55rem;
        }
        .cta-btns {
            display: grid;
            grid-template-columns: 1fr;
            gap: .65rem;
        }
        .footer-inner { flex-direction: column; align-items: flex-start; gap: 1rem; }
    }

    @media (max-width: 390px) {
        .section { padding-left: .82rem; padding-right: .82rem; }
        .hero { padding-left: .82rem; padding-right: .82rem; }
        .plan-head,
        .profile-head,
        .plan-body,
        .profile-body { padding-left: .9rem; padding-right: .9rem; }
        .btn-nav-cta { font-size: .66rem; }
        .cards-grid { grid-auto-columns: minmax(248px, 80vw); }
        .value-grid { grid-auto-columns: minmax(226px, 82vw); }
        #sobre .cbic-stats-grid {
            grid-auto-columns: minmax(176px, 64vw) !important;
        }
    }

    .plan-scope-modal-overlay {
        position: fixed;
        inset: 0;
        z-index: 900;
        display: none;
        align-items: center;
        justify-content: center;
        padding: 1rem;
        background: rgba(39,50,63,.56);
        backdrop-filter: blur(6px);
    }
    .plan-scope-modal-overlay.is-open {
        display: flex;
    }
    .plan-scope-modal {
        width: min(460px, 100%);
        border-radius: var(--radius-md);
        background: #fff;
        box-shadow: 0 24px 64px rgba(28,37,46,.24);
        border: 1px solid var(--gray-200);
        padding: 1.35rem;
        display: grid;
        grid-template-columns: 44px minmax(0, 1fr);
        gap: 1rem;
    }
    .plan-scope-modal-icon {
        width: 44px;
        height: 44px;
        border-radius: .8rem;
        background: rgba(238,64,74,.1);
        color: var(--cbic-red);
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: 1.25rem;
    }
    .plan-scope-modal-title {
        font-weight: 900;
        color: var(--ink);
        margin-bottom: .35rem;
    }
    .plan-scope-modal-desc {
        margin: 0 0 1rem;
        color: var(--gray-600);
        font-size: .9rem;
        line-height: 1.55;
    }
    .plan-scope-modal-close {
        border: 0;
        border-radius: var(--radius-sm);
        background: var(--cbic-red);
        color: #fff;
        font-weight: 800;
        padding: .72rem 1.1rem;
        cursor: pointer;
    }

    /*  HERO SLIDER  */
    .hero-slider {
        position: relative;
        width: 100%;
        overflow: hidden;
        background: var(--cbic-navy);
        user-select: none;
    }
    .hs-slide {
        position: absolute;
        inset: 0;
        height: 580px;
        min-height: 580px;
        opacity: 0;
        visibility: hidden;
        transition: opacity .7s cubic-bezier(.4,0,.2,1), visibility .7s;
    }
    .hs-slide--active {
        position: relative;
        opacity: 1;
        visibility: visible;
    }
    .hs-slide[hidden] {
        display: none !important;
    }
    .hs-slide__bg {
        position: absolute;
        inset: 0;
        z-index: 0;
    }
    .hs-bg-dots {
        position: absolute;
        inset: 0;
        background-image: radial-gradient(circle 1px at 1px 1px, rgba(255,255,255,.07) 1px, transparent 0);
        background-size: 32px 32px;
        pointer-events: none;
    }
    .hs-bg-glow {
        position: absolute;
        width: 500px;
        height: 500px;
        pointer-events: none;
        z-index: 1;
    }
    .hs-slide__inner {
        position: relative;
        z-index: 2;
        max-width: 1200px;
        height: 100%;
        min-height: 100%;
        margin: 0 auto;
        padding: 5rem 2rem 5.5rem;
        display: grid;
        grid-template-columns: minmax(0, 1fr);
        gap: 3rem;
        align-items: center;
        box-sizing: border-box;
    }
    .hs-slide__inner--split {
        grid-template-columns: 1fr 1fr;
        gap: 0;
        padding: 0;
        align-items: stretch;
    }
    .hs-slide__inner--split .hs-content {
        padding: 5rem 3rem;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    .hs-content {
        display: flex;
        flex-direction: column;
        min-width: 0;
    }
    .hs-benefits {
        background: rgba(255,255,255,.04);
        border-left: 1px solid rgba(255,255,255,.08);
        padding: 5rem 3rem;
        display: flex;
        flex-direction: column;
        justify-content: center;
        gap: 1.4rem;
    }
    .hs-benefits__label {
        font-size: .7rem;
        font-weight: 800;
        letter-spacing: .16em;
        text-transform: uppercase;
        color: var(--cbic-yellow);
        margin-bottom: .25rem;
    }
    .hs-benefit-item {
        display: flex;
        align-items: flex-start;
        gap: 1rem;
    }
    .hs-benefit-icon {
        width: 40px;
        height: 40px;
        background: rgba(255,255,255,.07);
        border: 1px solid rgba(255,255,255,.12);
        border-radius: .6rem;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        color: var(--cbic-yellow);
        font-size: 1.05rem;
    }
    .hs-benefit-title {
        font-size: .88rem;
        font-weight: 800;
        color: #fff;
        margin-bottom: .15rem;
    }
    .hs-benefit-desc {
        font-size: .78rem;
        color: rgba(255,255,255,.58);
        line-height: 1.5;
    }
    .hs-arrow {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        z-index: 20;
        width: 44px;
        height: 44px;
        background: rgba(255,255,255,.1);
        border: 1px solid rgba(255,255,255,.2);
        border-radius: 50%;
        color: #fff;
        font-size: 1.1rem;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: background .2s, border-color .2s, transform .2s;
        backdrop-filter: blur(4px);
    }
    .hs-arrow:hover {
        background: rgba(255,255,255,.2);
        border-color: rgba(255,255,255,.5);
        transform: translateY(-50%) scale(1.08);
    }
    .hs-arrow--prev { left: 1.5rem; }
    .hs-arrow--next { right: 1.5rem; }
    .hs-dots {
        position: absolute;
        bottom: 1.5rem;
        left: 50%;
        transform: translateX(-50%);
        z-index: 20;
        display: flex;
        gap: .5rem;
        align-items: center;
    }
    .hs-dot {
        width: 8px;
        height: 8px;
        border-radius: 999px;
        background: rgba(255,255,255,.35);
        border: none;
        cursor: pointer;
        transition: width .3s, background .3s;
        padding: 0;
    }
    .hs-dot--active {
        width: 24px;
        background: #fff;
    }
    .hs-progress {
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        height: 3px;
        background: rgba(255,255,255,.12);
        z-index: 15;
    }
    .hs-progress__bar {
        height: 100%;
        background: var(--cbic-red);
        width: 0%;
    }

    @media (max-width: 900px) {
        .hs-slide {
            height: auto;
            min-height: 520px;
        }
        .hs-slide__inner,
        .hs-slide__inner--split {
            grid-template-columns: 1fr !important;
            height: auto;
            min-height: 520px;
            padding: 3rem 1.25rem 4.5rem !important;
            gap: 2rem !important;
        }
        .hs-slide__inner--split .hs-content {
            padding: 0 !important;
        }
        .hs-benefits {
            border-left: none !important;
            border-top: 1px solid rgba(255,255,255,.08);
            min-height: auto !important;
            padding: 2rem 0 1rem !important;
        }
        .hs-arrow {
            display: none;
        }
    }
