/* =================================================================
   LIGGA MARKETING — style.css
   Checkpoint 1 (rev): reset + base + header + HERO (form + constelação)
   Depende de tokens.css (carregado antes).
   ================================================================= */

/* ---------- 1. RESET ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  font-size:var(--fs-body);
  line-height:var(--lh-body);
  color:var(--text-on-dark);
  background:var(--navy-900);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
[hidden]{display:none!important} /* garante que classes c/ display não revelem itens ocultos */
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
ul{list-style:none}
:focus-visible{outline:2px solid var(--gold-400);outline-offset:3px;border-radius:4px}
::selection{background:rgba(var(--gold-500-rgb),.28);color:#fff}

/* Lenis (smooth scroll) */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}

/* ---------- 2. LAYOUT ---------- */
.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:var(--gutter);
}

/* ---------- 3. BOTÕES ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);
  padding:15px 26px;
  font-family:var(--font-body);
  font-weight:700;font-size:.96rem;line-height:1.1;
  letter-spacing:.01em;
  border-radius:var(--r-sm);
  position:relative;
  transition:transform var(--dur-1) var(--ease-cubic),
             background-color var(--dur-2) var(--ease-cubic),
             box-shadow var(--dur-2) var(--ease-cubic),
             border-color var(--dur-2) var(--ease-cubic),
             color var(--dur-2) var(--ease-cubic);
  will-change:transform;
}
.btn svg{width:18px;height:18px;flex:none}

/* primário — dourado sólido, texto navy */
.btn--primary{
  background:var(--gold-500);
  color:var(--navy-900);
  box-shadow:0 6px 26px rgba(var(--gold-500-rgb),.30);
}
.btn--primary:hover{background:var(--gold-400);box-shadow:0 10px 36px rgba(var(--gold-500-rgb),.42)}
.btn--primary:active{background:var(--gold-600)}

/* breathing glow — só nos CTAs-âncora (hero / CTA final). Anima opacity/scale (GPU) */
.btn--breathe::after{
  content:"";position:absolute;inset:-2px;border-radius:inherit;
  box-shadow:var(--glow-gold-strong);
  opacity:.5;z-index:-1;
  animation:breathe 2.6s var(--ease-cubic) infinite;
}
@keyframes breathe{
  0%,100%{opacity:.32;transform:scale(.97)}
  50%{opacity:.8;transform:scale(1.03)}
}

/* secundário — outline discreto */
.btn--ghost{
  background:transparent;
  color:var(--text-on-dark);
  border:1px solid rgba(255,255,255,.16);
}
.btn--ghost:hover{border-color:rgba(var(--gold-500-rgb),.55);color:#fff;background:rgba(255,255,255,.03)}

/* pill (header) */
.btn--pill{border-radius:var(--r-pill);padding:11px 20px;font-size:.9rem}

/* ---------- 4. EYEBROW PILL ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  padding:7px 16px;
  font-size:var(--fs-eyebrow);font-weight:700;
  text-transform:uppercase;letter-spacing:var(--tracking-eyebrow);
  color:var(--gold-300);
  background:rgba(var(--gold-500-rgb),.07);
  border:1px solid rgba(var(--gold-500-rgb),.24);
  border-radius:var(--r-pill);
}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--gold-400);flex:none}

/* ---------- 5. HEADER ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:var(--z-header);
  padding-top:clamp(14px,2.4vw,22px);
  pointer-events:none;
  transition:padding-top var(--dur-2) var(--ease-cubic);
}
.site-header .container{
  display:flex;align-items:center;justify-content:space-between;gap:var(--sp-6);
  pointer-events:auto;
  padding-block:8px;border:1px solid transparent;border-radius:var(--r-pill);
  transition:background-color var(--dur-2) var(--ease-cubic),border-color var(--dur-2) var(--ease-cubic),
    box-shadow var(--dur-2) var(--ease-cubic);
}
/* sticky → pílula flutuante navy quando rola (legível sobre seções claras) */
.site-header.is-scrolled{padding-top:10px}
.site-header.is-scrolled .container{
  background:rgba(10,20,40,.72);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-color:rgba(255,255,255,.08);
  box-shadow:0 12px 40px rgba(0,0,0,.35);
}
/* marca: Ligga • Marketing */
.brand{display:inline-flex;align-items:baseline;gap:7px;font-family:var(--font-display)}
.brand__name{font-weight:800;font-size:1.4rem;letter-spacing:-0.02em;color:#fff}
.brand__dot{color:var(--gold-500);font-weight:800;font-size:1.4rem;line-height:1}
.brand__sub{font-weight:600;font-size:1.18rem;letter-spacing:-0.01em;color:var(--text-on-dark-muted)}

.nav{display:flex;align-items:center;gap:clamp(14px,1.8vw,28px)}
.nav a{
  position:relative;font-size:.92rem;font-weight:500;color:var(--text-on-dark-muted);
  padding:6px 2px;transition:color var(--dur-1) var(--ease-cubic);
}
.nav a:hover{color:#fff}
.nav a::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;
  background:var(--gold-500);transition:right var(--dur-2) var(--ease-expo);
}
.nav a:hover::after{right:0}

/* dropdown Segmentos */
.nav__group{position:relative}
.nav__trigger{display:inline-flex;align-items:center;gap:5px;font-size:.92rem;font-weight:500;
  color:var(--text-on-dark-muted);padding:6px 2px;transition:color var(--dur-1) var(--ease-cubic)}
.nav__trigger svg{width:15px;height:15px;transition:transform var(--dur-2) var(--ease-cubic)}
.nav__group.is-open .nav__trigger,.nav__group:focus-within .nav__trigger{color:#fff}
.nav__group.is-open .nav__trigger svg,.nav__group:focus-within .nav__trigger svg{transform:rotate(180deg)}
.nav__sub{position:absolute;top:calc(100% + 12px);left:50%;
  transform:translateX(-50%) translateY(6px);
  display:flex;flex-direction:column;gap:2px;min-width:168px;padding:8px;
  background:rgba(10,20,40,.94);backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.10);border-radius:var(--r-md);
  box-shadow:0 18px 50px rgba(0,0,0,.45);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity var(--dur-2) var(--ease-cubic),transform var(--dur-2) var(--ease-expo);
  z-index:var(--z-header)}
/* ponte invisível sobre o vão de 12px: o mouse não "cai fora" ao descer p/ o painel */
.nav__sub::before{content:"";position:absolute;left:0;right:0;top:-14px;height:16px}
.nav__group.is-open .nav__sub,.nav__group:focus-within .nav__sub{
  opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav__sub a{display:block;padding:9px 12px;border-radius:var(--r-sm);font-size:.9rem;color:var(--text-on-dark-muted)}
.nav__sub a::after{display:none}
.nav__sub a:hover{background:rgba(var(--gold-500-rgb),.10);color:#fff}

.header__cta{display:inline-flex;align-items:center;gap:var(--sp-4)}
.nav-toggle{display:none;width:44px;height:44px;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.16);border-radius:var(--r-sm);color:#fff}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:"";display:block;width:20px;height:2px;background:currentColor;position:relative;transition:.3s}
.nav-toggle span::before{position:absolute;top:-6px}
.nav-toggle span::after{position:absolute;top:6px}

/* ---------- 6. HERO ---------- */
.hero{
  position:relative;isolation:isolate;overflow:hidden;
  min-height:100svh;
  display:flex;align-items:center;
  padding:clamp(116px,13vh,150px) 0 clamp(56px,8vh,90px);
  background:
    radial-gradient(120% 100% at 80% -10%, var(--navy-800), transparent 60%),
    linear-gradient(180deg,var(--navy-900),var(--navy-950) 70%,#070b14);
}
/* constelação (canvas) — pontinhos dourados + linhas */
.hero__constellation{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
.hero .container{position:relative;z-index:1}

.hero__grid{
  display:grid;grid-template-columns:1.05fr .95fr;align-items:center;
  gap:clamp(28px,4vw,64px);width:100%;
}
.hero__content{max-width:600px}
.hero__title{
  font-family:var(--font-display);font-weight:var(--weight-display);
  /* Manrope 800, não-uppercase, tracking apertado (identidade do site atual) */
  font-size:clamp(2.3rem,4.7vw,3.9rem);line-height:1.08;
  letter-spacing:var(--tracking-display);
  color:#fff;margin-block:var(--sp-6) var(--sp-6);text-wrap:balance;
}
.hero__title .hl{color:var(--gold-500);font-style:italic;font-weight:800}
.hero__title .word{display:inline-block;will-change:transform}
.hero__sub{
  font-size:clamp(1.02rem,1.3vw,1.18rem);line-height:1.55;
  color:var(--text-on-dark-muted);max-width:50ch;
}
.hero__sub strong{color:var(--text-on-dark);font-weight:600}

.hero__actions{display:flex;flex-wrap:wrap;gap:var(--sp-4);margin-top:var(--sp-8)}

.trust{
  display:flex;flex-wrap:wrap;align-items:center;gap:10px 18px;margin-top:var(--sp-8);
  font-size:.85rem;color:var(--text-on-dark-muted);
}
.trust li{display:inline-flex;align-items:center;gap:8px}
.trust li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--gold-500)}

/* ---------- 7. FORM DE DIAGNÓSTICO (hero direita) ---------- */
.hero__form{width:100%;max-width:440px;margin-left:auto}
.dform{
  background:linear-gradient(165deg,rgba(30,50,85,.94),rgba(12,22,42,.97));
  border:1px solid rgba(var(--gold-500-rgb),.32);
  border-radius:var(--r-lg);
  padding:clamp(22px,2.6vw,30px);
  box-shadow:0 24px 70px rgba(0,0,0,.5), 0 0 0 1px rgba(var(--gold-500-rgb),.06);
  backdrop-filter:blur(10px);
}
.dform__head{margin-bottom:var(--sp-6)}
.dform__title{font-family:var(--font-display);font-weight:800;font-size:1.5rem;letter-spacing:-0.02em;color:#fff}
.dform__sub{font-size:.9rem;color:var(--text-on-dark-muted);margin-top:4px}
.dform__progress{display:flex;align-items:center;gap:12px;margin-top:16px}
.dform__bar{flex:1;height:4px;border-radius:var(--r-pill);background:rgba(255,255,255,.10);overflow:hidden}
.dform__bar i{display:block;height:100%;border-radius:inherit;background:var(--grad-gold);
  transition:width var(--dur-3) var(--ease-expo)}
.dform__step{font-size:.72rem;font-weight:600;color:var(--text-on-dark-muted);white-space:nowrap;
  text-transform:uppercase;letter-spacing:.06em}
.dform__step b{color:var(--gold-400)}

.dform__panel{border:0;display:grid;gap:14px}
.dform__panel[hidden]{display:none} /* sobrepõe o display:grid p/ ocultar etapas inativas */
.field{display:block}
.field__label{display:block;font-size:.8rem;font-weight:600;color:var(--text-on-dark-muted);margin-bottom:6px}
.field__opt{font-weight:400;text-transform:none;letter-spacing:0;color:#6b7793}
.field input,.field select,.field textarea{
  width:100%;padding:13px 14px;font:inherit;font-size:.95rem;color:#fff;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-sm);transition:border-color var(--dur-2) var(--ease-cubic),background var(--dur-2) var(--ease-cubic);
}
.field textarea{resize:vertical;min-height:60px;line-height:1.45}
.field input::placeholder,.field textarea::placeholder{color:#6b7793}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold-500);background:rgba(255,255,255,.06)}
.field select{
  appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%239AA4B8' stroke-width='2'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;
}
.field select option{color:#fff;background:var(--navy-800)}

.dform__actions{display:flex;gap:10px;margin-top:20px}
.dform__actions .btn{flex:1}
.dform__alt{font-size:.82rem;color:var(--text-on-dark-muted);text-align:center;margin-top:14px}
.dform__alt a{color:var(--gold-400);font-weight:600}
.dform__alt a:hover{text-decoration:underline}

/* ---------- 8. REVEAL (progressive enhancement) ---------- */
html.js [data-reveal]{opacity:0}

/* ---------- 9. RESPONSIVO ---------- */
@media (max-width:1024px){
  .hero__grid{grid-template-columns:1fr;gap:40px}
  .hero__content{max-width:none;order:1}
  .hero__form{order:2;margin-left:0;max-width:480px}
}
@media (max-width:760px){
  .nav{display:none} /* WhatsApp pill continua visível (pedido: sempre na barra no mobile) */
  .nav-toggle{display:inline-flex}
  .hero{min-height:auto;padding-top:108px}
  .hero__actions .btn{flex:1 1 100%}
  .brand__sub,.brand__dot{display:none} /* mobile aperta: mostra só "Ligga" */
  .btn--pill{font-size:.82rem;padding:10px 15px;white-space:nowrap} /* WhatsApp em 1 linha */
}
@media (max-width:420px){
  .dform{padding:20px}
}

/* ================================================================
   SEÇÕES — Checkpoint 3 (visual completo · ritmo claro/escuro)
   Contexto de cor por seção via custom props (--c-*).
   ================================================================ */
:root{ --header-h:72px } /* altura aproximada da pílula do header (compensa âncoras) */
.section{
  --c-title:#fff; --c-muted:var(--text-on-dark-muted);
  --c-surface:rgba(255,255,255,.04); --c-border:rgba(255,255,255,.12);
  position:relative; padding:var(--section-pad) 0;
  scroll-margin-top:calc(var(--header-h) + 20px);
}
.section--light{background:var(--paper);
  --c-title:var(--text-on-light); --c-muted:var(--text-on-light-muted);
  --c-surface:#fff; --c-border:var(--border-light)}
.section--light-2{background:var(--paper-2);
  --c-title:var(--text-on-light); --c-muted:var(--text-on-light-muted);
  --c-surface:#fff; --c-border:var(--border-light)}
.section--dark{background:var(--navy-800)}
.container--narrow{max-width:var(--container-narrow)}

/* cabeçalho de seção */
.section__head{max-width:760px;margin-bottom:var(--sp-12)}
.section__head--center{margin-inline:auto;text-align:center}
.section__head--center .eyebrow{margin-inline:auto}
.section__title{font-family:var(--font-display);font-weight:800;font-size:var(--fs-h2);
  line-height:1.1;letter-spacing:-0.02em;color:var(--c-title);margin-top:18px;text-wrap:balance}
.section__title .hl{color:var(--gold-500);font-style:italic;font-weight:800}
.section--light .section__title .hl,.section--light-2 .section__title .hl{color:var(--gold-600)}
.section__rule{display:block;width:54px;height:3px;border-radius:3px;background:var(--grad-gold);margin-top:20px}
.section__head--center .section__rule{margin-inline:auto}
.lead{color:var(--c-muted);font-size:clamp(1rem,1.2vw,1.1rem);line-height:1.62;max-width:64ch;margin-top:18px}
.lead strong{color:var(--c-title);font-weight:600}

/* eyebrow em seção clara (contraste AA) */
.section--light .eyebrow,.section--light-2 .eyebrow{
  color:var(--gold-700);background:rgba(var(--gold-500-rgb),.10);border-color:rgba(var(--gold-500-rgb),.35)}

/* ícones Lucide */
i[data-lucide]{display:inline-block;width:1.1em;height:1.1em}
svg.lucide{width:1.1em;height:1.1em;stroke-width:2}

/* ---- 2. Problema ---- */
.seg-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.seg-chips li{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--c-border);
  border-radius:var(--r-pill);padding:8px 16px;font-size:.88rem;font-weight:500;color:var(--c-title)}
.seg-chips svg{width:17px;height:17px;color:var(--gold-600);flex:none}
.pullquote{position:relative;margin-top:var(--sp-16);background:var(--navy-800);
  border-radius:var(--r-lg);padding:clamp(28px,5vw,52px);overflow:hidden;box-shadow:var(--glow-gold)}
.pullquote::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(70% 120% at 100% 0%,rgba(var(--gold-500-rgb),.16),transparent 60%)}
.pullquote__mark{width:38px;height:38px;color:var(--gold-500);opacity:.55;margin-bottom:10px;position:relative}
.pullquote p{position:relative;font-family:var(--font-display);font-weight:800;
  font-size:clamp(1.5rem,3.4vw,2.4rem);line-height:1.16;color:#fff;max-width:26ch}
.pullquote em{color:var(--gold-500);font-style:italic}

/* ---- 3. O que organizamos: diagrama ---- */
.diagram{position:relative;display:flex;justify-content:space-between;gap:12px;
  margin:var(--sp-12) 0;padding:28px 0;border-top:1px solid var(--c-border);border-bottom:1px solid var(--c-border)}
.diagram__line{position:absolute;top:54px;left:10%;right:10%;height:2px;z-index:0;
  transform-origin:left center;overflow:hidden;background:rgba(var(--gold-500-rgb),.55)}
.diagram__line::after{content:"";position:absolute;inset:0;width:32%;
  background:linear-gradient(90deg,transparent,rgba(230,196,94,.95),transparent);
  transform:translateX(-120%);animation:flow 3.6s var(--ease-cubic) infinite}
@keyframes flow{to{transform:translateX(420%)}}
.diagram__node{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;
  gap:12px;text-align:center;flex:1;min-width:84px}
.diagram__dot{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;
  background:var(--navy-700);border:1px solid rgba(var(--gold-500-rgb),.45);color:var(--gold-400)}
.diagram__dot svg{width:23px;height:23px}
.diagram__label{font-size:.85rem;font-weight:600;color:#fff}

/* carrossel — um slide grande por vez (slider) */
.carousel{margin-top:var(--sp-8)}
.carousel__viewport{overflow:hidden;border-radius:var(--r-lg);border:1px solid rgba(var(--gold-500-rgb),.18)}
.carousel__track{display:flex;will-change:transform;transition:transform var(--dur-3) var(--ease-expo)}
.slide{flex:0 0 100%;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,4vw,48px);
  align-items:center;min-height:360px;padding:clamp(28px,4vw,52px);
  background:linear-gradient(150deg,var(--navy-700),var(--navy-900))}
.slide__index{font-family:var(--font-display);font-weight:700;font-size:.8rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--gold-400);opacity:.85}
.slide__icon{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;margin:16px 0 18px;
  background:rgba(var(--gold-500-rgb),.10);border:1px solid rgba(var(--gold-500-rgb),.32);color:var(--gold-400)}
.slide__icon svg{width:28px;height:28px}
.slide__title{font-family:var(--font-display);font-weight:800;font-size:clamp(1.6rem,3vw,2.2rem);
  color:var(--gold-500);line-height:1.1}
.slide__desc{color:var(--text-on-dark);font-size:clamp(1rem,1.25vw,1.12rem);line-height:1.6;margin-top:14px;max-width:42ch}
.slide__link{display:inline-flex;align-items:center;gap:8px;margin-top:22px;color:var(--gold-400);font-weight:600}
.slide__link svg{width:16px;height:16px;transition:transform var(--dur-2) var(--ease-cubic)}
.slide__link:hover svg{transform:translateX(4px)}
.slide__visual{display:grid;place-items:center;min-height:230px}

/* ilustrações por frente (CSS puro, sem stock) */
.viz{position:relative;width:100%;max-width:330px;background:rgba(10,20,40,.55);
  border:1px solid rgba(255,255,255,.09);border-radius:var(--r-md);padding:18px;box-shadow:0 22px 50px rgba(0,0,0,.4)}
.viz__media{height:84px;border-radius:8px;background:linear-gradient(135deg,rgba(var(--gold-500-rgb),.5),rgba(var(--gold-500-rgb),.12))}
.viz__line{height:9px;border-radius:5px;background:rgba(255,255,255,.16);margin-top:12px}
.viz__line--sm{width:60%}
.viz__chip{position:absolute;top:12px;right:12px;font-size:.6rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--navy-900);background:var(--gold-500);border-radius:var(--r-pill);padding:3px 9px}
.viz__cta{display:inline-block;margin-top:14px;font-size:.72rem;font-weight:700;color:var(--text-on-dark-muted);
  border:1px solid rgba(255,255,255,.18);border-radius:var(--r-sm);padding:7px 12px}
.viz__cta--gold{color:var(--navy-900);background:var(--gold-500);border-color:transparent}
.viz__target{position:absolute;bottom:-14px;left:-14px;width:54px;height:54px;border-radius:50%;
  border:2px solid rgba(var(--gold-500-rgb),.5);box-shadow:0 0 0 6px rgba(var(--gold-500-rgb),.12)}
.viz__target::after{content:"";position:absolute;inset:17px;border-radius:50%;background:var(--gold-500)}
.viz__bar{display:flex;gap:6px;margin-bottom:12px}
.viz__bar i{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.22)}
.viz__bar i:first-child{background:rgba(var(--gold-500-rgb),.7)}
.viz__hero{height:64px;border-radius:8px;background:linear-gradient(135deg,rgba(43,72,120,.9),rgba(10,20,40,.6))}
.viz--content{display:grid;gap:12px}
.viz__post{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.04);border-radius:8px;padding:12px}
.viz__avatar{width:34px;height:34px;border-radius:50%;flex:none;background:linear-gradient(135deg,var(--gold-400),var(--gold-600))}
.viz__media--sm{height:46px;flex:1;margin:0}
.viz--crm{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-width:340px;padding:14px}
.viz__col{background:rgba(255,255,255,.04);border-radius:8px;padding:10px;display:grid;gap:8px;align-content:start}
.viz__coltitle{font-size:.56rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-on-dark-muted)}
.viz__ticket{height:26px;border-radius:5px;background:rgba(255,255,255,.10)}
.viz__ticket--gold{background:linear-gradient(135deg,rgba(var(--gold-500-rgb),.7),rgba(var(--gold-500-rgb),.3))}
.viz--chat{display:grid;gap:10px;max-width:300px}
.viz__bubble{height:30px;border-radius:14px}
.viz__bubble--in{width:62%;justify-self:start;background:rgba(255,255,255,.10);border-bottom-left-radius:4px}
.viz__bubble--out{width:54%;justify-self:end;background:rgba(var(--gold-500-rgb),.28);border-bottom-right-radius:4px}
.viz__bubble--typing{width:auto;justify-self:start;display:inline-flex;align-items:center;gap:5px;padding:0 14px}
.viz__bubble--typing i{width:6px;height:6px;border-radius:50%;background:var(--text-on-dark-muted);animation:typing 1.2s var(--ease-cubic) infinite}
.viz__bubble--typing i:nth-child(2){animation-delay:.2s}
.viz__bubble--typing i:nth-child(3){animation-delay:.4s}
@keyframes typing{0%,100%{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}

.carousel__ctrls{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:18px}
.carousel__arrow{width:44px;height:44px;border-radius:50%;border:1px solid var(--c-border);
  color:#fff;display:grid;place-items:center;transition:var(--dur-2) var(--ease-cubic)}
.carousel__arrow svg{width:20px;height:20px}
.carousel__arrow:hover{border-color:var(--gold-500);color:var(--gold-400);background:rgba(var(--gold-500-rgb),.08)}
.carousel__dots{display:flex;gap:8px}
.carousel__dot{width:8px;height:8px;border-radius:var(--r-pill);background:rgba(255,255,255,.22);transition:var(--dur-2) var(--ease-cubic)}
.carousel__dot.is-active{background:var(--gold-500);width:22px}
.org__close{display:inline-flex;align-items:center;gap:10px;margin-top:var(--sp-12);
  font-family:var(--font-display);font-weight:700;font-size:1.15rem;color:var(--gold-500)}
.org__close svg{width:20px;height:20px;flex:none}

/* ---- 4. Como funciona: passos ---- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;position:relative}
.steps::before{content:"";position:absolute;top:26px;left:7%;right:7%;height:2px;z-index:0;
  background:repeating-linear-gradient(90deg,rgba(var(--gold-500-rgb),.5) 0 8px,transparent 8px 16px)}
.step{position:relative;z-index:1}
.step__num{font-family:var(--font-display);font-weight:800;font-size:3rem;line-height:1;
  color:var(--gold-500);display:inline-block;background:var(--paper-2);padding-right:14px}
.step__title{margin-top:12px;font-family:var(--font-display);font-weight:700;font-size:1.12rem;color:var(--c-title)}
.step__desc{margin-top:8px;color:var(--c-muted);font-size:.92rem;line-height:1.55}

/* ---- 5. Bagagem: stats + chips ---- */
.stats{display:flex;flex-wrap:wrap;gap:clamp(28px,6vw,72px);margin:var(--sp-4) 0 var(--sp-12)}
.stat__num{font-family:var(--font-display);font-weight:800;font-size:var(--fs-stat);
  color:var(--gold-500);line-height:1;display:block}
.stat__label{color:var(--text-on-dark-muted);font-size:.92rem;margin-top:8px;display:block}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chips li{border:1px solid var(--c-border);border-radius:var(--r-pill);padding:8px 16px;
  font-size:.85rem;color:var(--c-muted);transition:var(--dur-2) var(--ease-cubic)}
.chips li:hover{border-color:rgba(var(--gold-500-rgb),.5);color:#fff}

/* ---- 6. É pra você: 2 colunas (peso igual) ---- */
.fit{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.fit__col{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);
  padding:clamp(22px,3vw,34px)}
.fit__title{display:flex;align-items:center;gap:10px;font-family:var(--font-display);
  font-weight:700;font-size:1.3rem;color:var(--c-title);margin-bottom:18px}
.fit__title svg{width:24px;height:24px;flex:none}
.fit__col:first-child .fit__title svg{color:var(--gold-600)}
.fit__col:last-child .fit__title svg{color:var(--text-on-light-muted)}
.fit__list{display:grid;gap:14px}
.fit__list li{display:flex;gap:12px;color:var(--c-muted);line-height:1.5}
.fit__list svg{width:20px;height:20px;flex:none;margin-top:1px}
.fit__list--yes svg{color:var(--gold-600)}
.fit__list--no svg{color:#9aa1b2}

/* ---- 7. FAQ ---- */
.faq{display:grid;gap:12px}
.faq__item{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);
  transition:border-color var(--dur-2) var(--ease-cubic),box-shadow var(--dur-2) var(--ease-cubic)}
.faq__item[open]{border-color:rgba(var(--gold-500-rgb),.5);box-shadow:var(--glow-gold)}
.faq__q{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  gap:16px;padding:18px 22px;font-weight:600;font-size:1.02rem;color:var(--c-title)}
.faq__q::-webkit-details-marker{display:none}
.faq__plus{position:relative;width:18px;height:18px;flex:none;transition:transform var(--dur-2) var(--ease-quart)}
.faq__plus::before,.faq__plus::after{content:"";position:absolute;background:var(--gold-600);border-radius:2px}
.faq__plus::before{top:8px;left:0;width:18px;height:2px}
.faq__plus::after{left:8px;top:0;width:2px;height:18px}
.faq__item[open] .faq__plus{transform:rotate(45deg)}
.faq__a{padding:0 22px 20px;color:var(--c-muted);line-height:1.6}

/* ---- 8. CTA final ---- */
.section--cta{text-align:center;overflow:hidden;
  background:radial-gradient(120% 130% at 50% 0%,var(--navy-700),var(--navy-900) 52%,var(--navy-950))}
.cta__inner{display:flex;flex-direction:column;align-items:center}
.cta__inner .eyebrow{margin-bottom:20px}
.cta__inner .section__title{max-width:20ch}
.cta__inner .lead{max-width:52ch}
.cta__actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:30px}
.cta__tagline{margin-top:28px;font-family:var(--font-display);font-weight:800;font-style:italic;
  font-size:clamp(1.2rem,2.4vw,1.65rem);color:var(--gold-500)}
.btn--lg{padding:17px 32px;font-size:1.02rem}

/* ---- Footer ---- */
.site-footer{background:var(--navy-950);padding:var(--sp-24) 0 var(--sp-12);color:var(--text-on-dark-muted)}
.site-footer .footer__grid{display:grid;grid-template-columns:2fr 1fr 1.6fr;gap:40px}
.footer__brand .brand{margin-bottom:14px}
.footer__brand p{max-width:42ch;line-height:1.6}
.footer__social{display:inline-flex;align-items:center;gap:8px;margin-top:16px;color:var(--gold-400);font-weight:600}
.footer__social svg{width:18px;height:18px}
.footer__col{display:flex;flex-direction:column;gap:11px}
.site-footer h3,.site-footer h4{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:#fff;
  font-weight:700;margin-bottom:6px}
.footer__col a,.footer__col p{display:inline-flex;align-items:center;gap:10px;color:var(--text-on-dark-muted);
  transition:color var(--dur-2) var(--ease-cubic)}
.footer__col a:hover{color:#fff}
.footer__col svg{width:17px;height:17px;color:var(--gold-500);flex:none}
.footer__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;
  margin-top:var(--sp-16);padding-top:20px;border-top:1px solid rgba(255,255,255,.08);font-size:.85rem}
.footer__tag{color:var(--gold-500);font-style:italic}

/* responsivo das seções */
@media (max-width:920px){
  .steps{grid-template-columns:1fr 1fr;gap:24px}
  .steps::before{display:none}
  .step__num{background:transparent;padding-right:0}
}
@media (max-width:760px){
  .fit{grid-template-columns:1fr}
  .site-footer .footer__grid{grid-template-columns:1fr;gap:30px}
  .diagram{flex-direction:column;gap:18px}
  .diagram__line{display:none}
  .slide{grid-template-columns:1fr;gap:26px;min-height:0}
}
@media (max-width:560px){
  .steps{grid-template-columns:1fr}
}

/* ================================================================
   MOVIMENTO — Checkpoint 4 (estados iniciais de reveal + ambiente)
   ================================================================ */
html.js :where(.section__head,.pullquote,.seg-chips,.carousel,.org__close,
  .step,.stats,.chips,.fit__col,.faq__item,.reveal-up,
  .section--cta .eyebrow,.section--cta .section__title,.section--cta .lead,
  .cta__actions,.cta__tagline){opacity:0}
html.js .diagram__node{opacity:0}
html.js .diagram__line{transform:scaleX(0)}

/* glow respirando atrás do CTA final */
.section--cta>.container{position:relative;z-index:1}
.section--cta::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(46% 56% at 50% 40%,rgba(var(--gold-500-rgb),.16),transparent 70%);
  animation:ctaGlow 5s var(--ease-cubic) infinite}
@keyframes ctaGlow{0%,100%{opacity:.45;transform:scale(.95)}50%{opacity:1;transform:scale(1.06)}}

/* ---------- 10. PREFERS-REDUCED-MOTION ---------- */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important}
  .btn--breathe::after{animation:none;opacity:.5}
  html.js [data-reveal]{opacity:1}
  html.js :where(.section__head,.pullquote,.seg-chips,.carousel,.org__close,
    .step,.stats,.chips,.fit__col,.faq__item,.reveal-up,
    .section--cta .eyebrow,.section--cta .section__title,.section--cta .lead,
    .cta__actions,.cta__tagline){opacity:1}
  html.js .diagram__node{opacity:1}
  html.js .diagram__line{transform:none}
  .diagram__line::after{display:none}
  .section--cta::before{animation:none}
}

/* ================================================================
   SEÇÕES NOVAS — Caminhos / Bastidores + menu mobile
   (Checkpoint final — reusa tokens e padrões de card existentes)
   ================================================================ */

/* alvos de âncora que não são .section também ganham folga sob o header */
.site-footer,#form-diagnostico{scroll-margin-top:calc(var(--header-h) + 20px)}

/* ---- Caminhos por perfil ---- */
.paths{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:var(--sp-4)}
.path-card{
  display:flex;flex-direction:column;gap:14px;height:100%;
  background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);
  padding:clamp(22px,2.4vw,28px);color:var(--c-title);box-shadow:0 1px 2px rgba(18,35,64,.04);
  transition:transform var(--dur-2) var(--ease-cubic),border-color var(--dur-2) var(--ease-cubic),box-shadow var(--dur-2) var(--ease-cubic);
}
.path-card:hover{transform:translateY(-4px);border-color:rgba(var(--gold-500-rgb),.55);box-shadow:0 20px 44px rgba(18,35,64,.12)}
.path-card__icon{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;
  background:rgba(var(--gold-500-rgb),.12);border:1px solid rgba(var(--gold-500-rgb),.30);color:var(--gold-600)}
.path-card__icon svg{width:24px;height:24px}
.path-card__title{font-family:var(--font-display);font-weight:700;font-size:1.18rem;line-height:1.2;color:var(--c-title)}
.path-card__desc{color:var(--c-muted);font-size:.95rem;line-height:1.55;flex:1}
.path-card__cta{display:inline-flex;align-items:center;gap:8px;margin-top:4px;font-weight:600;font-size:.92rem;color:var(--gold-600)}
.path-card__cta svg{width:16px;height:16px;transition:transform var(--dur-2) var(--ease-cubic)}
.path-card:hover .path-card__cta svg{transform:translateX(4px)}

/* ---- Bastidores (dentro da bagagem, fundo escuro) ---- */
.findings-block{margin-top:var(--sp-16);padding-top:var(--sp-12);border-top:1px solid var(--c-border)}
.findings__head{max-width:680px;margin-bottom:var(--sp-8)}
.findings__title{font-family:var(--font-display);font-weight:800;font-size:clamp(1.4rem,2.6vw,1.9rem);line-height:1.15;color:var(--c-title)}
.findings__sub{margin-top:12px;color:var(--c-muted);font-size:clamp(1rem,1.2vw,1.08rem);line-height:1.6}
.findings{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.finding{display:flex;flex-direction:column;gap:10px;background:var(--c-surface);
  border:1px solid var(--c-border);border-radius:var(--r-lg);padding:clamp(20px,2.4vw,26px);
  transition:border-color var(--dur-2) var(--ease-cubic)}
.finding:hover{border-color:rgba(var(--gold-500-rgb),.45)}
.finding__icon{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:rgba(var(--gold-500-rgb),.10);border:1px solid rgba(var(--gold-500-rgb),.28);color:var(--gold-400)}
.finding__icon svg{width:20px;height:20px}
.finding__title{font-family:var(--font-display);font-weight:700;font-size:1.08rem;line-height:1.25;color:var(--c-title)}
.finding__desc{color:var(--c-muted);font-size:.93rem;line-height:1.55}

/* ---- Responsivo das seções novas ---- */
@media (max-width:1024px){ .paths{grid-template-columns:repeat(2,1fr)} }
@media (max-width:560px){
  .paths{grid-template-columns:1fr}
  .findings{grid-template-columns:1fr}
}

/* ================================================================
   MENU MOBILE — painel sob a pílula (≤760px). O .nav-toggle vira X.
   Acionado por .is-menu-open (toggle via motion.js initMobileMenu).
   ================================================================ */
@media (max-width:760px){
  .site-header .container{position:relative}
  /* painel: escondido por padrão (já há .nav{display:none}); abre com .is-menu-open */
  .site-header.is-menu-open .nav{
    display:flex;flex-direction:column;align-items:stretch;gap:2px;
    position:absolute;top:calc(100% + 10px);left:0;right:0;
    background:rgba(10,20,40,.98);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid rgba(255,255,255,.10);border-radius:var(--r-md);
    padding:12px;box-shadow:0 24px 60px rgba(0,0,0,.5);max-height:calc(100svh - 120px);overflow:auto;
  }
  .site-header.is-menu-open .nav>a,
  .site-header.is-menu-open .nav__trigger{
    display:flex;align-items:center;width:100%;padding:12px 12px;border-radius:var(--r-sm);
    font-size:1.02rem;font-weight:500;color:var(--text-on-dark-muted)}
  .site-header.is-menu-open .nav>a:hover,
  .site-header.is-menu-open .nav__sub a:hover{background:rgba(255,255,255,.06);color:#fff}
  .site-header.is-menu-open .nav a::after{display:none} /* mata o underline animado no painel */
  .site-header.is-menu-open .nav__group{position:static}
  .site-header.is-menu-open .nav__trigger{justify-content:space-between;cursor:default}
  .site-header.is-menu-open .nav__trigger svg{transform:rotate(180deg)}
  .site-header.is-menu-open .nav__sub{
    position:static;transform:none;opacity:1;visibility:visible;pointer-events:auto;
    background:transparent;backdrop-filter:none;border:0;box-shadow:none;
    min-width:0;padding:0 0 6px 12px;display:flex}
  .site-header.is-menu-open .nav__sub a{font-size:.98rem}
  /* hambúrguer → X */
  .site-header.is-menu-open .nav-toggle span{background:transparent}
  .site-header.is-menu-open .nav-toggle span::before{top:0;transform:rotate(45deg)}
  .site-header.is-menu-open .nav-toggle span::after{top:0;transform:rotate(-45deg)}
}

/* ---- WhatsApp flutuante (presente em todas as páginas) ---- */
.wa-float{position:fixed;right:20px;bottom:20px;z-index:var(--z-sticky);
  width:56px;height:56px;border-radius:50%;display:grid;place-items:center;
  background:#25D366;color:#fff;box-shadow:0 12px 30px rgba(0,0,0,.32);
  transition:transform var(--dur-2) var(--ease-cubic),box-shadow var(--dur-2) var(--ease-cubic)}
.wa-float:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 16px 40px rgba(37,211,102,.45)}
.wa-float svg{width:30px;height:30px}
@media (max-width:760px){ .wa-float{right:16px;bottom:16px;width:52px;height:52px} }
@media (prefers-reduced-motion:reduce){ .wa-float{transition:none} }
