/* ══════════════════════════════════════════════════════════════
   NORVEX GROUP — Premium Landing Page Styles
   Based on Heat Company reference — adapted for Norvex
   Font: Bricolage Grotesque (headings) + Inter (body)
   Palette: #0a0a0a (body), #021038 (dark cards), #003DE1 (accent)
   ══════════════════════════════════════════════════════════════ */

/* ─── Reset & Base ─── */
*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    overflow-x: hidden;
    width: 100%;
}

body {
    font-family: 'Inter', sans-serif;
    font-weight: 400;
    font-size: 16px;
    line-height: 1.6;
    color: #B9B9B9;
    background-color: #0a0a0a;
    overflow-x: hidden;
    width: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body::-webkit-scrollbar {
    width: 5px;
}

body::-webkit-scrollbar-track {
    background: #121214;
}

body::-webkit-scrollbar-thumb {
    background: #003DE1;
    border-radius: 20px;
}

::selection {
    color: #fff;
    background: #003DE1;
}

p {
    margin-bottom: 0;
}

a {
    text-decoration: none;
    color: inherit;
}

img {
    max-width: 100%;
    height: auto;
}

/* ─── Container ─── */
.container {
    width: 100%;
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 20px;
}

/* ─── Typography ─── */
h1,
h2,
h3,
h4 {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 600;
    line-height: 1.15;
    color: #ffffff;
}

.section-title {
    font-size: clamp(25px, 4vw, 34px);
    color: #ffffff;
}

.section-title-white {
    font-size: clamp(25px, 4vw, 34px);
    color: #ffffff;
}

.section-sub {
    font-size: clamp(15px, 2.5vw, 18px);
    color: #B9B9B9;
    margin-top: 12px;
    max-width: 600px;
}

.section-sub-white {
    font-size: clamp(15px, 2.5vw, 20px);
    color: #ffffff;
    margin-top: 12px;
}

.microcopy {
    display: block;
    font-size: 13px;
    color: #666;
    margin-top: 12px;
}

/* ─── Animated Button (matching reference) ─── */
.btn-main {
    display: inline-block;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 16px;
    font-weight: 600;
    text-transform: uppercase;
    color: #ffffff;
    background-image: linear-gradient(45deg, #021547, #003DE1, #021547, #003DE1);
    background-size: 400% 200%;
    border: none;
    border-radius: 7px;
    padding: 18px 32px;
    cursor: pointer;
    transition: all 0.8s;
    animation: btnGradient 5s cubic-bezier(0.2, 0.5, 0.9, 0.6) 2s infinite;
    text-align: center;
    letter-spacing: 0.5px;
}

.btn-main:hover {
    background-color: #5F3434;
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(0, 61, 225, 0.3);
}

.btn-large {
    padding: 22px 44px;
    font-size: 17px;
}

@keyframes btnGradient {
    0% {
        background-position: 0 0;
    }

    100% {
        background-position: 100% 0;
    }
}


/* ══════════════════════════════════════════════════════════════
   SECTION 1: HERO — Unified Background (aspect-ratio driven)
   ══════════════════════════════════════════════════════════════ */
.hero {
    position: relative;
    width: 100%;
    min-height: 700px;
    display: flex;
    padding: 0;
    background-color: #060a18;
    overflow: hidden;
}

.hero-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.hero-bg-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: right center;
}

.hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(6, 10, 24, 0.95) 0%, rgba(6, 10, 24, 0.85) 35%, rgba(6, 10, 24, 0.4) 60%, rgba(6, 10, 24, 0) 80%);
    z-index: 2;
    pointer-events: none;
}

/* --- Container central --- */
.hero-inner {
    position: relative;
    z-index: 3;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    padding-top: 100px;
    /* Reduzido de 160px para engatar a stack inteira mais acima e encostar na nova linha vermelha da base métrica */
    width: 100%;
    max-width: 1210px;
    /* Aumentado em 120px a partir dos 1140px. Sendo centrado nativamente, puxa orgânica e incondicionalmente o eixo esquerdo 60 pixels mais pra beirada da tela em monitores largos. */
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 50px;
}

.hero-content {
    position: relative;
    z-index: 10;
    padding: 0;
    max-width: 555px;
    /* Alargado ligeiramente para garantir respiração na quebra do título */
    /* Devolvido ao fluxo Block nativo para não esticar os elementos 100% como o CTA e preservar Left Axis puro do .hero-inner */
    display: block;
}

.hero-logo {
    width: 100%;
    max-width: 300px;
    height: auto;
    /* O Box Model interage perfeitamente em bloco. Neutralizando o gap transparente do PNG nativamente */
    margin-left: -75px;
    /* Alinhamento de proximidade íntima e real ao box do título (a área do quadrado vermelho) */
    margin-bottom: 8px;
    display: block;
}

.hero-title {
    font-size: 42px;
    /* Adequado com o novo max-width da base */
    line-height: 0.96;
    /* Restaura line-height padronizado estável, extinguindo o corte engessado de pizel fixo que encavalava/afastava os limites */
    font-weight: 600;
    color: #ffffff;
    margin-bottom: 24px;
    max-width: 100%;
}

.hero-title .accent {
    color: #003DE1;
}

.hero-sub {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 19px;
    font-weight: 400;
    color: #B9B9B9;
    line-height: 22px;
    margin-bottom: 30px;
    max-width: 100%;
}

.hero-cta {
    margin-bottom: 24px;
    margin-top: 10px;
}

.hero-cta .btn-main {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    height: 57px;
    padding: 0 20px;
    font-size: 17px;
    font-weight: 600;
    width: 100%;
    max-width: 555px;
    /* Restauração física robusta e aprovada */
    background-image: linear-gradient(45deg, #021547, #003DE1, #021547, #003DE1);
    background-size: 400% 200%;
    animation: btnGradient 5s cubic-bezier(0.2, 0.5, 0.9, 0.6) 2s infinite normal none running;
    border-radius: 7px;
    border: none;
    color: #fff;
    cursor: pointer;
    text-decoration: none;
    letter-spacing: 0px;
    text-transform: uppercase;
}

.hero-cta .btn-main:hover {
    background-color: #5F3434;
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 61, 225, 0.4);
}

.hero-badge {
    display: flex;
    align-items: center;
    gap: 8px;
    /* Tighter alinhamento natural */
    padding: 8px 0;
}

.badge-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
}

.badge-label {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 14px;
    font-weight: 400;
    color: #e5e7eb;
    /* Acinzentado claro e limpo */
}

.badge-desc {
    font-size: 12px;
    color: #888;
}

/* --- Desktop visual: person anchored right --- */
.hero-visual {
    position: absolute;
    right: 0;
    top: 0;
    width: 50%;
    height: 100%;
    aspect-ratio: 960 / 751;
    z-index: 1;
}

/* Ambient glow strictly in the background */
.hero-visual::before {
    content: '';
    position: absolute;
    right: -100px;
    top: 50%;
    transform: translateY(-50%);
    width: 800px;
    height: 800px;
    background: radial-gradient(circle,
            rgba(0, 76, 190, 0.65) 0%,
            /* Brighter Royal Blue */
            rgba(15, 61, 185, 0.5) 20%,
            /* Vibrant Royal */
            rgba(0, 39, 192, 0.35) 45%,
            /* Deep Intense Blue */
            rgba(13, 17, 136, 0.2) 65%,
            /* Dark Purple-ish Blue */
            rgba(8, 17, 55, 0.05) 85%,
            /* Near Black/Midnight */
            transparent 100%);
    border-radius: 50%;
    filter: blur(60px);
    z-index: 0;
    /* ATRÁS do personagem */
    pointer-events: none;
}

/* Horizontal Premium Lens Flare correctly placed behind */
.hero-visual::after {
    content: '';
    position: absolute;
    right: -50px;
    top: 50%;
    width: 750px;
    height: 10px;
    background: radial-gradient(ellipse at center,
            rgba(89, 159, 231, 1) 0%,
            /* Light Sky/Ice Blue Core */
            rgba(0, 45, 192, 0.8) 15%,
            /* Vibrant Deep Blue */
            rgba(11, 28, 114, 0.4) 40%,
            /* Dark Navy */
            transparent 70%);
    filter: blur(2px);
    z-index: 0;
    /* ATRÁS do personagem */
    pointer-events: none;
}

.hero-desktop-banner {
    position: absolute;
    right: -80px;
    bottom: 0;
    height: 100%;
    width: auto;
    max-width: none;
    object-fit: contain;
    object-position: right bottom;
    /* Aumento de nitidez ótica, micro-contraste local e separação de borda via drop-shadow (sem fakes) */
    filter: contrast(1.18) saturate(1.05) brightness(1.02) drop-shadow(-4px 0px 15px rgba(0, 0, 0, 0.4));
    -webkit-filter: contrast(1.18) saturate(1.05) brightness(1.02) drop-shadow(-4px 0px 15px rgba(0, 0, 0, 0.4));
    z-index: 1;
    /* Otimizações de renderização para eliminar softness de escala (sub-pixel blur) */
    image-rendering: high-quality;
    transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}


/* ══════════════════════════════════════════════════════════════
   SECTION 2: PROVA DE PROCESSO
   ══════════════════════════════════════════════════════════════ */
.proof {
    position: relative;
    padding: 100px 0;
    border-top: 1px solid rgba(200, 200, 200, 0.08);
    overflow: hidden;
}

.proof-glow {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 500px;
    height: 800px;
    transform: translate(-50%, -50%);
    background: #011d63;
    border-radius: 100%;
    filter: blur(180px);
    opacity: 0.35;
    pointer-events: none;
}

.proof-header {
    text-align: center;
    margin-bottom: 48px;
}

.proof-header .section-sub {
    margin-left: auto;
    margin-right: auto;
}

.proof-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}

.proof-card {
    position: relative;
    background: #021038;
    border: 1px solid #011C64;
    border-radius: 15px;
    padding: 32px 28px 28px;
    transition: transform 0.3s, box-shadow 0.3s;
    overflow: hidden;
}

.proof-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(0, 61, 225, 0.15);
}

.proof-card-bar {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, #003DE1, #0066ff);
    border-radius: 15px 15px 0 0;
}

.proof-card-icon {
    width: 44px;
    height: 44px;
    color: #003DE1;
    margin-bottom: 16px;
}

.proof-card-icon svg {
    width: 100%;
    height: 100%;
}

.proof-card-title {
    font-size: 18px;
    font-weight: 600;
    color: #ffffff;
    margin-bottom: 8px;
}

.proof-card-desc {
    font-size: 15px;
    color: #888;
    line-height: 1.5;
}


/* ══════════════════════════════════════════════════════════════
   SECTION 3: DORES
   ══════════════════════════════════════════════════════════════ */
.pain {
    position: relative;
    padding: 100px 0;
    overflow: hidden;
    background-image: url("section3.png");
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
}

.pain-glow {
    display: none;
    /* Glow removido para não poluir a imagem principal */
}

.pain-header {
    text-align: center;
    margin-bottom: 48px;
}

.pain-header .section-sub {
    margin-left: auto;
    margin-right: auto;
}

.pain-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}

.pain-card {
    position: relative;
    background: #021038;
    border: 1px solid #011C64;
    border-radius: 15px;
    padding: 28px 25px 25px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    transition: transform 0.3s, box-shadow 0.3s;
    overflow: hidden;
}

.pain-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 35px rgba(0, 61, 225, 0.12);
}

.pain-card-bar {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, #003DE1, transparent);
    border-radius: 15px 15px 0 0;
}

.pain-card-icon {
    width: 40px;
    height: 40px;
    color: #003DE1;
    filter: brightness(134%) contrast(128%) saturate(149%) hue-rotate(128deg);
}

.pain-card-icon svg {
    width: 100%;
    height: 100%;
}

.pain-card-title {
    font-size: 18px;
    font-weight: 600;
    /* Aumentado peso do título para criar hierarquia forte com as novas descrições */
    color: #ffffff;
    margin: 0;
}

.pain-card-desc {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 15px;
    font-weight: 400;
    color: #B9B9B9;
    line-height: 1.5;
    margin: 0;
}


/* ══════════════════════════════════════════════════════════════
   SECTION 4: MECANISMO / ENTREGÁVEIS (fundo azul)
   ══════════════════════════════════════════════════════════════ */
.mechanism {
    padding: 100px 0;
    background-color: #003DE1;
    position: relative;
}

.mechanism-header {
    text-align: center;
    margin-bottom: 48px;
}

.mechanism-header .section-title-white {
    max-width: 700px;
    margin: 0 auto;
}

.mechanism-header .section-sub-white {
    margin-left: auto;
    margin-right: auto;
}

.mechanism-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}

.mech-card {
    background: #ffffff;
    border-radius: 30px;
    padding: 32px;
    transition: transform 0.3s;
}

.mech-card:hover {
    transform: translateY(-4px);
}

.mech-card-icon {
    width: 48px;
    height: 48px;
    margin-bottom: 20px;
}

.mech-card-icon.blue {
    color: #003DE1;
}

.mech-card-icon svg {
    width: 100%;
    height: 100%;
}

.mech-card-title {
    font-size: clamp(22px, 3vw, 27px);
    font-weight: 600;
    color: #0a0a0a;
    margin-bottom: 16px;
    line-height: 1.2;
}

.mech-card-desc {
    font-size: 16px;
    color: #303030;
    line-height: 1.5;
    font-family: 'Inter', sans-serif;
}

.mechanism-cta {
    text-align: center;
    margin-top: 40px;
}

.mechanism-cta .btn-main {
    background-image: linear-gradient(212deg, #FFFFFF 59%, #B4B4B4 100%);
    color: #4D4D4D;
    font-family: 'Inter', sans-serif;
    font-weight: 500;
    animation: none;
}

.mechanism-cta .btn-main:hover {
    background-image: linear-gradient(212deg, #ffffff 30%, #d4d4d4 100%);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2);
}


/* ══════════════════════════════════════════════════════════════
   SECTION 5: BÔNUS / VALOR ADICIONAL
   ══════════════════════════════════════════════════════════════ */
.bonus {
    padding: 100px 0;
    position: relative;
    overflow: hidden;
    background-image: url("valor adicional.png");
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
}

.bonus-header {
    text-align: center;
    margin-bottom: 48px;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}

.bonus-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}

.bonus-card {
    background: #1D1D1D;
    border: 1px solid rgba(84, 89, 95, 0.46);
    border-radius: 15px;
    padding: 28px;
}

.bonus-badge {
    display: inline-block;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 1px;
    color: #e4e4e4;
    background: #172448;
    border: 1px solid #172448;
    border-radius: 6px;
    padding: 6px 14px;
    margin-bottom: 20px;
}

.bonus-card-title {
    font-size: 23px;
    font-weight: 600;
    color: #ffffff;
    margin-bottom: 8px;
}

.bonus-card-desc {
    font-size: 15px;
    color: #999;
    line-height: 1.5;
}

.bonus-cta {
    text-align: center;
    margin-top: 40px;
}


/* ══════════════════════════════════════════════════════════════
   SECTION 6: ANTES x DEPOIS
   ══════════════════════════════════════════════════════════════ */
.contrast {
    padding: 100px 0;
    background-color: #000000;
    position: relative;
    overflow: hidden;
}

.contrast-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
}

.contrast::before {
    content: '';
    position: absolute;
    inset: 0;
    background-color: #000000;
    opacity: 0.72;
    z-index: 1;
    /* Overlay de proteção */
}

.contrast-header {
    text-align: center;
    margin-bottom: 48px;
    position: relative;
    z-index: 2;
    /* Conteúdo no topo */
}

.contrast-header .section-title-white {
    max-width: 500px;
    margin: 0 auto;
}

.contrast-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    position: relative;
    z-index: 2;
    /* Conteúdo no topo */
}

.contrast-col {
    border: 1px solid rgba(0, 61, 225, 0.52);
    border-radius: 20px;
    padding: 35px 24px 50px;
}

.contrast-col.before {
    background: linear-gradient(320deg, #818181 0%, #FFFFFF 100%);
}

.contrast-col.after {
    background: #062475;
}

.contrast-label {
    font-size: 30px;
    font-weight: 600;
    margin-bottom: 28px;
    text-align: center;
}

.contrast-col.before .contrast-label {
    color: #000000;
}

.contrast-col.after .contrast-label {
    color: #ffffff;
}

.contrast-items {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.contrast-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px 20px;
    border-radius: 10px;
    font-size: 15px;
    transition: transform 0.2s;
}

.contrast-col.before .contrast-item {
    background: rgba(230, 230, 230, 0.77);
    color: #000000;
}

.contrast-col.after .contrast-item {
    background: rgba(0, 6, 22, 0.8);
    color: #ffffff;
}

.contrast-item:hover {
    transform: translateX(4px);
}

.contrast-icon {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
}

.contrast-icon.red {
    color: #FF5050;
}

.contrast-icon.blue {
    color: #003DE1;
}


/* ══════════════════════════════════════════════════════════════
   SECTION 7: AUTORIDADE / INSTITUCIONAL
   ══════════════════════════════════════════════════════════════ */
.authority {
    position: relative;
    padding: 120px 0;
    background-color: #02050E;
    background-image:
        radial-gradient(circle at 85% 50%, rgba(0, 61, 225, 0.16) 0%, transparent 65%),
        radial-gradient(ellipse at 50% 120%, rgba(74, 115, 255, 0.08) 0%, transparent 60%),
        linear-gradient(90deg, #010205 0%, transparent 45%);
    overflow: hidden;
}

.authority-inner {
    position: relative;
    z-index: 2;
}

.authority-grid {
    display: grid;
    grid-template-columns: 0.8fr 1.2fr;
    gap: 80px;
    align-items: center;
}

.authority-image-box {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
}

.authority-img {
    width: 100%;
    max-width: 440px;
    border-radius: 20px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.8);
    border: 1px solid rgba(255, 255, 255, 0.08);
    object-fit: cover;
}

.authority-content {
    max-width: 100%;
}

.authority-label {
    display: inline-block;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 13px;
    font-weight: 600;
    color: #FFFFFF;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-bottom: 20px;
    background: rgba(255, 255, 255, 0.08);
    /* Cinza translúcido premium */
    border: 1px solid rgba(255, 255, 255, 0.25);
    padding: 6px 14px;
    border-radius: 6px;
}

.title-block-center {
    display: block;
    text-align: center;
}

.authority-content .section-title-white {
    margin-bottom: 32px;
}

.authority-text {
    font-size: 16px;
    color: #B9B9B9;
    line-height: 1.5;
    margin-bottom: 20px;
    font-family: 'Inter', sans-serif;
}

.authority-text:last-child {
    margin-bottom: 0;
}


/* ══════════════════════════════════════════════════════════════
   SECTION 8: CTA FINAL
   ══════════════════════════════════════════════════════════════ */
.final-cta {
    padding: 100px 0;
    position: relative;
    background-color: #01040A;
    background-image: url("section3.png");
    background-size: cover;
    background-position: center bottom;
    background-repeat: no-repeat;
    overflow: hidden;
}

.final-cta-box {
    position: relative;
    z-index: 2;
    text-align: center;
    max-width: 680px;
    margin: 0 auto;
    background: rgba(8, 14, 33, 0.7);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(94, 94, 94, 0.76);
    border-radius: 20px;
    padding: 70px 50px;
    box-shadow: 0 40px 80px -20px rgba(0, 0, 0, 0.8);
}

.final-cta-box .section-title {
    margin-bottom: 16px;
}

.final-cta-box .section-sub {
    margin: 0 auto 40px;
    max-width: 500px;
}

.final-cta-action {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

/* ══════════════════════════════════════════════════════════════
   DIVISORES DE FORMA (SHAPE DIVIDER) E ANIMACOES
   ══════════════════════════════════════════════════════════════ */
.shape-divider-bottom {
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
    z-index: 2;
    pointer-events: none;
}

.drop-shape {
    display: block;
    width: calc(100% + 1.3px);
    height: 60px;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
}

.drop-icon {
    position: absolute;
    bottom: 22px;
    left: 50%;
    margin-left: -10px;
    width: 20px;
    height: 20px;
    z-index: 3;
    animation: bounceDownDivider 2.5s infinite ease-in-out;
}

@media (max-width: 767px) {
    .drop-shape {
        height: 40px;
    }

    .drop-icon {
        bottom: 12px;
        width: 16px;
        height: 16px;
        margin-left: -8px;
    }
}

@keyframes bounceDownDivider {

    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(4px);
    }
}


/* ══════════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════════ */
.footer {
    padding: 20px 0;
    background: #181818;
    text-align: center;
}

.footer-text {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 14px;
    font-weight: 400;
    color: #8C8C8C;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 6px;
}

.footer-link {
    color: #8C8C8C;
    text-decoration: none;
    transition: color 0.2s ease;
}

.footer-link:hover {
    color: #fff;
}

.footer-divider {
    color: #555;
    margin: 0 4px;
}

/* ══════════════════════════════════════════════════════════════
   LEGAL PAGES & CONSENTIMIENTO
   ══════════════════════════════════════════════════════════════ */
.legal-wrapper {
    background-color: #0a0a0a;
    background-image: radial-gradient(circle at top center, rgba(0, 61, 225, 0.12) 0%, transparent 60%);
    min-height: 100vh;
    padding-bottom: 60px;
}

.legal-header {
    text-align: center;
    padding: 60px 20px 40px;
}

.legal-header img,
.legal-logo {
    height: auto !important;
    width: 220px !important;
    max-width: 100%;
    transition: opacity 0.3s ease;
}

.legal-header img:hover,
.legal-logo:hover {
    opacity: 0.8;
}

.legal-page {
    max-width: 800px;
    margin: 0 auto;
    padding: 0 20px;
}

.legal-title {
    font-size: 42px;
    font-weight: 700;
    margin-bottom: 12px;
    color: #ffffff;
    text-align: center;
    font-family: 'Bricolage Grotesque', sans-serif;
    line-height: 1.2;
}

.legal-subtitle {
    font-size: 15px;
    color: #6a6a6a;
    margin-bottom: 48px;
    text-align: center;
    font-weight: 500;
    letter-spacing: 0.5px;
}

.legal-content {
    background: #02081f; 
    padding: 50px 60px;
    border-radius: 16px;
    border: 1px solid rgba(0, 61, 225, 0.25);
    box-shadow: 0 24px 48px rgba(0, 0, 0, 0.4);
}

.legal-content p {
    font-size: 16px;
    line-height: 1.8;
    color: #B2B2B2;
    margin-bottom: 24px;
}

.legal-content h3 {
    font-size: 22px;
    color: #ffffff;
    margin-top: 48px;
    margin-bottom: 20px;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 600;
}

.legal-content h3:first-of-type {
    margin-top: 36px;
}

.legal-content ul {
    margin-bottom: 24px;
    padding-left: 20px;
    color: #B2B2B2;
}

.legal-content li {
    margin-bottom: 12px;
    line-height: 1.6;
}

.legal-content a {
    color: #003DE1;
    text-decoration: none;
    transition: color 0.2s ease;
}

.legal-content a:hover {
    color: #3b6cfa;
    text-decoration: underline;
}

.form-consent {
    font-size: 12px;
    color: #707070;
    text-align: center;
    margin-top: 20px;
    line-height: 1.5;
    max-width: 450px;
    margin-left: auto;
    margin-right: auto;
}

.form-consent a {
    color: #909090;
    text-decoration: underline;
    text-decoration-color: rgba(255, 255, 255, 0.2);
    text-underline-offset: 3px;
    transition: all 0.2s ease;
}

.form-consent a:hover {
    color: #fff;
    text-decoration-color: rgba(255, 255, 255, 0.8);
}

@media (max-width: 768px) {
    .footer-text {
        flex-direction: column;
        gap: 16px;
    }
    .footer-divider-main {
        display: none;
    }
    .footer-links {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        gap: 0;
    }
    .legal-content {
        padding: 32px 24px;
    }
    .legal-title {
        font-size: 32px;
    }
    .legal-header {
        padding: 40px 20px 30px;
    }
}


/* ══════════════════════════════════════════════════════════════
   ANIMATIONS
   ══════════════════════════════════════════════════════════════ */
.fade-up {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.7s ease-out, transform 0.7s ease-out;
}

.fade-up.visible {
    opacity: 1;
    transform: translateY(0);
}


/* ══════════════════════════════════════════════════════════════
   RESPONSIVE — Mobile
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 767px) {
    .hero {
        min-height: 850px;
        /* Garante espaço base na vertical */
        flex-direction: column;
        overflow: visible;
        background-color: #050813;
    }

    .hero-bg-img {
        object-position: top center;
        /* Crava o personagem incondicionalmente no topo do celular */
    }

    .hero-overlay {
        /* Ajuste do degrade se precisar ler melhor o texto, mas normalmente a arte já entrega */
        background: linear-gradient(180deg, rgba(6, 10, 24, 0) 0%, rgba(6, 10, 24, 0.4) 50%, rgba(6, 10, 24, 0.9) 100%);
    }

    .hero-inner {
        display: flex;
        flex-direction: column;
        justify-content: flex-start;
        /* Fixa o texto a partir do topo */
        padding-top: 420px;
        /* Exatamente onde terminava o recorte antigo, joga o texto pra debaixo do personagem de forma segura e não dependente do Vh */
        padding-bottom: 60px;
        /* Respiro pro fundo */
        padding-left: 20px;
        padding-right: 20px;
        margin-top: 0;
    }

    .hero-content {
        padding: 0;
        max-width: 100%;
        text-align: center;
    }

    .hero-logo {
        max-width: 255px;
        height: auto;
        margin: 0 auto 16px auto;
        display: block;
        transform: none;
        /* Invalida o compensador X do desktop para não quebrar a simetria centralizada */
    }

    .hero-title {
        font-size: 26px;
        margin: 0 auto 16px auto;
        line-height: 1.1em;
        max-width: 345px;
    }

    .hero-title br {
        display: none;
    }

    .hero-sub {
        font-size: 14px;
        line-height: 1.3em;
        margin: 0 auto 24px auto;
        max-width: 100%;
    }

    .hero-sub br {
        display: none;
    }

    .hero-content .hero-cta {
        display: flex;
        justify-content: center;
        margin-top: 8px;
        width: 100%;
    }

    .hero-cta .btn-main {
        width: 100%;
        max-width: 357px;
        height: 57px;
        padding: 0 20px;
        border-radius: 7px;
    }

    .hero-badge {
        display: inline-flex;
        flex-direction: row;
        flex-wrap: nowrap;
        justify-content: center;
        align-items: flex-start;
        gap: 8px;
        margin-top: 16px;
        margin-bottom: 16px;
        text-align: center;
        width: 100%;
    }

    .hero-badge .badge-icon {
        flex-shrink: 0;
        margin-top: 2px;
    }

    .hero-badge .badge-label {
        text-align: center;
    }

    .hero-visual {
        display: none;
    }

    .hero-title {
        font-size: 26px;
        line-height: 1.1;
    }

    .hero-sub {
        font-size: 15px;
    }

    .proof {
        padding: 60px 0;
    }

    .pain {
        padding: 60px 0;
    }

    .mechanism {
        padding: 60px 0;
    }

    .bonus {
        padding: 60px 0;
    }

    .contrast {
        padding: 60px 0;
    }

    .authority {
        padding: 60px 20px;
    }

    .final-cta {
        padding: 60px 0;
    }

    .proof-grid,
    .pain-grid,
    .mechanism-grid,
    .bonus-grid,
    .contrast-grid,
    .authority-grid {
        grid-template-columns: 1fr;
    }

    .mech-card {
        border-radius: 20px;
        padding: 24px;
    }

    .mech-card-title {
        font-size: 22px;
    }

    .mech-card-desc {
        font-size: 15px;
    }

    .final-cta-box {
        padding: 40px 20px;
        border-radius: 15px;
    }

    .btn-main {
        width: 100%;
        text-align: center;
    }

    .btn-large {
        padding: 18px 20px;
        font-size: 15px;
    }

    .contrast-col {
        padding: 24px 16px 32px;
    }

    .contrast-label {
        font-size: 25px;
    }

    .authority-content {
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        margin-top: -40px;
    }

    .authority-label {
        font-size: 10px;
        padding: 6px 12px;
        letter-spacing: 0.5px;
        margin-bottom: 20px;
        white-space: normal;
        /* Allow wrap if device is ultra small, but otherwise keeps it tight */
    }

    .authority-content .section-title-white {
        text-align: center;
        font-size: 26px;
        /* Ensuring great hierarchy on mobile */
    }

    .authority-text {
        text-align: center;
    }

    .contrast-item {
        padding: 12px 14px;
        font-size: 14px;
        gap: 12px;
    }

    .mechanism-cta .btn-main {
        padding: 18px 20px;
    }

    .section-title,
    .section-title-white {
        font-size: 25px;
    }

    .bonus-card-title {
        font-size: 20px;
    }
}

/* Tablet */
@media (min-width: 768px) and (max-width: 1024px) {
    .hero {
        padding: 100px 20px 80px;
    }

    .proof-grid,
    .pain-grid,
    .mechanism-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .bonus-grid,
    .contrast-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .authority-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }
}