/* ==========================================================================
   ponto.me · Landing Page
   Tokens herdados do Design System v1.0
   ========================================================================== */
:root{
  --c-blue:#3D93EA; --c-indigo:#6A69B0; --c-violet:#735CB6; --c-magenta:#B559A2; --c-lavender:#DCDFEE;
  --indigo-50:#F0F0F8; --indigo-100:#DCDBEE; --indigo-200:#BCBADD; --indigo-300:#9B99CB; --indigo-400:#8281BE;
  --indigo-500:#6A69B0; --indigo-600:#565595; --indigo-700:#444376; --indigo-800:#333258; --indigo-900:#22213B;
  --magenta-50:#FAEFF7; --magenta-100:#F1D4E9; --magenta-200:#E2A9D3; --magenta-300:#D27EBC; --magenta-400:#C46BAF;
  --magenta-500:#B559A2; --magenta-600:#964886; --magenta-700:#743768; --magenta-800:#52274A; --magenta-900:#31172C;
  --ink:#15141C; --ink-soft:#3A3947; --gray-700:#555461; --gray-500:#87868F; --gray-300:#C9C8D2;
  --gray-200:#E6E5EE; --gray-100:#F2F1F8; --gray-50:#FAFAFD; --white:#FFFFFF;
  --success:#2FB67C; --warning:#E8A53D; --error:#E0517A; --info:var(--c-blue);
  --gradient-brand:linear-gradient(90deg,var(--c-blue) 0%,var(--c-indigo) 35%,var(--c-magenta) 70%,var(--c-lavender) 100%);
  --gradient-soft:linear-gradient(135deg,var(--indigo-500) 0%,var(--c-magenta) 100%);
  --font-display:'Poppins',system-ui,sans-serif; --font-body:'Inter',system-ui,sans-serif;
  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:32px; --r-pill:999px;
  --sh-sm:0 1px 2px rgba(21,20,28,.06),0 1px 3px rgba(21,20,28,.08);
  --sh-md:0 4px 12px rgba(21,20,28,.08),0 2px 4px rgba(21,20,28,.06);
  --sh-lg:0 12px 32px rgba(34,33,59,.12),0 4px 8px rgba(34,33,59,.06);
  --sh-brand:0 12px 28px rgba(106,105,176,.32);
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px; --s-6:32px; --s-7:48px; --s-8:64px; --s-9:96px;
  --maxw:1180px;
}

/* — Base — */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:clip}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.18;letter-spacing:-.01em}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--s-5)}
.section{padding:var(--s-9) 0}
@media(max-width:760px){.section{padding:var(--s-8) 0}}

/* — Eyebrow / kicker — */
.kicker{font-family:var(--font-display);font-size:.74rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--c-magenta);margin-bottom:var(--s-3)}
.kicker.on-dark{color:var(--magenta-300)}

/* — Botões — */
.btn{font-family:var(--font-display);font-weight:600;font-size:1rem;border:none;border-radius:var(--r-pill);
  padding:16px 32px;cursor:pointer;display:inline-flex;align-items:center;gap:10px;transition:.18s;line-height:1;text-align:center}
.btn-gradient{background:var(--gradient-soft);color:#fff;box-shadow:var(--sh-brand)}
.btn-gradient:hover{filter:brightness(1.06);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--indigo-700)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--sh-lg)}
.btn-lg{padding:18px 40px;font-size:1.08rem}
.btn .arrow{transition:.18s}
.btn:hover .arrow{transform:translateX(4px)}

/* — Microcopy pill — */
.micro{display:inline-flex;align-items:center;gap:8px;font-size:.85rem;color:var(--gray-700);background:rgba(255,255,255,.08);border:1px solid var(--gray-200);border-radius:var(--r-pill);padding:8px 16px}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{position:relative;background:var(--indigo-900);color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:right center;z-index:0;
  background-image:url('../opt/hero-desk.jpg');
  background-image:image-set(url('../opt/hero-desk.webp') type('image/webp'), url('../opt/hero-desk.jpg') type('image/jpeg'))}
.hero-overlay{position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,rgba(20,16,48,.92) 0%,rgba(28,20,70,.78) 38%,rgba(34,24,90,.35) 62%,rgba(34,24,90,0) 80%)}
.hero .wrap{position:relative;z-index:2}
.hero-inner{max-width:620px;padding:var(--s-9) 0}
.hero-logo{height:38px;width:auto;margin-bottom:var(--s-6);filter:drop-shadow(0 4px 12px rgba(0,0,0,.25))}
.hero h1{font-size:3.1rem;font-weight:800;color:#fff;margin-bottom:var(--s-5);text-wrap:balance}
.hero h1 .hl{background:linear-gradient(90deg,#fff,var(--magenta-200));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p.lead{font-size:1.18rem;color:rgba(255,255,255,.9);margin-bottom:var(--s-6);max-width:54ch}
.hero .cta-row{display:flex;align-items:center;gap:var(--s-5);flex-wrap:wrap;margin-bottom:var(--s-5)}
.hero .micro{color:rgba(255,255,255,.82);background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18)}
@media(max-width:980px){
  .hero h1{font-size:2.2rem}
  /* troca para o BG vertical (pessoa centralizada embaixo, topo livre p/ texto) */
  .hero-bg{background-position:center bottom;background-size:cover;
    background-image:url('../opt/hero-mob.jpg');
    background-image:image-set(url('../opt/hero-mob.webp') type('image/webp'), url('../opt/hero-mob.jpg') type('image/jpeg'))}
  .hero-overlay{background:linear-gradient(180deg,rgba(20,16,48,.92) 0%,rgba(20,16,48,.7) 28%,rgba(20,16,48,.15) 48%,rgba(20,16,48,0) 62%)}
  .hero-inner{max-width:100%;padding-top:var(--s-8);padding-bottom:74vh}
}
@media(max-width:600px){
  .hero h1{font-size:1.9rem}
  .hero p.lead{font-size:1.05rem}
  .hero-inner{padding-bottom:86vh}
}

/* ==========================================================================
   TÍTULOS DE SEÇÃO
   ========================================================================== */
.sec-title{font-size:2.3rem;font-weight:700;color:var(--ink);text-wrap:balance;margin-bottom:var(--s-4)}
.sec-title.sm{font-size:1.9rem}
.sec-sub{font-size:1.1rem;color:var(--gray-700);max-width:62ch}
.center{text-align:center;margin-left:auto;margin-right:auto}
.center .sec-sub{margin-left:auto;margin-right:auto}
@media(max-width:760px){.sec-title{font-size:1.8rem}}

/* ==========================================================================
   PLACEHOLDERS DE IMAGEM  (trocar o src quando a imagem for gerada)
   ========================================================================== */
.ph{position:relative;width:100%;aspect-ratio:var(--ar,16/9);border-radius:var(--r-lg);overflow:hidden;
  background:var(--gray-100);box-shadow:var(--sh-md)}
.ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 35%;z-index:2}
.ph picture{position:absolute;inset:0;z-index:2}
.ph figcaption{position:relative;z-index:1;font-family:var(--font-display);font-weight:600;font-size:.9rem;
  color:var(--indigo-500);text-align:center;padding:var(--s-4);line-height:1.5}
.ph figcaption .tag{display:block;margin-top:6px;font-size:.74rem;color:var(--indigo-400);font-weight:500;letter-spacing:.02em}
.ph figcaption .ico{display:block;margin:0 auto var(--s-2);opacity:.6}

/* Bloco texto + imagem lado a lado.
   align-items:stretch faz as duas colunas terem a MESMA altura; a imagem
   preenche essa altura (sem vãos) e o texto fica centralizado dentro dela. */
.media-split{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-7);align-items:start;margin:var(--s-7) 0}
.media-split>div{min-width:0}
.media-split .ph{aspect-ratio:4/5}     /* retângulo vertical real (4:5), sem cortar */
.media-split.rev .ph{order:-1}
/* grade de custos em 2 colunas (quando dentro do split) */
.cost-grid.cg-2{grid-template-columns:1fr 1fr;margin:var(--s-4) 0 0}
/* lista de diferenciais na vertical (ícone à esquerda + rótulo) */
.diff-list.vert{grid-template-columns:1fr;gap:var(--s-3);margin:var(--s-3) 0 var(--s-5)}
.diff-list.vert li{display:flex;flex-direction:row;align-items:center;text-align:left;gap:var(--s-4);padding:var(--s-3) var(--s-4)}
.diff-list.vert li .ic{margin:0;flex-shrink:0;width:38px;height:38px}
@media(max-width:860px){
  .media-split{grid-template-columns:1fr;gap:var(--s-5)}
  .media-split .ph{aspect-ratio:4/5}
  .media-split.rev .ph{order:0}
  .cost-grid.cg-2{grid-template-columns:1fr 1fr}
}

/* ==========================================================================
   SEÇÃO 02 — PROBLEMA
   ========================================================================== */
.alt{background:var(--gray-50)}
.lead-text{font-size:1.12rem;color:var(--ink-soft);max-width:64ch;margin-bottom:var(--s-4)}
.cost-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-4);margin:var(--s-6) 0}
.cost-card{background:var(--white);border:1px solid var(--gray-200);border-left:4px solid var(--c-magenta);border-radius:var(--r-md);padding:var(--s-4) var(--s-5);font-family:var(--font-display);font-weight:600;color:var(--ink);box-shadow:var(--sh-sm)}
@media(max-width:760px){.cost-grid{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.cost-grid{grid-template-columns:1fr}}

.check-list{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-3) var(--s-5);margin:var(--s-5) 0}
.check-list li{list-style:none;display:flex;gap:12px;align-items:flex-start;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-md);padding:var(--s-4);box-shadow:var(--sh-sm)}
.check-list li .mk{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--indigo-50);color:var(--indigo-600);display:grid;place-items:center;margin-top:2px}
.check-list li span{color:var(--ink-soft);font-size:.98rem}
@media(max-width:760px){.check-list{grid-template-columns:1fr}}

.closer{margin-top:var(--s-6);padding:var(--s-6);background:var(--gradient-soft);border-radius:var(--r-lg);color:#fff;box-shadow:var(--sh-brand)}
.closer p{font-size:1.2rem;font-family:var(--font-display);font-weight:500}
.closer p+p{margin-top:var(--s-2);font-weight:700;font-size:1.35rem}

/* ==========================================================================
   SEÇÃO 03 — CENÁRIO (stats, fundo escuro)
   ========================================================================== */
.dark{background:var(--indigo-900);color:#fff;position:relative;overflow:hidden}
.dark::before{content:"";position:absolute;top:-20%;right:-10%;width:480px;height:480px;border-radius:50%;
  background:radial-gradient(circle,rgba(181,89,162,.45),transparent 70%);filter:blur(40px)}
.dark::after{content:"";position:absolute;bottom:-25%;left:-10%;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(61,147,234,.4),transparent 70%);filter:blur(40px)}
.dark .wrap{position:relative;z-index:2}
.dark .sec-title{color:#fff}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-5);margin:var(--s-7) 0 var(--s-5)}
.stat .num{font-family:var(--font-display);font-weight:800;font-size:3rem;line-height:1;
  background:linear-gradient(90deg,var(--magenta-200),#fff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat .lbl{margin-top:10px;color:rgba(255,255,255,.82);font-size:.98rem}
.stat .lbl em{display:block;color:var(--magenta-200);font-style:normal;font-size:.85rem;margin-top:4px}
@media(max-width:760px){.stats{grid-template-columns:1fr 1fr;gap:var(--s-5) var(--s-4)}.stat .num{font-size:2.3rem}}
@media(max-width:480px){.stats{grid-template-columns:1fr}.stat .num{font-size:2.6rem}}
.sources{font-size:.84rem;color:rgba(255,255,255,.6);letter-spacing:.02em}
.law-box{margin-top:var(--s-6);padding:var(--s-5) var(--s-6);border-left:4px solid var(--magenta-400);background:rgba(255,255,255,.05);border-radius:var(--r-md)}
.law-box .tag{font-family:var(--font-display);font-weight:700;color:var(--magenta-200);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}
.law-box p{color:rgba(255,255,255,.92);font-size:1.05rem}
.law-box p+p{margin-top:var(--s-3)}

/* ==========================================================================
   SEÇÃO 04 — POSICIONAMENTO
   ========================================================================== */
.versus{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-5);margin:var(--s-6) 0}
.vs-card{border-radius:var(--r-lg);padding:var(--s-6);border:1px solid var(--gray-200);background:var(--white);box-shadow:var(--sh-sm)}
.vs-card.bad{background:var(--gray-50)}
.vs-card .lbl{font-family:var(--font-display);font-weight:700;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--s-3)}
.vs-card.bad .lbl{color:var(--gray-500)}
.vs-card.good .lbl{color:var(--c-magenta)}
.vs-card p{color:var(--ink-soft)}
@media(max-width:760px){.versus{grid-template-columns:1fr}}
.diff-list{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--s-3);margin:var(--s-5) 0}
.diff-list li{list-style:none;text-align:center;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-md);padding:var(--s-5) var(--s-3);font-family:var(--font-display);font-weight:600;font-size:.92rem;box-shadow:var(--sh-sm)}
.diff-list li .ic{width:40px;height:40px;margin:0 auto var(--s-3);border-radius:12px;background:var(--gradient-soft);color:#fff;display:grid;place-items:center}
@media(max-width:760px){.diff-list{grid-template-columns:1fr 1fr}}

/* ==========================================================================
   SEÇÃO 05 — SOLUÇÃO
   ========================================================================== */
.sol-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5);margin-top:var(--s-7)}
.sol-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-lg);padding:var(--s-6);box-shadow:var(--sh-md);transition:.2s}
.sol-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.sol-card .ic{width:52px;height:52px;border-radius:16px;background:var(--gradient-soft);color:#fff;display:grid;place-items:center;margin-bottom:var(--s-4)}
.sol-card h3{font-size:1.2rem;margin-bottom:var(--s-3)}
.sol-card p{color:var(--gray-700);font-size:.96rem}
.sol-card ul{margin:var(--s-2) 0 0;padding:0}
.sol-card ul li{list-style:none;display:flex;gap:8px;align-items:center;color:var(--ink-soft);font-size:.95rem;padding:4px 0}
.sol-card ul li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--c-magenta);flex-shrink:0}
@media(max-width:880px){.sol-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.sol-grid{grid-template-columns:1fr}}

/* ==========================================================================
   SEÇÃO 06 — COMO FUNCIONA
   ========================================================================== */
.phases{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-5);margin-top:var(--s-7)}
.phase{border-radius:var(--r-xl);padding:var(--s-7);position:relative;overflow:hidden}
.phase.p1{background:var(--gray-50);border:1px solid var(--gray-200)}
.phase.p2{background:var(--gradient-soft);color:#fff;box-shadow:var(--sh-brand)}
.phase .pnum{font-family:var(--font-display);font-weight:800;font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;opacity:.7;margin-bottom:var(--s-2)}
.phase h3{font-size:1.45rem;margin-bottom:var(--s-5)}
.phase.p1 h3{color:var(--ink)}
.step-list{padding:0;margin:0}
.step-list li{list-style:none;display:flex;gap:12px;align-items:flex-start;padding:7px 0;font-size:.98rem}
.step-list li .n{flex-shrink:0;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:.74rem}
.phase.p1 .step-list li .n{background:var(--indigo-100);color:var(--indigo-700)}
.phase.p2 .step-list li .n{background:rgba(255,255,255,.22);color:#fff}
.phase .endcap{margin-top:var(--s-5);padding-top:var(--s-5);border-top:1px dashed}
.phase.p1 .endcap{border-color:var(--gray-300)}
.phase.p2 .endcap{border-color:rgba(255,255,255,.35)}
.phase .endcap .t{font-family:var(--font-display);font-weight:700;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:var(--s-3);opacity:.85}
.tag-row{display:flex;flex-wrap:wrap;gap:8px}
.tag-row .t-pill{font-family:var(--font-display);font-weight:600;font-size:.85rem;padding:7px 14px;border-radius:var(--r-pill)}
.phase.p1 .t-pill{background:var(--indigo-500);color:#fff}
.phase.p2 .t-pill{background:#fff;color:var(--indigo-700)}
@media(max-width:880px){.phases{grid-template-columns:1fr}}

/* ==========================================================================
   SEÇÃO 07 — INVESTIMENTO
   ========================================================================== */
.inv-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-5);margin-top:var(--s-6)}
.inv-col h4{font-family:var(--font-display);font-size:1.05rem;margin-bottom:var(--s-4);display:flex;align-items:center;gap:10px}
.inv-col.loss h4{color:var(--error)}
.inv-col.gain h4{color:var(--success)}
.inv-col ul{padding:0;margin:0}
.inv-col ul li{list-style:none;display:flex;gap:10px;align-items:center;padding:9px 0;border-bottom:1px solid var(--gray-200);color:var(--ink-soft)}
.inv-col ul li:last-child{border-bottom:0}
.board{margin-top:var(--s-6);background:var(--indigo-900);color:#fff;border-radius:var(--r-lg);padding:var(--s-7)}
.board .tag{font-family:var(--font-display);font-weight:700;color:var(--magenta-200);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:var(--s-4)}
.board ul{padding:0;margin:0}
.board ul li{list-style:none;position:relative;padding:8px 0 8px 24px;color:rgba(255,255,255,.9)}
.board ul li::before{content:"→";position:absolute;left:0;top:8px;color:var(--magenta-300);font-weight:700}
.board strong{color:#fff}
@media(max-width:760px){.inv-grid{grid-template-columns:1fr}}

/* ==========================================================================
   SEÇÃO 08 — FILTRO DE PERFIL
   ========================================================================== */
.fit{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-5);margin-top:var(--s-6)}
.fit-card{border-radius:var(--r-lg);padding:var(--s-6);border:1px solid var(--gray-200);box-shadow:var(--sh-sm)}
.fit-card.yes{background:linear-gradient(180deg,var(--indigo-50),#fff)}
.fit-card.no{background:var(--gray-50)}
.fit-card h3{font-size:1.3rem;margin-bottom:var(--s-4);display:flex;align-items:center;gap:10px}
.fit-card.yes h3{color:var(--indigo-700)}
.fit-card.no h3{color:var(--gray-700)}
.fit-card ul{padding:0;margin:0}
.fit-card ul li{list-style:none;display:flex;gap:12px;align-items:flex-start;padding:9px 0;color:var(--ink-soft)}
.fit-card ul li .mk{flex-shrink:0;margin-top:3px}
.fit-card.yes li .mk{color:var(--success)}
.fit-card.no li .mk{color:var(--gray-400,#9b9aa3)}
@media(max-width:760px){.fit{grid-template-columns:1fr}}

/* ==========================================================================
   SEÇÃO 09 — AUTORIDADE
   ========================================================================== */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5);margin:var(--s-7) 0}
.member{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-lg);padding:var(--s-6);box-shadow:var(--sh-sm);text-align:center}
.member .photo{width:120px;height:120px;border-radius:50%;margin:0 auto var(--s-4);position:relative;overflow:hidden;
  border:3px solid var(--white);box-shadow:var(--sh-md);background:var(--indigo-50);display:grid;place-items:center}
.member .photo>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2}
.member .photo span{font-family:var(--font-display);font-weight:700;color:var(--indigo-300);font-size:1.6rem;z-index:1}
.member h3{font-size:1.2rem;margin-bottom:8px}
.member p{color:var(--gray-700);font-size:.94rem}
@media(max-width:760px){.team{grid-template-columns:1fr}}
.together{text-align:center;max-width:680px;margin:0 auto}
.together .reps{display:flex;justify-content:center;gap:var(--s-3);flex-wrap:wrap;margin-top:var(--s-5)}
.together .reps span{font-family:var(--font-display);font-weight:600;font-size:.92rem;padding:9px 18px;border-radius:var(--r-pill);background:var(--indigo-50);color:var(--indigo-700)}

/* ==========================================================================
   SEÇÃO 10 — FAQ
   ========================================================================== */
.faq{max-width:820px;margin:var(--s-7) auto 0}
.faq details{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-md);margin-bottom:var(--s-3);box-shadow:var(--sh-sm);overflow:hidden}
.faq details[open]{border-color:var(--indigo-300)}
.faq summary{cursor:pointer;list-style:none;padding:var(--s-5);font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:var(--s-4)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .ic{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--indigo-50);color:var(--indigo-600);display:grid;place-items:center;transition:.2s}
.faq details[open] summary .ic{background:var(--gradient-soft);color:#fff;transform:rotate(45deg)}
.faq .ans{padding:0 var(--s-5) var(--s-5);color:var(--ink-soft)}

/* ==========================================================================
   SEÇÃO 11 — CTA FINAL + FORM
   ========================================================================== */
.cta-final{background:var(--gradient-brand);color:#fff;position:relative;overflow:hidden}
.cta-final .grid2{display:grid;grid-template-columns:1.05fr .95fr;gap:var(--s-8);align-items:center}
.cta-final h2{font-size:2.5rem;color:#fff;font-weight:800;margin-bottom:var(--s-4);text-wrap:balance}
.cta-final p{color:rgba(255,255,255,.92);font-size:1.08rem;margin-bottom:var(--s-3);max-width:50ch}
.cta-final .nocost{display:flex;gap:var(--s-4);margin:var(--s-5) 0;flex-wrap:wrap}
.cta-final .nocost span{font-family:var(--font-display);font-weight:600}
.cta-final .micro{color:rgba(255,255,255,.9);background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.25);margin-top:var(--s-5)}
@media(max-width:880px){.cta-final .grid2{grid-template-columns:1fr;gap:var(--s-6)}.cta-final h2{font-size:2rem}}

.form-card{background:#fff;border-radius:var(--r-xl);padding:var(--s-7);box-shadow:var(--sh-lg);color:var(--ink)}
.form-card h3{font-size:1.25rem;margin-bottom:var(--s-5);color:var(--ink)}
.field{margin-bottom:var(--s-4)}
.field label{display:block;font-family:var(--font-display);font-weight:500;font-size:.85rem;margin-bottom:6px;color:var(--ink-soft)}
.field input,.field select{width:100%;font-family:var(--font-body);font-size:.95rem;color:var(--ink);padding:13px 14px;border:1.5px solid var(--gray-300);border-radius:var(--r-md);background:#fff;transition:.15s}
.field input:focus,.field select:focus{outline:none;border-color:var(--indigo-500);box-shadow:0 0 0 4px var(--indigo-50)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-4)}
@media(max-width:480px){.field-row{grid-template-columns:1fr}}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.footer{background:var(--ink);color:rgba(255,255,255,.72);padding:var(--s-8) 0}
.footer .wrap{display:flex;flex-direction:column;gap:var(--s-4);align-items:flex-start}
.footer img{height:30px;width:auto}
.footer h4{color:#fff;font-size:1.05rem;font-weight:600}
.footer .lines p{font-size:.95rem}
.footer .site{font-family:var(--font-display);font-weight:600;color:var(--magenta-300);letter-spacing:.02em}
.footer .legal{margin-top:var(--s-5);padding-top:var(--s-5);border-top:1px solid rgba(255,255,255,.12);width:100%;font-size:.82rem;color:rgba(255,255,255,.5)}

/* ==========================================================================
   ANIMAÇÕES  (somente opacity/transform · respeita prefers-reduced-motion)
   ========================================================================== */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
@keyframes bgShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

@media (prefers-reduced-motion: no-preference){
  /* Entrada da hero ao carregar (cascata) */
  .hero-logo,.hero .kicker,.hero h1,.hero .lead,.hero .cta-row,.hero .micro{
    animation:fadeUp .7s cubic-bezier(.22,1,.36,1) both}
  .hero-logo{animation-delay:.05s}
  .hero .kicker{animation-delay:.15s}
  .hero h1{animation-delay:.24s}
  .hero .lead{animation-delay:.36s}
  .hero .cta-row{animation-delay:.48s}
  .hero .micro{animation-delay:.58s}

  /* Reveal ao rolar (classe .reveal adicionada via JS) */
  .reveal{opacity:0;transform:translateY(28px);will-change:opacity,transform;
    transition:opacity .6s ease,transform .7s cubic-bezier(.22,1,.36,1)}
  .reveal.in{opacity:1;transform:none}

  /* Brilho deslizante nos botões em gradiente */
  .btn-gradient{position:relative;overflow:hidden;isolation:isolate}
  .btn-gradient::after{content:"";position:absolute;inset:0 auto 0 -130%;width:55%;z-index:-1;
    background:linear-gradient(100deg,transparent,rgba(255,255,255,.4),transparent);
    transform:skewX(-18deg);transition:left .55s ease}
  .btn-gradient:hover::after{left:150%}

  /* Gradiente em movimento suave nos blocos de destaque */
  .cta-final,.closer{background-size:200% 200%;animation:bgShift 16s ease-in-out infinite}

  /* Microinterações de ícones nos cards */
  .sol-card .ic,.feature-card .ico,.diff-list li .ic{transition:transform .3s cubic-bezier(.22,1,.36,1)}
  .sol-card:hover .ic,.feature-card:hover .ico,.diff-list li:hover .ic{transform:scale(1.08) rotate(-3deg)}

  /* Pulso sutil no microcopy da hero */
  .hero .micro{transition:transform .3s}
}
