/* ════════════════════════════════════════════════════════════════════
   M PERÍCIAS · HOME v2 · institucional editorial
   Paleta: #073949 deep · #3a9d98 teal · #efe3d1 cream · #548b9d mid
═══════════════════════════════════════════════════════════════════════ */
:root{
  /* core */
  --deep:#03222c; --deep-1:#052e3b; --deep-2:#073949; --deep-3:#0b4859; --deep-4:#0f5567;
  --teal:#3a9d98; --teal-bright:#4eb4ae; --teal-soft:#5fc5bf; --teal-deep:#2d847f; --teal-darker:#1e6360;
  --mid:#548b9d; --mid-light:#6da3b4;
  --cream:#efe3d1; --cream-2:#f5ecd9; --cream-warm:#ebdfca; --cream-deep:#dccab0;
  --paper:#faf7f0;
  --ink:#021820; --ink-soft:#053040;

  /* acento dourado · vida e calor contrastando com o teal */
  --gold:#e4b659; --gold-bright:#f0c772; --gold-soft:#f7d896; --gold-deep:#b88c30;
  --gold-glow:rgba(228,182,89,.40);
  --gold-20:rgba(228,182,89,.20); --gold-10:rgba(228,182,89,.10);

  /* texto */
  --pure:#ffffff;
  --w98:rgba(255,255,255,.98); --w90:rgba(255,255,255,.90); --w75:rgba(255,255,255,.75);
  --w60:rgba(255,255,255,.60); --w40:rgba(255,255,255,.40); --w25:rgba(255,255,255,.25);
  --w15:rgba(255,255,255,.15); --w10:rgba(255,255,255,.10); --w05:rgba(255,255,255,.05);

  /* ink translúcidos (light) */
  --i90:rgba(2,24,32,.92); --i75:rgba(2,24,32,.75); --i55:rgba(2,24,32,.55);
  --i35:rgba(2,24,32,.35); --i20:rgba(2,24,32,.20); --i12:rgba(2,24,32,.12); --i08:rgba(2,24,32,.08);

  /* teal acentos */
  --t50:rgba(58,157,152,.50); --t30:rgba(58,157,152,.30); --t20:rgba(58,157,152,.20);
  --t12:rgba(58,157,152,.12); --t08:rgba(58,157,152,.08);

  --ff:'Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --ease:cubic-bezier(.2,.8,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-expo:cubic-bezier(.19,1,.22,1);
  --r-sm:10px; --r-md:14px; --r-lg:20px; --r-xl:28px; --r-pill:999px;
  --sh-1:0 6px 20px rgba(0,0,0,.20);
  --sh-2:0 16px 40px rgba(0,0,0,.30);
  --sh-3:0 32px 70px rgba(0,0,0,.45);
  --sh-teal:0 16px 40px rgba(58,157,152,.30);

  /* tamanhos */
  --hdr-h:84px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;overflow-x:hidden;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff);background:var(--deep);color:var(--pure);
  font-weight:400;line-height:1.55;letter-spacing:-.005em;
  overflow-x:clip;position:relative;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:'ss01','cv11','liga','kern','tnum';
}
img,svg,video,canvas{display:block;max-width:100%}
a{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;cursor:pointer}
button{font-family:inherit;border:none;background:none;cursor:pointer;color:inherit;padding:0}
ul{list-style:none}
::selection{background:var(--teal);color:var(--pure)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--deep)}
::-webkit-scrollbar-thumb{background:var(--teal-darker);border-radius:6px}
::-webkit-scrollbar-thumb:hover{background:var(--teal)}

/* ═══ AMBIENTE ═══ */
body::before{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 50% at 50% -10%, rgba(58,157,152,.10), transparent 60%),
    radial-gradient(ellipse 60% 40% at 100% 100%, rgba(84,139,157,.06), transparent 65%),
    linear-gradient(180deg, var(--deep) 0%, var(--ink) 60%, var(--deep) 100%);
}
.grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 240 240' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 .85 0 0 0 0 .89 0 0 0 0 .82 0 0 0 .8 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
#cursor-glow{
  position:fixed;width:480px;height:480px;border-radius:50%;
  background:radial-gradient(circle,rgba(58,157,152,.18),transparent 65%);
  mix-blend-mode:screen;pointer-events:none;z-index:2;opacity:0;
  transform:translate(-50%,-50%);transition:opacity .6s;will-change:transform;display:none;
}
@media(hover:hover) and (pointer:fine){#cursor-glow{display:block}}

/* ═══ UTILS ═══ */
.container{max-width:1340px;margin:0 auto;padding:0 28px;position:relative}
.container-wide{max-width:1560px;margin:0 auto;padding:0 28px;position:relative}
.section{padding:140px 0;position:relative;overflow:hidden}
.section-cream{background:linear-gradient(180deg, var(--cream-2) 0%, var(--cream) 100%);color:var(--ink)}
.section-paper{background:var(--paper);color:var(--ink)}
.section-deep{background:linear-gradient(180deg, var(--ink) 0%, var(--deep) 100%);color:var(--pure)}

.eyebrow{
  font-size:11px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;
  color:var(--teal-bright);display:inline-flex;align-items:center;gap:14px;
  font-variant-numeric:tabular-nums;
}
.eyebrow::before{content:'';width:28px;height:1px;background:var(--teal-bright)}
.section-cream .eyebrow, .section-paper .eyebrow{color:var(--teal-darker)}
.section-cream .eyebrow::before, .section-paper .eyebrow::before{background:var(--teal-darker)}

.h-xl{font-size:clamp(40px,5.8vw,82px);font-weight:700;line-height:1.0;letter-spacing:-.032em}
.h-lg{font-size:clamp(32px,4.4vw,58px);font-weight:700;line-height:1.04;letter-spacing:-.028em}
.h-md{font-size:clamp(26px,3vw,40px);font-weight:700;line-height:1.1;letter-spacing:-.022em}
.h-sm{font-size:clamp(20px,1.8vw,26px);font-weight:600;line-height:1.2;letter-spacing:-.015em}
.h-xl em, .h-lg em, .h-md em{
  font-style:normal;font-weight:700;
  color:var(--teal-bright);letter-spacing:-.022em;
}
.section-cream .h-xl em, .section-cream .h-lg em, .section-cream .h-md em,
.section-paper .h-xl em, .section-paper .h-lg em, .section-paper .h-md em{color:var(--teal-darker)}

.lead{font-size:clamp(16px,1.3vw,19px);line-height:1.6;color:var(--w90);font-weight:400}
.body{font-size:15px;line-height:1.7;color:var(--w75);font-weight:400}
.section-cream .lead, .section-paper .lead, .split-cream .lead{color:var(--i75)}
.section-cream .body, .section-paper .body, .split-cream .body{color:var(--i75)}
.split-cream .body strong{color:var(--ink);font-weight:600}

.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-stagger > *{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal-stagger.in > *{opacity:1;transform:translateY(0)}
.reveal-stagger.in > *:nth-child(1){transition-delay:0s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.07s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.14s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.21s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.28s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.35s}
.reveal-stagger.in > *:nth-child(7){transition-delay:.42s}
.reveal-stagger.in > *:nth-child(8){transition-delay:.49s}

/* hairlines decorativas (separadores entre seções) */
.hairline{
  position:relative;height:1px;width:100%;
  background:linear-gradient(90deg, transparent, var(--t50) 30%, var(--t50) 70%, transparent);
  opacity:.6;
}

/* ═══════════════════════════════════════════════════════════════════
   HEADER · full-width ancorado, institucional
═══════════════════════════════════════════════════════════════════════ */
.header{
  position:fixed;top:0;left:0;right:0;z-index:90;
  height:var(--hdr-h);
  /* DEFAULT = topo, sobre a hero clara → frosted claro, mistura com a hero */
  background:rgba(244,247,247,.70);
  backdrop-filter:blur(22px) saturate(1.5);
  -webkit-backdrop-filter:blur(22px) saturate(1.5);
  border-bottom:1px solid rgba(2,24,32,.06);
  transition:background .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease);
}
.header.is-scrolled{
  /* rolando sobre seções escuras → dark glass */
  background:rgba(2,24,32,.88);
  border-bottom-color:rgba(58,157,152,.18);
  box-shadow:0 10px 30px -12px rgba(0,0,0,.4);
}
/* ── PÁGINAS INTERNAS: header no fluxo no topo; vira barra fixa ao rolar (reveal) ──
   No topo (scroll 0) é position:relative → NUNCA sobrepõe o conteúdo (desktop+mobile).
   Ao rolar além da própria altura, o JS (footer) adiciona .is-stuck → vira fixed e
   "desce" suave. Um spacer (.hdr-spacer) reserva a altura nesse instante, então NÃO
   existe pulo de layout. */
body.page-internal .header{
  position:relative; top:auto;
  background:#fff;
  -webkit-backdrop-filter:none; backdrop-filter:none;
  border-bottom:1px solid rgba(2,24,32,.08);
  box-shadow:0 1px 0 rgba(2,24,32,.03);
}
body.page-internal .header.is-stuck{
  position:fixed; top:0; left:0; right:0; z-index:95;
  background:rgba(255,255,255,.92);
  -webkit-backdrop-filter:blur(16px) saturate(1.5); backdrop-filter:blur(16px) saturate(1.5);
  border-bottom:1px solid rgba(2,24,32,.07);
  box-shadow:0 12px 32px -16px rgba(2,24,32,.3);
  animation:hdrReveal .34s cubic-bezier(.22,1,.36,1) both;
}
@keyframes hdrReveal{ from{ transform:translateY(-100%) } to{ transform:translateY(0) } }
/* spacer que reserva a altura do header quando ele fica fixed (anti-pulo) */
body.page-internal .hdr-spacer{ height:0; flex:0 0 auto; pointer-events:none; }
.header-inner{
  max-width:1480px;margin:0 auto;height:100%;padding:0 28px;
  display:flex;align-items:center;gap:16px;
}

/* LOGO · tile escuro (logo é branca → tile garante leitura em qualquer estado) */
.h-logo{display:inline-flex;align-items:center;flex-shrink:0;height:100%}
.h-logo .logo-tile{
  display:grid;place-items:center;height:62px;padding:0 20px;border-radius:16px;
  background:linear-gradient(160deg, #08495a 0%, #03222c 100%);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12), 0 10px 24px -8px rgba(2,24,32,.45);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.h-logo:hover .logo-tile{transform:translateY(-1px);box-shadow:inset 0 1px 0 rgba(255,255,255,.16), 0 16px 30px -8px rgba(2,24,32,.5)}
.h-logo .logo-tile img{height:42px;width:auto;display:block}

.h-divider{width:1px;height:26px;background:rgba(2,24,32,.10);flex-shrink:0;margin:0 6px;transition:background .4s var(--ease)}
.is-scrolled .h-divider{background:rgba(255,255,255,.10)}

.h-nav{display:flex;align-items:center;gap:2px;flex-shrink:0}
.h-nav a{
  display:inline-flex;align-items:center;gap:6px;padding:9px 13px;border-radius:10px;
  color:var(--i55);font-size:13.5px;font-weight:550;letter-spacing:-.006em;white-space:nowrap;
  transition:all .2s var(--ease);
}
.h-nav a:hover{background:rgba(2,24,32,.05);color:var(--ink)}
.is-scrolled .h-nav a{color:var(--w75)}
.is-scrolled .h-nav a:hover{background:rgba(255,255,255,.06);color:#fff}

.h-spacer{flex:1}

.h-cta-secondary{
  display:inline-flex;align-items:center;gap:8px;padding:0 16px;height:42px;border-radius:12px;
  color:var(--ink-soft);font-size:13.5px;font-weight:600;letter-spacing:-.004em;white-space:nowrap;
  border:1px solid rgba(2,24,32,.12);background:rgba(255,255,255,.5);
  transition:all .2s var(--ease);
}
.h-cta-secondary:hover{background:#fff;border-color:var(--teal);color:var(--ink)}
.h-cta-secondary i{color:var(--teal-darker);font-size:12px}
.is-scrolled .h-cta-secondary{color:var(--w90);border-color:rgba(255,255,255,.12);background:rgba(255,255,255,.04)}
.is-scrolled .h-cta-secondary:hover{background:rgba(255,255,255,.08);border-color:var(--t30);color:#fff}
.is-scrolled .h-cta-secondary i{color:var(--teal-bright)}

.h-cta-primary{
  display:inline-flex;align-items:center;gap:8px;padding:0 20px;height:46px;border-radius:12px;
  background:linear-gradient(180deg, var(--teal-bright), var(--teal) 50%, var(--teal-deep));
  color:#fff;font-size:13.5px;font-weight:600;letter-spacing:-.003em;white-space:nowrap;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.30), 0 12px 26px -6px rgba(45,132,127,.45);
  transition:all .25s var(--ease);
}
.h-cta-primary:hover{transform:translateY(-1px);filter:brightness(1.06);box-shadow:inset 0 1px 0 rgba(255,255,255,.35), 0 18px 34px -6px rgba(45,132,127,.55)}
.h-cta-primary i{font-size:11px}

.h-hamb{
  display:none;width:42px;height:42px;border-radius:12px;
  border:1px solid rgba(2,24,32,.12);background:rgba(255,255,255,.5);
  align-items:center;justify-content:center;color:var(--ink);font-size:15px;
}
.is-scrolled .h-hamb{border-color:rgba(255,255,255,.10);background:rgba(255,255,255,.04);color:#fff}
.h-hamb:active{transform:scale(.94)}

/* ═══════════════════════════════════════════════════════════════════
   MENU MOBILE · drawer premium
═══════════════════════════════════════════════════════════════════════ */
.mnav{position:fixed;inset:0;z-index:200;visibility:hidden;pointer-events:none}
.mnav.is-open{visibility:visible;pointer-events:auto}
.mnav-backdrop{
  position:absolute;inset:0;background:rgba(2,16,22,.55);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;transition:opacity .4s var(--ease);
}
.mnav.is-open .mnav-backdrop{opacity:1}
.mnav-panel{
  position:absolute;top:0;right:0;bottom:0;
  width:min(88vw, 400px);
  display:flex;flex-direction:column;
  padding:20px 22px calc(22px + env(safe-area-inset-bottom));
  background:linear-gradient(180deg, var(--deep-1), var(--ink));
  border-left:1px solid var(--w10);
  box-shadow:-30px 0 80px rgba(0,0,0,.5);
  transform:translateX(100%);
  transition:transform .42s var(--ease-out);
  overflow-y:auto;overscroll-behavior:contain;
}
.mnav.is-open .mnav-panel{transform:translateX(0)}
.mnav-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px}
.mnav-top .logo-tile{height:58px;padding:0 18px;border-radius:14px}
.mnav-top .logo-tile img{height:36px}
.mnav-close{
  width:44px;height:44px;border-radius:12px;flex-shrink:0;
  border:1px solid var(--w10);background:var(--w05);color:#fff;font-size:17px;
  display:grid;place-items:center;transition:all .2s var(--ease);
}
.mnav-close:active{transform:scale(.92);background:var(--w10)}
.mnav-links{display:flex;flex-direction:column;gap:4px;margin-bottom:24px}
.mnav-links a{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 14px;border-radius:14px;
  color:#fff;font-size:17px;font-weight:600;letter-spacing:-.01em;
  border:1px solid transparent;transition:all .2s var(--ease);
}
.mnav-links a span{display:inline-flex;align-items:center;gap:14px}
.mnav-links a span > i{color:var(--teal-bright);font-size:15px;width:20px;text-align:center}
.mnav-links a > i:last-child{color:var(--w25);font-size:12px;transition:transform .2s var(--ease)}
.mnav-links a:active{background:rgba(58,157,152,.10);border-color:var(--t20)}
.mnav-links a:active > i:last-child{transform:translateX(3px);color:var(--teal-bright)}
.mnav-ctas{display:flex;flex-direction:column;gap:10px;margin-top:auto}
.mnav-cta-primary, .mnav-cta-secondary{
  display:flex;align-items:center;justify-content:center;gap:10px;
  height:56px;border-radius:14px;font-size:15px;font-weight:600;letter-spacing:-.003em;
  transition:all .2s var(--ease);
}
.mnav-cta-primary{
  background:linear-gradient(180deg, var(--teal-bright), var(--teal) 50%, var(--teal-deep));
  color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.3), 0 12px 26px -6px rgba(45,132,127,.5);
}
.mnav-cta-primary:active{transform:scale(.98);filter:brightness(1.05)}
.mnav-cta-secondary{
  background:var(--w05);border:1px solid var(--w15);color:#fff;
}
.mnav-cta-secondary i{color:var(--teal-bright)}
.mnav-cta-secondary:active{background:var(--w10)}
.mnav-foot{
  margin-top:24px;padding-top:22px;border-top:1px solid var(--w08);
  display:flex;flex-direction:column;gap:14px;
}
.mnav-wa{
  display:inline-flex;align-items:center;gap:10px;align-self:flex-start;
  padding:10px 16px;border-radius:999px;
  background:rgba(37,211,102,.12);border:1px solid rgba(37,211,102,.3);
  color:#fff;font-size:13.5px;font-weight:600;
}
.mnav-wa i{color:#25D366;font-size:16px}
.mnav-meta{font-size:12px;color:var(--w60);display:inline-flex;align-items:center;gap:8px;font-variant-numeric:tabular-nums}
.mnav-meta b{color:#fff;font-weight:700}
.mnav-meta .ld{
  width:7px;height:7px;border-radius:50%;background:var(--teal-bright);
  box-shadow:0 0 0 0 rgba(78,180,174,.7);animation:livePulse 2.4s ease-out infinite;
}
/* entrada escalonada dos links */
.mnav.is-open .mnav-links a{animation:mnavItemIn .5s var(--ease-out) both}
.mnav.is-open .mnav-links a:nth-child(1){animation-delay:.08s}
.mnav.is-open .mnav-links a:nth-child(2){animation-delay:.14s}
.mnav.is-open .mnav-links a:nth-child(3){animation-delay:.20s}
.mnav.is-open .mnav-links a:nth-child(4){animation-delay:.26s}
@keyframes mnavItemIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

/* ═══════════════════════════════════════════════════════════════════
   HERO · cool-tech "console" · light gray, blueprint, teal energy
═══════════════════════════════════════════════════════════════════════ */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  padding:200px 0 130px;overflow:visible;isolation:isolate;z-index:40;
  background:
    radial-gradient(130% 95% at 50% -25%, #fafbfb 0%, #eef2f2 52%, #e4eaea 100%);
  color:var(--ink);
}
/* Conter visualmente o vídeo/rede/glow que antes eram clipados pelo overflow:hidden do hero */
.hero > .hero-video,
.hero > .hero-bg,
.hero > .hero-glow,
.hero > .hero-network{clip-path:inset(0)}

/* vídeo de fundo · globo branco → multiply faz o branco sumir, só o globo fica */
.hero-video{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  width:100%;height:100%;object-fit:cover;object-position:center 56%;
  mix-blend-mode:multiply;
  filter:contrast(1.14) saturate(.95) brightness(.97);
  -webkit-mask-image:radial-gradient(ellipse 66% 74% at 50% 52%, #000 36%, transparent 80%);
          mask-image:radial-gradient(ellipse 66% 74% at 50% 52%, #000 36%, transparent 80%);
  animation:heroVideoIn 1.8s ease both;
}
@keyframes heroVideoIn{
  from{opacity:0;transform:scale(1.05)}
  to  {opacity:1;transform:scale(1)}
}

/* camada 0 · grão + glow teal respirando */
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-bg::before{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 .08 0 0 0 0 .12 0 0 0 0 .14 0 0 0 .7 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.10;mix-blend-mode:multiply;
}
/* glow teal central · a "energia" tecnológica */
.hero-glow{
  position:absolute;z-index:1;pointer-events:none;
  top:48%;left:50%;width:1040px;height:680px;
  transform:translate(-50%,-50%);
  background:
    radial-gradient(50% 50% at 50% 48%, rgba(58,157,152,.12), transparent 70%),
    radial-gradient(40% 40% at 38% 62%, rgba(95,197,191,.08), transparent 70%);
  filter:blur(44px);
  animation:glowBreathe 11s ease-in-out infinite alternate;
}
@keyframes glowBreathe{
  0%  {opacity:.5;transform:translate(-50%,-50%) scale(1)}
  100%{opacity:.72;transform:translate(-50%,-51%) scale(1.05)}
}

/* ════════ NETWORK · malha de conexão entre peritos ════════ */
.hero-network{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  width:100%;height:100%;
  mask-image:radial-gradient(ellipse 95% 92% at 50% 48%, #000 55%, transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 95% 92% at 50% 48%, #000 55%, transparent 100%);
}
/* drift ambiente num grupo interno (mantém o mapeamento do mouse exato no <svg>) */
.net-drift{animation:netDrift 26s ease-in-out infinite alternate}
@keyframes netDrift{
  0%  {transform:translate(0,0)}
  100%{transform:translate(-14px,10px)}
}
/* linhas */
.hero-network .nl{
  stroke:rgba(2,24,32,.14);stroke-width:1;
  stroke-dasharray:5 7;
  animation:netLineDraw 1.6s ease-out both, netLineFlow 9s linear infinite;
}
@keyframes netLineDraw{from{opacity:0}to{opacity:1}}
@keyframes netLineFlow{to{stroke-dashoffset:-48}}
/* nós comuns */
.hero-network .nd{
  fill:rgba(2,24,32,.32);
  transition:fill .35s var(--ease), filter .35s var(--ease);
  animation:netNodeIn .7s cubic-bezier(.16,1,.3,1) both;
}
@keyframes netNodeIn{from{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}
/* hubs · peritos ativos (teal, pulsam) */
.hero-network .hub{fill:var(--teal);transition:filter .35s var(--ease)}
.hero-network .hub-core{
  fill:var(--teal-darker);
  filter:drop-shadow(0 2px 6px rgba(45,132,127,.45));
}
.hero-network .hub-halo{
  fill:none;stroke:var(--teal);stroke-width:1.5;
  transform-box:fill-box;transform-origin:center;
  animation:hubPulse 3s ease-out infinite;
}
@keyframes hubPulse{
  0%  {transform:scale(.5);opacity:.8}
  100%{transform:scale(2.8);opacity:0}
}

/* ── interação com o cursor · "você entra na rede" ── */
.hero-network .nd.lit{
  fill:var(--teal);
  filter:drop-shadow(0 0 5px rgba(58,157,152,.85));
}
.hero-network .hub.lit{filter:drop-shadow(0 0 7px rgba(58,157,152,.9))}
.net-cursor-line{
  stroke:var(--teal);stroke-width:1.3;stroke-linecap:round;
  opacity:0;
}
.net-cursor-halo{
  fill:none;stroke:var(--teal);stroke-width:1;
  opacity:0;transition:opacity .4s var(--ease);
}
.net-cursor-dot{
  fill:var(--teal-darker);
  opacity:0;transition:opacity .4s var(--ease);
  filter:drop-shadow(0 0 6px rgba(45,132,127,.7));
}
.net-cursor-layer.on .net-cursor-halo{opacity:.5}
.net-cursor-layer.on .net-cursor-dot{opacity:.95}

.hero-inner{position:relative;z-index:5;width:100%}

/* ════════ CONTEÚDO CENTRAL ════════ */
.hero-content{
  position:relative;z-index:6;
  max-width:1120px;margin:0 auto;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:30px;
}

/* Eyebrow · chip de status técnico */
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px 8px 12px;border-radius:999px;
  background:rgba(255,255,255,.7);
  border:1px solid rgba(2,24,32,.08);
  backdrop-filter:blur(10px);
  font-size:11.5px;font-weight:600;letter-spacing:.05em;
  color:var(--ink-soft);font-variant-numeric:tabular-nums;
  box-shadow:0 6px 18px -8px rgba(2,24,32,.18);
  animation:fadeUp 1s cubic-bezier(.16,1,.3,1) .1s both;
}
.hero-eyebrow .dot{
  width:8px;height:8px;border-radius:50%;background:var(--teal);
  box-shadow:0 0 0 0 rgba(58,157,152,.5), 0 0 10px rgba(58,157,152,.5);
  animation:livePulse 2.4s ease-out infinite;flex-shrink:0;
}
.hero-eyebrow b{color:var(--ink);font-weight:700}
.hero-eyebrow .mono{
  font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;
  font-size:10.5px;letter-spacing:0;color:var(--teal-darker);font-weight:600;
}

/* Headline · UMA fonte (Inter), uppercase, exatamente 2 linhas */
.hero-h1{
  font-size:clamp(36px, 5.7vw, 78px);
  font-weight:800;line-height:1.02;letter-spacing:-.03em;
  text-transform:uppercase;
  color:var(--ink);margin:0;
  animation:h1In 1.2s cubic-bezier(.16,1,.3,1) .25s both;
}
.hero-h1 .l1, .hero-h1 .l2{display:block;white-space:nowrap}
.hero-h1 .accent{color:var(--teal-darker);position:relative}
@keyframes h1In{
  from{opacity:0;transform:translateY(20px);filter:blur(6px)}
  to  {opacity:1;transform:translateY(0);filter:blur(0)}
}

/* Subtítulo */
.hero-sub{
  font-size:clamp(16px,1.2vw,18.5px);line-height:1.55;
  color:var(--i75);max-width:600px;margin:0;
  animation:fadeUp 1s cubic-bezier(.16,1,.3,1) .45s both;
}
.hero-sub b{color:var(--ink);font-weight:600}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(12px)}
  to  {opacity:1;transform:translateY(0)}
}

/* Search wrapper */
.hero-search{
  width:100%;max-width:720px;position:relative;margin:6px auto 0;z-index:60;
  animation:fadeUp 1s cubic-bezier(.16,1,.3,1) .60s both;
}
.hero-stats{position:relative;z-index:1}

/* OVERRIDES light theme · search dentro da hero */
.hero .hs-box{
  background:linear-gradient(180deg, #ffffff, #f4f7f7);
  border:1px solid rgba(2,24,32,.09);
  box-shadow:
    inset 0 1px 0 #fff,
    0 32px 64px -24px rgba(2,24,32,.22),
    0 8px 20px -8px rgba(2,24,32,.08);
}
.hero .hs-box::before{
  background:linear-gradient(135deg, rgba(58,157,152,.5), rgba(2,24,32,.10) 55%, rgba(95,197,191,.4));
  opacity:.45;
}
.hero .hs-box:focus-within{
  border-color:transparent;
  box-shadow:
    inset 0 1px 0 #fff,
    0 0 0 3px rgba(58,157,152,.18),
    0 32px 64px -24px rgba(2,24,32,.24);
}
.hero .hs-icon{
  background:linear-gradient(160deg, #08495a, #03222c);
  border:none;color:var(--teal-soft);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10), 0 6px 14px rgba(2,24,32,.25);
}
.hero .hs-box input{color:var(--ink)}
.hero .hs-box input::placeholder{color:var(--i35)}
.hero .hs-clear{background:rgba(2,24,32,.06);color:var(--i55)}
.hero .hs-clear:hover{background:rgba(2,24,32,.12);color:var(--ink)}
.hero .hs-go{
  background:linear-gradient(180deg, var(--teal), var(--teal-darker));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.25), 0 10px 22px rgba(45,132,127,.40);
}

/* Chips · light */
.hero .hs-chips{margin-top:18px}
.hero .hs-chips .lbl{color:var(--i35)}
.hero .chip{
  background:rgba(255,255,255,.72);
  border:1px solid rgba(2,24,32,.09);
  color:var(--i75);
  backdrop-filter:blur(8px);
  box-shadow:0 2px 6px rgba(2,24,32,.04);
}
.hero .chip:hover{
  background:#fff;border-color:rgba(58,157,152,.4);color:var(--ink);
  transform:translateY(-1px);box-shadow:0 8px 16px rgba(2,24,32,.08);
}
.hero .chip i{color:var(--teal-darker)}

/* Stats · pill institucional light */
.hero-stats{
  display:inline-flex;align-items:center;gap:22px;flex-wrap:wrap;justify-content:center;
  padding:16px 26px;border-radius:18px;margin-top:8px;
  background:rgba(255,255,255,.6);
  border:1px solid rgba(2,24,32,.07);
  backdrop-filter:blur(12px);
  font-size:13px;color:var(--i55);font-variant-numeric:tabular-nums;
  box-shadow:0 10px 30px -14px rgba(2,24,32,.16);
  animation:fadeUp 1s cubic-bezier(.16,1,.3,1) .75s both;
}
.hero-stats .s-item{display:inline-flex;align-items:center;gap:8px}
.hero-stats .s-item b{color:var(--ink);font-weight:700}
.hero-stats .s-item .ld{
  width:8px;height:8px;border-radius:50%;background:var(--teal);
  box-shadow:0 0 0 0 rgba(58,157,152,.5), 0 0 8px rgba(58,157,152,.4);
  animation:livePulse 2.4s ease-out infinite;
}
.hero-stats .s-sep{width:1px;height:14px;background:rgba(2,24,32,.14)}
.hero-stats .s-gold{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 11px;border-radius:999px;
  background:linear-gradient(135deg, var(--gold-bright), var(--gold));
  color:var(--ink);font-size:10.5px;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5), 0 4px 12px rgba(228,182,89,.30);
}
.hero-stats .s-gold i{font-size:9px}

/* Scroll cue · light */
.hero-scroll{
  position:absolute;left:50%;bottom:34px;transform:translateX(-50%);
  z-index:6;
  display:inline-flex;flex-direction:column;align-items:center;gap:10px;
  font-size:10px;font-weight:700;color:var(--i35);
  letter-spacing:.26em;text-transform:uppercase;
  animation:fadeUp 1.4s cubic-bezier(.16,1,.3,1) 1.4s both;
}
.hero-scroll .line{
  width:1px;height:40px;
  background:linear-gradient(180deg, rgba(2,24,32,.3), transparent);
  position:relative;overflow:hidden;
}
.hero-scroll .line::after{
  content:'';position:absolute;top:-12px;left:0;width:1px;height:16px;
  background:var(--teal-darker);
  animation:scrollDot 2.2s ease-in-out infinite;
}
@keyframes scrollDot{
  0%  {transform:translateY(0);opacity:0}
  20% {opacity:1}
  100%{transform:translateY(50px);opacity:0}
}

/* keyframe usado em vários componentes (activity-ticker, hub dots, etc.) */
@keyframes livePulse{
  0%{box-shadow:0 0 0 0 rgba(78,180,174,.7)}
  70%{box-shadow:0 0 0 12px rgba(78,180,174,0)}
  100%{box-shadow:0 0 0 0 rgba(78,180,174,0)}
}

/* botões globais reutilizados em outras seções */
.btn-primary{
  display:inline-flex;align-items:center;gap:10px;padding:0 24px;height:54px;border-radius:13px;
  background:linear-gradient(180deg, var(--teal-bright), var(--teal) 50%, var(--teal-deep));
  color:#fff;font-size:14px;font-weight:600;letter-spacing:-.003em;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.30), 0 16px 36px rgba(58,157,152,.40);
  transition:all .25s var(--ease);
}
.btn-primary:hover{transform:translateY(-2px);filter:brightness(1.08);box-shadow:inset 0 1px 0 rgba(255,255,255,.35), 0 24px 48px rgba(58,157,152,.5)}
.btn-primary i{font-size:13px}

.btn-secondary{
  display:inline-flex;align-items:center;gap:10px;padding:0 22px;height:54px;border-radius:13px;
  border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.04);
  color:#fff;font-size:14px;font-weight:500;letter-spacing:-.003em;
  backdrop-filter:blur(10px);transition:all .25s var(--ease);
}
.btn-secondary:hover{background:rgba(255,255,255,.08);border-color:var(--t30);transform:translateY(-2px)}
.btn-secondary i{color:var(--teal-bright);font-size:12px}

.btn-link{
  display:inline-flex;align-items:center;gap:10px;padding:0 26px;height:54px;border-radius:13px;
  background:var(--deep-2);color:#fff;font-size:14px;font-weight:600;
  border:1px solid rgba(255,255,255,.10);
  transition:all .25s var(--ease);
}
.btn-link:hover{background:var(--deep-3);transform:translateY(-2px)}
.btn-link i{font-size:11px;color:var(--teal-bright)}

/* ═══════════════════════════════════════════════════════════════════
   HERO-SEARCH · search embutido na hero
═══════════════════════════════════════════════════════════════════════ */
.hs-box{
  display:flex;align-items:center;gap:10px;padding:8px;border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(18px) saturate(1.2);
  -webkit-backdrop-filter:blur(18px) saturate(1.2);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.14),
    0 30px 60px -20px rgba(0,0,0,.6),
    0 0 0 1px rgba(58,157,152,.08);
  position:relative;
}
/* anel gradiente premium */
.hs-box::before{
  content:'';position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:linear-gradient(135deg, rgba(58,157,152,.5), rgba(228,182,89,.25) 50%, rgba(58,157,152,.3));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  pointer-events:none;opacity:.6;transition:opacity .3s var(--ease);
}
.hs-box:focus-within{border-color:transparent;box-shadow:inset 0 1px 0 rgba(255,255,255,.18), 0 0 0 3px rgba(58,157,152,.22), 0 30px 60px -20px rgba(0,0,0,.6)}
.hs-box:focus-within::before{opacity:1}
.hs-icon{
  width:50px;height:50px;border-radius:12px;background:rgba(58,157,152,.14);
  border:1px solid var(--t30);color:var(--teal-bright);
  display:grid;place-items:center;font-size:16px;flex-shrink:0;
}
.hs-box input{
  flex:1;background:transparent;border:none;outline:none;color:#fff;
  font-family:var(--ff);font-size:16px;font-weight:500;letter-spacing:-.005em;
  height:50px;padding:0 6px;min-width:0;
}
.hs-box input::placeholder{color:var(--w40);font-weight:400}
.hs-clear{
  display:none;width:30px;height:30px;border-radius:9px;
  background:rgba(255,255,255,.06);color:var(--w60);
  align-items:center;justify-content:center;font-size:11px;flex-shrink:0;
}
.has-value .hs-clear{display:inline-flex}
.hs-clear:hover{background:var(--t20);color:#fff}
.hs-go{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  width:50px;height:50px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(180deg, var(--teal-bright), var(--teal-deep));
  color:#fff;font-size:15px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.30), 0 10px 22px rgba(58,157,152,.45);
  transition:all .25s var(--ease);
}
.hs-go:hover{transform:translateX(2px);filter:brightness(1.1)}

.hs-chips{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:16px;flex-wrap:wrap}
.hs-chips .lbl{font-size:10px;color:var(--w40);font-weight:600;letter-spacing:.16em;text-transform:uppercase;margin-right:4px}
.chip{
  display:inline-flex;align-items:center;gap:6px;padding:6px 11px;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);
  color:var(--w80);font-size:12px;font-weight:500;cursor:pointer;
  transition:all .2s var(--ease);backdrop-filter:blur(6px);
}
.chip:hover{background:rgba(58,157,152,.14);border-color:var(--t30);color:#fff;transform:translateY(-1px)}
.chip i{color:var(--teal-bright);font-size:10px}

.search-results{
  position:absolute;top:calc(100% + 10px);left:0;right:0;z-index:200;
  max-height:420px;overflow:auto;border-radius:16px;
  border:1px solid rgba(58,157,152,.22);
  background:linear-gradient(180deg, rgba(3,34,44,.98), rgba(2,24,32,.98));
  backdrop-filter:blur(24px);
  box-shadow:0 36px 70px -16px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.06);
  display:none;text-align:left;
}
.search-results.show{display:block;animation:resIn .25s var(--ease-out)}
@keyframes resIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.res-head{
  padding:14px 20px 8px;display:flex;align-items:center;justify-content:space-between;
  font-size:11px;color:var(--w40);letter-spacing:.16em;text-transform:uppercase;font-weight:600;
}
.res-head b{color:var(--teal-bright)}
.res-item{
  display:flex;align-items:center;gap:14px;padding:13px 20px;
  border-top:1px solid rgba(255,255,255,.04);cursor:pointer;transition:background .15s ease;
}
.res-item:hover, .res-item.is-active{background:rgba(58,157,152,.08)}
.res-avatar{
  width:46px;height:46px;border-radius:12px;background:var(--deep-3);
  overflow:hidden;flex-shrink:0;border:1px solid rgba(255,255,255,.10);
}
.res-avatar img{width:100%;height:100%;object-fit:cover}
.res-text{flex:1;min-width:0}
.res-name{color:#fff;font-size:14px;font-weight:600;margin-bottom:3px;letter-spacing:-.005em}
.search-results mark{
  background:rgba(95,197,191,.22);color:var(--teal-soft);
  padding:0 2px;border-radius:3px;font-weight:700;
}
.res-name mark{color:#fff}
.res-meta{color:var(--w60);font-size:12px;display:flex;align-items:center;gap:12px}
.res-meta span{display:inline-flex;align-items:center;gap:5px}
.res-meta i{color:var(--teal-bright);font-size:10px}
.res-arrow{
  width:32px;height:32px;border-radius:10px;border:1px solid var(--w10);
  background:var(--w05);color:var(--teal-bright);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:all .2s var(--ease);
}
.res-item:hover .res-arrow{background:var(--teal);color:#fff;border-color:var(--teal);transform:rotate(-45deg)}
.res-empty{padding:40px 20px;text-align:center;color:var(--w60)}
.res-empty i{font-size:24px;color:var(--teal-bright);margin-bottom:10px;display:block}
.res-empty b{display:block;color:#fff;font-weight:600;margin-bottom:4px;font-size:14px}
.res-foot{
  padding:14px 20px;display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid rgba(255,255,255,.06);font-size:11.5px;color:var(--w40);
}
.res-foot a{color:var(--teal-bright);font-weight:600;display:inline-flex;align-items:center;gap:6px}

/* ═══════════════════════════════════════════════════════════════════
   STATS BAND
═══════════════════════════════════════════════════════════════════════ */
.stats-band{
  padding:80px 0;background:var(--ink);position:relative;
  border-bottom:1px solid var(--w08);
}
.stats-band::before{
  content:'';position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--t50) 30%, var(--t50) 70%, transparent);
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat-cell{
  padding:28px 36px;border-right:1px solid rgba(255,255,255,.08);position:relative;
}
.stat-cell:last-child{border-right:0}
.stat-cell .lbl-top{
  font-size:10.5px;font-weight:600;letter-spacing:.20em;text-transform:uppercase;
  color:var(--teal-bright);margin-bottom:18px;
}
.stat-cell .num{
  font-size:clamp(40px,4.8vw,64px);font-weight:700;letter-spacing:-.03em;
  color:#fff;line-height:1;font-variant-numeric:tabular-nums;
  display:flex;align-items:baseline;gap:6px;margin-bottom:14px;
}
.stat-cell .num .suffix{font-size:.45em;color:var(--teal-bright);font-weight:600}
.stat-cell .lbl{
  font-size:13px;color:var(--w75);font-weight:400;letter-spacing:-.005em;line-height:1.45;
}
.stat-cell .lbl b{color:#fff;font-weight:600}
.spark{margin-top:18px;height:22px;display:flex;align-items:flex-end;gap:2px}
.spark span{
  flex:1;background:linear-gradient(180deg, var(--teal-bright), var(--teal-darker));
  border-radius:2px;opacity:.4;transform-origin:bottom;
  animation:sparkRise 1s var(--ease-out) backwards;
}
@keyframes sparkRise{from{transform:scaleY(0);opacity:0}to{transform:scaleY(1);opacity:.4}}

/* ═══════════════════════════════════════════════════════════════════
   MAP · cobertura nacional
═══════════════════════════════════════════════════════════════════════ */
.map-section{padding:140px 0;position:relative}
.map-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.map-head h2{margin:18px 0 22px;color:#fff}
.map-bullets{display:flex;flex-direction:column;gap:14px;margin-top:36px}
.map-bullet{
  display:flex;align-items:flex-start;gap:14px;padding:16px;border-radius:14px;
  border:1px solid var(--w10);background:rgba(255,255,255,.03);
  transition:all .25s var(--ease);
}
.map-bullet:hover{border-color:var(--t30);background:rgba(58,157,152,.05)}
.map-bullet .mi{
  width:38px;height:38px;border-radius:11px;background:rgba(58,157,152,.10);
  border:1px solid var(--t30);color:var(--teal-bright);display:grid;place-items:center;
  flex-shrink:0;font-size:14px;
}
.map-bullet b{display:block;color:#fff;font-size:14.5px;font-weight:600;margin-bottom:3px;letter-spacing:-.005em}
.map-bullet span{font-size:13px;color:var(--w75);line-height:1.45}

/* ═══ MAPA BRASIL · SVG puro, sem card, sem borda ═══ */
.map-wrap{
  position:relative;aspect-ratio:1/1.12;
  background:transparent;border:0;padding:0;
  overflow:visible;
}

.brazil-map{
  width:100%;height:100%;overflow:visible;display:block;
}

/* OUTLINE · branco sutil, traçado */
.bm-outline{
  fill:none;stroke:rgba(255,255,255,.22);stroke-width:1.2;
  stroke-linecap:round;stroke-linejoin:round;
  vector-effect:non-scaling-stroke;
  filter:drop-shadow(0 0 6px rgba(95,197,191,.15));
  stroke-dasharray:3500;stroke-dashoffset:3500;
  transition:stroke-dashoffset 3.4s var(--ease-out) .2s;
}
.map-wrap.in .bm-outline{stroke-dashoffset:0}

/* FILL interno · imperceptível */
.bm-fill{
  fill:rgba(58,157,152,.05);stroke:none;
  opacity:0;transition:opacity 1.5s ease 1.8s;
}
.map-wrap.in .bm-fill{opacity:1}

/* CONEXÕES · linhas finas teal */
.bm-conn{
  fill:none;stroke:rgba(95,197,191,.30);stroke-width:.7;
  vector-effect:non-scaling-stroke;
  opacity:0;transition:opacity 1s ease 2.3s;
}
.map-wrap.in .bm-conn{opacity:1}

.bm-conn.flow{
  stroke:rgba(95,197,191,.65);stroke-width:.9;
  stroke-dasharray:3 6;vector-effect:non-scaling-stroke;
  animation:bmFlow 1.6s linear infinite;
  animation-delay:3s;
}
@keyframes bmFlow{to{stroke-dashoffset:-18}}
.bm-conn.flow.gold{stroke:rgba(240,199,114,.65);animation-duration:2.2s}

/* DOTS · cidades comuns */
.bm-dot{
  fill:#fff;
  filter:drop-shadow(0 0 3px var(--teal-bright));
  opacity:0;
  transform-origin:center;transform-box:fill-box;transform:scale(0);
  transition:opacity .4s ease, transform .55s cubic-bezier(.34,1.56,.64,1);
}
.map-wrap.in .bm-dot{opacity:.9;transform:scale(1)}

/* HUBS · capitais principais */
.bm-hub{
  fill:#fff;
  filter:drop-shadow(0 0 8px var(--teal-bright)) drop-shadow(0 0 2px #fff);
  opacity:0;
  transform-origin:center;transform-box:fill-box;transform:scale(0);
  transition:opacity .4s ease, transform .55s cubic-bezier(.34,1.56,.64,1);
}
.map-wrap.in .bm-hub{opacity:1;transform:scale(1)}
.bm-hub-gold{
  fill:var(--gold-bright);
  filter:drop-shadow(0 0 12px var(--gold)) drop-shadow(0 0 3px #fff);
}

/* HALOS · pulsando infinitamente nos hubs */
.bm-halo{
  fill:none;stroke:var(--teal-bright);stroke-width:1;
  vector-effect:non-scaling-stroke;
  opacity:0;
  transform-origin:center;transform-box:fill-box;
}
.map-wrap.in .bm-halo{animation:bmPulse 2.8s ease-out infinite;animation-delay:3.4s}
.bm-halo-gold{stroke:var(--gold-bright)}
@keyframes bmPulse{
  0%{transform:scale(.7);opacity:.8}
  100%{transform:scale(5);opacity:0}
}

/* ═══ DOT MATRIX · grid denso preenchendo o Brasil, regiões acendendo em onda ═══ */
.bm-grid-dot{
  fill:rgba(95,197,191,.22);
  transition:fill .4s ease;
}
/* onda de cor apenas (sem drop-shadow → barato, não trava com centenas de pontos) */
@keyframes lightWave{
  0%, 100%{fill:rgba(95,197,191,.22)}
  10%     {fill:#7fe9e4}
  22%     {fill:#5fc5bf}
  40%     {fill:rgba(95,197,191,.40)}
}
.map-wrap.in .bm-grid-dot{
  animation:lightWave 11s ease-in-out infinite;
}

/* ═══════════════════════════════════════════════════════════════════
   REDE DE PERITOS · carrossel infinito 4 linhas
═══════════════════════════════════════════════════════════════════════ */
.featured{
  padding:140px 0 120px;background:var(--ink);color:#fff;position:relative;
  overflow:hidden;
}
.featured::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 40% at 50% 0%, rgba(58,157,152,.10), transparent 60%),
    radial-gradient(ellipse 60% 40% at 50% 100%, rgba(84,139,157,.08), transparent 65%);
}
.featured-head{text-align:center;max-width:780px;margin:0 auto 70px;position:relative}
.featured-head h2{margin-top:18px;color:#fff}
.featured-head .lead{margin-top:18px}

/* container do carrossel */
.peritos-carousel{
  position:relative;display:flex;flex-direction:column;gap:18px;
  padding:30px 0;
  mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}

.carousel-row{
  position:relative;display:flex;width:100%;overflow:hidden;
  height:96px;
}
.carousel-track{
  display:flex;align-items:center;gap:18px;flex-shrink:0;
  animation:rowScroll var(--dur, 80s) linear infinite;
  will-change:transform;
}
.carousel-row[data-dir="right"] .carousel-track{
  animation-direction:reverse;
}
@keyframes rowScroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.carousel-row:hover .carousel-track{animation-play-state:paused}

/* cada face */
.face{
  position:relative;width:88px;height:88px;flex-shrink:0;
  border-radius:50%;overflow:hidden;
  background:var(--deep-2);
  border:1px solid var(--t30);
  cursor:pointer;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
}
.face::before{
  content:'';position:absolute;inset:-2px;border-radius:50%;
  background:conic-gradient(from 0deg, var(--teal-bright), transparent 40%, transparent 60%, var(--teal-soft) 100%);
  opacity:0;transition:opacity .4s var(--ease);
  z-index:-1;
  filter:blur(6px);
}
.face:hover{
  transform:scale(1.18);z-index:5;border-color:var(--teal-bright);
  box-shadow:0 14px 36px rgba(58,157,152,.5), 0 0 0 3px rgba(58,157,152,.25);
}
.face:hover::before{opacity:1}
.face img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.8) contrast(1.05);
  transition:filter .35s var(--ease);
}
.face:hover img{filter:saturate(1.1) contrast(1.1)}

/* halo pulsante em algumas faces (efeito tech) */
.face.is-live::after{
  content:'';position:absolute;bottom:4px;right:4px;
  width:12px;height:12px;border-radius:50%;
  background:var(--teal-bright);border:2px solid var(--ink);
  box-shadow:0 0 0 0 rgba(58,157,152,.6);
  animation:facePulse 2.4s ease-out infinite;
  z-index:2;
}
@keyframes facePulse{
  0%{box-shadow:0 0 0 0 rgba(58,157,152,.6)}
  70%{box-shadow:0 0 0 8px rgba(58,157,152,0)}
  100%{box-shadow:0 0 0 0 rgba(58,157,152,0)}
}

/* tooltip que aparece no hover */
.face-tip{
  position:absolute;bottom:100%;left:50%;transform:translateX(-50%) translateY(-8px);
  padding:8px 12px;border-radius:10px;
  background:rgba(3,34,44,.96);border:1px solid var(--t30);
  font-size:11.5px;font-weight:600;color:#fff;white-space:nowrap;
  pointer-events:none;opacity:0;transition:opacity .25s var(--ease);
  box-shadow:0 12px 24px rgba(0,0,0,.4);z-index:10;
}
.face-tip::after{
  content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:5px solid transparent;border-top-color:rgba(3,34,44,.96);
}
.face-tip span{color:var(--teal-bright);display:block;font-size:10px;font-weight:500;margin-top:2px;letter-spacing:.04em;text-transform:uppercase}
.face:hover .face-tip{opacity:1;transform:translateX(-50%) translateY(-12px)}

/* hairlines decorativas entre rows (efeito grid tecnológico) */
.peritos-carousel::before,
.peritos-carousel::after{
  content:'';position:absolute;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--t30) 30%, var(--t30) 70%, transparent);
}
.peritos-carousel::before{top:0}
.peritos-carousel::after{bottom:0}

.featured-foot{margin-top:60px;text-align:center;position:relative}
.featured-foot .btn-link{background:var(--teal-darker);box-shadow:0 14px 30px rgba(58,157,152,.3)}
.featured-foot .btn-link:hover{background:var(--teal)}

/* ═══════════════════════════════════════════════════════════════════
   SPLIT · 2 públicos
═══════════════════════════════════════════════════════════════════════ */
.split{padding:0;position:relative;overflow:hidden}
.split-grid{display:grid;grid-template-columns:1fr 1fr;min-height:680px}
.split-side{
  position:relative;padding:110px 80px;display:flex;flex-direction:column;justify-content:center;
  overflow:hidden;isolation:isolate;
}
.split-dark{background:linear-gradient(135deg, var(--deep-1) 0%, var(--ink) 100%);color:#fff}
.split-cream{background:linear-gradient(135deg, var(--cream) 0%, var(--cream-warm) 100%);color:var(--ink)}
.split-side .eyebrow{margin-bottom:22px}
.split-side h3{margin-bottom:20px}
.split-side .body{margin-bottom:34px;max-width:480px}
.split-features{display:flex;flex-direction:column;gap:11px;margin-bottom:40px}
.split-feature{display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500}
.split-feature i{
  width:22px;height:22px;border-radius:50%;background:var(--t20);color:var(--teal-bright);
  display:grid;place-items:center;font-size:9px;flex-shrink:0;
}
.split-cream .split-feature i{background:rgba(45,132,127,.15);color:var(--teal-darker)}
.split-dark .split-feature{color:var(--w90)}
.split-cream .split-feature{color:var(--i75)}
.split-cta{display:flex;gap:10px;flex-wrap:wrap}
.split-cream .btn-secondary{background:rgba(2,24,32,.06);border-color:var(--i12);color:var(--deep)}
.split-cream .btn-secondary:hover{background:rgba(2,24,32,.10)}
.split-cream .btn-secondary i{color:var(--teal-darker)}

.split-side::after{
  content:'';position:absolute;font-weight:800;
  font-size:clamp(140px, 22vw, 280px);
  bottom:-50px;right:-20px;line-height:1;pointer-events:none;letter-spacing:-.05em;
}
.split-dark::after{content:'01';color:rgba(255,255,255,.04)}
.split-cream::after{content:'02';color:rgba(2,24,32,.05)}

.split-divider{
  position:absolute;left:50%;top:0;bottom:0;width:1px;
  background:linear-gradient(180deg, transparent, var(--teal-bright) 30%, var(--teal-bright) 70%, transparent);
  z-index:2;pointer-events:none;opacity:.7;
}

/* @property pra animar conic-gradient angle */
@property --m-angle{
  syntax:'<angle>';
  initial-value:0deg;
  inherits:false;
}

.split-m{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:88px;height:88px;border-radius:50%;
  background:var(--ink);
  display:grid;place-items:center;
  z-index:4;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.6),
    0 0 50px rgba(58,157,152,.30),
    0 0 100px rgba(228,182,89,.10),
    inset 0 1px 0 rgba(255,255,255,.06);
}
/* borda com conic-gradient rotacionando */
.split-m::before{
  content:'';position:absolute;inset:-3px;border-radius:50%;padding:3px;
  background:conic-gradient(from var(--m-angle, 0deg),
    var(--teal-bright) 0%,
    var(--gold-bright) 22%,
    var(--teal-soft) 44%,
    var(--teal-deep) 66%,
    var(--gold) 88%,
    var(--teal-bright) 100%
  );
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  animation:rotateMGrad 5s linear infinite;
}
@keyframes rotateMGrad{
  to{--m-angle:360deg}
}
/* halo decorativo */
.split-m::after{
  content:'';position:absolute;inset:-12px;border-radius:50%;
  background:conic-gradient(from var(--m-angle, 0deg),
    transparent 0%,
    rgba(95,197,191,.18) 25%,
    transparent 50%,
    rgba(240,199,114,.14) 75%,
    transparent 100%
  );
  filter:blur(8px);
  animation:rotateMGrad 5s linear infinite reverse;
  z-index:-1;
}
.split-m span{
  font-size:32px;font-weight:800;color:#fff;
  letter-spacing:-.025em;
  background:linear-gradient(135deg, var(--teal-bright), var(--gold-bright));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  filter:drop-shadow(0 0 8px rgba(58,157,152,.4));
}

/* ═══════════════════════════════════════════════════════════════════
   GROWTH
═══════════════════════════════════════════════════════════════════════ */
.growth{padding:140px 0;background:linear-gradient(180deg, var(--ink) 0%, var(--deep) 100%);position:relative}
.growth-head{text-align:center;max-width:760px;margin:0 auto 64px}
.growth-head h2{margin:18px 0 18px;color:#fff}
.growth-chart{
  position:relative;padding:30px 36px 18px;border-radius:24px;
  background:
    radial-gradient(ellipse 50% 60% at 100% 0%, rgba(228,182,89,.14), transparent 65%),
    radial-gradient(ellipse 40% 50% at 0% 100%, rgba(58,157,152,.10), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid var(--w10);overflow:hidden;
}
.growth-chart::before{
  content:'';position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--t40) 30%, var(--gold) 80%, transparent);
}

/* TAG CORNERS · "Hoje 2026" + "Crescimento +2.594%" */
.growth-tag{
  position:absolute;z-index:8;
  display:flex;align-items:center;gap:12px;
  padding:11px 16px;border-radius:14px;
  background:rgba(3,34,44,.92);border:1px solid var(--w12);
  backdrop-filter:blur(10px);
  box-shadow:0 14px 30px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.06);
}
.growth-tag-current{top:18px;left:18px;border-color:var(--t30)}
.growth-tag-current .dot{
  width:9px;height:9px;border-radius:50%;background:var(--teal-bright);
  box-shadow:0 0 0 4px rgba(58,157,152,.22);
  animation:livePulse 2.4s ease-out infinite;
}
.growth-tag-growth{top:18px;right:18px;border-color:rgba(228,182,89,.30)}
.growth-tag-growth i{color:var(--gold-bright);font-size:17px}
.growth-tag .lbl{
  font-size:9.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--w50);margin-bottom:3px;
}
.growth-tag .val{
  font-size:17px;font-weight:700;color:#fff;letter-spacing:-.018em;
  font-variant-numeric:tabular-nums;line-height:1;
}
.growth-tag-growth .val{color:var(--gold-bright)}

/* CHART INNER · área do gráfico em si */
.growth-chart-inner{
  position:relative;height:380px;margin-top:60px;
}

/* SVG · só linha, área, dots */
.growth-svg{
  position:absolute;inset:0;width:100%;height:100%;overflow:visible;
}

/* grid de fundo (dashed sutil) */
.growth-grid line{stroke:rgba(255,255,255,.05);stroke-width:1;stroke-dasharray:3 6;vector-effect:non-scaling-stroke}

/* fill area · gradient teal vertical */
.growth-fill{
  fill:url(#growthGrad);opacity:0;
  transition:opacity 1.4s var(--ease) 1.2s;
}
.growth.in .growth-fill{opacity:1}

/* GLOW HALO embaixo da linha */
.growth-line-glow{
  fill:none;stroke:#5fc5bf;stroke-width:5;
  vector-effect:non-scaling-stroke;
  stroke-linecap:round;stroke-linejoin:round;
  filter:blur(6px);opacity:0;
  stroke-dasharray:1200;stroke-dashoffset:1200;
  transition:stroke-dashoffset 2.8s var(--ease-out), opacity 1s ease .4s;
}
.growth.in .growth-line-glow{stroke-dashoffset:0;opacity:.7}

/* LINE PRINCIPAL · gradient teal → mint → gold */
.growth-line{
  fill:none;stroke:url(#lineGrad);stroke-width:3.5;
  vector-effect:non-scaling-stroke;
  stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:1200;stroke-dashoffset:1200;
  transition:stroke-dashoffset 2.8s var(--ease-out);
}
.growth.in .growth-line{stroke-dashoffset:0}

/* MILESTONES · pop bounce em sequência */
.growth-ms{
  fill:var(--deep);stroke:var(--teal-bright);stroke-width:2.5;
  vector-effect:non-scaling-stroke;
  transform:scale(0);transform-origin:center;transform-box:fill-box;opacity:0;
  transition:transform .55s cubic-bezier(.34,1.56,.64,1), opacity .3s ease;
}
.growth.in .growth-ms{opacity:1;transform:scale(1)}
.growth.in .growth-ms[data-i="0"]{transition-delay:1.8s}
.growth.in .growth-ms[data-i="1"]{transition-delay:2.05s}
.growth.in .growth-ms[data-i="2"]{transition-delay:2.30s}
.growth.in .growth-ms[data-i="3"]{transition-delay:2.55s}
.growth.in .growth-ms[data-i="4"]{transition-delay:2.80s}
.growth.in .growth-ms[data-i="5"]{transition-delay:3.10s;stroke:var(--gold);fill:var(--gold-bright);stroke-width:3}

/* HALO DOURADO pulsante no ponto final */
.growth-ms-final-halo{
  fill:none;stroke:var(--gold);stroke-width:2.5;
  vector-effect:non-scaling-stroke;opacity:0;
  transform-origin:center;transform-box:fill-box;
}
.growth.in .growth-ms-final-halo{
  animation:finalHaloPulse 2.6s ease-out infinite;animation-delay:3.6s;opacity:1;
}
@keyframes finalHaloPulse{
  0%  {transform:scale(.8);opacity:.9}
  100%{transform:scale(4);opacity:0}
}

/* TRACER luminoso · roda na linha após desenho */
.growth-tracer{
  fill:#fff;filter:drop-shadow(0 0 12px var(--gold-bright)) drop-shadow(0 0 4px #fff);
  opacity:0;
}
.growth.in .growth-tracer{opacity:1}

/* Y-AXIS labels (HTML overlay, esquerda) */
.growth-y-axis{
  position:absolute;left:-22px;top:0;bottom:0;width:46px;pointer-events:none;z-index:2;
}
.growth-y-axis span{
  position:absolute;right:0;transform:translateY(50%);
  font-size:10.5px;font-weight:600;color:var(--w40);
  font-variant-numeric:tabular-nums;letter-spacing:.02em;
}

/* VALUE BADGES (HTML overlay, acima de cada milestone) */
.growth-vbadges{position:absolute;inset:0;pointer-events:none;z-index:3}
.gv{
  position:absolute;
  padding:6px 11px;border-radius:9px;
  background:rgba(3,34,44,.92);border:1px solid var(--t30);
  font-size:12.5px;font-weight:700;color:#fff;
  font-variant-numeric:tabular-nums;letter-spacing:-.01em;
  white-space:nowrap;
  backdrop-filter:blur(8px);
  box-shadow:0 6px 14px rgba(0,0,0,.3);
  opacity:0;transform:translate(-50%, -8px);
  transition:opacity .45s ease, transform .55s var(--ease-out);
}
.growth.in .gv{opacity:1;transform:translate(-50%, -16px)}
.growth.in .gv[data-i="0"]{transition-delay:1.95s}
.growth.in .gv[data-i="1"]{transition-delay:2.20s}
.growth.in .gv[data-i="2"]{transition-delay:2.45s}
.growth.in .gv[data-i="3"]{transition-delay:2.70s}
.growth.in .gv[data-i="4"]{transition-delay:2.95s}
.growth.in .gv[data-i="5"]{transition-delay:3.25s}
.gv-final{
  background:linear-gradient(135deg, var(--gold-bright), var(--gold));
  border-color:var(--gold-bright);color:var(--ink);
  padding:8px 14px;font-size:14px;font-weight:800;
  box-shadow:0 12px 28px rgba(228,182,89,.45), inset 0 1px 0 rgba(255,255,255,.4);
}

/* X-AXIS · anos (HTML overlay, GRANDE e legível) */
.growth-x-axis{
  position:relative;margin-top:18px;height:30px;
}
.growth-x-axis span{
  position:absolute;transform:translateX(-50%);
  font-size:13.5px;font-weight:700;color:var(--w75);
  font-variant-numeric:tabular-nums;letter-spacing:.02em;
}
.growth-x-axis span.is-gold{
  color:var(--gold-bright);
  text-shadow:0 0 16px rgba(240,199,114,.35);
}

/* tick marks acima dos anos */
.growth-x-axis::before{
  content:'';position:absolute;left:0;right:0;top:-8px;height:1px;
  background:linear-gradient(90deg, transparent, var(--w15) 8%, var(--w15) 92%, transparent);
}

/* ═══ YoY GROWTH PILLS · acendem em cascata sincronizadas com o tracer ═══ */
.yoy-pill{
  position:absolute;transform:translate(-50%,-50%) scale(.7);
  display:inline-flex;align-items:center;gap:3px;
  padding:3px 9px;border-radius:999px;
  background:linear-gradient(135deg, rgba(58,157,152,.25), rgba(58,157,152,.10));
  border:1px solid var(--t40);
  font-size:10.5px;font-weight:800;color:var(--teal-bright);
  font-variant-numeric:tabular-nums;letter-spacing:-.005em;
  backdrop-filter:blur(8px);
  box-shadow:0 6px 14px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.10);
  opacity:0;pointer-events:none;z-index:4;
  will-change:transform,opacity,box-shadow;
}
.yoy-pill i{font-size:8px}

/* keyframes teal · pill normal · flash sutil */
@keyframes yoyPulse{
  /* 0% · MOMENTO DA TRACER · brilho contido */
  0%{
    opacity:1;
    transform:translate(-50%,-50%) scale(1.12);
    background:linear-gradient(135deg, rgba(95,197,191,.45), rgba(58,157,152,.20));
    border-color:var(--teal-bright);color:#fff;
    box-shadow:
      0 0 18px rgba(95,197,191,.45),
      0 0 36px rgba(95,197,191,.18),
      0 6px 14px rgba(0,0,0,.4);
    filter:brightness(1.15);
  }
  /* settle */
  8%{
    opacity:1;
    transform:translate(-50%,-50%) scale(1.04);
    background:linear-gradient(135deg, rgba(58,157,152,.30), rgba(58,157,152,.12));
    border-color:var(--t50);color:var(--teal-bright);
    box-shadow:0 0 12px rgba(95,197,191,.20), 0 6px 14px rgba(0,0,0,.4);
  }
  /* normal lit · resto do ciclo */
  16%, 100%{
    opacity:1;
    transform:translate(-50%,-50%) scale(1);
    background:linear-gradient(135deg, rgba(58,157,152,.25), rgba(58,157,152,.10));
    border-color:var(--t40);color:var(--teal-bright);
    box-shadow:0 6px 14px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.10);
    filter:brightness(1);
  }
}

/* keyframes gold · pill is-peak · flash sutil */
@keyframes yoyPulseGold{
  0%{
    opacity:1;
    transform:translate(-50%,-50%) scale(1.12);
    background:linear-gradient(135deg, rgba(240,199,114,.45), rgba(228,182,89,.20));
    border-color:var(--gold-bright);color:var(--gold-bright);
    box-shadow:
      0 0 18px rgba(228,182,89,.45),
      0 0 36px rgba(228,182,89,.18),
      0 6px 14px rgba(0,0,0,.4);
    filter:brightness(1.15);
  }
  8%{
    opacity:1;
    transform:translate(-50%,-50%) scale(1.04);
    background:linear-gradient(135deg, rgba(228,182,89,.35), rgba(228,182,89,.14));
    border-color:var(--gold-bright);color:var(--gold-bright);
    box-shadow:0 0 12px rgba(228,182,89,.22), 0 6px 14px rgba(0,0,0,.4);
  }
  16%, 100%{
    opacity:1;
    transform:translate(-50%,-50%) scale(1);
    background:linear-gradient(135deg, rgba(228,182,89,.30), rgba(228,182,89,.10));
    border-color:var(--gold);color:var(--gold-bright);
    box-shadow:0 8px 18px rgba(228,182,89,.30), inset 0 1px 0 rgba(255,255,255,.20);
    filter:brightness(1);
  }
}

/* aplicar as animações em loop sincronizado com a tracer */
.growth.in .yoy-pill{animation:yoyPulse 4s linear infinite}
.growth.in .yoy-pill.is-peak{animation:yoyPulseGold 4s linear infinite}

/* delays exatos · sincronizam com a tracer passando em cada midpoint */
/* tracer começa em 3.4s, dura 4s · tempo no midpoint = 3.4 + (pct × 4) */
.growth.in .yoy-pill[data-i="0"]{animation-delay:3.78s} /* 9.58% do caminho */
.growth.in .yoy-pill[data-i="1"]{animation-delay:4.56s} /* 29.09% */
.growth.in .yoy-pill[data-i="2"]{animation-delay:5.36s} /* 49.11% */
.growth.in .yoy-pill[data-i="3"]{animation-delay:6.17s} /* 69.31% */
.growth.in .yoy-pill[data-i="4"]{animation-delay:6.99s} /* 89.81% */

.yoy-pill.is-peak{
  background:linear-gradient(135deg, rgba(228,182,89,.30), rgba(228,182,89,.10));
  border-color:var(--gold);color:var(--gold-bright);
  box-shadow:0 8px 18px rgba(228,182,89,.30), inset 0 1px 0 rgba(255,255,255,.20);
}

/* ═══ TRIPLE RADAR PULSE no ponto final ═══ */
.growth.in .growth-ms-final-halo.halo-2{animation-delay:4.2s}
.growth.in .growth-ms-final-halo.halo-3{animation-delay:4.8s}

/* ═══ Crown icon dentro do gv-final ═══ */
.gv-final i{font-size:12px;margin-right:2px;color:var(--ink)}

/* ═══ INTERACTIVE CROSSHAIR · hover scrub ═══ */
.growth-crosshair{
  position:absolute;top:0;bottom:0;width:1px;left:0;
  background:linear-gradient(180deg, transparent, rgba(95,197,191,.5) 15%, rgba(95,197,191,.5) 85%, transparent);
  pointer-events:none;z-index:6;
  opacity:0;transition:opacity .2s ease;
}
.growth-crosshair::before, .growth-crosshair::after{
  content:'';position:absolute;left:50%;width:6px;height:6px;border-radius:50%;
  transform:translateX(-50%);background:var(--teal-bright);
  box-shadow:0 0 8px var(--teal-bright);
}
.growth-crosshair::before{top:0}
.growth-crosshair::after{bottom:0}
.growth-chart-inner:hover .growth-crosshair{opacity:1}

.growth-tooltip{
  position:absolute;left:0;top:-12px;
  transform:translate(-50%,-100%);
  padding:10px 14px;border-radius:12px;
  background:linear-gradient(180deg, rgba(7,57,73,.96), rgba(3,34,44,.96));
  border:1px solid var(--t40);
  font-size:13px;color:#fff;
  white-space:nowrap;pointer-events:none;z-index:7;
  opacity:0;transition:opacity .2s ease;
  box-shadow:0 18px 36px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter:blur(12px);
}
.growth-tooltip::after{
  content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:6px solid transparent;border-top-color:rgba(3,34,44,.96);
}
.growth-chart-inner:hover .growth-tooltip{opacity:1}
.gt-year{
  font-size:10px;color:var(--teal-bright);font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;margin-bottom:5px;
  display:flex;align-items:center;gap:6px;
}
.gt-year::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--teal-bright)}
.gt-value{font-size:15px;font-weight:700;color:#fff;font-variant-numeric:tabular-nums;letter-spacing:-.012em}
.gt-value b{color:var(--gold-bright)}

/* KPI strip abaixo do chart */
.growth-kpis{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:32px;
}
.kpi{
  padding:22px;border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid var(--w10);position:relative;overflow:hidden;
  transition:all .3s var(--ease);
}
.kpi:hover{border-color:var(--t30);transform:translateY(-3px)}
.kpi.kpi-gold{
  background:linear-gradient(180deg, rgba(228,182,89,.10), rgba(228,182,89,.02));
  border-color:rgba(228,182,89,.25);
}
.kpi.kpi-gold:hover{border-color:var(--gold)}
.kpi .kt{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--w50);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.kpi .kt i{color:var(--teal-bright);font-size:10px}
.kpi.kpi-gold .kt i{color:var(--gold-bright)}
.kpi .kv{font-size:28px;font-weight:700;color:#fff;letter-spacing:-.022em;line-height:1;font-variant-numeric:tabular-nums;margin-bottom:6px;display:flex;align-items:baseline;gap:5px}
.kpi .kv .ksuffix{font-size:.5em;color:var(--teal-bright);font-weight:600}
.kpi.kpi-gold .kv .ksuffix{color:var(--gold-bright)}
.kpi .kd{font-size:12px;color:var(--w60);font-weight:500;letter-spacing:-.005em}
.kpi .kd b{color:var(--teal-bright);font-weight:700}
.kpi.kpi-gold .kd b{color:var(--gold-bright)}
.kpi-spark{margin-top:14px;height:24px;display:flex;align-items:flex-end;gap:2px}
.kpi-spark span{
  flex:1;background:linear-gradient(180deg, var(--teal-bright), var(--teal-darker));
  border-radius:2px;opacity:.55;transform-origin:bottom;
}
.kpi.kpi-gold .kpi-spark span{background:linear-gradient(180deg, var(--gold-bright), var(--gold-deep))}

.timeline{display:grid;grid-template-columns:repeat(var(--tl-cols,6),minmax(0,1fr));gap:0;margin-top:64px;position:relative}
.timeline::before{
  content:'';position:absolute;left:calc(50% / var(--tl-cols,6));right:calc(50% / var(--tl-cols,6));top:11px;height:2px;border-radius:2px;
  background:linear-gradient(90deg, transparent, var(--teal-bright) 16%, var(--teal-bright) 84%, transparent);opacity:.55;
}
.timeline-item{text-align:center;position:relative;padding:0 10px}
.timeline-dot{
  width:22px;height:22px;border-radius:50%;background:var(--deep);border:2px solid var(--teal-bright);
  margin:0 auto 14px;position:relative;z-index:2;
  box-shadow:0 0 12px rgba(58,157,152,.4);
}
.timeline-year{font-size:18px;font-weight:700;color:#fff;letter-spacing:-.012em;margin-bottom:5px;font-variant-numeric:tabular-nums}
.timeline-text{font-size:12.5px;color:var(--w75);line-height:1.5;max-width:180px;margin:0 auto}

/* ═══════════════════════════════════════════════════════════════════
   TRIBUNAIS · discreto
═══════════════════════════════════════════════════════════════════════ */
.tribunais{padding:90px 0;background:var(--paper);color:var(--ink);position:relative;overflow:hidden}
.tribunais .container{text-align:center}
.tribunais-head{
  font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal-darker);margin-bottom:36px;
}

/* SWIPER · auto-scroll infinito */
.tribunais-swiper{
  position:relative;overflow:hidden;
  mask-image:linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
}
.tribunais-track{
  display:flex;gap:14px;width:max-content;padding:10px 7px;
  animation:tribScroll 55s linear infinite;
  will-change:transform;
}
.tribunais-swiper:hover .tribunais-track{animation-play-state:paused}
@keyframes tribScroll{
  from{transform:translateX(0)}
  to{transform:translateX(calc(-50% - 7px))}
}

/* CARD do tribunal */
.trib{
  flex-shrink:0;width:180px;
  padding:26px 16px 22px;
  border-radius:14px;background:#fff;
  border:1px solid var(--i08);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  position:relative;overflow:hidden;
  transition:transform .35s var(--ease), border-color .3s, box-shadow .35s;
  cursor:default;
}
/* top accent bar (cresce no hover) */
.trib::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--accent, var(--teal));
  transform:scaleX(.35);transform-origin:center;opacity:.55;
  transition:transform .45s var(--ease), opacity .35s ease;
}
/* dot indicator canto sup direito */
.trib::after{
  content:'';position:absolute;top:13px;right:13px;
  width:6px;height:6px;border-radius:50%;
  background:var(--accent, var(--teal));
  box-shadow:0 0 8px var(--accent, var(--teal)), 0 0 0 3px rgba(255,255,255,.6);
  opacity:.85;
}
.trib:hover{
  transform:translateY(-6px);
  border-color:var(--accent, var(--teal));
  box-shadow:0 20px 38px -12px rgba(2,24,32,.14);
}
.trib:hover::before{transform:scaleX(1);opacity:1}
.trib i{
  font-size:24px;color:var(--accent, var(--teal));
  filter:drop-shadow(0 2px 4px rgba(2,24,32,.08));
  transition:transform .4s cubic-bezier(.34,1.56,.64,1);
}
.trib:hover i{transform:scale(1.15) rotate(-6deg)}
.trib b{font-size:13.5px;font-weight:800;letter-spacing:-.005em;color:var(--deep)}
.trib span{
  font-size:10px;color:var(--i55);
  letter-spacing:.10em;text-transform:uppercase;font-weight:600;
  text-align:center;line-height:1.3;
}

/* ═══════════════════════════════════════════════════════════════════
   METODOLOGIA
═══════════════════════════════════════════════════════════════════════ */
.method{padding:140px 0}
.method-head{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;margin-bottom:68px;align-items:end}
.method-head h2{margin-top:18px;color:#fff}
.method-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.method-card{
  padding:30px;border-radius:20px;border:1px solid var(--w10);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  position:relative;overflow:hidden;transition:all .3s var(--ease);
}
.method-card:hover{border-color:var(--t30);transform:translateY(-4px)}
.method-card::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(220px 110px at 0% 0%, rgba(58,157,152,.12), transparent 60%);
  opacity:0;transition:opacity .3s var(--ease);
}
.method-card:hover::before{opacity:1}
.method-num{
  font-size:38px;color:var(--teal-bright);
  font-weight:800;letter-spacing:-.03em;line-height:1;margin-bottom:18px;
  font-variant-numeric:tabular-nums;
}
.method-card h4{font-size:18px;font-weight:700;color:#fff;letter-spacing:-.012em;margin-bottom:10px}
.method-card p{font-size:13.5px;color:var(--w75);line-height:1.6}
.method-card i.ico{position:absolute;top:28px;right:28px;font-size:22px;color:var(--teal-bright);opacity:.35}

/* ═══════════════════════════════════════════════════════════════════
   DEPOIMENTOS
═══════════════════════════════════════════════════════════════════════ */
.testim{padding:140px 0 120px;background:linear-gradient(180deg, var(--cream-2), var(--cream));overflow:hidden}
.testim-head{text-align:center;max-width:680px;margin:0 auto 60px}
.testim-head h2{margin-top:18px}

/* swiper · auto-scroll infinito, pausa no hover */
.testim-swiper{
  position:relative;overflow:hidden;padding:12px 0;
  mask-image:linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
}
.testim-track{
  display:flex;gap:22px;width:max-content;padding:0 11px;
  animation:testimScroll 60s linear infinite;
  will-change:transform;
}
.testim-swiper:hover .testim-track{animation-play-state:paused}
@keyframes testimScroll{
  from{transform:translateX(0)}
  to{transform:translateX(calc(-50% - 11px))}
}

/* card */
.test-card{
  flex-shrink:0;width:340px;
  padding:22px 26px 24px;border-radius:20px;
  background:linear-gradient(180deg, #fff, rgba(255,255,255,.96));
  border:1px solid var(--i08);
  box-shadow:0 12px 28px -10px rgba(2,24,32,.08);
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;gap:16px;
  transition:transform .4s var(--ease), border-color .35s, box-shadow .4s;
  cursor:default;
}
.test-card:hover{
  transform:translateY(-8px);
  border-color:var(--teal-darker);
  box-shadow:0 26px 52px -12px rgba(2,24,32,.16), 0 0 0 1px rgba(45,132,127,.08);
}

/* top row · verified badge + stars lado a lado */
.test-top{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}

.test-verified{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 10px;border-radius:999px;
  background:rgba(45,132,127,.10);border:1px solid rgba(45,132,127,.25);
  color:var(--teal-darker);font-size:9.5px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;
}
.test-verified i{font-size:8px}

.test-stars{
  display:flex;gap:3px;color:var(--gold-bright);font-size:11px;
  filter:drop-shadow(0 1px 1px rgba(228,182,89,.3));
}

/* texto do depoimento · limpo, sem aspa decorativa */
.test-text{
  font-size:14.5px;line-height:1.68;color:var(--i75);font-weight:400;
  letter-spacing:-.005em;flex:1;
  margin:0;padding:0;
}

/* foot · nome + função + cidade */
.test-foot{
  display:flex;flex-direction:column;gap:3px;
  padding-top:18px;margin-top:4px;border-top:1px solid var(--i08);
}
.test-name{
  color:var(--ink);font-size:14px;font-weight:700;letter-spacing:-.005em;
}
.test-role{color:var(--i55);font-size:12px;font-weight:500}
.test-city{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--teal-darker);font-size:11px;font-weight:700;
  letter-spacing:.10em;text-transform:uppercase;margin-top:5px;
}
.test-city i{font-size:9px}

/* ═══════════════════════════════════════════════════════════════════
   BLOG · grid 3×2 simples e refinado
═══════════════════════════════════════════════════════════════════════ */
.blog{padding:140px 0;background:var(--ink);position:relative}
.blog-head{display:flex;justify-content:space-between;align-items:end;gap:40px;margin-bottom:60px;flex-wrap:wrap}
.blog-head h2{margin-top:18px;color:#fff;max-width:580px}

.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.blog-card{
  display:flex;flex-direction:column;border-radius:20px;overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid var(--w08);transition:all .35s var(--ease);
  text-decoration:none;color:inherit;
}
.blog-card:hover{transform:translateY(-6px);border-color:var(--t30);box-shadow:0 24px 50px -16px rgba(0,0,0,.4)}
.blog-card .img{aspect-ratio:16/10;overflow:hidden;background:var(--deep-3);position:relative}
.blog-card .img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.blog-card:hover .img img{transform:scale(1.06)}
.blog-card .img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg, transparent 65%, rgba(2,24,32,.5))}
.blog-card .b{padding:22px;display:flex;flex-direction:column;flex:1}
.blog-card .cat-row{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.cat-pill{
  display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;
  background:rgba(58,157,152,.12);border:1px solid var(--t30);
  font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-bright);
}
.cat-pill i{font-size:8px}
.meta-text{font-size:11.5px;color:var(--w60);display:inline-flex;align-items:center;gap:6px}
.meta-text i{font-size:10px;color:var(--teal-bright)}
.blog-card h4{font-size:16.5px;font-weight:700;color:#fff;line-height:1.32;letter-spacing:-.012em;margin-bottom:10px;flex:1}
.blog-card p{font-size:13px;color:var(--w65);line-height:1.6;margin-bottom:18px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.blog-card .foot{
  display:flex;align-items:center;gap:8px;padding-top:14px;border-top:1px solid var(--w05);
  font-size:11.5px;color:var(--w50);
}
.blog-card .foot i{color:var(--teal-bright);font-size:10px}
.blog-card .foot .read{margin-left:auto;color:var(--teal-bright);font-weight:700;display:inline-flex;align-items:center;gap:6px}

.blog-foot{margin-top:56px;text-align:center}
.blog-foot .btn-link{background:transparent;border:1px solid var(--w15);color:#fff}
.blog-foot .btn-link:hover{background:var(--teal-darker);border-color:var(--teal-darker)}

/* ═══════════════════════════════════════════════════════════════════
   CTA FINAL
═══════════════════════════════════════════════════════════════════════ */
.cta-final{
  padding:160px 0 140px;position:relative;overflow:hidden;
  background:
    radial-gradient(ellipse 50% 40% at 50% 0%, rgba(228,182,89,.22), transparent 65%),
    radial-gradient(ellipse 70% 50% at 50% 100%, rgba(58,157,152,.12), transparent 65%),
    linear-gradient(180deg, var(--cream-2) 0%, var(--cream) 100%);
  color:var(--ink);
}
.cta-final::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(7,57,73,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(7,57,73,.04) 1px, transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 70% 50% at 50% 50%, #000, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 70% 50% at 50% 50%, #000, transparent 80%);
  opacity:.8;
}
/* gold orb decorativo flutuante */
.cta-final::after{
  content:'';position:absolute;width:520px;height:520px;
  top:-240px;left:50%;
  background:radial-gradient(circle, rgba(228,182,89,.30), transparent 65%);
  filter:blur(70px);pointer-events:none;
  animation:ctaOrb 9s ease-in-out infinite alternate;
}
@keyframes ctaOrb{
  0%  {transform:translate(-50%, 0) scale(1)}
  100%{transform:translate(-45%, 30px) scale(1.12)}
}

.cta-final .container{position:relative;text-align:center;max-width:880px;z-index:2}

.cta-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px;border-radius:999px;
  background:linear-gradient(135deg, rgba(228,182,89,.20), rgba(228,182,89,.06));
  border:1px solid rgba(228,182,89,.40);
  font-size:11.5px;font-weight:700;color:var(--gold-deep);
  letter-spacing:.16em;text-transform:uppercase;
  margin-bottom:32px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5), 0 8px 18px rgba(228,182,89,.18);
}
.cta-eyebrow .dot{
  width:7px;height:7px;border-radius:50%;background:var(--gold);
  box-shadow:0 0 0 0 rgba(228,182,89,.5);
  animation:livePulse 2s ease-out infinite;
}

.cta-final h2{
  margin-bottom:28px;color:var(--ink);
  font-size:clamp(38px,5.2vw,72px);letter-spacing:-.035em;line-height:1.0;font-weight:700;
}
.cta-final h2 em{
  color:var(--teal-darker);font-style:normal;font-weight:700;
}

.cta-final p{
  margin:0 auto 48px;max-width:660px;
  font-size:clamp(16px,1.35vw,19px);color:var(--i75);line-height:1.55;
}
.cta-final p b{color:var(--ink);font-weight:600}

.cta-buttons{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-bottom:48px}
.cta-final .btn-primary{
  padding:0 30px;height:60px;font-size:15px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.32),
    0 22px 50px rgba(58,157,152,.35),
    0 0 0 6px rgba(58,157,152,.06);
}
.cta-final .btn-primary:hover{
  transform:translateY(-3px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.35),
    0 30px 60px rgba(58,157,152,.45),
    0 0 0 8px rgba(58,157,152,.08);
}
.cta-final .btn-secondary{
  background:#fff;border-color:rgba(2,24,32,.10);color:var(--deep);
  padding:0 28px;height:60px;font-size:15px;font-weight:600;
  box-shadow:0 14px 28px rgba(2,24,32,.06), inset 0 1px 0 rgba(255,255,255,.8);
}
.cta-final .btn-secondary:hover{
  background:#fff;border-color:var(--teal-darker);transform:translateY(-3px);
  box-shadow:0 22px 40px rgba(2,24,32,.10), inset 0 1px 0 rgba(255,255,255,.8);
}
.cta-final .btn-secondary i{color:var(--teal-darker)}

/* trust line abaixo dos CTAs */
.cta-trust{
  display:flex;justify-content:center;align-items:center;gap:36px;flex-wrap:wrap;
  padding-top:36px;border-top:1px solid rgba(2,24,32,.08);
  font-size:13px;color:var(--i55);font-weight:500;
}
.cta-trust span{display:inline-flex;align-items:center;gap:8px;font-variant-numeric:tabular-nums}
.cta-trust span i{color:var(--teal-darker);font-size:13px}
.cta-trust span b{color:var(--ink);font-weight:700}

/* ═══════════════════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════════════════════ */
.footer{
  background:var(--ink);padding:76px 0 18px;color:var(--w75);
  border-top:1px solid var(--w08);position:relative;
}
.footer::before{
  content:'';position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--t50) 30%, var(--t50) 70%, transparent);
  opacity:.5;
}
.footer-grid{display:grid;grid-template-columns:1.6fr repeat(5,1fr);gap:36px;margin-bottom:38px}
.footer-brand img{height:46px;margin-bottom:18px;filter:brightness(1.1)}
.footer-brand p{font-size:13.5px;color:var(--w60);line-height:1.6;max-width:310px;margin-bottom:18px}
.footer-col h5{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--teal-bright);margin-bottom:20px}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col a{font-size:13.5px;color:var(--w75);transition:color .2s var(--ease)}
.footer-col a:hover{color:#fff}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  padding-top:26px;border-top:1px solid var(--w08);
  font-size:12px;color:var(--w40);
}
.footer-bottom b{color:var(--w75);font-weight:600}
.footer-cnpj{font-size:12px;color:var(--w40)}
.footer-cnpj b{color:var(--w75);font-weight:600}

/* back-to-top legado (index.php) ficava SEM estilo no fluxo após o footer,
   criando uma faixa com a cor do body (≈ cor do footer) = "espaço fantasma".
   Escopo por href p/ não afetar o .transition do menu. */
a.transition[href="#top"]{display:none!important}
.footer-bottom .soc{display:flex;gap:6px}
.footer-bottom .soc a{
  width:36px;height:36px;border-radius:50%;border:1px solid var(--w10);background:var(--w05);
  display:grid;place-items:center;color:var(--teal-bright);transition:all .2s var(--ease);
}
.footer-bottom .soc a:hover{background:var(--teal);color:#fff;border-color:var(--teal)}

/* linha legal (CNPJ + endereço) abaixo do WhatsApp na coluna da marca */
.footer-legal{font-size:11.5px;line-height:1.7;color:var(--w40);margin-top:18px;max-width:300px}
.footer-legal b{color:var(--w60);font-weight:700}

/* crédito do desenvolvedor — pílula sutil que vira luxo no hover */
.footer-dev{
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;
  font-family:inherit;font-size:12px;font-weight:500;color:var(--w40);
  background:var(--w05);border:1px solid var(--w08);border-radius:999px;
  padding:7px 15px;transition:all .25s var(--ease);-webkit-tap-highlight-color:transparent;
}
.footer-dev b{color:var(--w75);font-weight:700;transition:color .25s var(--ease)}
.footer-dev svg{width:12px;height:12px;opacity:.5;transition:all .25s var(--ease)}
.footer-dev-dot{width:6px;height:6px;border-radius:50%;background:var(--teal-bright);box-shadow:0 0 0 0 rgba(95,197,191,.5);animation:fdevPulse 2.4s infinite}
.footer-dev:hover{border-color:var(--t50);background:rgba(58,157,152,.08);color:var(--w75);transform:translateY(-1px)}
.footer-dev:hover b{color:#fff}
.footer-dev:hover svg{opacity:1;transform:translate(2px,-2px);color:var(--teal-bright)}
@keyframes fdevPulse{0%{box-shadow:0 0 0 0 rgba(95,197,191,.5)}70%{box-shadow:0 0 0 7px rgba(95,197,191,0)}100%{box-shadow:0 0 0 0 rgba(95,197,191,0)}}

/* ═══ MODAL do desenvolvedor — glass premium ═══ */
.devm{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:22px;
  opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s}
.devm.open{opacity:1;visibility:visible}
.devm-ov{position:absolute;inset:0;background:rgba(2,12,16,.72);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.devm-card{position:relative;width:100%;max-width:420px;overflow:hidden;
  background:linear-gradient(168deg,#0b2f38 0%,#072730 52%,#041a21 100%);
  border:1px solid rgba(95,197,191,.18);border-radius:26px;
  padding:34px 30px 30px;color:#eaf4f3;
  box-shadow:0 40px 100px -30px rgba(0,0,0,.8),inset 0 1px 0 rgba(255,255,255,.06);
  transform:translateY(22px) scale(.96);opacity:0;transition:transform .42s cubic-bezier(.16,1,.3,1),opacity .42s}
.devm.open .devm-card{transform:none;opacity:1}
.devm-glow{position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:340px;height:340px;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(95,197,191,.28),rgba(228,182,89,.08) 45%,transparent 70%);filter:blur(20px)}
.devm-x{position:absolute;top:16px;right:16px;z-index:3;width:36px;height:36px;border-radius:50%;
  border:1px solid var(--w10);background:var(--w05);color:var(--w60);display:grid;place-items:center;cursor:pointer;transition:.2s}
.devm-x svg{width:16px;height:16px}
.devm-x:hover{background:var(--w10);color:#fff;transform:rotate(90deg)}
.devm-head{position:relative;z-index:2;display:flex;align-items:center;gap:18px}
.devm-av{position:relative;width:84px;height:84px;flex-shrink:0;border-radius:50%;padding:3px;
  background:linear-gradient(135deg,#5fc5bf,#e4b659);box-shadow:0 16px 40px -12px rgba(0,0,0,.6)}
.devm-av img{width:100%;height:100%;border-radius:50%;object-fit:cover;object-position:center 20%;border:3px solid #072730;display:block}
.devm-av-on{position:absolute;right:5px;bottom:5px;width:16px;height:16px;border-radius:50%;background:#25d366;border:3px solid #072730;box-shadow:0 0 0 0 rgba(37,211,102,.5);animation:fdevPulse 2.4s infinite}
.devm-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-bright)}
.devm-eyebrow svg{width:14px;height:14px}
.devm-id h3{font-size:25px;font-weight:800;letter-spacing:-.02em;color:#fff;margin:9px 0 3px;line-height:1}
.devm-role{font-size:12.5px;color:var(--w60);font-weight:500}
.devm-copy{position:relative;z-index:2;font-size:14.5px;line-height:1.65;color:var(--w75);margin:22px 0 0}
.devm-copy b{color:#fff;font-weight:700}
.devm-copy em{font-style:normal;color:var(--gold-bright);font-weight:600}
.devm-stats{position:relative;z-index:2;display:flex;gap:0;margin:22px 0 24px;border:1px solid var(--w08);border-radius:16px;overflow:hidden;background:var(--w03)}
.devm-stat{flex:1;text-align:center;padding:14px 8px}
.devm-stat+.devm-stat{border-left:1px solid var(--w08)}
.devm-stat b{display:block;font-size:23px;font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1}
.devm-stat span{display:block;font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--w40);margin-top:5px}
.devm-actions{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:14px}
.devm-wa{display:flex;align-items:center;justify-content:center;gap:11px;width:100%;height:54px;border-radius:15px;
  font-size:16px;font-weight:800;letter-spacing:-.01em;color:#06241a;
  background:linear-gradient(135deg,#2bea73 0%,#25D366 48%,#16b35a 100%);
  box-shadow:0 16px 36px -12px rgba(37,211,102,.6),inset 0 1.5px 0 rgba(255,255,255,.45);transition:transform .2s var(--ease),box-shadow .2s}
.devm-wa i{font-size:21px}
.devm-wa:hover{transform:translateY(-2px);box-shadow:0 22px 46px -12px rgba(37,211,102,.7),inset 0 1.5px 0 rgba(255,255,255,.5)}
.devm-site{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--w60);transition:color .2s}
.devm-site svg{width:13px;height:13px;opacity:.6;transition:.2s}
.devm-site:hover{color:#fff}.devm-site:hover svg{opacity:1;transform:translate(2px,-2px);color:var(--teal-bright)}
@media(max-width:480px){
  .devm-card{padding:30px 22px 26px;border-radius:22px}
  .devm-head{flex-direction:column;text-align:center;gap:14px}
  .devm-id h3{font-size:23px}
  .devm-copy{font-size:14px;text-align:center}
}

/* ═══════════════════════════════════════════════════════════════════
   FLOATING · WhatsApp + ticker (não sobrepor)
═══════════════════════════════════════════════════════════════════════ */
.wa-float{
  position:fixed;right:24px;bottom:24px;z-index:80;
  width:60px;height:60px;border-radius:50%;
  background:linear-gradient(135deg, #25D366, #128C7E);
  color:#fff;display:flex;align-items:center;justify-content:center;font-size:26px;
  box-shadow:0 14px 30px rgba(37,211,102,.4), inset 0 1px 0 rgba(255,255,255,.30);
  transition:all .3s var(--ease);border:1px solid rgba(255,255,255,.20);
}
.wa-float:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 22px 44px rgba(37,211,102,.55)}

.activity-ticker{
  position:fixed;left:24px;bottom:24px;z-index:79;
  display:inline-flex;align-items:center;gap:10px;padding:10px 16px 10px 12px;
  border-radius:999px;border:1px solid var(--t30);
  background:rgba(3,34,44,.92);backdrop-filter:blur(16px);
  font-size:12px;color:var(--w90);font-weight:500;
  box-shadow:0 14px 30px rgba(0,0,0,.4);
  opacity:0;transform:translateY(20px);transition:all .5s var(--ease);
  max-width:340px;
}
.activity-ticker.show{opacity:1;transform:translateY(0)}
.activity-ticker .at-dot{width:8px;height:8px;border-radius:50%;background:var(--teal-bright);box-shadow:0 0 0 3px rgba(58,157,152,.25);animation:livePulse 2.4s ease-out infinite;flex-shrink:0}
.activity-ticker b{color:#fff;font-weight:700}

/* ao chegar no rodapé · oculta os flutuantes */
body.at-footer .wa-float,
body.at-footer .activity-ticker{
  opacity:0;pointer-events:none;transform:translateY(26px);
}

/* ═══════════════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════════════════ */
/* ── TABLET ── */
@media(max-width:1180px){
  .hero-glow{width:760px;height:560px}
  .map-grid{grid-template-columns:1fr;gap:48px}
  .method-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1.5fr 1fr 1fr;gap:36px}
  .h-nav, .h-divider{display:none}
  .h-hamb{display:flex}
  .split-grid{grid-template-columns:1fr;min-height:0}
  .split-side{padding:80px 50px}
  .split-divider, .split-m{display:none}
}
/* ── MOBILE ── */
@media(max-width:780px){
  .container-wide{max-width:100%;padding:0 18px}   /* container-wide vira container normal */
  .container{padding:0 18px}

  /* HEADER */
  .header-inner{padding:0 12px;gap:8px}
  .header{height:68px}
  .h-logo .logo-tile{height:52px;padding:0 15px;border-radius:13px}
  .h-logo .logo-tile img{height:33px}
  .h-cta-secondary{display:none}                                   /* esconde "Encontrar perito" */
  .h-cta-primary{display:inline-flex;padding:0 14px;height:42px;font-size:13px}  /* "Quero ser perito" em evidência */
  .h-hamb{display:flex}

  /* HERO */
  .hero{padding:100px 0 70px;min-height:auto}
  .hero-content{gap:22px}
  .hero-eyebrow{font-size:10.5px;padding:7px 13px 7px 11px;flex-wrap:wrap;justify-content:center;text-align:center}
  .hero-h1{font-size:clamp(23px,6.4vw,46px);letter-spacing:-.03em;line-height:1.06}
  .hero-h1 .l1, .hero-h1 .l2{white-space:nowrap}
  .hero-sub{font-size:14.5px;max-width:92%}
  .hero-glow{width:520px;height:420px}
  .hero-network{display:none}        /* sem rede de pontos/hover no mobile */

  /* hero não corta o dropdown da busca + fica acima das seções seguintes */
  .hero{overflow:visible;z-index:5}
  .hero-bg{overflow:hidden}          /* contém o mesh que vazaria com overflow visível */

  .hs-icon{width:46px;height:46px;font-size:15px}
  .hs-box input{height:46px;font-size:16px}            /* 16px evita zoom no iOS */
  .hs-go{width:46px;height:46px;font-size:14px}

  /* chips · UMA linha, rolagem horizontal */
  .hs-chips{
    flex-wrap:nowrap;justify-content:flex-start;
    gap:8px;margin-top:14px;padding-bottom:2px;
    overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    -webkit-mask-image:linear-gradient(90deg,#000 88%,transparent);
            mask-image:linear-gradient(90deg,#000 88%,transparent);
  }
  .hs-chips::-webkit-scrollbar{display:none}
  .hero .chip{font-size:12px;padding:7px 12px;flex-shrink:0}
  .hs-chips .lbl{display:none}

  /* dropdown de resultados · otimizado pro touch */
  .search-results{max-height:min(56vh,440px);border-radius:14px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
  .res-head{padding:12px 16px 6px}
  .res-head span:last-child{display:none}              /* esconde "ENTER · ESC" (sem teclado) */
  .res-item{padding:13px 16px;gap:12px}
  .res-avatar{width:44px;height:44px}
  .res-name{font-size:14px}
  .res-foot{padding:12px 16px;flex-wrap:wrap;gap:4px 10px;font-size:11px;line-height:1.4}
  /* stats · cápsula única: linha de números + faixa dourada integrada */
  .hero-stats{
    flex-direction:row;flex-wrap:wrap;justify-content:center;align-items:center;
    gap:0;padding:0;margin-top:10px;border-radius:16px;overflow:hidden;
    background:rgba(255,255,255,.68);
    border:1px solid rgba(2,24,32,.08);
    backdrop-filter:blur(14px);
    box-shadow:0 14px 34px -18px rgba(2,24,32,.22), inset 0 1px 0 rgba(255,255,255,.7);
  }
  .hero-stats .s-item{font-size:12.5px;padding:13px 13px}
  .hero-stats .s-item b{font-size:14px}
  .hero-stats > *:nth-child(5){display:none}        /* esconde "80+ profissionais…" */
  .hero-stats .s-sep{display:none}
  .hero-stats > .s-sep:nth-child(2){display:block;height:16px;margin:0}  /* divisor entre os 2 números */
  .hero-stats .s-gold{
    flex-basis:100%;justify-content:center;margin:0;border-radius:0;
    padding:10px 14px;font-size:10.5px;letter-spacing:.16em;
    border-top:1px solid rgba(2,24,32,.06);
    background:linear-gradient(135deg, var(--gold-bright), var(--gold) 58%, var(--gold-deep));
    box-shadow:inset 0 1px 0 rgba(255,255,255,.5);
  }
  .hero-stats .s-gold i{font-size:10px}
  .hero-scroll{display:none}

  /* paddings globais de seção */
  .featured, .method, .blog, .map-section, .growth, .testim, .cta-final{padding:72px 0}

  /* STATS BAND */
  .stats-band{padding:0}
  .stats-grid{grid-template-columns:1fr 1fr;gap:0}
  .stat-cell{padding:24px 20px;border-bottom:1px solid var(--w08)}
  .stat-cell:nth-child(2n){border-right:0}
  .stat-cell:nth-child(3), .stat-cell:nth-child(4){border-bottom:0}
  .stat-cell .num{font-size:33px}
  .stat-cell .lbl-top{margin-bottom:12px}
  .spark{display:none}

  /* MAP */
  .map-section{padding:72px 0}
  .map-head h2{margin:14px 0 16px}
  .map-bullets{margin-top:24px;gap:10px}
  .map-bullet{padding:14px}
  .map-wrap{max-width:360px;margin:8px auto 0}

  /* CARROSSEL DE PERITOS (perf: 4→3 linhas, faces menores) */
  .peritos-carousel{gap:12px;padding:20px 0}
  .carousel-row{height:70px}
  .carousel-track{gap:12px}
  .face{width:62px;height:62px}
  .carousel-row:nth-child(4){display:none}
  .featured-foot{margin-top:40px}

  /* SPLIT */
  .split-side{padding:60px 24px}
  .split-side .body{margin-bottom:28px;max-width:none}
  .split-features{margin-bottom:30px}
  .split-side::after{font-size:130px;bottom:-26px;right:-4px}
  .split-cta{flex-direction:column;gap:10px}
  .split-cta .btn-primary, .split-cta .btn-secondary{width:100%;justify-content:center}

  /* GROWTH · curva limpa (sem badges flutuantes que se sobrepõem no mobile) */
  .growth-chart{padding:16px 14px 14px}
  .growth-tag{padding:8px 12px;border-radius:12px;gap:9px}
  .growth-tag .val{font-size:14px}
  .growth-tag .lbl{font-size:8px;letter-spacing:.12em;margin-bottom:2px}
  .growth-tag-growth i{font-size:14px}
  .growth-tag-current{top:14px;left:14px}
  .growth-tag-growth{top:14px;right:14px}
  .growth-chart-inner{height:200px;margin-top:86px}
  .growth-y-axis, .yoy-pill, .growth-vbadges,
  .growth-tooltip, .growth-crosshair{display:none}   /* sem overlays = curva limpa */
  .growth-ms{stroke-width:3}
  .growth-x-axis{margin-top:14px}
  .growth-x-axis span{font-size:11.5px}
  .growth-kpis{grid-template-columns:1fr 1fr;gap:10px}
  .kpi{padding:16px}
  .kpi .kv{font-size:24px}
  .timeline{display:flex;flex-direction:column;gap:0;margin-top:42px;padding-left:2px}
  .timeline::before{display:none}
  .timeline-item{display:grid;grid-template-columns:22px 1fr;column-gap:16px;text-align:left;padding:0 0 26px}
  .timeline-item:last-child{padding-bottom:0}
  .timeline-item:not(:last-child)::after{content:'';position:absolute;left:10px;top:11px;height:100%;width:2px;background:linear-gradient(180deg,var(--teal-bright),rgba(94,197,191,.22));z-index:0}
  .timeline-dot{margin:0;grid-column:1;grid-row:1 / span 2;align-self:start}
  .timeline-year{grid-column:2;grid-row:1;align-self:start;margin:0 0 4px}
  .timeline-text{grid-column:2;grid-row:2;max-width:none;margin:0;text-align:left}

  /* MÉTODO / TRIBUNAIS */
  .method-grid{grid-template-columns:1fr}
  .method-head{grid-template-columns:1fr;gap:18px}

  /* DEPOIMENTOS */
  .test-card{width:84vw;max-width:330px;padding:24px 22px}

  /* BLOG */
  .blog-grid{grid-template-columns:1fr;gap:16px}
  .blog-head{flex-direction:column;align-items:flex-start;gap:14px}

  /* CTA FINAL */
  .cta-buttons{flex-direction:column;width:100%}
  .cta-buttons .btn-primary, .cta-buttons .btn-secondary{width:100%;justify-content:center}
  .cta-trust{gap:12px;font-size:12px}

  /* FOOTER */
  .footer{padding:56px 0 24px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:26px 28px;margin-bottom:34px}
  .footer-brand{grid-column:1 / -1}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:14px}

  /* MODAIS · inputs 16px evitam zoom no iOS */
  .modal-content input, .modal-content select, .modal-content textarea{font-size:16px}

  /* FLUTUANTES */
  .activity-ticker{max-width:calc(100vw - 92px);font-size:11px;left:14px;bottom:16px;padding:9px 14px 9px 11px}
  .wa-float{right:16px;bottom:16px;width:54px;height:54px;font-size:22px}
}

/* ── ACESSIBILIDADE / BATERIA · reduz movimento ── */
@media(prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important;
  }
  .hero-video{display:none}
  .carousel-track{animation:none}
}

/* ── PHONE PEQUENO ── */
@media(max-width:430px){
  .container, .container-wide{padding:0 16px}
  .header-inner{gap:6px}
  .h-cta-primary{padding:0 12px;height:40px;font-size:12px}   /* compacto mas visível */
  .h-cta-primary i{display:none}                               /* sem seta pra economizar espaço */
  .hero{padding:94px 0 60px}
  .hero-stats{align-items:center;text-align:center}
  .hero-stats .s-item{justify-content:center;padding:13px 9px;font-size:12px}
  .stats-grid{grid-template-columns:1fr}
  .stat-cell{border-right:0!important;text-align:center}
  .stat-cell .num{justify-content:center}
  .stat-cell:nth-child(4){border-bottom:0}
  .growth-kpis{grid-template-columns:1fr}
  .timeline{grid-template-columns:1fr}
  .map-wrap{max-width:300px}
  .activity-ticker{display:none}                                    /* libera espaço; WhatsApp continua */
}

/* ════════════════════════════════════════════════════════════════════
   MODAIS MULTISTEP · premium glass + animações cinematográficas
═══════════════════════════════════════════════════════════════════════ */
body.modal-open{overflow:hidden}

.modal-overlay{
  position:fixed;inset:0;z-index:300;
  background:rgba(2,18,24,.70);
  backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  display:none;align-items:center;justify-content:center;padding:28px;
  opacity:0;transition:opacity .35s ease;
}
.modal-overlay.is-open{display:flex;opacity:1}

.modal-box{
  position:relative;width:100%;max-width:680px;
  max-height:calc(100vh - 56px);
  border-radius:24px;
  background:linear-gradient(180deg, #ffffff 0%, #faf7f0 100%);
  box-shadow:
    0 0 0 1px rgba(58,157,152,.15),
    0 40px 90px -20px rgba(2,24,32,.55),
    0 20px 40px -12px rgba(2,24,32,.35);
  overflow:hidden;
  transform:scale(.94) translateY(20px);opacity:0;
  transition:opacity .4s ease, transform .55s cubic-bezier(.16,1,.3,1);
  display:flex;flex-direction:column;
}
.modal-overlay.is-open .modal-box{opacity:1;transform:scale(1) translateY(0);transition-delay:.05s}

/* glow border decorativo */
.modal-box::after{
  content:'';position:absolute;inset:0;border-radius:24px;padding:1px;
  background:linear-gradient(135deg, rgba(58,157,152,.5), rgba(228,182,89,.25), rgba(58,157,152,.5));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  pointer-events:none;opacity:.6;
}

.modal-close{
  position:absolute;top:16px;right:16px;z-index:10;
  width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(2,24,32,.08);background:rgba(2,24,32,.04);
  color:var(--ink);font-size:14px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .25s ease;
}
.modal-close:hover{background:rgba(255,79,79,.10);border-color:rgba(255,79,79,.3);color:#d33;transform:rotate(90deg)}

/* PROGRESS */
.modal-progress{padding:32px 36px 0;position:relative;flex-shrink:0}
.progress-bar{
  position:relative;height:4px;border-radius:999px;
  background:rgba(2,24,32,.06);overflow:hidden;margin-bottom:18px;
}
.progress-fill{
  position:absolute;left:0;top:0;bottom:0;width:25%;
  background:linear-gradient(90deg, var(--teal-deep), var(--teal-bright), var(--gold-bright));
  border-radius:999px;
  transition:width .55s cubic-bezier(.16,1,.3,1);
  box-shadow:0 0 12px rgba(58,157,152,.5);
}
.progress-fill::after{
  content:'';position:absolute;right:-2px;top:-3px;width:10px;height:10px;border-radius:50%;
  background:var(--gold-bright);box-shadow:0 0 14px var(--gold-bright);
  animation:dotShine 1.6s ease-in-out infinite;
}
@keyframes dotShine{
  0%,100%{opacity:.7;transform:scale(.85)}
  50%{opacity:1;transform:scale(1.1)}
}

.progress-pills{display:flex;align-items:center;justify-content:space-between;gap:8px}
.step-pill{
  display:flex;align-items:center;gap:7px;
  font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:rgba(2,24,32,.4);
  transition:color .35s ease;
}
.step-pill.is-active{color:var(--teal-darker)}
.step-pill.is-done{color:var(--teal-deep)}
.step-pill .ix{
  width:24px;height:24px;border-radius:50%;
  border:1.5px solid rgba(2,24,32,.15);background:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:rgba(2,24,32,.4);
  flex-shrink:0;transition:all .35s ease;
}
.step-pill.is-active .ix{
  background:var(--teal-darker);border-color:var(--teal-darker);color:#fff;
  box-shadow:0 0 0 4px rgba(45,132,127,.18);
}
.step-pill.is-done .ix{
  background:var(--teal-bright);border-color:var(--teal-bright);color:#fff;
  animation:pillDone .4s ease;
}
@keyframes pillDone{0%{transform:scale(.7)}50%{transform:scale(1.15)}100%{transform:scale(1)}}

/* CONTENT */
.modal-content{
  position:relative;flex:1;overflow:hidden auto;
  padding:32px 36px 24px;min-height:340px;
}
.modal-content::-webkit-scrollbar{width:6px}
.modal-content::-webkit-scrollbar-thumb{background:rgba(2,24,32,.15);border-radius:3px}

.step-panel{display:none}
.step-panel.is-active{
  display:block;
  animation:stepIn .5s cubic-bezier(.16,1,.3,1);
}
@keyframes stepIn{
  from{opacity:0;transform:translateX(30px)}
  to{opacity:1;transform:translateX(0)}
}

.step-header{margin-bottom:24px}
.step-num{
  display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.20em;
  text-transform:uppercase;color:var(--teal-darker);margin-bottom:12px;
  padding:3px 10px;border-radius:999px;background:rgba(45,132,127,.10);
}
.step-header h3{
  font-size:22px;font-weight:700;color:var(--ink);
  letter-spacing:-.022em;margin-bottom:6px;line-height:1.18;
}
.step-header p{font-size:13.5px;color:rgba(2,24,32,.6);line-height:1.55}

/* FIELDS */
.step-fields{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:7px;position:relative}
.field-full{grid-column:1/-1}
.field label{
  font-size:12px;font-weight:600;color:var(--ink);
  display:flex;align-items:center;gap:6px;
}
.field label .req{color:#d33}
.field input, .field select, .field textarea{
  width:100%;height:44px;padding:0 14px;border-radius:11px;
  border:1px solid rgba(2,24,32,.12);
  background:#fff;color:var(--ink);
  font-family:var(--ff);font-size:13.5px;font-weight:500;
  transition:all .22s ease;outline:none;
}
.field textarea{height:auto;min-height:96px;padding:12px 14px;resize:vertical;line-height:1.55}
.field select{
  appearance:none;cursor:pointer;padding-right:36px;
  background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23073949' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;
}
.field input::placeholder, .field textarea::placeholder{color:rgba(2,24,32,.4)}
.field input:focus, .field select:focus, .field textarea:focus{
  border-color:var(--teal-darker);
  box-shadow:0 0 0 3px rgba(45,132,127,.15);
}
.field input.error, .field select.error, .field textarea.error{
  border-color:#d33;animation:errorShake .35s ease;
}
@keyframes errorShake{
  0%,100%{transform:translateX(0)}
  25%{transform:translateX(-5px)}50%{transform:translateX(5px)}75%{transform:translateX(-3px)}
}
.field .hint{font-size:10.5px;color:rgba(2,24,32,.5);margin-top:-2px}

/* checkbox/radio */
.field-checkbox{
  flex-direction:row;align-items:flex-start;gap:10px;cursor:pointer;
  padding:12px 14px;border-radius:11px;border:1px solid rgba(2,24,32,.08);
  background:rgba(2,24,32,.02);transition:all .22s;
}
.field-checkbox:hover{border-color:rgba(45,132,127,.3);background:rgba(45,132,127,.04)}
.field-checkbox input{
  width:18px;height:18px;margin-top:1px;flex-shrink:0;cursor:pointer;
  accent-color:var(--teal-darker);
}
.field-checkbox span{font-size:12.5px;color:rgba(2,24,32,.78);line-height:1.5}
.field-checkbox span a{color:var(--teal-darker);font-weight:600}

/* RADIO PILLS · linha de opções */
.radio-pills{display:flex;gap:8px;flex-wrap:wrap}
.radio-pill{
  position:relative;flex:1;min-width:120px;cursor:pointer;
}
.radio-pill input{position:absolute;opacity:0;pointer-events:none}
.radio-pill-label{
  display:flex;align-items:center;gap:8px;justify-content:center;
  padding:10px 14px;border-radius:11px;
  border:1px solid rgba(2,24,32,.12);background:#fff;
  font-size:12.5px;font-weight:600;color:var(--ink);
  transition:all .2s ease;
}
.radio-pill-label i{color:rgba(2,24,32,.4);font-size:11px;transition:color .2s}
.radio-pill:hover .radio-pill-label{border-color:rgba(45,132,127,.3)}
.radio-pill input:checked + .radio-pill-label{
  background:rgba(45,132,127,.10);border-color:var(--teal-darker);
  color:var(--teal-darker);
  box-shadow:0 0 0 3px rgba(45,132,127,.10);
}
.radio-pill input:checked + .radio-pill-label i{color:var(--teal-darker)}

/* UPLOAD ZONE · drag-drop */
.upload-zone{
  position:relative;
  padding:24px;border-radius:14px;
  border:2px dashed rgba(45,132,127,.32);
  background:rgba(45,132,127,.04);
  text-align:center;cursor:pointer;
  transition:all .28s ease;
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.upload-zone:hover{border-color:var(--teal-darker);background:rgba(45,132,127,.08)}
.upload-zone.is-dragging{
  border-color:var(--teal-bright);background:rgba(95,197,191,.14);
  transform:scale(1.02);box-shadow:0 0 0 8px rgba(95,197,191,.08);
}
.upload-zone i.upload-ico{
  font-size:30px;color:var(--teal-darker);
  transition:transform .3s ease;
}
.upload-zone:hover i.upload-ico{transform:translateY(-3px) scale(1.05)}
.upload-zone .ul-title{font-size:13.5px;font-weight:600;color:var(--ink)}
.upload-zone .ul-hint{font-size:11.5px;color:rgba(2,24,32,.55)}
.upload-zone input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer}

/* upload preview */
.upload-zone.has-file{padding:14px;border-style:solid;border-color:rgba(45,132,127,.5);background:rgba(45,132,127,.06)}
.upload-zone.has-file > i.upload-ico,
.upload-zone.has-file > .ul-title,
.upload-zone.has-file > .ul-hint{display:none}
.upload-preview{display:none;align-items:center;gap:12px;width:100%;text-align:left}
.upload-zone.has-file .upload-preview{display:flex;animation:fileIn .35s ease}
@keyframes fileIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.upload-thumb{
  width:50px;height:50px;border-radius:11px;
  background:linear-gradient(135deg, var(--teal-darker), var(--teal-deep));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:18px;overflow:hidden;flex-shrink:0;
}
.upload-thumb img{width:100%;height:100%;object-fit:cover}
.upload-info{flex:1;min-width:0}
.upload-info b{display:block;font-size:13px;color:var(--ink);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.upload-info span{font-size:11px;color:rgba(2,24,32,.55)}
.upload-remove{
  width:32px;height:32px;border-radius:50%;cursor:pointer;
  background:rgba(255,79,79,.12);color:#d33;border:0;
  display:flex;align-items:center;justify-content:center;font-size:11px;
  transition:all .22s;
}
.upload-remove:hover{background:rgba(255,79,79,.22);transform:rotate(90deg)}

/* SUMMARY card · final step */
.summary-card{
  border:1px solid rgba(45,132,127,.20);
  background:linear-gradient(180deg, rgba(45,132,127,.05), rgba(45,132,127,.02));
  border-radius:14px;padding:18px 20px;
  display:flex;flex-direction:column;gap:10px;
}
.sum-row{
  display:flex;align-items:flex-start;justify-content:space-between;gap:14px;
  padding-bottom:8px;border-bottom:1px dashed rgba(2,24,32,.06);
}
.sum-row:last-child{border-bottom:0;padding-bottom:0}
.sum-key{font-size:11px;font-weight:700;color:var(--teal-darker);letter-spacing:.10em;text-transform:uppercase;flex-shrink:0}
.sum-val{font-size:13px;color:var(--ink);font-weight:500;text-align:right;word-break:break-word}

/* ACTIONS */
.modal-actions{
  padding:18px 36px 24px;flex-shrink:0;
  display:flex;align-items:center;gap:12px;
  border-top:1px solid rgba(2,24,32,.06);
  background:rgba(255,255,255,.6);
}
.step-counter{
  font-size:11px;color:rgba(2,24,32,.5);font-weight:700;letter-spacing:.10em;text-transform:uppercase;
  margin-right:auto;font-variant-numeric:tabular-nums;
}
.step-counter b{color:var(--teal-darker)}
.btn-back-modal{
  display:inline-flex;align-items:center;gap:8px;padding:0 18px;height:42px;border-radius:11px;
  background:transparent;border:1px solid rgba(2,24,32,.12);color:var(--ink);
  font-size:13px;font-weight:600;cursor:pointer;
  transition:all .22s ease;
}
.btn-back-modal:hover{background:rgba(2,24,32,.04);border-color:rgba(2,24,32,.2)}
.btn-back-modal:disabled{opacity:0;pointer-events:none}
.btn-next-modal, .btn-submit-modal{
  display:inline-flex;align-items:center;gap:8px;padding:0 22px;height:46px;border-radius:11px;
  background:linear-gradient(180deg, var(--teal-bright), var(--teal-darker));
  color:#fff;font-size:13.5px;font-weight:700;cursor:pointer;border:0;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.25), 0 14px 30px rgba(45,132,127,.30);
  transition:all .25s ease;
}
.btn-next-modal:hover, .btn-submit-modal:hover{
  transform:translateY(-2px);filter:brightness(1.06);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.30), 0 20px 40px rgba(45,132,127,.4);
}
.btn-submit-modal{
  background:linear-gradient(180deg, var(--gold-bright), var(--gold-deep));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.35), 0 14px 30px rgba(228,182,89,.4);
}
.btn-submit-modal:hover{box-shadow:inset 0 1px 0 rgba(255,255,255,.4), 0 22px 44px rgba(228,182,89,.5)}

/* SUCCESS state */
.modal-success{display:none;flex-direction:column;align-items:center;text-align:center;padding:48px 32px}
.modal-success.is-active{display:flex;animation:stepIn .5s ease}
.success-check{
  width:104px;height:104px;border-radius:50%;
  background:linear-gradient(135deg, var(--teal-bright), var(--teal-darker));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:44px;margin-bottom:24px;
  box-shadow:0 24px 60px rgba(45,132,127,.45);
  animation:successPulse 2.2s ease-out infinite;
}
@keyframes successPulse{
  0%,100%{transform:scale(1);box-shadow:0 24px 60px rgba(45,132,127,.45), 0 0 0 0 rgba(95,197,191,.4)}
  50%   {transform:scale(1.05);box-shadow:0 28px 70px rgba(45,132,127,.55), 0 0 0 18px rgba(95,197,191,0)}
}
.modal-success h3{font-size:26px;font-weight:700;color:var(--ink);margin-bottom:10px;letter-spacing:-.022em}
.modal-success p{font-size:14.5px;color:rgba(2,24,32,.65);max-width:420px;line-height:1.55;margin-bottom:28px}
.modal-success p b{color:var(--ink);font-weight:700}

/* DARK variant para modal contratar */
.modal-overlay.modal-dark .modal-box{
  background:linear-gradient(180deg, var(--deep-1) 0%, var(--ink) 100%);
}
.modal-overlay.modal-dark .modal-box::after{
  background:linear-gradient(135deg, rgba(95,197,191,.5), rgba(228,182,89,.2), rgba(95,197,191,.5));
}
.modal-overlay.modal-dark .modal-close{border-color:rgba(255,255,255,.10);background:rgba(255,255,255,.04);color:#fff}
.modal-overlay.modal-dark .progress-bar{background:rgba(255,255,255,.10)}
.modal-overlay.modal-dark .step-pill{color:rgba(255,255,255,.4)}
.modal-overlay.modal-dark .step-pill.is-active{color:var(--teal-bright)}
.modal-overlay.modal-dark .step-pill.is-done{color:var(--teal-soft)}
.modal-overlay.modal-dark .step-pill .ix{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.15);color:rgba(255,255,255,.5)}
.modal-overlay.modal-dark .step-pill.is-active .ix{background:var(--teal-bright);border-color:var(--teal-bright);color:var(--ink);box-shadow:0 0 0 4px rgba(95,197,191,.18)}
.modal-overlay.modal-dark .step-pill.is-done .ix{background:var(--teal-bright);border-color:var(--teal-bright);color:var(--ink)}
.modal-overlay.modal-dark .step-num{background:rgba(95,197,191,.12);color:var(--teal-bright)}
.modal-overlay.modal-dark .step-header h3{color:#fff}
.modal-overlay.modal-dark .step-header p{color:rgba(255,255,255,.7)}
.modal-overlay.modal-dark .field label{color:#fff}
.modal-overlay.modal-dark .field input,
.modal-overlay.modal-dark .field select,
.modal-overlay.modal-dark .field textarea{
  background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.10);color:#fff;
}
.modal-overlay.modal-dark .field input::placeholder, .modal-overlay.modal-dark .field textarea::placeholder{color:rgba(255,255,255,.4)}
.modal-overlay.modal-dark .field input:focus, .modal-overlay.modal-dark .field select:focus, .modal-overlay.modal-dark .field textarea:focus{
  border-color:var(--teal-bright);background:rgba(255,255,255,.10);
  box-shadow:0 0 0 3px rgba(95,197,191,.18);
}
.modal-overlay.modal-dark .field select{background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23fff' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E")}
.modal-overlay.modal-dark .field-checkbox{border-color:rgba(255,255,255,.08);background:rgba(255,255,255,.03)}
.modal-overlay.modal-dark .field-checkbox:hover{background:rgba(95,197,191,.06);border-color:rgba(95,197,191,.3)}
.modal-overlay.modal-dark .field-checkbox span{color:rgba(255,255,255,.85)}
.modal-overlay.modal-dark .field-checkbox span a{color:var(--teal-bright)}
.modal-overlay.modal-dark .radio-pill-label{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.10);color:rgba(255,255,255,.85)}
.modal-overlay.modal-dark .radio-pill input:checked + .radio-pill-label{background:rgba(95,197,191,.14);border-color:var(--teal-bright);color:var(--teal-bright);box-shadow:0 0 0 3px rgba(95,197,191,.14)}
.modal-overlay.modal-dark .summary-card{background:rgba(95,197,191,.06);border-color:rgba(95,197,191,.20)}
.modal-overlay.modal-dark .sum-row{border-bottom-color:rgba(255,255,255,.08)}
.modal-overlay.modal-dark .sum-key{color:var(--teal-bright)}
.modal-overlay.modal-dark .sum-val{color:#fff}
.modal-overlay.modal-dark .modal-actions{background:rgba(0,0,0,.25);border-top-color:rgba(255,255,255,.06)}
.modal-overlay.modal-dark .step-counter{color:rgba(255,255,255,.55)}
.modal-overlay.modal-dark .step-counter b{color:var(--teal-bright)}
.modal-overlay.modal-dark .btn-back-modal{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.10);color:#fff}
.modal-overlay.modal-dark .btn-back-modal:hover{background:rgba(255,255,255,.08)}
.modal-overlay.modal-dark .modal-success h3{color:#fff}
.modal-overlay.modal-dark .modal-success p{color:rgba(255,255,255,.7)}
.modal-overlay.modal-dark .modal-success p b{color:#fff}

/* mobile */
@media(max-width:640px){
  .modal-overlay{padding:0;align-items:flex-end}
  .modal-box{max-height:94vh;border-radius:24px 24px 0 0}
  .modal-progress{padding:24px 22px 0}
  .modal-content{padding:24px 22px}
  .step-fields{grid-template-columns:1fr;gap:14px}
  .modal-actions{padding:14px 22px 20px;gap:8px}
  .step-pill .lbl,.step-counter{display:none}
  .step-header h3{font-size:19px}
  .btn-back-modal{padding:0 14px;height:40px;font-size:12px}
  .btn-next-modal,.btn-submit-modal{padding:0 18px;height:44px;font-size:13px}
}

/* ════════════════════════════════════════════════════════════════════
   MOBILE TABBAR · barra de ações flutuante (Buscar perito · WhatsApp · Quero ser perito)
   Substitui o wa-float no mobile. Aparece apenas em telas ≤ 900px.
═══════════════════════════════════════════════════════════════════════ */
.mtab{
  position:fixed; left:14px; right:14px;
  bottom:calc(12px + env(safe-area-inset-bottom));
  z-index:120; display:none;
  grid-template-columns:1fr 92px 1fr; align-items:stretch;
  height:66px; padding:0 4px;
  background:
    radial-gradient(120% 160% at 50% -40%, rgba(58,157,152,.16), transparent 60%),
    linear-gradient(180deg, rgba(7,57,73,.94) 0%, rgba(2,24,32,.97) 100%);
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;
  box-shadow:
    0 22px 50px -10px rgba(0,0,0,.6),
    0 2px 0 0 rgba(255,255,255,.05) inset,
    0 0 0 1px rgba(58,157,152,.08);
  -webkit-backdrop-filter:blur(20px) saturate(1.25);
  backdrop-filter:blur(20px) saturate(1.25);
}
/* fio dourado no topo */
.mtab::before{
  content:''; position:absolute; left:26px; right:26px; top:0; height:1.5px; border-radius:2px;
  background:linear-gradient(90deg, transparent, var(--gold-20) 18%, var(--gold) 50%, var(--gold-20) 82%, transparent);
  opacity:.65;
}

.mtab-item{
  position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px;
  text-decoration:none; color:var(--w60); height:100%;
  font-size:11px; font-weight:700; letter-spacing:-.012em; text-align:center;
  -webkit-tap-highlight-color:transparent;
  transition:color .2s var(--ease), transform .12s var(--ease);
}
.mtab-item .mtab-ic{
  display:flex; align-items:center; justify-content:center;
  width:38px; height:30px; font-size:19px; color:var(--teal-soft);
  transition:transform .22s var(--ease), color .2s var(--ease);
}
.mtab-item .mtab-lb{ white-space:nowrap; line-height:1; padding:0 4px; }
.mtab-item:hover{ color:var(--w90); }
.mtab-item:hover .mtab-ic{ transform:translateY(-2px); }
.mtab-item:active{ transform:scale(.93); }
.mtab-item:active .mtab-ic{ color:var(--gold-bright); }

/* célula central — WhatsApp elevado */
.mtab-center{
  position:relative; display:flex; align-items:flex-end; justify-content:center;
  padding-bottom:10px; height:100%; text-decoration:none;
  -webkit-tap-highlight-color:transparent;
}
.mtab-center-lb{ font-size:11px; font-weight:800; color:#86e3cb; letter-spacing:.005em; line-height:1; }
.mtab-center-btn{
  position:absolute; top:-26px; left:50%; transform:translateX(-50%);
  width:64px; height:64px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-size:28px; color:#fff;
  background:linear-gradient(135deg,#2bea73 0%,#25D366 48%,#0e9f6e 100%);
  border:4px solid var(--ink);
  box-shadow:0 14px 30px rgba(37,211,102,.5), inset 0 1.5px 0 rgba(255,255,255,.45);
  transition:transform .2s var(--ease), box-shadow .2s var(--ease);
}
.mtab-center-btn::after{
  content:''; position:absolute; inset:-5px; border-radius:50%;
  border:1.5px solid rgba(37,211,102,.45); pointer-events:none;
  animation:mtabPulse 2.8s cubic-bezier(.4,0,.2,1) infinite;
}
.mtab-center:hover .mtab-center-btn{ box-shadow:0 18px 40px rgba(37,211,102,.62), inset 0 1.5px 0 rgba(255,255,255,.5); }
.mtab-center:active .mtab-center-btn{ transform:translateX(-50%) scale(.9); }
@keyframes mtabPulse{
  0%{transform:scale(.92);opacity:.75}
  70%{transform:scale(1.3);opacity:0}
  100%{transform:scale(1.3);opacity:0}
}

/* divisórias verticais sutis ao lado do centro */
.mtab-item::after{
  content:''; position:absolute; top:50%; height:30px; width:1px; transform:translateY(-50%);
  background:linear-gradient(180deg, transparent, var(--w10), transparent);
}
.mtab-item:first-child::after{ right:0; }
.mtab-item:last-child::after{ left:0; }

@media(max-width:900px){
  .mtab{ display:grid; transition:opacity .3s var(--ease), transform .3s var(--ease); }
  .wa-float{ display:none !important; }
  .activity-ticker{ display:none !important; }
  body{ padding-bottom:calc(96px + env(safe-area-inset-bottom)); transition:padding-bottom .3s var(--ease); }
  /* ao chegar no FINAL do footer: tabbar desliza pra fora e o respiro
     do rodapé é removido (elimina o espaço vazio sob o footer) */
  body.at-foot-end .mtab{ opacity:0; pointer-events:none; transform:translateY(120%); }
  body.at-foot-end{ padding-bottom:0; }
}
@media(max-width:380px){
  .mtab-item{ font-size:10px; }
  .mtab-item .mtab-ic{ font-size:18px; }
}

/* links legais no rodapé (Política de Privacidade · LGPD) */
.footer-legal-links{margin-top:8px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.footer-legal-links a{color:var(--w60);font-weight:600;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.18);padding-bottom:1px;transition:color .2s,border-color .2s}
.footer-legal-links a:hover{color:#fff;border-color:var(--teal,#3a9d98)}
.footer-legal-links span{color:var(--w40)}
