/* =========================================================================
   Suporte a Oficina — folha de estilo principal
   Tema escuro REFINADO "grafite + ciano elétrico".
   Mesma estrutura de classes do site antigo (todas as páginas herdam este
   visual), só que com uma identidade mais sóbria, high-tech e premium.
   ========================================================================= */

/* -------------------------------------------------------------------------
   TOKENS (as "variáveis" de cor, tamanho e raio usadas no site inteiro).
   Mudar uma cor aqui muda em todo o site de uma vez só.
   ------------------------------------------------------------------------- */
:root{
  --ink:#080B10;            /* fundo principal (grafite quase preto) */
  --ink-2:#0B0F15;          /* fundo de faixas (ticker, "como funciona") */
  --panel:#10151D;          /* superfície dos cards */
  --panel-2:#161D27;        /* superfície no hover */
  --line:rgba(125,185,215,0.10);   /* linhas finas (hairlines) */
  --line-2:rgba(125,185,215,0.20); /* linhas um pouco mais visíveis */

  --volt:#34D6EC;           /* acento CIANO — reservado p/ efeitos técnicos (scope, sinais) */
  --volt-bright:#67ECFF;    /* ciano mais brilhante */
  --blue:#3B82F6;           /* azul de apoio p/ gradientes técnicos */
  --accent-soft:rgba(52,214,236,0.12); /* fundo suave do ciano */

  /* COR DA MARCA (do cartão de visita): amarelo + check-engine. Usada na
     identidade — logo, botões principais e palavras de destaque. */
  --brand:#F7C32E;
  --brand-bright:#FFD64A;
  --grad-brand:linear-gradient(135deg,#FFD64A,#F2A900); /* gradiente amarelo da marca */

  --text-hi:#EBF1F7;        /* texto claro (principal) */
  --text-lo:#93A3B4;        /* texto suave (secundário) */
  --text-mut:#8593A2;       /* texto apagado — contraste >=4.5:1 (WCAG AA) */

  --r:16px;                 /* raio padrão de borda arredondada */
  --r-lg:22px;              /* raio maior (faixas, cta) */
  --maxw:1200px;            /* largura máxima do conteúdo */
  --grad:linear-gradient(135deg,var(--volt),var(--blue)); /* gradiente CIANO técnico (acentos/UI) */
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:64px} /* folga ao rolar p/ âncoras (o padding do hero completa o resto) */
@media(max-width:880px){html{scroll-padding-top:80px}} /* no celular a diagbar some */
body{
  background:var(--ink);
  color:var(--text-hi);
  font-family:"Inter",system-ui,sans-serif;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}
/* Luz ambiente do fundo num pseudo-elemento ABSOLUTO (não fixo).
   IMPORTANTE: nada de position:fixed nem background-attachment:fixed aqui —
   isso disparava um bug do Safari que fazia o conteúdo animado (ex.: o texto
   do "Quem somos") aparecer e sumir ao rolar. Absoluto cobre a página toda
   e mantém o mesmo visual, sem o bug. */
body::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1400px;z-index:-1;pointer-events:none;
  background:
    radial-gradient(900px 500px at 80% -8%,rgba(52,214,236,.08),transparent 60%),
    radial-gradient(700px 500px at -5% 5%,rgba(59,130,246,.06),transparent 55%);
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
a{color:inherit;text-decoration:none}
.mono{font-family:"JetBrains Mono",monospace}

/* Acessibilidade: contorno bem visível quando se navega pelo TECLADO (Tab). */
:focus-visible{outline:2px solid var(--volt);outline-offset:3px;border-radius:6px}

/* Pular para o conteúdo (aparece só ao focar via teclado) */
.skip{position:absolute;left:50%;transform:translateX(-50%) translateY(-150%);top:8px;z-index:100;
  background:var(--ink-2);color:var(--text-hi);border:1px solid var(--line-2);
  padding:10px 18px;border-radius:10px;font-size:14px;font-weight:600;transition:transform .2s}
.skip:focus{transform:translateX(-50%) translateY(0)}

.eyebrow{
  font-family:"JetBrains Mono",monospace;
  font-size:12px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--volt);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--grad);display:inline-block}
h1,h2,h3{font-family:"Sora",sans-serif;font-weight:700;line-height:1.06;letter-spacing:-.025em;color:var(--text-hi)}

/* ---- NAV (barra de navegação fixa no topo, com desfoque) ---- */
nav{
  position:sticky;top:0;z-index:50;
  background:rgba(8,11,16,.70);
  backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--line);
}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo{display:flex;align-items:center;gap:11px;font-family:"Sora";font-weight:700;font-size:17px;letter-spacing:-.02em}
.logo-full{height:40px;width:auto;display:block}
footer .logo-full{height:46px}
.logo b{font-weight:700}
.logo span{color:var(--text-hi)}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{font-size:14.5px;color:var(--text-lo);transition:color .2s;position:relative}
.nav-links a:hover{color:var(--text-hi)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--grad);border-radius:2px;transition:width .25s}
.nav-links a:hover::after{width:100%}

/* ---- Submenu "Ferramentas" (dropdown) ---- */
.dropdown{position:relative;display:flex;align-items:center}
.dropdown::after{content:"";position:absolute;top:100%;left:0;right:0;height:18px} /* ponte invisível p/ o hover não cair no vão */
.dd-toggle{display:inline-flex;align-items:center;gap:5px;font-family:inherit;font-size:14.5px;color:var(--text-lo);background:none;border:none;cursor:pointer;transition:color .2s}
.dropdown:hover .dd-toggle,.dropdown:focus-within .dd-toggle,.dropdown.open .dd-toggle{color:var(--text-hi)}
.dd-toggle .ti{font-size:16px;transition:transform .25s}
.dropdown:hover .dd-toggle .ti,.dropdown:focus-within .dd-toggle .ti,.dropdown.open .dd-toggle .ti{transform:rotate(180deg)}
.dd-menu{position:absolute;top:calc(100% + 16px);left:50%;transform:translateX(-50%) translateY(8px);min-width:212px;
  background:var(--ink-2);border:1px solid var(--line-2);border-radius:14px;padding:8px;
  display:flex;flex-direction:column;gap:2px;opacity:0;visibility:hidden;
  box-shadow:0 26px 54px -22px rgba(0,0,0,.75);transition:opacity .2s,transform .2s;z-index:60}
.dropdown:hover .dd-menu,.dropdown:focus-within .dd-menu,.dropdown.open .dd-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dd-menu a{padding:11px 14px;border-radius:9px;font-size:14px;color:var(--text-lo);white-space:nowrap;transition:background .15s,color .15s}
.dd-menu a::after{display:none}
.dd-menu a:hover{background:var(--accent-soft);color:var(--text-hi)}

.btn{
  font-family:"Sora";font-weight:600;font-size:14px;cursor:pointer;border:none;
  display:inline-flex;align-items:center;gap:8px;border-radius:12px;
  transition:transform .18s ease,box-shadow .25s,background .2s,border-color .2s,color .2s;
}
.btn-volt{background:var(--grad-brand);color:#1a1400;padding:12px 20px;box-shadow:0 8px 24px -10px rgba(247,195,46,.65)}
.btn-volt:hover{transform:translateY(-2px);box-shadow:0 14px 36px -10px rgba(247,195,46,.8)}
.btn-ghost{background:rgba(255,255,255,.02);color:var(--text-hi);border:1px solid var(--line-2);padding:12px 20px}
.btn-ghost:hover{border-color:var(--volt);color:var(--volt);background:var(--accent-soft)}
.nav-cta{display:flex;align-items:center;gap:14px}
.burger{display:none;background:none;border:none;color:var(--text-hi);font-size:26px;cursor:pointer}

/* Seletor de idioma (BR / EN / ES) — bandeira de fundo */
.lang-switch{display:flex;align-items:center;gap:4px;border:1px solid var(--line-2);border-radius:10px;padding:3px}
.lang-switch a{position:relative;display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:22px;
  font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:700;letter-spacing:.03em;color:#fff;
  border-radius:6px;background-size:cover;background-position:center;overflow:hidden;
  text-shadow:0 1px 3px rgba(0,0,0,1);filter:brightness(.86) saturate(.95);transition:filter .15s,box-shadow .15s}
.lang-switch a:hover{filter:brightness(1)}
.lang-switch a.active{filter:brightness(1.05);box-shadow:0 0 0 2px var(--volt),0 2px 8px -2px rgba(0,0,0,.5)}
.lang-switch a::after{display:none}
/* a cópia do seletor que fica DENTRO do menu só aparece no celular (ver @media) */
.nav-links .lang-switch{display:none}
.lang-switch a[hreflang="pt-BR"]{background-image:linear-gradient(rgba(0,0,0,.5),rgba(0,0,0,.5)),url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20viewBox%3D%270%200%2028%2020%27%3E%3Crect%20width%3D%2728%27%20height%3D%2720%27%20fill%3D%27%23009b3a%27%2F%3E%3Cpath%20d%3D%27M14%202%2026%2010%2014%2018%202%2010Z%27%20fill%3D%27%23ffdf00%27%2F%3E%3Ccircle%20cx%3D%2714%27%20cy%3D%2710%27%20r%3D%274%27%20fill%3D%27%23002776%27%2F%3E%3C%2Fsvg%3E")}
.lang-switch a[hreflang="en"]{background-image:linear-gradient(rgba(0,0,0,.5),rgba(0,0,0,.5)),url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20viewBox%3D%270%200%2028%2020%27%3E%3Crect%20width%3D%2728%27%20height%3D%2720%27%20fill%3D%27%23fff%27%2F%3E%3Cg%20fill%3D%27%23b22234%27%3E%3Crect%20width%3D%2728%27%20height%3D%272%27%2F%3E%3Crect%20y%3D%274%27%20width%3D%2728%27%20height%3D%272%27%2F%3E%3Crect%20y%3D%278%27%20width%3D%2728%27%20height%3D%272%27%2F%3E%3Crect%20y%3D%2712%27%20width%3D%2728%27%20height%3D%272%27%2F%3E%3Crect%20y%3D%2716%27%20width%3D%2728%27%20height%3D%272%27%2F%3E%3C%2Fg%3E%3Crect%20width%3D%2712%27%20height%3D%2711%27%20fill%3D%27%233c3b6e%27%2F%3E%3C%2Fsvg%3E")}
.lang-switch a[hreflang="es"]{background-image:linear-gradient(rgba(0,0,0,.5),rgba(0,0,0,.5)),url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20viewBox%3D%270%200%2028%2020%27%3E%3Crect%20width%3D%2728%27%20height%3D%2720%27%20fill%3D%27%23c60b1e%27%2F%3E%3Crect%20y%3D%275%27%20width%3D%2728%27%20height%3D%2710%27%20fill%3D%27%23ffc400%27%2F%3E%3C%2Fsvg%3E")}

/* ---- HERO (primeira tela, com a onda de sinal) ---- */
.hero{position:relative;padding:104px 0 76px;overflow:hidden}
.hero-grid{
  position:absolute;inset:0;z-index:0;opacity:.6;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:60px 60px;
  -webkit-mask-image:radial-gradient(ellipse 90% 70% at 72% 8%,#000 25%,transparent 75%);
          mask-image:radial-gradient(ellipse 90% 70% at 72% 8%,#000 25%,transparent 75%);
}
.glow{position:absolute;z-index:0;width:680px;height:680px;border-radius:50%;
  background:radial-gradient(circle,rgba(52,214,236,.18),rgba(59,130,246,.06) 45%,transparent 68%);
  top:-260px;right:-180px;filter:blur(10px);pointer-events:none}
.hero-in{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(40px,5.6vw,74px);margin:24px 0 22px;letter-spacing:-.035em}
.hero h1 em{font-style:normal;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;position:relative}
.hero p.lead{font-size:19px;color:var(--text-lo);max-width:480px;margin-bottom:36px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-meta{margin-top:38px;display:flex;gap:14px 30px;flex-wrap:wrap}
.hero-meta div{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--text-lo)}
.hero-meta i{color:var(--volt);font-size:18px}

/* Painel de mídia + a "assinatura": a onda de osciloscópio que se desenha */
.media{position:relative;aspect-ratio:4/5;border-radius:var(--r-lg);border:1px solid var(--line-2);
  background:linear-gradient(160deg,#141c26,#090d12);overflow:hidden;display:flex;align-items:flex-end;
  box-shadow:0 40px 80px -40px rgba(0,0,0,.8),0 0 0 1px rgba(52,214,236,.05)}
.media::before{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(180deg,transparent 55%,rgba(8,11,16,.55) 100%)}
.media .tag{position:absolute;top:18px;left:18px;z-index:4;font-size:11px;letter-spacing:.16em;
  background:rgba(8,11,16,.6);border:1px solid var(--line-2);padding:5px 11px;border-radius:999px;backdrop-filter:blur(6px)}
.media .ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--text-mut)}
.media .ph i{font-size:34px}
.media .ph span{font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.scan{position:relative;z-index:4;width:100%;height:120px}
.scan svg{width:100%;height:100%;display:block}
.wave-path{fill:none;stroke:var(--volt);stroke-width:2.5;filter:drop-shadow(0 0 7px rgba(52,214,236,.9));
  stroke-dasharray:1400;stroke-dashoffset:1400;animation:draw 3.2s ease forwards}
.dot{fill:var(--volt-bright);filter:drop-shadow(0 0 9px var(--volt))}
@keyframes draw{to{stroke-dashoffset:0}}

/* Quando há uma FOTO real no painel, esta classe a coloca cobrindo o fundo */
.media .photo,.about-media .photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}

/* ---- TICKER (faixa de termos técnicos que desliza) ---- */
.ticker{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--ink-2);overflow:hidden;padding:15px 0;position:relative}
.ticker::before,.ticker::after{content:"";position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.ticker::before{left:0;background:linear-gradient(90deg,var(--ink-2),transparent)}
.ticker::after{right:0;background:linear-gradient(270deg,var(--ink-2),transparent)}
.ticker-track{display:flex;gap:0;white-space:nowrap;animation:scroll 30s linear infinite;width:max-content}
.ticker-track span{font-family:"JetBrains Mono";font-size:13px;letter-spacing:.14em;color:var(--text-lo);padding:0 28px}
.ticker-track i{color:var(--volt)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---- SEÇÕES ---- */
section.block{padding:108px 0}
.sec-head{max-width:640px;margin-bottom:56px}
.sec-head h2{font-size:clamp(30px,3.8vw,46px);margin:18px 0 16px}
.sec-head p{color:var(--text-lo);font-size:17.5px}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:34px 30px;position:relative;overflow:hidden;
  transition:transform .25s ease,border-color .25s,background .25s,box-shadow .25s}
.card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;opacity:0;transition:opacity .25s;
  background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude}
.card:hover{transform:translateY(-6px);background:var(--panel-2);box-shadow:0 28px 60px -34px rgba(0,0,0,.9)}
.card:hover::before{opacity:.55}
.card .ci{width:52px;height:52px;border-radius:14px;background:var(--accent-soft);color:var(--volt);display:flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:22px;border:1px solid var(--line-2)}
.card h3{font-size:21px;font-weight:600;margin-bottom:11px}
.card p{color:var(--text-lo);font-size:15px}
.card .arrow{margin-top:20px;color:var(--volt);font-size:14px;display:inline-flex;align-items:center;gap:7px;font-family:"Sora";font-weight:500}
.card .arrow i{transition:transform .2s}
.card:hover .arrow i{transform:translateX(4px)}

/* Faixa de números / prova de credibilidade (opcional, usada na home) */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:8px}
.stat{text-align:center;padding:30px 18px;border:1px solid var(--line);border-radius:var(--r);background:var(--panel)}
.stat b{display:block;font-family:"Sora";font-weight:700;font-size:clamp(28px,4vw,40px);
  background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.03em}
.stat span{display:block;margin-top:8px;font-size:13.5px;color:var(--text-lo)}

/* "Como funciona" (passos numerados) */
.process{background:var(--ink-2)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--panel)}
.step{padding:38px 32px;border-right:1px solid var(--line);position:relative;transition:background .25s}
.step:last-child{border-right:none}
.step:hover{background:var(--panel-2)}
.step .num{font-family:"JetBrains Mono";font-size:13px;color:var(--volt);letter-spacing:.12em}
.step h3{font-size:19px;font-weight:600;margin:22px 0 11px}
.step p{color:var(--text-lo);font-size:14.5px}
.step .bar{position:absolute;top:0;left:0;height:3px;width:48px;background:var(--grad)}

/* "Quem somos" */
.about-in{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.about-media{display:block;width:100%;height:100%;max-width:100%;aspect-ratio:5/4;object-fit:cover;border-radius:var(--r-lg);border:1px solid var(--line-2);background:linear-gradient(150deg,#141c26,#090d12);overflow:hidden;box-shadow:0 40px 80px -44px rgba(0,0,0,.85)}
.about-media i{font-size:34px}
.about-media span{font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.about h2{font-size:clamp(30px,3.8vw,44px);margin:18px 0 20px}
.about p{color:var(--text-lo);font-size:16.5px;margin-bottom:15px;max-width:480px}
.about strong{color:var(--text-hi)}
.vmv{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}
.vmv span{font-family:"JetBrains Mono";font-size:12px;letter-spacing:.08em;color:var(--text-hi);border:1px solid var(--line-2);border-radius:999px;padding:8px 16px;background:rgba(255,255,255,.015)}

/* CTA final (faixa de chamada para ação) */
.cta-band{position:relative;overflow:hidden;border-radius:var(--r-lg);background:linear-gradient(135deg,#0f1a24,#0a0e13);border:1px solid var(--line-2);padding:76px 44px;text-align:center;
  box-shadow:0 40px 100px -50px rgba(52,214,236,.25)}
.cta-band::after{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:54px 54px;
  -webkit-mask-image:radial-gradient(ellipse 70% 90% at 50% 120%,#000,transparent 70%);mask-image:radial-gradient(ellipse 70% 90% at 50% 120%,#000,transparent 70%)}
.cta-band .glow{top:auto;bottom:-340px;left:50%;transform:translateX(-50%);right:auto;opacity:.95}
.cta-band h2{position:relative;z-index:2;font-size:clamp(30px,4.2vw,50px);margin-bottom:18px}
.cta-band p{position:relative;z-index:2;color:var(--text-lo);font-size:18.5px;margin-bottom:34px}
.cta-band .hero-cta{position:relative;z-index:2;justify-content:center}

/* RODAPÉ */
footer{border-top:1px solid var(--line);padding:64px 0 40px;margin-top:108px;background:var(--ink-2)}
.foot-in{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:44px}
.foot-in h4{font-family:"JetBrains Mono";font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-mut);margin-bottom:20px;font-weight:400}
.foot-in a,.foot-in p{display:block;color:var(--text-lo);font-size:14px;margin-bottom:12px;transition:color .2s}
.foot-in a:hover{color:var(--volt)}
.foot-bottom{margin-top:48px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;color:var(--text-mut);font-size:12px}
.foot-bottom a{color:var(--text-lo);transition:color .2s}
.foot-bottom a:hover{color:var(--volt)}
.socials{display:flex;gap:12px}
.socials a{width:40px;height:40px;border:1px solid var(--line-2);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--text-lo);font-size:18px;transition:all .2s}
.socials a:hover{color:var(--volt);border-color:var(--volt);background:var(--accent-soft);transform:translateY(-2px)}

/* "reveal" = elementos que aparecem suavemente conforme você rola a página */
/* O conteúdo só é escondido para animar QUANDO o JS confirma que vai revelar
   (html.reveal-on, adicionado por js/main.js). Sem JS, ou se o script falhar,
   o conteúdo permanece visível — nunca fica uma página em branco. */
.reveal{transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
html.reveal-on .reveal{opacity:0;transform:translateY(24px)}
html.reveal-on .reveal.in{opacity:1;transform:none}

/* ---- RESPONSIVO (celular / telas pequenas) ---- */
@media(max-width:880px){
  .hero-in,.about-in{grid-template-columns:1fr;gap:40px}
  .media{aspect-ratio:16/12;order:-1}
  .cards,.steps{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr;gap:14px}
  .step{border-right:none;border-bottom:1px solid var(--line)}
  .step:last-child{border-bottom:none}
  .foot-in{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .burger{display:block}
  section.block{padding:72px 0}
  .hero{padding:64px 0 48px}
  .cta-band{padding:56px 26px}
}

/* Menu aberto no celular (controlado pelo botão hambúrguer) */
@media(max-width:880px){
  .nav-links.open{
    display:flex;flex-direction:column;align-items:flex-start;
    position:absolute;top:74px;left:0;right:0;
    background:var(--ink-2);padding:20px 28px;gap:18px;
    border-bottom:1px solid var(--line);
  }
  .nav-links.open a::after{display:none}
  /* no celular o submenu aparece aberto (indentado), sem depender de hover */
  .nav-links.open .dropdown{flex-direction:column;align-items:flex-start;gap:14px;width:100%}
  .nav-links.open .dd-toggle{padding:0;cursor:default}
  .nav-links.open .dd-toggle .ti{display:none}
  .nav-links.open .dd-menu{position:static;transform:none;opacity:1;visibility:visible;
    box-shadow:none;border:none;background:none;padding:0 0 0 14px;min-width:0;gap:12px}
  .nav-links.open .dropdown::after{display:none}
  /* no celular: tira o seletor de idioma da barra e mostra no topo do menu aberto */
  .nav-cta .lang-switch{display:none}
  .nav-links .lang-switch{display:flex;order:-1;margin-bottom:4px}
}

/* =========================================================================
   PÁGINAS INTERNAS (Serviços, Facilitador SPS, Contato)
   Componentes extras reaproveitando os mesmos tokens/cores do site.
   ========================================================================= */

/* Cabeçalho das páginas internas: um "mini-hero" com título */
.page-hero{position:relative;padding:96px 0 64px;overflow:hidden;border-bottom:1px solid var(--line)}
.page-hero .hero-grid{opacity:.45}
.page-hero .wrap{position:relative;z-index:2;max-width:800px}
.page-hero h1{font-size:clamp(34px,5vw,60px);margin:20px 0 20px;letter-spacing:-.03em}
.page-hero p.lead{font-size:18.5px;color:var(--text-lo);max-width:640px;margin-bottom:30px}
.crumbs{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--text-mut);letter-spacing:.04em;margin-bottom:6px}
.crumbs a:hover{color:var(--volt)}

/* Texto corrido das páginas */
.prose{max-width:780px}
.prose h2{font-size:clamp(25px,3vw,36px);margin:0 0 18px}
.prose h3{font-size:21px;margin:36px 0 13px}
.prose p{color:var(--text-lo);font-size:16.5px;margin-bottom:17px}
.prose strong{color:var(--text-hi)}

/* Lista de benefícios / "o que oferecemos" com marcador */
.flist{list-style:none;display:grid;gap:14px;margin:6px 0}
.flist li{display:flex;gap:16px;align-items:flex-start;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:20px 22px;transition:border-color .2s,background .2s,transform .2s}
.flist li:hover{border-color:var(--line-2);background:var(--panel-2);transform:translateX(4px)}
.flist .fi{flex:0 0 auto;width:42px;height:42px;border-radius:12px;background:var(--accent-soft);color:var(--volt);display:flex;align-items:center;justify-content:center;font-size:21px;border:1px solid var(--line-2)}
.flist b{display:block;font-family:"Sora";font-size:16px;font-weight:600;margin-bottom:4px;color:var(--text-hi)}
.flist span{color:var(--text-lo);font-size:14.5px}

/* Numbered steps em coluna (variação dos passos para páginas internas) */
.steps-col{display:grid;gap:14px;max-width:780px}
.steps-col .step{border:1px solid var(--line);border-radius:var(--r);background:var(--panel);display:flex;gap:20px;align-items:flex-start;padding:24px 26px}
.steps-col .step .n{flex:0 0 auto;font-family:"JetBrains Mono";font-size:13px;color:#06121a;background:var(--grad);border-radius:11px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-weight:500}
.steps-col .step h3{font-size:18px;margin:0 0 7px}
.steps-col .step p{color:var(--text-lo);font-size:14.5px;margin:0}

/* Faixa de marcas atendidas (logos das montadoras) */
.brands{padding:52px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--ink-2)}
.brands p{text-align:center;font-family:"JetBrains Mono";font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-mut);margin-bottom:28px}
.brand-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px}
.brand-row span{font-family:"Sora",sans-serif;font-weight:600;font-size:16px;color:var(--text-hi);border:1px solid var(--line-2);border-radius:999px;padding:10px 22px;transition:border-color .2s,color .2s,background .2s}
.brand-row span:hover{border-color:var(--volt);color:var(--volt);background:var(--accent-soft)}
.brand-row span.more{font-family:"JetBrains Mono";font-weight:400;font-size:13px;color:var(--text-lo);background:transparent;text-transform:none}

/* Página de contato */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start}
.contact-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:28px 26px;margin-bottom:16px;transition:border-color .2s}
.contact-card:hover{border-color:var(--line-2)}
.contact-card h3{font-size:16px;margin-bottom:16px;display:flex;align-items:center;gap:11px}
.contact-card h3 i{color:var(--volt)}
.contact-card a,.contact-card p{display:block;color:var(--text-lo);font-size:15px;margin-bottom:9px}
.contact-card a:hover{color:var(--volt)}
.map-ph{aspect-ratio:4/3;border-radius:var(--r);border:1px solid var(--line-2);background:linear-gradient(150deg,#141c26,#090d12);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--text-mut)}
.map-ph i{font-size:34px}
.map-ph span{font-size:11px;letter-spacing:.18em;text-transform:uppercase}

@media(max-width:880px){
  .contact-grid{grid-template-columns:1fr;gap:28px}
  .brand-row{gap:18px}
  .brand-row img{height:38px}
}

/* Acessibilidade: respeita quem pediu "menos animação" no sistema */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .wave-path{stroke-dashoffset:0}
  .reveal,html.reveal-on .reveal{opacity:1!important;transform:none!important}
}

/* =========================================================================
   MODO HUD — "Scanner vivo / Diagnóstico em tempo real" (HOME)
   Faz a home parecer a interface de uma ferramenta de scan ligada no carro.
   Tudo aqui é tema-consistente com os tokens lá de cima.
   ========================================================================= */

/* Barra de telemetria viva, logo abaixo do menu */
.diagbar{position:sticky;top:74px;z-index:40;background:rgba(8,11,16,.82);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);font-family:"JetBrains Mono",monospace}
.diag-in{display:flex;align-items:center;gap:26px;height:46px;overflow:hidden;white-space:nowrap}
.diag-item{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--text-lo);letter-spacing:.04em}
.diag-item .k{color:var(--text-mut);text-transform:uppercase;letter-spacing:.14em;font-size:10.5px}
.diag-item .v{color:var(--text-hi);font-variant-numeric:tabular-nums}
.diag-item.ok .v{color:var(--volt)}
.diag-led{width:8px;height:8px;border-radius:50%;background:var(--volt);box-shadow:0 0 10px var(--volt);animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 10px var(--volt)}50%{opacity:.35;box-shadow:0 0 3px var(--volt)}}
.diag-bar-mini{width:80px;height:7px;border-radius:4px;background:rgba(125,185,215,.12);overflow:hidden;border:1px solid var(--line-2)}
.diag-bar-mini i{display:block;height:100%;background:var(--grad);width:30%;transition:width .25s linear}
@media(max-width:880px){.diagbar{display:none}}

/* HERO em modo HUD */
.hud{position:relative;padding:88px 0 80px;overflow:hidden}
.hud-in{position:relative;z-index:2;display:grid;grid-template-columns:1.02fr .98fr;gap:54px;align-items:center}
.hud h1{font-size:clamp(40px,5.4vw,72px);margin:22px 0 22px;letter-spacing:-.035em}
.hud h1 em{font-style:normal;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hud p.lead{font-size:19px;color:var(--text-lo);max-width:480px;margin-bottom:30px}

/* Painel do osciloscópio (canvas) com molduras de canto e overlay de grade */
.scope{position:relative;aspect-ratio:1/1;border-radius:var(--r-lg);overflow:hidden;
  background:radial-gradient(120% 120% at 50% 0%,#12202b,#070b10 70%);
  border:1px solid var(--line-2);box-shadow:0 50px 110px -50px rgba(0,0,0,.9),inset 0 0 0 1px rgba(52,214,236,.06)}
.scope canvas{position:absolute;inset:0;width:100%;height:100%;display:block}
.scope .corner{position:absolute;width:22px;height:22px;border:2px solid var(--volt);opacity:.55;z-index:3}
.scope .corner.tl{top:14px;left:14px;border-right:none;border-bottom:none}
.scope .corner.tr{top:14px;right:14px;border-left:none;border-bottom:none}
.scope .corner.bl{bottom:14px;left:14px;border-right:none;border-top:none}
.scope .corner.br{bottom:14px;right:14px;border-left:none;border-top:none}
.scope .s-tag{position:absolute;top:18px;left:46px;z-index:3;font-family:"JetBrains Mono";font-size:11px;
  letter-spacing:.16em;color:var(--volt);display:flex;align-items:center;gap:8px}
.scope .s-tag .diag-led{width:7px;height:7px}
.scope .readout{position:absolute;right:18px;top:44px;z-index:3;text-align:right;font-family:"JetBrains Mono"}
.scope .readout .big{font-size:34px;font-weight:500;color:var(--text-hi);line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.scope .readout .sub{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-mut);margin-top:4px}
.scope .strip{position:absolute;left:0;right:0;bottom:0;z-index:3;display:flex;justify-content:space-between;
  gap:0;padding:13px 18px;background:linear-gradient(0deg,rgba(7,11,16,.92),transparent);
  font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.08em}
.scope .strip div{color:var(--text-mut);text-align:center;flex:1}
.scope .strip div b{display:block;color:var(--volt);font-weight:500;font-size:13px;margin-top:3px}

/* "Chips" de módulos que acendem em sequência */
.modchips{display:flex;flex-wrap:wrap;gap:9px;margin-top:6px}
.modchips span{font-family:"JetBrains Mono";font-size:11.5px;letter-spacing:.1em;color:var(--text-lo);
  border:1px solid var(--line-2);border-radius:8px;padding:7px 13px;transition:all .3s;position:relative}
.modchips span::before{content:"●";color:var(--text-mut);margin-right:7px;font-size:9px;transition:color .3s}
.modchips span.live{color:var(--text-hi);border-color:var(--volt);background:var(--accent-soft)}
.modchips span.live::before{color:var(--volt);text-shadow:0 0 8px var(--volt)}

@media(max-width:880px){
  .hud-in{grid-template-columns:1fr;gap:40px}
  .scope{order:-1;max-width:440px;margin:0 auto}
  .hud{padding:48px 0}
}

/* =========================================================================
   MODO HUD v2 — painéis realistas de diagnóstico e programação
   ========================================================================= */

/* Osciloscópio: barra de medições estilo bancada (V/div, T/div, Vpp, Freq) */
.scope .meas{position:absolute;top:14px;right:14px;z-index:3;display:flex;flex-direction:column;gap:5px;align-items:flex-end;
  font-family:"JetBrains Mono";font-size:10px;letter-spacing:.06em;text-align:right}
.scope .meas .row{color:var(--text-mut);background:rgba(7,11,16,.55);border:1px solid var(--line);
  padding:2px 7px;border-radius:6px;backdrop-filter:blur(4px)}
.scope .meas .row b{color:var(--volt);font-weight:500}
.scope .meas .row.ch2 b{color:#febc2e}
.scope .chtag{position:absolute;left:14px;bottom:54px;z-index:3;font-family:"JetBrains Mono";font-size:10px;display:flex;gap:12px}
.scope .chtag i{font-style:normal}
.scope .chtag .c1{color:var(--volt)}.scope .chtag .c2{color:#febc2e}

/* Faixa "diagnóstico + programação ao vivo": dois painéis lado a lado */
.live-section{background:var(--ink-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.live-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:stretch}
.lpanel{background:linear-gradient(180deg,rgba(16,21,29,.92),rgba(9,13,18,.92));
  border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;
  box-shadow:0 30px 70px -44px rgba(0,0,0,.9)}
.lpanel .lp-head{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line);
  font-family:"JetBrains Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-lo)}
.lpanel .lp-head .diag-led{margin-left:auto}
.lpanel .lp-head i.ti{color:var(--volt);font-size:16px}
.lpanel .lp-body{padding:18px;flex:1}

/* Console de GRAVAÇÃO (flash) — grade de memória + progresso + log */
.flashwrap{display:flex;flex-direction:column;gap:14px}
#flash{width:100%;display:block;border-radius:8px;background:#070b10;border:1px solid var(--line)}
.flash-prog{font-family:"JetBrains Mono";font-size:12px;color:var(--text-lo)}
.flash-prog .bar{height:8px;border-radius:5px;background:rgba(125,185,215,.12);overflow:hidden;border:1px solid var(--line-2);margin-top:8px}
.flash-prog .bar i{display:block;height:100%;width:0;background:var(--grad);box-shadow:0 0 12px var(--volt)}
.flash-prog .nums{display:flex;justify-content:space-between;margin-bottom:0}
.flash-prog .nums b{color:var(--volt);font-weight:500}
.flash-log{font-family:"JetBrains Mono";font-size:11.5px;line-height:1.85;color:var(--text-lo);min-height:88px}
.flash-log .ok{color:var(--volt)}.flash-log .ad{color:var(--text-hi)}

/* Tráfego CAN ao vivo — linhas em hex que sobem */
.canbus{font-family:"JetBrains Mono";font-size:12px;line-height:1.95;height:230px;overflow:hidden;position:relative}
.canbus::after{content:"";position:absolute;left:0;right:0;top:0;height:46px;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(13,18,21,.96),transparent)}
.canbus .cols{display:grid;grid-template-columns:64px 42px 1fr;gap:10px;color:var(--text-mut);
  border-bottom:1px solid var(--line);padding-bottom:6px;margin-bottom:6px;letter-spacing:.1em;font-size:10px;text-transform:uppercase}
.can-row{display:grid;grid-template-columns:64px 42px 1fr;gap:10px;color:var(--text-lo);white-space:nowrap;
  animation:canin .35s ease}
.can-row .id{color:var(--volt)}.can-row.req .id{color:#febc2e}
.can-row .data{color:var(--text-hi);letter-spacing:.06em}
@keyframes canin{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* Sparkline viva dentro de cada card de serviço */
.card .spark{width:100%;height:38px;display:block;margin-top:18px;opacity:.9}

/* Medidor com ponteiro (rótulo central) */
.readout .g-label{font-family:"JetBrains Mono";font-size:9.5px;letter-spacing:.16em;color:var(--text-mut);
  text-transform:uppercase;text-align:center;margin-top:2px}

@media(max-width:880px){
  .live-grid{grid-template-columns:1fr;gap:16px}
  .canbus{height:200px}
}

/* =========================================================================
   SESSÃO REMOTA — janela que cicla pelas plataformas de fábrica
   (FDRS, Techstream, Techline, ODIS, ISTA/E-Sys). Foco: programação remota.
   A cor da marca atual vem da variável --b setada pelo JS.
   ========================================================================= */
.rsession{position:relative;aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--line-2);background:linear-gradient(180deg,#0c131b,#070b10);
  display:flex;flex-direction:column;
  box-shadow:0 50px 110px -50px rgba(0,0,0,.9),inset 0 0 0 1px rgba(52,214,236,.05)}
.rs-bar{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:1px solid var(--line);
  font-family:"JetBrains Mono"}
.rs-bar .d{width:10px;height:10px;border-radius:50%}
.rs-bar .d:nth-child(1){background:#ff5f57}.rs-bar .d:nth-child(2){background:#febc2e}.rs-bar .d:nth-child(3){background:var(--volt)}
.rs-bar b{margin-left:9px;font-weight:400;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-lo)}
.rs-screen{position:relative;flex:1;padding:30px 28px;display:flex;flex-direction:column;justify-content:center;overflow:hidden;
  transition:opacity .35s,filter .35s;
  background:radial-gradient(130% 90% at 50% -10%,color-mix(in srgb,var(--b,#34D6EC) 16%,transparent),transparent 60%)}
.rsession.switching .rs-screen{opacity:.15;filter:blur(6px)}
/* "scanline" de feed remoto */
.rs-screen::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background:repeating-linear-gradient(0deg,rgba(255,255,255,.018) 0 1px,transparent 1px 3px)}
.rs-screen::after{content:"";position:absolute;left:0;right:0;height:90px;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent,color-mix(in srgb,var(--b,#34D6EC) 14%,transparent),transparent);
  animation:rsfeed 4.5s linear infinite}
@keyframes rsfeed{0%{top:-90px}100%{top:100%}}
.rs-screen>*{position:relative;z-index:2}
.rs-tool{font-family:"Sora";font-weight:700;font-size:clamp(40px,7.4vw,66px);letter-spacing:-.045em;line-height:.95;
  color:var(--b,#fff);text-shadow:0 0 34px color-mix(in srgb,var(--b,#34D6EC) 60%,transparent)}
.rs-brand{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-mut);margin-top:12px}
.rs-veh{margin-top:24px;font-size:14.5px;color:var(--text-hi);display:flex;align-items:center;gap:9px}
.rs-veh i{color:var(--b,var(--volt));font-size:18px}
.rs-op{font-family:"JetBrains Mono";font-size:12.5px;color:var(--text-lo);margin-top:20px;min-height:1.6em}
.rs-op .ok{color:var(--volt)}
.rs-bar2{height:9px;border-radius:6px;background:rgba(125,185,215,.12);overflow:hidden;border:1px solid var(--line-2);margin-top:12px}
.rs-bar2 i{display:block;height:100%;width:0;border-radius:6px;
  background:linear-gradient(90deg,var(--b,#34D6EC),var(--volt));
  box-shadow:0 0 14px var(--b,var(--volt));transition:width .8s cubic-bezier(.4,.6,.2,1)}
.rs-meta{display:flex;justify-content:space-between;font-family:"JetBrains Mono";font-size:11px;color:var(--text-mut);margin-top:10px}
.rs-meta b{color:var(--b,var(--volt));font-weight:500}
.rs-foot{display:flex;align-items:center;gap:8px;padding:13px 16px;border-top:1px solid var(--line);
  font-family:"JetBrains Mono";font-size:11px;letter-spacing:.04em;color:var(--text-mut)}
.rs-foot i{color:var(--volt);font-size:15px}

/* marquee de plataformas (chips) */
.platchips{display:flex;flex-wrap:wrap;gap:9px;margin-top:6px}
.platchips span{font-family:"JetBrains Mono";font-size:11.5px;letter-spacing:.08em;color:var(--text-lo);
  border:1px solid var(--line-2);border-radius:8px;padding:7px 13px;transition:all .3s}
.platchips span.live{color:var(--text-hi);border-color:var(--volt);background:var(--accent-soft);box-shadow:0 0 0 1px rgba(52,214,236,.15)}

@media(max-width:880px){
  .rsession{order:-1;max-width:440px;margin:0 auto;aspect-ratio:4/4.4}
}
