/* ============================================================
   MOVIA — Tecnologia que te move
   Design system + estilos  ·  estética clean / minimal
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* Brand gradient (do logo: índigo → azul → ciano) */
  --g-violet:#4b3fd6;
  --g-indigo:#5559e8;
  --g-blue:#4f78f0;
  --g-cyan:#2ec1e8;
  --grad-brand:linear-gradient(122deg,#4b3fd6 0%,#5160ec 42%,#2ec1e8 100%);
  --grad-soft:linear-gradient(122deg,#6a5cf0,#41a9ef);

  --accent:#4a5ff0;

  /* Tinta / neutros frios */
  --ink:#13151b;
  --ink-2:#3c4150;
  --muted:#7c8190;
  --line:rgba(18,20,28,.08);
  --line-2:rgba(18,20,28,.05);

  /* Fundos */
  --bg:#ffffff;
  --bg-2:#f6f7f9;
  --bg-3:#eef0f4;
  --ink-bg:#0c0e14;

  /* Tipografia */
  --sans:'Manrope',system-ui,sans-serif;
  --disp:'Space Grotesk','Manrope',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;

  --container:1180px;
  --radius:16px;
  --radius-lg:24px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);color:var(--ink);background:var(--bg);
  line-height:1.6;font-size:17px;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:rgba(79,120,240,.22)}

/* ---------- Layout helpers ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(20px,5vw,40px)}
.section{padding-block:clamp(76px,12vh,140px);position:relative}
.eyebrow{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--accent);font-weight:500;display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:24px;height:1.5px;background:var(--grad-brand);border-radius:2px}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:"";width:24px;height:1.5px;background:var(--grad-brand);border-radius:2px}

h1,h2,h3{font-family:var(--disp);font-weight:600;line-height:1.04;letter-spacing:-.03em;color:var(--ink)}
.lead{font-size:clamp(1.06rem,1.5vw,1.3rem);color:var(--ink-2);line-height:1.55;font-weight:400}
.grad-text{
  background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;padding:.92em 1.5em;border-radius:100px;
  font-weight:600;font-size:.98rem;letter-spacing:-.01em;white-space:nowrap;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),background .3s,border-color .3s;
}
.btn .ico{display:inline-flex;transition:transform .4s var(--ease)}
.btn-primary{
  background:var(--grad-brand);color:#fff;
  box-shadow:0 6px 22px -8px rgba(75,63,214,.55),0 2px 6px -2px rgba(46,193,232,.4);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 34px -10px rgba(75,63,214,.65),0 3px 10px -2px rgba(46,193,232,.5)}
.btn-primary:hover .ico{transform:translateX(3px)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn-lg{padding:1.08em 1.9em;font-size:1.05rem}
.wa-ico{width:18px;height:18px;flex:none}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:60;border-bottom:1px solid transparent;
  transition:background .35s,border-color .35s,backdrop-filter .35s;
}
.nav.scrolled{
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom-color:var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;height:72px}
.brand{display:flex;align-items:center;gap:11px}
.brand img{width:32px;height:32px}
.brand .wm{font-family:var(--disp);font-weight:700;font-size:1.3rem;letter-spacing:-.02em;color:var(--ink)}
.brand .wm small{display:block;font-family:var(--mono);font-weight:500;font-size:.5rem;letter-spacing:.42em;color:var(--muted);margin-top:-3px;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:34px;flex:1;justify-content:center}
.nav-links a{font-size:.94rem;font-weight:500;color:var(--ink-2);position:relative;transition:color .25s;white-space:nowrap}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1.5px;background:var(--grad-brand);transition:width .3s var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{width:100%}
.nav-links a.nav-contact{color:var(--ink);font-weight:600}
.nav-cta{display:flex;align-items:center;gap:14px}

/* hambúrguer (mobile) */
.nav-toggle{display:none;width:42px;height:42px;border-radius:12px;border:1px solid var(--line);
  background:rgba(255,255,255,.6);backdrop-filter:blur(8px);align-items:center;justify-content:center}
.nav-toggle span{position:relative;width:18px;height:2px;border-radius:2px;background:var(--ink);transition:background .2s}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;width:18px;height:2px;border-radius:2px;background:var(--ink);transition:transform .25s var(--ease),top .25s var(--ease)}
.nav-toggle span::before{top:-6px}.nav-toggle span::after{top:6px}
.nav.open .nav-toggle span{background:transparent}
.nav.open .nav-toggle span::before{top:0;transform:rotate(45deg)}
.nav.open .nav-toggle span::after{top:0;transform:rotate(-45deg)}

/* ============================================================
   HERO — clean / claro (estilo Apple)
   ============================================================ */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  background:var(--bg);color:var(--ink);overflow:hidden;isolation:isolate;
  padding:140px 0 112px;text-align:center;
}
/* mesh de gradiente da marca — claro, à deriva lenta */
.hero-aurora{
  position:absolute;inset:-30% -20%;z-index:0;filter:blur(100px);opacity:.5;
  background:
    radial-gradient(34% 42% at 24% 28%,rgba(75,63,214,.30) 0,transparent 64%),
    radial-gradient(30% 38% at 78% 24%,rgba(46,193,232,.26) 0,transparent 62%),
    radial-gradient(40% 44% at 60% 86%,rgba(81,96,236,.20) 0,transparent 64%);
  animation:aurora 26s ease-in-out infinite;will-change:transform;
}
@keyframes aurora{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(-3%,2%) scale(1.06)}
  66%{transform:translate(4%,-2%) scale(1.03)}
}
/* textura de ondas concêntricas (motivo de movimento) — substitui a malha quadriculada de IA */
.hero-rings{
  position:absolute;inset:0;z-index:1;pointer-events:none;will-change:transform,opacity;
  background:repeating-radial-gradient(circle at 50% 36%,rgba(75,63,214,.06) 0 1.5px,transparent 1.5px 72px);
  -webkit-mask-image:radial-gradient(ellipse 80% 72% at 50% 38%,#000 6%,transparent 74%);
  mask-image:radial-gradient(ellipse 80% 72% at 50% 38%,#000 6%,transparent 74%);
  animation:ripple 16s ease-in-out infinite;
}
@keyframes ripple{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.05);opacity:1}}
.hero-streak{display:none}

.hero-inner{position:relative;z-index:3;width:100%;display:flex;flex-direction:column;align-items:center}
.hero-status{
  display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  padding:.55em 1.05em;border:1px solid var(--line);border-radius:100px;
  background:rgba(255,255,255,.6);backdrop-filter:blur(8px);margin-bottom:30px;
}
.hero-status .dot{width:7px;height:7px;border-radius:50%;background:#34d399;box-shadow:0 0 0 0 rgba(52,211,153,.6);animation:ping 2.4s ease-out infinite}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(52,211,153,.5)}70%,100%{box-shadow:0 0 0 9px rgba(52,211,153,0)}}

.hero-title{
  font-family:var(--disp);font-weight:600;letter-spacing:-.045em;line-height:.94;color:var(--ink);
  font-size:clamp(3.2rem,11vw,9rem);
}
.hero-title .line{display:block;overflow:hidden;padding-block:.04em}
.hero-title .line>i{display:inline-block;font-style:normal}
.js .hero-title .line>i{transform:translateY(112%);will-change:transform}
.js .hero-anim .hero-title .line>i{animation:lineUp 1.05s var(--ease) forwards}
.hero-anim .hero-title .l2>i{animation-delay:.1s}
@keyframes lineUp{to{transform:none}}

/* a palavra "move" — gradiente vivo + traço de movimento (assinatura Kinetic Light) */
.move{position:relative;display:inline-block}
.move .move-main{
  background:linear-gradient(100deg,#5b4ef0 0%,#4f78f0 38%,#2ec1e8 62%,#5b4ef0 100%);
  background-size:280% 100%;-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:sweep 6s linear infinite;
}
@keyframes sweep{to{background-position:280% 0}}
.move .g{
  position:absolute;left:0;top:0;pointer-events:none;
  background:linear-gradient(100deg,#6a5cf0,#2ec1e8);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;opacity:0;
}
.move .g1{animation:trail 3.6s ease-in-out infinite}
.move .g2{animation:trail 3.6s ease-in-out infinite .16s}
.move .g3{animation:trail 3.6s ease-in-out infinite .32s}
@keyframes trail{0%{opacity:0;transform:translateX(0)}35%{opacity:.22;transform:translateX(-.1em)}75%,100%{opacity:0;transform:translateX(-.26em)}}

.hero-lead{margin-top:30px;max-width:54ch;font-size:clamp(1.08rem,1.5vw,1.3rem);color:var(--ink-2);line-height:1.55}
.hero-cta{margin-top:40px;display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.js .hero-reveal{opacity:0;transform:translateY(20px)}
.js .hero-anim .hero-reveal{animation:rise 1s var(--ease) forwards}
.hero-anim .hr1{animation-delay:.5s}.hero-anim .hr2{animation-delay:.62s}.hero-anim .hr3{animation-delay:.74s}

@keyframes rise{to{opacity:1;transform:none}}

/* faixa de palavras-chave na base do hero (clara, fina) */
.hero-band{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:18px 0;border-top:1px solid var(--line);overflow:hidden;background:linear-gradient(180deg,transparent,rgba(246,247,249,.55))}
.hero-band-track{display:flex;width:max-content;animation:scroll-x 32s linear infinite}
.hero-band-track span{
  font-family:var(--disp);font-weight:600;font-size:clamp(1.05rem,2.3vw,1.65rem);letter-spacing:-.02em;
  padding-inline:26px;display:flex;align-items:center;gap:26px;color:var(--muted);
}
.hero-band-track span b{color:transparent;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text}
.hero-band-track span::after{content:"";width:7px;height:7px;border-radius:50%;background:var(--grad-brand)}
@keyframes scroll-x{to{transform:translateX(-50%)}}

/* ============================================================
   Reveal on scroll
   ============================================================ */
.reveal{transition:opacity .85s var(--ease),transform .85s var(--ease)}
.js .reveal{opacity:0;transform:translateY(30px)}
.reveal.in{opacity:1;transform:none}
[data-stagger]>*{transition:opacity .75s var(--ease),transform .75s var(--ease)}
.js [data-stagger]>*{opacity:0;transform:translateY(28px)}
[data-stagger].in>*{opacity:1;transform:none}
[data-stagger].in>*:nth-child(2){transition-delay:.09s}
[data-stagger].in>*:nth-child(3){transition-delay:.18s}
[data-stagger].in>*:nth-child(4){transition-delay:.27s}
[data-stagger].in>*:nth-child(5){transition-delay:.36s}

/* ============================================================
   SEÇÃO — cabeçalho central
   ============================================================ */
.head{max-width:720px;margin-bottom:18px}
.head.center{margin-inline:auto;text-align:center}
.head h2{font-size:clamp(2.2rem,4.6vw,3.5rem);margin-top:18px}
.head p{margin-top:18px}

/* ============================================================
   POR QUE A MOVIA — pergunta forte, língua de PME
   ============================================================ */
.why{background:var(--ink-bg);color:#fff;position:relative;overflow:hidden}
.why .glow{position:absolute;width:560px;height:560px;border-radius:50%;background:var(--grad-brand);filter:blur(100px);opacity:.28;left:-160px;top:-160px;pointer-events:none;will-change:transform}
.why .glow.g2{right:-200px;bottom:-220px;left:auto;top:auto;background:var(--grad-soft);opacity:.2}
.why .inner{position:relative;z-index:2}
.why .ask{max-width:920px}
.why .eyebrow{color:#9fc4ff}
.why .ask h2{
  color:#fff;font-size:clamp(2.6rem,7vw,5.4rem);letter-spacing:-.04em;margin-top:22px;line-height:1.0;
}
.why .ask h2 em{font-style:normal}
.why .ask .answer{margin-top:30px;max-width:60ch;font-size:clamp(1.15rem,1.8vw,1.5rem);color:rgba(255,255,255,.82);line-height:1.5;font-weight:400}
.why .ask .answer strong{color:#fff;font-weight:600}
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:64px;border-top:1px solid rgba(255,255,255,.14)}
.why-item{padding:38px 40px 40px 0;border-bottom:1px solid rgba(255,255,255,.14)}
.why-item:nth-child(odd){border-right:1px solid rgba(255,255,255,.14);padding-right:48px}
.why-item:nth-child(even){padding-left:48px}
.why-item .n{font-family:var(--mono);font-size:.8rem;color:#8fb4ff;margin-bottom:18px;display:block}
.why-item h3{color:#fff;font-size:1.62rem;margin-bottom:12px;letter-spacing:-.025em}
.why-item p{color:rgba(255,255,255,.66);font-size:1.04rem;line-height:1.6}
.why-cta{margin-top:56px;display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.why-cta .line{color:rgba(255,255,255,.7);font-size:1.05rem}

/* ============================================================
   PROCESSO
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:48px}
.step{position:relative;padding:34px 26px 30px 0}
.step .bar{height:3px;background:var(--line);border-radius:4px;position:relative;overflow:hidden;margin-bottom:26px}
.step .bar::after{content:"";position:absolute;inset:0;width:0;background:var(--grad-brand);border-radius:4px;transition:width 1s var(--ease)}
.steps.in .step .bar::after{width:100%}
.no-js .step .bar::after{width:100%}
.steps.in .step:nth-child(2) .bar::after{transition-delay:.15s}
.steps.in .step:nth-child(3) .bar::after{transition-delay:.3s}
.steps.in .step:nth-child(4) .bar::after{transition-delay:.45s}
.step .num{font-family:var(--mono);font-size:.78rem;color:var(--accent);margin-bottom:12px}
.step h3{font-size:1.3rem;margin-bottom:10px}
.step p{color:var(--ink-2);font-size:.98rem;padding-right:14px}

/* ============================================================
   CTA FINAL
   ============================================================ */
.cta{position:relative;overflow:hidden;background:var(--bg-2);border-top:1px solid var(--line)}
.cta::before{
  content:"";position:absolute;inset:-20%;z-index:0;pointer-events:none;filter:blur(90px);opacity:.6;
  background:
    radial-gradient(34% 40% at 28% 30%,rgba(75,63,214,.22),transparent 64%),
    radial-gradient(30% 38% at 76% 72%,rgba(46,193,232,.20),transparent 62%);
}
.cta::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:repeating-radial-gradient(circle at 50% 46%,rgba(75,63,214,.05) 0 1.5px,transparent 1.5px 70px);
  -webkit-mask-image:radial-gradient(ellipse 80% 90% at 50% 50%,#000 4%,transparent 72%);
  mask-image:radial-gradient(ellipse 80% 90% at 50% 50%,#000 4%,transparent 72%);
}
.cta .inner{position:relative;z-index:2;text-align:center;max-width:820px;margin-inline:auto}
.cta h2{font-size:clamp(2.4rem,5.5vw,4.2rem);margin-top:20px}
.cta p{color:var(--ink-2);margin:24px auto 0;max-width:50ch;font-size:1.15rem}
.cta .cta-row{margin-top:40px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta .sub{margin-top:22px;font-family:var(--mono);font-size:.78rem;letter-spacing:.04em;color:var(--muted)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--bg);border-top:1px solid var(--line);padding-block:60px 34px}
.footer .top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid var(--line)}
.footer .brand img{width:36px;height:36px}
.footer .slogan{margin-top:20px;color:var(--ink-2);max-width:34ch;font-size:1.02rem}
.footer h5{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.footer ul{list-style:none;display:grid;gap:12px}
.footer ul a{color:var(--ink-2);font-size:.98rem;transition:color .25s}
.footer ul a:hover{color:var(--ink)}
.footer .bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:26px;color:var(--muted);font-size:.84rem;flex-wrap:wrap}
.footer .bottom .mono{font-family:var(--mono)}

/* ============================================================
   Grain overlay (sutil)
   ============================================================ */
/* SEM mix-blend-mode: blend num overlay fixo de tela cheia re-compõe o viewport
   inteiro a cada frame de scroll (causava o "scroll pesado"). Overlay estático é barato. */
.grain{position:fixed;inset:0;pointer-events:none;z-index:1000;opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ============================================================
   Responsivo
   ============================================================ */
@media(max-width:920px){
  .why-grid{grid-template-columns:1fr}
  .why-item{padding:32px 0!important;border-right:none!important}
  .steps{grid-template-columns:1fr 1fr;gap:8px 24px}
  .footer .top{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .nav-toggle{display:flex}
  .nav.open{background:rgba(255,255,255,.96);backdrop-filter:saturate(160%) blur(16px);border-bottom-color:var(--line)}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:rgba(255,255,255,.97);backdrop-filter:saturate(160%) blur(16px);
    border-bottom:1px solid var(--line);padding:6px 0 10px;
    clip-path:inset(0 0 100% 0);opacity:0;pointer-events:none;
    transition:clip-path .38s var(--ease),opacity .25s;
  }
  .nav.open .nav-links{clip-path:inset(0 0 0 0);opacity:1;pointer-events:auto}
  .nav-links a{padding:13px clamp(20px,5vw,40px);font-size:1.02rem}
  .nav-links a::after{display:none}
  .nav-links a.nav-contact{color:var(--accent)}
}
@media(max-width:560px){
  body{font-size:16px}
  .steps{grid-template-columns:1fr}
  .footer .top{grid-template-columns:1fr}
}

/* ============================================================
   BOTÃO WhatsApp (secundário verde)
   ============================================================ */
.btn-wa{background:#1fb855;color:#fff;box-shadow:0 6px 22px -8px rgba(31,184,85,.55)}
.btn-wa:hover{transform:translateY(-2px);box-shadow:0 14px 34px -10px rgba(31,184,85,.7)}
.btn-wa .wa-ico{width:18px;height:18px}

/* ============================================================
   HERO — cue de rolagem + faixa de prova
   ============================================================ */
.hero-cue{margin-top:36px;display:inline-flex;flex-direction:column;align-items:center;gap:7px;color:var(--muted);
  font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase}
.hero-cue .ln{width:1.5px;height:30px;border-radius:2px;background:linear-gradient(var(--accent),transparent);position:relative;overflow:hidden}
.hero-cue .ln::after{content:"";position:absolute;left:0;right:0;top:-40%;height:40%;background:var(--accent);border-radius:2px}
.js .hero-cue .ln::after{animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{top:-40%}70%,100%{top:120%}}

/* ============================================================
   PROVA 1 · Faixa de logos (placeholders honestos)
   ============================================================ */
.trust{padding-block:clamp(34px,6vh,56px);border-bottom:1px solid var(--line);background:var(--bg);position:relative;z-index:4;overflow:hidden}
.trust .tlabel{text-align:center;font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:28px}
.logo-marquee{position:relative;width:100%;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.logo-track{display:flex;align-items:center;gap:clamp(42px,7vw,86px);width:max-content;animation:logoscroll 40s linear infinite}
.logo-track img{height:29px;width:auto;flex:none;opacity:.6;filter:grayscale(1);transition:opacity .3s var(--ease),filter .3s var(--ease),transform .3s var(--ease)}
.logo-track img:hover{opacity:1;filter:none;transform:translateY(-2px)}
@keyframes logoscroll{to{transform:translateX(-50%)}}
.trust:hover .logo-track{animation-play-state:paused}

/* ============================================================
   PROVA 2 · Resultados (números grandes)
   ============================================================ */
.results{background:var(--bg);position:relative;overflow:hidden}
.results .rgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:clamp(26px,4vw,46px);margin-top:clamp(40px,6vh,64px)}
.metric{position:relative;padding-top:26px}
.metric::before{content:"";position:absolute;top:0;left:0;width:48px;height:3px;border-radius:99px;background:var(--grad-brand)}
.metric .num{font-family:var(--disp);font-weight:600;letter-spacing:-.04em;line-height:.95;font-size:clamp(2.9rem,7vw,4.4rem);color:var(--ink)}
.metric .num .u{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.metric .mlab{margin-top:14px;color:var(--ink-2);font-size:1.04rem;line-height:1.45;max-width:26ch}
.metric .mnote{margin-top:10px;font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

/* ============================================================
   PROVA 3 · Cases (Desafio → Ação → Resultado)
   ============================================================ */
.cases{background:var(--bg-2);border-top:1px solid var(--line)}
.cases .cgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:clamp(40px,6vh,60px)}
.case-card{position:relative;display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s}
.case-card:hover{transform:translateY(-5px);box-shadow:0 32px 64px -36px rgba(20,22,40,.4);border-color:transparent}
.case-thumb{height:116px;position:relative;display:flex;align-items:flex-end;padding:14px;background:var(--grad-brand)}
.case-card:nth-child(2) .case-thumb{background:linear-gradient(122deg,#1f9d8f,#43c9a0)}
.case-card:nth-child(3) .case-thumb{background:linear-gradient(122deg,#c0452e,#e0903a)}
.case-thumb .badge{font-family:var(--mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:rgba(12,14,20,.28);backdrop-filter:blur(4px);padding:.45em .8em;border-radius:99px}
.case-body{padding:24px;display:flex;flex-direction:column;flex:1}
.case-body .seg{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.case-body h3{font-size:1.22rem;letter-spacing:-.02em;line-height:1.15;margin-bottom:14px}
.case-line{display:flex;gap:9px;font-size:.94rem;color:var(--ink-2);line-height:1.45;margin-bottom:9px}
.case-line svg{width:16px;height:16px;flex:none;margin-top:3px;color:var(--g-blue)}
.case-result{margin-top:auto;padding-top:16px;border-top:1px solid var(--line);display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.case-result .r{font-family:var(--disp);font-weight:600;font-size:1.55rem;letter-spacing:-.02em;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.case-result .rl{font-size:.86rem;color:var(--ink-2)}
.case-ill{display:block;margin-top:14px;font-family:var(--mono);font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

/* ============================================================
   PROVA 4 · Depoimentos
   ============================================================ */
.tmls{background:var(--bg);border-top:1px solid var(--line)}
.tmls .tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:clamp(40px,6vh,60px)}
.tcard{display:flex;flex-direction:column;gap:20px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.tcard:hover{transform:translateY(-4px);box-shadow:0 30px 60px -38px rgba(20,22,40,.35)}
.tcard .quote{font-size:1.06rem;line-height:1.55;color:var(--ink);letter-spacing:-.01em}
.tcard .quote .qm{font-family:var(--disp);font-weight:700;color:var(--accent);margin-right:.12em}
.tperson{display:flex;align-items:center;gap:13px;margin-top:auto}
.tperson .tav{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-family:var(--disp);font-weight:700;font-size:1rem;color:#fff;background:var(--grad-brand);flex:none}
.tperson .tn{font-weight:600;font-size:.98rem;letter-spacing:-.01em}
.tperson .tr{font-size:.82rem;color:var(--muted);margin-top:1px}
.tcard .till{font-family:var(--mono);font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

/* nota "ilustrativo" comum às provas */
.proof-foot{margin-top:clamp(28px,4vh,40px);text-align:center;font-family:var(--mono);font-size:.64rem;letter-spacing:.06em;color:var(--muted)}

/* ============================================================
   FOOTER — linha de confiança
   ============================================================ */
.footer .trustline{display:flex;align-items:center;gap:10px;margin-top:20px;color:var(--muted);font-size:.82rem}
.footer .trustline .dotg{width:7px;height:7px;border-radius:50%;background:#34d399;flex:none;box-shadow:0 0 0 4px rgba(52,211,153,.14)}

/* ============================================================
   Performance — content-visibility (blocos sem âncora)
   ============================================================ */
.tmls,.footer{content-visibility:auto;contain-intrinsic-size:auto 700px}

/* ============================================================
   Responsivo — seções novas
   ============================================================ */
@media(max-width:880px){
  .cases .cgrid{grid-template-columns:1fr}
  .tmls .tgrid{grid-template-columns:1fr}
}
@media(max-width:760px){
  .logos-row{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:480px){
  .logos-row{grid-template-columns:repeat(2,1fr)}
}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto}
  .rise{opacity:1;transform:none}
  .reveal,[data-stagger]>*{opacity:1;transform:none}
  .hero-press{animation:none}
  .move::after{transform:scaleX(1)}
}
