/* ===========================================================================
   Greeta — Design System (Landing V2 + Apresentação Web V1)
   Dark premium, alinhado ao Sales Deck. Roxo apenas como destaque.
   Sem dependência de framework. Tokens + componentes.
   =========================================================================== */
:root{
  --bg:#0b0910; --surface:#15111e; --surface-2:#1d1729; --surface-3:#241c33;
  --border:rgba(168,85,247,.14); --border-strong:rgba(168,85,247,.30);
  --text:#f3eefb; --text-dim:#a89cbd; --text-faint:#847a96; /* AA ≥4.5:1 sobre --bg (a11y) */
  --brand:#8405bc;            /* Greeta Purple — destaque/CTA */
  --accent:#a855f7;           /* brilho do roxo sobre escuro */
  --accent-dim:rgba(168,85,247,.12);
  --green:#34d399; --amber:#fbbf24; --red:#f87171; --blue:#60a5fa;
  --maxw:1180px;
  --r-sm:10px; --r-md:14px; --r-lg:20px;
  --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --shadow:0 30px 70px -28px rgba(0,0,0,.6);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---------- layout ---------- */
.section{padding:clamp(64px,10vh,120px) clamp(20px,5vw,40px);position:relative;overflow:hidden}
.wrap{max-width:var(--maxw);margin:0 auto;width:100%}
.center{text-align:center}
.glow-tl{background-image:radial-gradient(ellipse at 18% 12%,rgba(132,5,188,.20),transparent 55%)}
.glow-c{background-image:radial-gradient(ellipse at 50% 20%,rgba(168,85,247,.16),transparent 55%)}
/* cabeçalho de seção: container centralizado sobre o conteúdo (cards/fluxo),
   título + subtítulo centralizados, leitura confortável (Sprint 09.1.1 —
   balanceamento visual de Operações e Problema) */
.sec-intro{max-width:940px;margin-inline:auto;text-align:center;line-height:1.6}
/* subtítulo do Ciclo: em uma única linha no desktop largo, responsivo abaixo */
.ciclo-lead{max-width:60ch}
@media(min-width:1280px){.ciclo-lead{max-width:none;white-space:nowrap}}

/* ---------- type ---------- */
.eyebrow{font-size:clamp(11px,1.3vw,13px);font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.h1{font-size:clamp(34px,6vw,62px);font-weight:800;letter-spacing:-2px;line-height:1.02;text-wrap:balance}
.h2{font-size:clamp(26px,4vw,46px);font-weight:800;letter-spacing:-1.2px;line-height:1.08;text-wrap:balance}
.h3{font-size:clamp(18px,2.2vw,24px);font-weight:700;letter-spacing:-.4px}
.lead{font-size:clamp(16px,2vw,22px);color:var(--text-dim);text-wrap:pretty}
.body{font-size:clamp(15px,1.6vw,18px);color:var(--text-dim);text-wrap:pretty}
.emph{color:var(--text);font-weight:600}
.mt-s{margin-top:14px}.mt-m{margin-top:24px}.mt-l{margin-top:40px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:15px;border-radius:var(--r-sm);padding:13px 22px;cursor:pointer;border:1px solid transparent;transition:transform .15s,filter .15s,border-color .15s}
.btn--primary{background:var(--brand);color:#fff;box-shadow:0 8px 26px -8px rgba(132,5,188,.7)}
.btn--primary:hover{transform:translateY(-2px);filter:brightness(1.08)}
.btn--ghost{background:transparent;color:var(--text);border-color:var(--border-strong)}
.btn--ghost:hover{border-color:var(--accent)}
/* acessibilidade: foco visível por teclado (não aparece em clique de mouse) */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.btn:focus-visible{outline-offset:3px}

/* ---------- header / sticky CTA ---------- */
.hdr{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;height:72px;padding:0 clamp(20px,5vw,40px);background:transparent;border-bottom:1px solid transparent;transition:background .25s ease,backdrop-filter .25s ease,border-color .25s ease}
.hdr.is-scrolled{background:color-mix(in srgb,var(--bg) 72%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom-color:var(--border)}
.hdr__logo{height:26px;width:auto}
/* wordmark vetorial transparente (sem caixa branca); cor clara para o tema escuro */
.hdr__brand{display:inline-flex;line-height:0}
.brand-logo{height:26px;width:auto;display:block;color:var(--text)}
.ftr .brand-logo{height:24px}
.hdr__nav{display:flex;gap:26px;font-size:14px;color:var(--text-dim)}
.hdr__nav a:hover{color:var(--text)}
@media(max-width:820px){.hdr__nav{display:none}}

/* ---------- chips / tags ---------- */
.tag{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);background:var(--accent-dim);border:1px solid var(--border-strong);padding:6px 12px;border-radius:999px}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.chip{font-size:13px;color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:8px 14px}

/* ---------- generic grid/cards ---------- */
.grid{display:grid;gap:clamp(14px,2vw,22px)}
.g-2{grid-template-columns:repeat(2,1fr)}.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}.g-5{grid-template-columns:repeat(5,1fr)}
@media(max-width:900px){.g-3,.g-4,.g-5{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.g-2,.g-3,.g-4,.g-5{grid-template-columns:1fr}}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:clamp(18px,2.5vw,26px)}
.card .ic{width:38px;height:38px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;background:var(--accent-dim);color:var(--accent);font-size:18px;margin-bottom:12px}

/* ---------- Plataforma Greeta® — grid de módulos (arquitetura visual) ----------
   Reusa .grid.g-4 (4x2 desktop · 2x4 tablet · 1col mobile) e .card/.ic do DS.
   Cards escuros, ícones lineares, muito espaço negativo — mesma linguagem de
   GEF®/Greeta Vision®/Greeta Analytics®. Sem gradiente/glassmorphism. */
.modgrid{text-align:left}
/* Sprint 09.1 — refinamento: +respiro (padding/gaps), borda suavizada, sombra, raio +2px */
.module{position:relative;display:flex;flex-direction:column;align-items:flex-start;
  padding:clamp(26px,2.8vw,34px);
  border-color:rgba(168,85,247,.11);
  border-radius:16px;
  box-shadow:0 8px 20px rgba(0,0,0,.15);
  transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease}
.module:hover{border-color:var(--border-strong);transform:translateY(-2px);box-shadow:0 14px 30px rgba(0,0,0,.22)}
.module .ic{margin-bottom:16px}            /* gap ícone→título 12 → 16 */
.module .ic svg{width:20px;height:20px}
.module__name{font-size:clamp(15px,1.5vw,17px);font-weight:700;letter-spacing:-.2px;color:var(--text)}
.module__desc{margin-top:12px;font-size:13.5px;line-height:1.55;color:var(--text-dim)}  /* gap título→desc 8 → 12 */
/* Pronto para links individuais por módulo (futuro), sem mudar a arquitetura:
   inserir <a class="module__link" href="/..."> dentro do .card. */
.module__link{position:absolute;inset:0;border-radius:inherit}

/* ---------- CTA final — fechamento institucional (texto + CTAs, sem cards/fundos) ----------
   Desktop: botões lado a lado, centralizados. Mobile: empilhados full-width
   (mesmo comportamento dos botões do Hero). */
.cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
@media(max-width:520px){
  .cta-actions{flex-direction:column;align-items:stretch}
  .cta-actions .btn{justify-content:center}
}

/* ---------- split ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,64px);align-items:center}
.split--rev{grid-template-columns:.95fr 1.05fr}
@media(max-width:900px){.split,.split--rev{grid-template-columns:1fr}}

/* ---------- score (reuso no slot ICR da seção Resultados, gated por flag) ---------- */
.cmp__score{font-size:28px;font-weight:800;color:#fff;line-height:1}
.cmp__score small{display:block;font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim);margin-top:4px}

/* ---------- ciclo (loop) ---------- */
.loop{display:flex;flex-wrap:wrap;align-items:stretch;gap:12px;margin-top:34px}
.loop__node{flex:1;min-width:160px;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-md);padding:18px}
.loop__node .n{font-size:11px;color:var(--accent);font-weight:700;letter-spacing:1px}
.loop__node .t{font-size:clamp(15px,1.7vw,19px);font-weight:800;margin:6px 0;letter-spacing:-.3px}
.loop__node .s{font-size:13px;color:var(--text-dim)}

/* ---------- accordion (FAQ — SSR, conteúdo sempre no DOM) ---------- */
.faq details{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);margin-bottom:12px;overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:18px 20px;display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary h3{font-size:clamp(15px,1.8vw,18px);font-weight:600}
.faq summary .pl{color:var(--accent);font-size:20px;flex:0 0 auto;transition:transform .2s}
.faq details[open] summary .pl{transform:rotate(45deg)}
.faq .ans{padding:0 20px 18px;color:var(--text-dim);font-size:15px}

/* ---------- seller card (apresentação) ---------- */
/* card agrupa foto+texto+CTA como uma unidade; largura limitada evita CTA orfa no desktop */
.seller{display:flex;align-items:center;gap:20px;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow);flex-wrap:wrap;max-width:680px}
/* avatar discreto: pequeno, circular, borda sutil, sem realce — humaniza sem competir com a mensagem */
.seller__photo{width:48px;height:48px;border-radius:50%;object-fit:cover;border:1px solid var(--border);flex:0 0 auto}
.seller__name{font-size:20px;font-weight:800}
.seller__role{color:var(--text-dim);font-size:14px}
/* CTA fica imediatamente ao lado/abaixo do texto (sem margin-left:auto empurrando p/ a borda) */
.seller__links{display:flex;gap:10px;flex-wrap:wrap}
@media(max-width:560px){.seller__links{width:100%}}

/* ---------- footer institucional (Sprint 09.1) ---------- */
.ftr{border-top:1px solid var(--border);padding:clamp(48px,7vh,72px) clamp(20px,5vw,40px) 0;color:var(--text-faint);font-size:14px}
.ftr a{color:var(--text-dim);transition:color .15s}.ftr a:hover{color:var(--text)}
.ftr__top{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1.2fr .8fr;gap:clamp(28px,4vw,56px)}
.ftr__tag{margin-top:14px;max-width:34ch;color:var(--text-dim);line-height:1.55}
.ftr__h{font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-faint);margin-bottom:16px}
.ftr__links{display:flex;flex-direction:column;gap:10px}
.ftr__addr{font-style:normal;line-height:1.7;color:var(--text-dim)}
.ftr__social{display:inline-flex;color:#fff;opacity:.8;transition:opacity .15s}
.ftr__social:hover{opacity:1}
.ftr__social svg{width:22px;height:22px}
.ftr__bottom{max-width:var(--maxw);margin:clamp(32px,5vh,48px) auto 0;padding:20px 0 28px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px}
.ftr__legal{display:flex;gap:20px;flex-wrap:wrap}
@media(max-width:760px){
  .ftr__top{grid-template-columns:1fr 1fr}
  .ftr__bottom{flex-direction:column;gap:12px}
}
@media(max-width:480px){.ftr__top{grid-template-columns:1fr}}

/* ---------- botão flutuante WhatsApp (Sprint 09.1) ---------- */
.wa-float{position:fixed;right:24px;bottom:24px;z-index:90;width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;background:#111111;color:#fff;
  box-shadow:0 10px 25px rgba(0,0,0,.35);transition:transform .15s ease}
.wa-float:hover{transform:scale(1.05)}
.wa-float svg{width:28px;height:28px}
@media(max-width:560px){
  .wa-float{right:20px;bottom:20px;width:50px;height:50px}
  .wa-float svg{width:26px;height:26px}
  /* folga para os links legais não ficarem sob o botão flutuante */
  .ftr__bottom{padding-bottom:84px}
}

/* ---------- consent (LGPD/GA4) — barra inferior full-width; reserva espaco via body.has-consent ---------- */
.consent{position:fixed;left:0;right:0;bottom:0;background:var(--surface-2);border-top:1px solid var(--border-strong);padding:14px clamp(16px,4vw,40px);z-index:200;font-size:13px;color:var(--text-dim);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.consent[hidden]{display:none}
.consent__actions{display:flex;gap:10px;flex:0 0 auto}
/* quando o banner esta ativo, o body reserva espaco para nao cobrir o conteudo final */
body.has-consent{padding-bottom:112px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* ===========================================================================
   Sprint 01 — Hero Enterprise (primeira dobra)
   Layout 45/55 desktop · texto→dashboard→botões no mobile · espaço negativo
   =========================================================================== */
.hero-section{position:relative;overflow:clip}
.hero-ent{position:relative;display:grid;grid-template-columns:45% 55%;align-items:center;
  gap:clamp(26px,3.2vw,46px);
  min-height:calc(100vh - 72px);min-height:calc(100svh - 72px);
  padding:clamp(96px,13vh,140px) 0 clamp(56px,8vh,96px)}
.hero-ent>*{min-width:0}
.hero-ent__text{grid-column:1;grid-row:1;align-self:end}
.hero-ent__actions{grid-column:1;grid-row:2;align-self:start;display:flex;gap:14px;flex-wrap:wrap;
  margin-top:clamp(16px,2.1vh,26px)}
.hero-ent__visual{grid-column:2;grid-row:1 / span 2;align-self:center}
/* headline cabe em ≤3 linhas no desktop (spec) — coluna de texto é 45% */
.hero-ent .h1{font-size:clamp(25px,2.5vw,34px);letter-spacing:-1px;line-height:1.1;max-width:none}
.hero-ent .lead{max-width:46ch;margin-top:clamp(12px,1.7vh,18px)}

/* glow roxo discreto + grid quase invisível — escopados ao hero (sem bleed horizontal) */
.hero-ent::before{content:"";position:absolute;inset:-10% 0;z-index:-2;pointer-events:none;
  background-image:radial-gradient(ellipse 62% 56% at 80% 44%,rgba(132,5,188,.13),transparent 62%)}
.hero-ent::after{content:"";position:absolute;inset:0;z-index:-2;pointer-events:none;opacity:.45;
  background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:62px 62px;
  -webkit-mask-image:radial-gradient(ellipse 78% 72% at 72% 46%,#000,transparent 76%);
  mask-image:radial-gradient(ellipse 78% 72% at 72% 46%,#000,transparent 76%)}

/* entrada do dashboard: fade + deslocamento + scale muito discreto */
@keyframes heroIn{from{opacity:0;transform:translateY(16px) scale(.985)}to{opacity:1;transform:none}}
.hero-ent__visual{animation:heroIn .7s cubic-bezier(.16,1,.3,1) both;animation-delay:.12s}
@media(prefers-reduced-motion:reduce){.hero-ent__visual{animation:none}}

/* ---------- Greeta Analytics® — ativo visual oficial (componente .ganalytics) ----------
   Apenas a imagem oficial: sem overlay, card, gauge ou efeito extra (a arte já
   comunica tudo). Ocupa 100% da coluna 55% do Hero; proporção 3:2 preservada,
   nunca distorce. Cantos arredondados para casar com a linguagem do DS. */
.ganalytics{margin:0;width:100%}
.ganalytics__img{display:block;width:100%;height:auto;aspect-ratio:1536/1024;border-radius:var(--r-lg);
  /* Sprint 09.1 — refinamento premium (sombra dupla + +3% brilho), sem mockup 3D */
  box-shadow:0 20px 40px rgba(0,0,0,.25),0 8px 16px rgba(0,0,0,.15);
  filter:brightness(1.03)}

/* Refinamento Hero — correção óptica do "dashboard baixo" em todo layout 2 colunas */
@media(min-width:901px){
  .hero-ent__visual{margin-top:-10px}
  /* perspectiva extremamente discreta (estática, sem animação) — eleva sem distorcer */
  .ganalytics__img{transform:perspective(1600px) rotateX(1.2deg) rotateY(1.8deg);transform-origin:center}
}
/* Dashboard ~6% maior só no desktop largo (≥1280px), onde a margem da página
   absorve o leve bleed sem clipar; centralizado, proporção 3:2 intacta. */
@media(min-width:1280px){
  .ganalytics{width:106%;margin-left:-3%}
}

/* Tablet/Mobile: texto → dashboard → botões */
@media(max-width:900px){
  .hero-ent{grid-template-columns:1fr;min-height:0;gap:20px;
    padding:clamp(84px,11vh,104px) 0 clamp(40px,6vh,64px)}
  .hero-ent__text{grid-column:1;grid-row:auto;order:1;align-self:auto}
  .hero-ent__visual{grid-column:1;grid-row:auto;order:2;align-self:auto}
  .hero-ent__actions{grid-column:1;grid-row:auto;order:3;align-self:auto;margin-top:6px}
  .hero-ent .h1,.hero-ent .lead{max-width:none}
  .hero-ent::after{opacity:.3}
}
@media(max-width:520px){
  .hero-ent__actions .btn{flex:1 1 auto;justify-content:center}
}
/* navbar CTA compacto em telas estreitas (evita corte do botão) */
@media(max-width:560px){
  .hdr{padding:0 16px}
  .hdr .btn--primary{padding:9px 14px;font-size:13px}
  .hdr__brand .brand-logo{height:24px}
}

/* ===========================================================================
   Sprint 02 — Credibilidade: "Operações complexas" + "O Problema"
   Mesmo ritmo do Hero · muito espaço negativo · separação clara entre seções
   =========================================================================== */
.ops-section{border-top:1px solid var(--border)}
.problema-section{border-top:1px solid var(--border)}

/* Seção 01 — cards de formatos de operação (limpos, ícone linear pequeno) */
.opcard{display:flex;flex-direction:column;transition:transform .2s ease,border-color .2s ease,background .2s ease}
.opcard:hover{transform:translateY(-3px);border-color:var(--border-strong);background:var(--surface-2)}
.opcard__ic{color:var(--accent);display:inline-flex;margin-bottom:16px}
.opcard__ic svg{width:20px;height:20px}
.opcard .h3{font-size:clamp(16px,1.6vw,18px)}
.opcard .body{color:var(--text-dim)}

/* Seção 02 — diagrama horizontal Matriz → … → Resultados diferentes */
.pflow{display:flex;align-items:stretch;justify-content:center;flex-wrap:nowrap;
  gap:clamp(4px,.8vw,12px);margin-top:clamp(40px,6vh,68px)}
.pflow__node{flex:1 1 0;min-width:0;max-width:188px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow);
  padding:clamp(16px,1.7vw,22px) clamp(10px,1.1vw,16px);
  display:flex;flex-direction:column;align-items:center;gap:11px;text-align:center}
.pflow__ic{color:var(--accent);display:inline-flex}
.pflow__ic svg{width:22px;height:22px}
.pflow__lbl{font-size:clamp(12px,1.15vw,14px);font-weight:600;letter-spacing:-.2px;line-height:1.25;color:var(--text)}
.pflow__arrow{display:flex;align-items:center;justify-content:center;flex:0 0 auto;color:var(--border-strong)}
.pflow__arrow svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
/* nó final: divergência (acento de alerta, sem neon) */
.pflow__node--diverge{border-color:rgba(248,113,113,.38);background:rgba(248,113,113,.05)}
.pflow__node--diverge .pflow__ic{color:var(--red)}
.pflow__node--diverge .pflow__lbl{color:var(--red)}

/* Tablet/Mobile: diagrama empilha na vertical, setas apontam para baixo */
@media(max-width:820px){
  .pflow{flex-direction:column;align-items:center;gap:6px}
  .pflow__node{flex:0 0 auto;width:100%;max-width:360px;flex-direction:row;justify-content:flex-start;gap:14px;text-align:left}
  .pflow__arrow{transform:rotate(90deg)}
}

/* ===========================================================================
   Sprint 03 — Framework Greeta (estrutura/placeholder; arte oficial futura)
   =========================================================================== */
.framework-section{border-top:1px solid var(--border)}
/* GEF® — ativo visual oficial (componente .gef reutilizável).
   Proporção 16:9 preservada via width/height intrínsecos; nunca distorce. */
.gef{margin:0;width:100%;max-width:1000px;margin-inline:auto;
  border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--border-strong);box-shadow:var(--shadow);background:var(--surface-2)}
.gef__img{display:block;width:100%;height:auto;aspect-ratio:1672/941;object-fit:contain}
/* Greeta Vision® — ativo visual oficial (componente .gvision reutilizável).
   A arte já contém toda a comunicação visual: centralizada, max-width igual ao GEF®,
   sem borda/sombra/elementos extras. Proporção 3:2 preservada; nunca distorce. */
.gvision{margin:0;width:100%;max-width:1000px;margin-inline:auto}
.gvision__img{display:block;width:100%;height:auto;aspect-ratio:1536/1024}
/* benefícios: reusa .chips/.chip, centralizado, com ícone linear pequeno */
.fw-benefits{justify-content:center}
.fw-benefits .chip{display:inline-flex;align-items:center;gap:8px}
.fw-benefits .chip svg{width:15px;height:15px;color:var(--accent);flex:0 0 auto}

/* ===========================================================================
   Sprint 10 — Páginas institucionais (Política/Termos/LGPD)
   Reusa head/navbar/footer/tokens/DS. Leitura longa, dark, container central.
   =========================================================================== */
.legal{padding:72px clamp(20px,5vw,40px) 0}
.legal-hero{max-width:820px;margin:0 auto;padding:clamp(48px,8vh,88px) 0 clamp(28px,4vh,44px);text-align:center}
.legal-hero .h1{font-size:clamp(30px,5vw,48px);letter-spacing:-1.4px}
.legal-hero .updated{margin-top:14px;font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-faint)}
.legal-hero .lead{margin-top:18px}
/* layout: TOC (esq, fixa quando há espaço) + artigo (~920px, dentro de 900–980) */
.legal-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:220px minmax(0,1fr);gap:40px;align-items:start}
.legal-article{min-width:0}
/* índice automático: <details open> = aberto no desktop, colapsável no mobile */
.legal-toc{position:sticky;top:96px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);padding:16px 18px}
.legal-toc>summary{cursor:pointer;font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-faint);list-style:none;display:flex;align-items:center;justify-content:space-between;gap:10px}
.legal-toc>summary::-webkit-details-marker{display:none}
.legal-toc>summary::after{content:"–";color:var(--accent);font-weight:700}
.legal-toc:not([open])>summary::after{content:"+"}
.legal-toc nav{display:flex;flex-direction:column;gap:9px;margin-top:14px}
.legal-toc a{font-size:13px;color:var(--text-dim);line-height:1.4}
.legal-toc a:hover{color:var(--text)}
/* prosa: hierarquia clara + ritmo de leitura */
.legal-article section{scroll-margin-top:96px}
.legal-article h2{font-size:clamp(20px,2.4vw,26px);font-weight:800;letter-spacing:-.4px;line-height:1.2;margin:clamp(36px,5vh,52px) 0 16px;color:var(--text)}
.legal-article section:first-child h2{margin-top:0}
.legal-article h3{font-size:clamp(16px,1.8vw,18px);font-weight:700;color:var(--text);margin:26px 0 10px}
.legal-article p{color:var(--text-dim);margin:0 0 14px;line-height:1.75}
.legal-article ul{margin:0 0 18px;padding-left:22px;display:flex;flex-direction:column;gap:7px}
.legal-article li{color:var(--text-dim);line-height:1.6}
.legal-article li::marker{color:var(--accent)}
.legal-article a{color:var(--accent)}
.legal-article a:hover{text-decoration:underline}
.legal-cta{max-width:820px;margin:clamp(48px,7vh,76px) auto 0;text-align:center;padding:clamp(40px,7vh,64px) 0 clamp(64px,10vh,104px);border-top:1px solid var(--border)}
@media(max-width:900px){
  .legal-grid{grid-template-columns:1fr;gap:24px}
  .legal-toc{position:static}
}
