/* ============================================================
   FOX GRID — Design System 2026
   Estética editorial bege/preto (ref: briefing/gfteam)
   Fontes: Playfair Display (títulos) + DM Sans (corpo/UI)
   ============================================================ */

:root{
  /* trava o esquema de cores: impede o modo escuro do aparelho/navegador de alterar as cores */
  color-scheme: only light;
  /* Acento Fox Grid */
  --purple:#8B2FC9; --purple-dk:#6B1FA8; --magenta:#D4167A; --orange:#F7941D;
  --grad:linear-gradient(135deg,#F7941D 0%,#D4167A 50%,#8B2FC9 100%);
  --grad-h:linear-gradient(135deg,#FF9F2E 0%,#E0218A 50%,#9B3FD9 100%);

  /* Neutros */
  --ink:#0D0D0D; --charcoal:#141414; --dark2:#1C1C1C; --dark3:#222;
  --sand:#F7F4EF; --sand2:#EDE9E1; --sand3:#E0D8D0;
  --warm:#8A8178; --rule:#D4CEC5; --white:#FFFFFF;

  --font-head:'Playfair Display',Georgia,serif;
  --font-body:'DM Sans',system-ui,sans-serif;

  --maxw:1200px;
  --maxw-narrow:820px;
  --ease:cubic-bezier(.16,.84,.44,1);
}

/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
/* Lenis (scroll suave) — desliga o smooth nativo quando o Lenis está ativo p/ não conflitar */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto !important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}
.lenis.lenis-smooth iframe{pointer-events:none}
body{
  font-family:var(--font-body);
  background:var(--sand);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::selection{background:var(--magenta);color:#fff}

/* ===== HELPERS ===== */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.narrow{max-width:var(--maxw-narrow);margin:0 auto;padding:0 32px}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.kicker{
  font-size:10px;letter-spacing:3px;text-transform:uppercase;font-weight:600;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;display:inline-block;margin-bottom:16px;
}
.sec{padding:96px 0;position:relative}
/* honeypot anti-spam (campo invisível p/ robôs) */
.hp-field{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}
/* ===== reveals de scroll estilo Arolax (data-fx) ===== */
[data-fx="reveal"]{clip-path:inset(100% 0 0 0);opacity:0;transition:clip-path 1s var(--ease),opacity 1s var(--ease)}
[data-fx="reveal"].fx-in{clip-path:inset(0 0 0 0);opacity:1}
[data-fx="char"] .fx-w{display:inline-block}
[data-fx="char"] .fx-c{display:inline-block;opacity:0;transform:translateY(.5em) rotate(6deg);
  transition:transform .6s var(--ease),opacity .6s var(--ease);transition-delay:calc(var(--i) * .028s)}
[data-fx="char"].fx-in .fx-c{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){[data-fx]{clip-path:none!important;opacity:1!important}[data-fx="char"] .fx-c{opacity:1!important;transform:none!important}}
.sec-dark{background:var(--charcoal);color:var(--white)}
.gbar{width:5px;flex-shrink:0;background:var(--grad)}

/* títulos */
h1,h2,h3,.serif{font-family:var(--font-head)}
.sec-title{font-family:var(--font-head);font-size:clamp(30px,4vw,46px);line-height:1.12;font-weight:700;letter-spacing:-.5px}
.sec-lead{color:var(--warm);font-size:15px;font-weight:300;max-width:560px;margin-top:16px;line-height:1.75}
.sec-dark .sec-lead{color:#a8a29a}

/* botões */
@property --beam-angle{syntax:'<angle>';initial-value:0deg;inherits:false}
.btn{
  display:inline-flex;align-items:center;gap:9px;position:relative;overflow:hidden;
  font-size:12px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;
  padding:15px 30px;transition:all .25s var(--ease);border-radius:8px;
}
.btn svg{width:13px;height:13px;position:relative;z-index:2}
/* linha fina de luz correndo pela borda (apenas nos botões com a classe .btn-beam) */
.btn-beam::before{content:'';position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;z-index:3;
  background:conic-gradient(from var(--beam-angle), transparent 0 78%, #F7941D 84%, #fff 88%, #D4167A 93%, transparent 99%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  animation:btn-beam 3.5s linear infinite}
@keyframes btn-beam{to{--beam-angle:360deg}}
/* brilho deslizante sutil no hover */
.btn::after{content:'';position:absolute;top:0;left:-120%;width:55%;height:100%;pointer-events:none;z-index:1;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.38),transparent);transform:skewX(-20deg)}
.btn:hover::after{animation:btn-shine .7s var(--ease)}
@keyframes btn-shine{to{left:140%}}
@media(prefers-reduced-motion:reduce){.btn-beam::before{animation:none}.btn:hover::after{animation:none}}
.btn-grad{background:var(--grad);color:#fff}
.btn-grad:hover{background:var(--grad-h);transform:translateY(-2px);box-shadow:0 12px 30px rgba(212,22,122,.28)}
.btn-dark{background:var(--charcoal);color:#fff}
.btn-dark:hover{background:#000;transform:translateY(-2px)}
.btn-ghost{border:1.5px solid var(--rule);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:#fff}
/* ghost em fundos escuros (sec-dark, hero, contato): borda branca + texto branco, legível sem hover */
.sec-dark .btn-ghost,.hero .btn-ghost,.cta .btn-ghost{border-color:rgba(255,255,255,.5);color:#fff}
.sec-dark .btn-ghost:hover,.hero .btn-ghost:hover,.cta .btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
/* botão "preenche no hover" estilo Read More (Techwix): preto+texto branco em repouso → preenche BRANCO e texto PRETO, com a seta andando */
.btn-slide{background:var(--ink);color:#fff;border:1.5px solid rgba(255,255,255,.3)}
.btn-slide::before{content:'';position:absolute;inset:-2px;z-index:1;border-radius:inherit;background:#fff;
  transform:translateX(-101%);transition:transform .45s var(--ease)}
.btn-slide:hover::before{transform:translateX(0)}
.btn-slide:hover{border-color:#fff;color:var(--ink)}
.btn-slide>span{position:relative;z-index:2}
.btn-slide svg{transition:transform .35s var(--ease)}
.btn-slide:hover svg{transform:translateX(4px)}
@media(prefers-reduced-motion:reduce){.btn-slide::before{transition:none}.btn-slide:hover svg{transform:none}}

/* Botão com preenchimento por máscara animada (efeito "Start a Project" do arolax) */
.btn-mask{display:inline-flex;align-items:center;justify-content:center;position:relative;overflow:hidden;z-index:1;
  padding:9px 18px;border-radius:8px;font-family:var(--font-body);font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;
  color:#fff;border:1.5px solid rgba(255,255,255,.55);background:transparent;cursor:pointer;transition:border-color .4s ease}
.btn-mask > *{position:relative;z-index:2}
/* variante: preenchimento branco por padrão, gradiente no hover, sem borda (usa o beam) */
.btn-mask--solid{padding:15px 30px;font-size:12px;background:#fff;color:var(--ink);border:none}
/* variante invertida: gradiente por padrão, branco preenche no hover */
.btn-mask--invert{padding:15px 30px;font-size:12px;background:var(--grad);color:#fff;border:none}
.btn-mask.btn-mask--invert::after{background:#fff;color:var(--ink)}
/* o preenchimento por máscara (sprite de tinta) está em css/btn-mask.css (embutido em base64) */

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:stretch;background:var(--charcoal);transition:box-shadow .3s,background-color .3s}
.site-header.scrolled{box-shadow:0 8px 30px rgba(0,0,0,.25)}
/* barra de gradiente mantida no header ao rolar (some no topo, onde a .edge-bar já cobre) */
.site-header::before{content:'';position:absolute;top:0;left:0;width:5px;height:100%;z-index:250;pointer-events:none;
  background:linear-gradient(180deg,#F7941D,#D4167A,#8B2FC9,#D4167A,#F7941D);background-size:100% 200%;
  animation:edge-flow 7s linear infinite, line-neon 2.4s ease-in-out infinite;opacity:0;transition:opacity .3s}
.site-header.header-line::before{opacity:1}
@media(prefers-reduced-motion:reduce){.site-header::before{animation:none;background:var(--grad)}}
.header-in{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px 32px;flex:1}
.brand{display:flex;align-items:center;gap:11px}
.brand img{height:42px;width:auto}
.brand-name{font-family:var(--font-head);font-size:18px;font-weight:700;letter-spacing:3px;color:#fff;line-height:1;white-space:nowrap}
.brand-name .x{color:#fff;-webkit-text-fill-color:#fff;background:none}
.brand-tag{display:block;font-size:8px;letter-spacing:3px;text-transform:uppercase;color:var(--warm);margin-top:1px}

/* menu estilo Grupi: número no canto superior direito, link embaixo, sublinha da direita p/ esquerda */
.nav{display:flex;align-items:center;gap:36px;counter-reset:navnum}
.nav a{position:relative;display:inline-block;padding-top:11px;padding-bottom:7px;
  color:#cfcac4;font-size:13px;font-weight:500;letter-spacing:.3px;text-transform:uppercase;line-height:1.1;transition:color .25s}
.nav a::before{counter-increment:navnum;content:counter(navnum,decimal-leading-zero);
  position:absolute;top:0;right:0;font-size:9px;font-weight:600;letter-spacing:1px;color:var(--warm);transition:color .25s}
.nav a::after{content:'';position:absolute;left:0;bottom:0;width:100%;height:2px;background:var(--grad);
  transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.nav a:hover,.nav a.active{color:#fff}
.nav a:hover::before,.nav a.active::before{color:var(--magenta)}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1);transform-origin:right}

.header-right{display:flex;align-items:center;gap:16px}
.lang{position:relative}
.lang-btn{display:flex;align-items:center;gap:7px;padding:7px 11px;border:1px solid #2c2c2c;border-radius:4px;color:#fff;font-size:12px;font-weight:600}
.lang-btn img{width:20px;height:14px;object-fit:cover;border-radius:1px}
.lang-btn:hover{border-color:var(--magenta)}
.lang-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--dark2);border:1px solid #2c2c2c;border-radius:6px;min-width:160px;padding:6px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .22s var(--ease);box-shadow:0 14px 40px rgba(0,0,0,.4)}
.lang.open .lang-menu{opacity:1;visibility:visible;transform:translateY(0)}
.lang-menu a{display:flex;align-items:center;gap:10px;padding:9px 12px;font-size:13px;color:#cfcac4;border-radius:4px}
.lang-menu a img{width:20px;height:14px;object-fit:cover}
.lang-menu a:hover,.lang-menu a.active{background:rgba(212,22,122,.12);color:#fff}

.hamburger{display:none;flex-direction:column;gap:5px;padding:6px}
.hamburger span{width:24px;height:2px;background:#fff;transition:.3s}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* extras do menu mobile (idioma + CTA) — escondidos no desktop, exibidos só no menu aberto */
.nav-extra{display:none;flex-direction:column;gap:16px;margin-top:12px;padding-top:16px;border-top:1px solid #242424}
.nav-lang{display:flex;gap:10px}
.nav-lang a{display:inline-flex;align-items:center;gap:7px;padding:9px 13px;border:1px solid #2c2c2c;border-radius:8px;font-size:13px;font-weight:600;color:#cfcac4;letter-spacing:.5px}
.nav-lang a img{width:20px;height:14px;object-fit:cover;border-radius:2px}
.nav-lang a.active,.nav-lang a:hover{border-color:#8B2FC9;color:#fff}
.nav-cta{justify-content:center;width:100%}

/* ============================================================
   HERO
   ============================================================ */
/* Barra de gradiente única e contínua (topo → marquee) */
.topwrap{position:relative}
.edge-bar{position:absolute;top:0;left:0;width:5px;height:100%;z-index:250;pointer-events:none;
  background:linear-gradient(180deg,#F7941D,#D4167A,#8B2FC9,#D4167A,#F7941D);
  background-size:100% 200%;animation:edge-flow 7s linear infinite, line-neon 2.4s ease-in-out infinite}
@keyframes edge-flow{to{background-position:0 -200%}}
@media(prefers-reduced-motion:reduce){.edge-bar{animation:none;background:var(--grad);box-shadow:none}}

.hero{position:relative;overflow:hidden;color:#fff;padding:110px 0 0;min-height:84vh;display:flex;align-items:center;
  background:var(--charcoal) center/cover no-repeat;background-image:url('../images/hero-poster.jpg')}
/* vídeo de fundo em loop (tamanho/posição da raposa já embutidos no arquivo) */
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
/* overlay escura: mais densa à esquerda (texto) e funde para o preto embaixo (marquee) */
.hero-overlay{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(90deg,rgba(13,13,13,.94) 0%,rgba(13,13,13,.8) 40%,rgba(13,13,13,.5) 74%,rgba(13,13,13,.66) 100%),
             linear-gradient(0deg,#0D0D0D 0%,rgba(13,13,13,0) 24%)}
/* camada de partículas (brasas/estrelas nas cores da marca) — acima do vídeo, abaixo do texto */
.hero-particles{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero-inner{position:relative;z-index:2;width:100%}
.hero h1{font-family:var(--font-head);font-size:clamp(38px,5.2vw,68px);line-height:1.05;font-weight:700;letter-spacing:-1px;margin-bottom:22px;max-width:680px}
.hero p{color:#cfc9c2;font-size:16px;font-weight:300;line-height:1.8;max-width:480px;margin-bottom:34px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{display:flex;gap:44px;margin-top:54px;padding:26px 0 40px;border-top:1px solid rgba(255,255,255,.14);flex-wrap:wrap;position:relative;z-index:2}
/* acessibilidade: sem autoplay de vídeo para quem prefere menos movimento (mostra o poster) */
@media (prefers-reduced-motion: reduce){ .hero-video{display:none} }
.hero-meta .mi-l{font-size:9px;letter-spacing:2px;color:#555;text-transform:uppercase;display:block;margin-bottom:6px}
.hero-meta .mi-v{font-family:var(--font-head);font-size:30px;font-weight:700;line-height:1}
.hero-meta .mi-v span{font-size:16px;color:var(--warm)}

/* ============================================================
   CLIENTES (marquee)
   ============================================================ */
.clients{background:var(--ink);color:#fff;padding:34px 0;border-top:1px solid #1e1e1e}
.clients-row{display:flex;align-items:center;gap:32px}
.clients-label{flex-shrink:0;font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--warm);white-space:nowrap}
.marquee{overflow:hidden;flex:1;-webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;align-items:center;gap:48px;width:max-content;animation:scroll-x 42s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
/* logos padronizadas pela ALTURA, caixa abraça cada uma → espaços uniformes */
.marquee-track .cl{display:inline-flex;align-items:center;justify-content:center;height:60px;flex-shrink:0}
.marquee-track .cl img{max-height:42px;max-width:185px;width:auto;height:auto;object-fit:contain;
  opacity:.78;filter:grayscale(1) brightness(1.15);transition:opacity .3s var(--ease),filter .3s var(--ease)}
/* logos compactas: um pouco maiores */
.marquee-track .cl--lg img{max-height:56px;max-width:200px}
/* logos largas que precisam de mais espaço */
.marquee-track .cl--xl img{max-height:58px;max-width:290px}
/* logo colorida: escala de cinza no repouso (preserva o desenho) → cor no hover */
.marquee-track .cl:hover img{opacity:1;filter:none}
/* logo preta/escura: branca no repouso (sem cor pra mostrar) → acende com brilho no hover */
.marquee-track .cl--dark img{filter:brightness(0) invert(1)}
.marquee-track .cl--dark:hover img{opacity:1;filter:brightness(0) invert(1) drop-shadow(0 0 7px rgba(255,255,255,.5))}
@keyframes scroll-x{to{transform:translateX(-50%)}}

/* ============================================================
   SOLUÇÕES (grid de cards editoriais)
   ============================================================ */
/* fundo da seção: grade de pontos sutil + respingos de tinta */
#solucoes{position:relative;overflow:hidden}
#solucoes::before{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:radial-gradient(rgba(28,28,35,.06) 1px,transparent 1.6px);background-size:24px 24px;
  -webkit-mask:linear-gradient(180deg,transparent,#000 12%,#000 88%,transparent);
  mask:linear-gradient(180deg,transparent,#000 12%,#000 88%,transparent)}
#solucoes > .wrap{position:relative;z-index:1}

/* fundo blueprint da seção Soluções (grid técnico + esquemas de device) */
#solucoes{overflow:hidden}
#solucoes>.wrap{position:relative;z-index:1}
.sol-bp{position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(rgba(60,42,28,.055) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(60,42,28,.055) 1px,transparent 1px);
  background-size:26px 26px}
.sol-bp .bp-dev{position:absolute;top:20px;right:0;width:min(580px,52%);height:auto}
.sol-bp svg{position:absolute;height:auto}
.sol-bp svg *{vector-effect:non-scaling-stroke}
.sol-bp .bp-server{top:28%;left:-58px;width:min(200px,17%)}
.sol-bp .bp-shield{bottom:14%;left:5%;width:min(190px,15%)}
.sol-bp .bp-fox{top:14px;left:22px;width:min(150px,13%)}
/* rabo da logo (no lugar da sacola): linhas + base preenchida no gradiente Fox */
.sol-bp .bp-tail{position:absolute;bottom:11%;right:4%;width:min(210px,17%);aspect-ratio:1/1}
.sol-bp .bp-tail img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain}
.sol-bp .bp-tail-lines{opacity:.32}
.sol-bp .bp-tail-color{opacity:.7;
  -webkit-mask-image:linear-gradient(to top,#000 8%,rgba(0,0,0,.6) 32%,transparent 64%);
  mask-image:linear-gradient(to top,#000 8%,rgba(0,0,0,.6) 32%,transparent 64%)}
@media(max-width:980px){.sol-bp .bp-server{display:none}}
@media(max-width:760px){
  .sol-bp .bp-dev,.sol-bp .bp-shield{display:none}     /* esconde os detalhados/largos */
  .sol-bp .bp-fox{width:84px;top:10px;left:12px}        /* raposa geométrica visível */
  .sol-bp .bp-tail{width:104px;top:62px;right:6px;bottom:auto}  /* rabo colorido visível */
}

.sol-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:54px}
.sol-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.sol-card{background:var(--white);border:1px solid var(--rule);border-radius:14px;padding:36px 30px;
  position:relative;min-height:280px;display:flex;flex-direction:column;overflow:hidden;
  transition:box-shadow .65s var(--ease),border-color .65s var(--ease)}
.sol-card::after{content:'';position:absolute;inset:0 0 auto 0;height:3px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .7s var(--ease)}
.sol-card:hover{box-shadow:0 22px 48px rgba(28,28,35,.1);border-color:transparent}
.sol-card:hover::after{transform:scaleX(1)}
.sol-card .num{position:absolute;top:24px;right:28px;font-family:var(--font-head);font-size:42px;font-weight:700;line-height:1;color:var(--sand2);transition:color .65s var(--ease)}
.sol-card:hover .num{color:var(--sand3)}
.sol-card .ico{width:56px;height:56px;border-radius:15px;background:var(--sand2);display:flex;align-items:center;justify-content:center;margin-bottom:24px;transition:background .65s var(--ease)}
.sol-card .ico svg{width:28px;height:28px;stroke:var(--ink);fill:none;transition:stroke .65s var(--ease)}
/* preenchimento no gradiente Fox, só um pouco menos vibrante */
.sol-card:hover .ico{background:linear-gradient(135deg,#EE8C3C 0%,#CB3F7E 50%,#8A39BE 100%)}
.sol-card:hover .ico svg{stroke:#fff}
.sol-card h3{font-family:var(--font-head);font-size:22px;font-weight:700;margin-bottom:12px;line-height:1.25}
.sol-card p{font-size:13.5px;color:var(--warm);font-weight:300;line-height:1.7;flex:1}
.sol-card .bar{display:none}

/* ============================================================
   SOBRE / METODOLOGIA
   ============================================================ */
/* fundo de fitas fluidas (curvas da marca) na seção Metodologia */
#sobre{overflow:hidden}
#sobre>.wrap{position:relative;z-index:1}
.about-bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.about-bg svg{position:absolute;inset:-6%;width:112%;height:112%;
  transform-origin:55% 50%;will-change:transform;
  animation:about-sway 13s ease-in-out infinite}
@keyframes about-sway{0%,100%{transform:translate(0,0) rotate(0deg)}
  50%{transform:translate(-28px,16px) rotate(-2.6deg)}}
@media(prefers-reduced-motion:reduce){.about-bg svg{animation:none}}

.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-media{position:relative}
/* moldura da imagem: zoom + brilho passando no hover */
.about-img{position:relative;overflow:hidden;border-radius:4px}
.about-img img{display:block;width:100%;border-radius:4px;
  transition:transform .8s var(--ease),filter .8s var(--ease)}
.about-media:hover .about-img img{transform:scale(1.06);filter:saturate(1.1) contrast(1.03)}
.about-img::after{content:'';position:absolute;top:0;left:-65%;width:55%;height:100%;pointer-events:none;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.28),transparent);transform:skewX(-18deg);
  transition:left .85s var(--ease)}
.about-media:hover .about-img::after{left:125%}
/* barra de gradiente com glow neon no lado DIREITO (igual à do topo) */
.about-media::after{content:'';position:absolute;top:2%;bottom:2%;right:-3px;width:2.5px;border-radius:3px;z-index:3;
  background:linear-gradient(180deg,#F7941D,#D4167A,#8B2FC9,#D4167A,#F7941D);background-size:100% 200%;
  animation:line-flow-v 6s linear infinite, line-neon 2.4s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.about-media::after{animation:none;background:var(--grad)}
  .about-img img{transition:none}.about-img::after{display:none}}
.about-media img{border-radius:4px;width:100%}
.about-media .badge-float{position:absolute;left:-24px;bottom:28px;background:var(--charcoal);color:#fff;padding:22px 26px;border-left:4px solid;border-image:var(--grad) 1;max-width:230px}
.about-media .badge-float strong{font-family:var(--font-head);font-size:34px;display:block;line-height:1}
.about-media .badge-float span{font-size:11px;color:var(--warm);letter-spacing:1px;text-transform:uppercase}
/* painel branco com linhas; cada item acende em bege no hover; badges no gradiente Fox */
.feat-list{margin-top:36px;display:grid;background:var(--white);border:1px solid var(--rule);border-radius:16px;
  overflow:hidden;box-shadow:0 20px 50px rgba(28,28,35,.06)}
.feat{display:flex;gap:18px;align-items:flex-start;padding:24px 28px;border-bottom:1px solid var(--rule);transition:background .25s var(--ease)}
.feat:last-child{border-bottom:none}
.feat:hover{background:var(--sand)}
.feat .fi{flex-shrink:0;width:44px;height:44px;border-radius:12px;background:var(--sand2);border:1px solid var(--rule);display:flex;align-items:center;justify-content:center;color:var(--purple);font-size:19px}
.feat h4{font-size:16px;font-weight:600;margin-bottom:5px}
.feat p{font-size:13.5px;color:var(--warm);font-weight:300;line-height:1.65}

/* ============================================================
   TIME
   ============================================================ */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.member{background:var(--white);border:1px solid var(--rule);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s}
.member:hover{transform:translateY(-6px);box-shadow:0 20px 44px rgba(20,20,20,.1)}
.member-img{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--sand2)}
.member-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(1);transition:filter .4s}
.member:hover .member-img img{filter:grayscale(0)}
.member-img .soc{position:absolute;inset:auto 0 0 0;display:flex;gap:14px;justify-content:center;padding:14px;background:linear-gradient(transparent,rgba(13,13,13,.78));transform:translateY(100%);transition:transform .3s var(--ease)}
.member:hover .soc{transform:translateY(0)}
.member-img .soc a{color:#fff;font-size:16px;opacity:.85}
.member-img .soc a:hover{opacity:1}
.member-info{padding:20px 22px}
.member-info h4{font-family:var(--font-head);font-size:18px;font-weight:700}
.member-info span{font-size:11.5px;color:var(--magenta);letter-spacing:.6px;text-transform:uppercase;font-weight:500}

/* ============================================================
   PORTFÓLIO
   ============================================================ */
/* fundo animado da seção Portfólio: raios de luz + poeira de estrelas */
#projetos{overflow:hidden}
#projetos>.wrap{position:relative;z-index:2}
.port-bg{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.pbeam{position:absolute;top:-40%;height:180%;width:130px;transform:skewX(-18deg);filter:blur(20px);opacity:.13}
.pb1{left:-8%;background:linear-gradient(#F7941D,transparent);animation:port-sweep 16s linear infinite}
.pb2{left:38%;background:linear-gradient(#D4167A,transparent);animation:port-sweep 21s linear infinite;animation-delay:-7s}
.pb3{left:74%;background:linear-gradient(#8B2FC9,transparent);animation:port-sweep 18s linear infinite;animation-delay:-11s}
@keyframes port-sweep{from{transform:skewX(-18deg) translateX(-220px)}to{transform:skewX(-18deg) translateX(112vw)}}
.pstars{position:absolute;inset:-50%;background-repeat:repeat;
  background-image:radial-gradient(1.5px 1.5px at 20px 30px,rgba(255,255,255,.5),transparent),
                   radial-gradient(1px 1px at 200px 160px,rgba(255,255,255,.4),transparent),
                   radial-gradient(1.5px 1.5px at 300px 60px,rgba(224,33,138,.5),transparent),
                   radial-gradient(1px 1px at 120px 90px,rgba(255,210,170,.45),transparent);
  background-size:320px 260px;animation:port-starpan 90s linear infinite}
@keyframes port-starpan{to{transform:translate(150px,120px)}}
@media(prefers-reduced-motion:reduce){.pbeam,.pstars{animation:none}}
/* roadmap + detalhes em branco; a linha "se desenha" (revela L→R) ao entrar na seção */
.port-fx{position:absolute;top:0;left:0;width:100%;z-index:1;pointer-events:none;
  -webkit-clip-path:inset(0 100% 0 0);clip-path:inset(0 100% 0 0);
  transition:clip-path 1.7s ease,-webkit-clip-path 1.7s ease}
#projetos.fx-drawn .port-fx{-webkit-clip-path:inset(0 0 0 0);clip-path:inset(0 0 0 0)}
.port-fx svg{display:block;width:100%;height:auto}
.port-fx svg *{vector-effect:non-scaling-stroke}
@media(prefers-reduced-motion:reduce){.port-fx{-webkit-clip-path:none;clip-path:none;transition:none}}

.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.port-card{position:relative;overflow:hidden;border:1px solid var(--rule);background:var(--charcoal);aspect-ratio:4/3}
.port-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease),opacity .4s;opacity:.92}
.port-card:hover img{transform:scale(1.06);opacity:.5}
.port-over{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:26px;background:linear-gradient(transparent 40%,rgba(13,13,13,.85));opacity:0;transition:opacity .35s}
.port-card:hover .port-over{opacity:1}
.port-over .tag{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--orange);margin-bottom:8px;font-weight:600}
.port-over h3{font-family:var(--font-head);font-size:22px;color:#fff;display:flex;align-items:center;gap:10px}
.port-over h3 svg{width:14px;height:14px;stroke:#fff}

/* ============================================================
   CTA grande (marquee texto)
   ============================================================ */
.cta{color:#fff;text-align:center;padding:110px 0;position:relative;overflow:hidden;background-color:var(--charcoal)}
/* base: foto do time escura e P&B; colore e clareia (foto inteira) no hover, com fade lento */
.cta-photo{position:absolute;inset:0;z-index:0;pointer-events:none;
  background:url('../images/contact-bg.png') center 22%/cover no-repeat;
  filter:grayscale(1) brightness(.34);
  transition:filter 2.8s var(--ease)}
.cta:hover .cta-photo{filter:grayscale(0) brightness(.82)}
/* véu escuro p/ legibilidade — alivia um pouco no hover */
.cta::after{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(rgba(13,13,13,.55) 0%,rgba(13,13,13,.74) 52%,rgba(10,10,10,.92) 100%);
  transition:opacity 2.8s var(--ease)}
.cta:hover::after{opacity:.62}
/* linha separadora: desenha do centro ao entrar na tela, depois flui sutilmente */
.cta::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;z-index:3;border-radius:3px;
  background:linear-gradient(90deg,#F7941D,#D4167A,#8B2FC9,#D4167A,#F7941D);
  background-size:200% 100%;animation:line-flow 6s linear infinite, line-neon 2.4s ease-in-out infinite;
  transform:scaleX(0);transform-origin:center;transition:transform 1s var(--ease)}
.cta.line-drawn::before{transform:scaleX(1)}
@keyframes line-flow{to{background-position:-200% 0}}
@keyframes line-neon{0%,100%{box-shadow:0 0 4px rgba(212,22,122,.35)}50%{box-shadow:0 0 14px rgba(212,22,122,.9),0 0 30px rgba(139,47,201,.55)}}
@media(prefers-reduced-motion:reduce){.cta::before{animation:none;background:var(--grad);transform:none;transition:none;box-shadow:none}}
.cta .narrow{position:relative;z-index:2}
.cta h2{font-family:var(--font-head);font-size:clamp(30px,4.4vw,54px);font-weight:700;line-height:1.18;max-width:880px;margin:0 auto 38px;letter-spacing:-.5px;text-shadow:0 2px 26px rgba(0,0,0,.5)}
.cta h2 .grad-text{display:inline}
.cta h2 .cta-word{display:inline-block;white-space:nowrap;min-height:1em}
.cta h2 .cta-word.typing::after{content:'';display:inline-block;width:2px;height:.92em;margin-left:3px;
  background:#D4167A;vertical-align:-.1em;border-radius:1px;animation:cta-caret .8s steps(1) infinite}
@keyframes cta-caret{50%{opacity:0}}
@media(prefers-reduced-motion:reduce){.cta h2 .cta-word.typing::after{display:none}}

/* ---- CTA em 2 colunas: texto + formulário embutido ---- */
.cta-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;text-align:left}
.cta-info h2{font-size:clamp(28px,3.2vw,42px);line-height:1.16;max-width:none;margin:14px 0 30px}
/* inglês: frases mais longas ("makes the difference.") — dá mais espaço ao texto p/ a palavra
   ficar colada no "on what" sem quebrar; PT/ES ficam intactos */
html[lang="en"] .cta-grid{grid-template-columns:1.14fr .86fr}
html[lang="en"] .cta-info h2{font-size:clamp(26px,2.9vw,37px)}
.cta-info .kicker{justify-content:flex-start}
.cta-direct{display:flex;flex-direction:column;align-items:flex-start;gap:18px}
.cta-direct .btn-grad{align-self:flex-start}
.cta-phone{display:inline-flex;align-items:center;gap:9px;color:rgba(255,255,255,.82);font-size:15px;font-weight:500;letter-spacing:.2px;text-decoration:none;transition:color .25s}
.cta-phone i{font-size:15px;color:#F7941D}
.cta-phone:hover{color:#fff}

/* card branco do formulário */
.cta-form-card{position:relative;background:#fff;border-radius:14px;padding:38px 36px 34px;
  box-shadow:0 34px 80px rgba(0,0,0,.42);text-align:left}
.cta-form-card::before{content:'';position:absolute;left:0;top:26px;bottom:26px;width:3px;border-radius:3px;
  background:linear-gradient(180deg,#F7941D,#D4167A,#8B2FC9,#D4167A,#F7941D);
  background-size:100% 200%;
  animation:line-flow-v 6s linear infinite, line-neon 2.4s ease-in-out infinite}
@keyframes line-flow-v{to{background-position:0 -200%}}
@media(prefers-reduced-motion:reduce){.cta-form-card::before{animation:none;background:var(--grad)}}
.cta-form-title{font-family:var(--font-head);font-size:24px;font-weight:700;color:var(--ink);margin:0 0 6px;letter-spacing:-.3px}
.cta-form-desc{font-size:13.5px;color:var(--warm);line-height:1.55;margin:0 0 22px}
.cta-form{display:flex;flex-direction:column;gap:14px}
.cta-field{display:flex;flex-direction:column}
.cta-field--2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cta-form input,.cta-form textarea{width:100%;box-sizing:border-box;font-family:var(--font-body);font-size:14px;color:var(--ink);
  background:var(--sand);border:1.5px solid var(--rule);border-radius:9px;padding:13px 15px;outline:none;
  transition:border-color .22s,background .22s,box-shadow .22s}
.cta-form input::placeholder,.cta-form textarea::placeholder{color:#a9a298}
.cta-form input:focus,.cta-form textarea:focus{border-color:#8B2FC9;background:#fff;box-shadow:0 0 0 3px rgba(139,47,201,.12)}
.cta-form input:not(:placeholder-shown):invalid{border-color:#d9536b}
.cta-form textarea{resize:vertical;min-height:104px;line-height:1.5}
.cta-form-btn{justify-content:center;width:100%;margin-top:4px}
.cta-form-feedback{margin:4px 0 0;font-size:13.5px;font-weight:500;color:#1f8a4c}
.cta-form-feedback.is-error{color:#d9536b}

@media(max-width:860px){
  .cta-grid{grid-template-columns:1fr;gap:38px}
  .cta-form-card{padding:30px 24px 26px}
  .cta-field--2{grid-template-columns:1fr}
}
@media(max-width:720px){
  .cta-info h2{font-size:24px;line-height:1.22}
  /* a palavra animada flui junto com o texto (sem reserva de largura que isola a palavra) */
  .cta h2 .cta-word{min-width:0!important;white-space:normal}
}

/* ============================================================
   FOOTER
   ============================================================ */
footer{background:var(--ink);color:#cfcac4;padding:74px 0 0;position:relative}
/* separador em gradiente marcando o fim da seção anterior */
footer::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:min(1180px,88%);height:2px;border-radius:2px;
  background:linear-gradient(90deg,transparent,rgba(247,148,29,.45),rgba(212,22,122,.7),rgba(139,47,201,.45),transparent)}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:54px;border-bottom:1px solid #1e1e1e}
.foot-brand img{height:38px;filter:brightness(0) invert(1);margin-bottom:18px}
.foot-brand .bn{font-family:var(--font-head);font-size:22px;letter-spacing:4px;color:#fff;font-weight:700}
.foot-brand p{font-size:13px;color:var(--warm);font-weight:300;line-height:1.75;margin:16px 0 22px;max-width:260px}
.foot-locs{display:grid;gap:7px;font-size:12.5px;color:var(--warm)}
.foot-locs span{color:#fff}
.foot-col h5{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:#fff;margin-bottom:20px;font-weight:600}
.foot-col ul{display:grid;gap:11px}
.foot-col a{font-size:13.5px;color:var(--warm);font-weight:300;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-contact{display:grid;gap:14px;margin-top:4px}
.foot-contact a{display:flex;align-items:center;gap:11px;font-size:13.5px;color:#cfcac4}
.foot-contact a i{color:var(--magenta);font-size:16px}
.foot-contact a:hover{color:#fff}
.foot-btm{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;padding:26px 0}
.foot-btm p{font-size:12.5px;color:var(--warm)}
.foot-social{display:flex;gap:16px}
.foot-social a{color:var(--warm);font-size:17px;transition:color .2s}
.foot-social a:hover{color:#fff}

/* ============================================================
   BOTÃO FLUTUANTE WHATSAPP
   ============================================================ */
.wa-float{position:fixed;right:24px;bottom:24px;z-index:300;width:58px;height:58px;border-radius:50%;
  background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;font-size:30px;
  box-shadow:0 8px 26px rgba(37,211,102,.45);transition:transform .25s var(--ease),box-shadow .25s}
.wa-float::before{content:'';position:absolute;inset:0;border-radius:50%;background:#25D366;z-index:-1;
  animation:wa-pulse 2.6s ease-out infinite}
.wa-float:hover{transform:scale(1.08);color:#fff;box-shadow:0 12px 32px rgba(37,211,102,.62)}
.wa-tip{position:absolute;right:calc(100% + 12px);top:50%;transform:translateY(-50%);
  background:var(--ink);color:#fff;font-size:12px;font-weight:600;white-space:nowrap;font-family:var(--font-body);
  padding:8px 13px;border-radius:7px;opacity:0;pointer-events:none;transition:opacity .25s;box-shadow:0 6px 18px rgba(0,0,0,.25)}
.wa-tip::after{content:'';position:absolute;left:100%;top:50%;transform:translateY(-50%);
  border:6px solid transparent;border-left-color:var(--ink)}
.wa-float:hover .wa-tip{opacity:1}
@keyframes wa-pulse{0%{transform:scale(1);opacity:.55}70%{transform:scale(1.7);opacity:0}100%{opacity:0}}
@media(prefers-reduced-motion:reduce){.wa-float::before{animation:none}}
@media(max-width:720px){.wa-float{right:16px;bottom:16px;width:52px;height:52px;font-size:27px}.wa-tip{display:none}}

/* ===== Máquina de escrever (kicker) + troca de headline (h1) ===== */
.kicker-type.typing::after{content:'';display:inline-block;width:2px;height:1.05em;background:var(--magenta);
  margin-left:4px;vertical-align:-1px;animation:caret-blink .7s steps(1) infinite}
@keyframes caret-blink{50%{opacity:0}}
/* palavra colorida do hero que troca (rolagem vertical) — fica sozinha na linha, não empurra nada */
.hero-word{display:inline-block;white-space:nowrap;will-change:transform,opacity}

/* ============================================================
   ANIMAÇÃO REVEAL
   ============================================================ */
/* Estado inicial dos reveals — a animação é dirigida por GSAP ScrollTrigger (scroll.js) */
.reveal{opacity:0;transform:translateY(42px)}
.reveal-stagger > *{opacity:0;transform:translateY(46px) scale(.978);filter:blur(8px)}

@media(prefers-reduced-motion:reduce){
  .reveal,.reveal-stagger > *{opacity:1;transform:none;filter:none}
}

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media(max-width:980px){
  .hero{min-height:78vh}
  /* foto menor e entre o texto e as caixas brancas (texto → foto → features) */
  .about-grid{display:flex;flex-direction:column;gap:0;align-items:stretch;text-align:left}
  .about-content{display:contents}
  .about-content > .kicker{order:1}
  .about-content > .sec-title{order:2}
  .about-content > .sec-lead{order:3}
  .about-media{order:4;max-width:330px;width:100%;margin:26px auto 0}
  .about-content > .feat-list{order:5;margin-top:28px}
  .sol-grid{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .port-grid{grid-template-columns:repeat(2,1fr)}
  .foot-top{grid-template-columns:1fr 1fr;gap:34px}
}
@media(max-width:720px){
  .wrap,.narrow{padding:0 20px}
  .hero{min-height:auto;padding:104px 0 56px}   /* mais respiro do header (texto não corta) */
  .sec{padding:64px 0}
  /* header vira menu hambúrguer; idioma e CTA vão PARA DENTRO do menu */
  .nav,.header-right .lang,.header-right .btn{display:none}
  .hamburger{display:flex}
  .nav.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;
    background:var(--charcoal);border-top:1px solid #242424;padding:16px 24px 22px;gap:2px;z-index:199;
    box-shadow:0 22px 44px rgba(0,0,0,.5);max-height:calc(100vh - 62px);overflow-y:auto}
  .nav.open a{padding:14px 2px;font-size:15px;color:#e8e4de}
  .nav.open > a{border-bottom:1px solid #1e1e1e}
  .nav.open a::before,.nav.open a::after{display:none}   /* sem número/sublinha no menu mobile */
  .nav-extra{display:flex}
  /* hero: os 2 botões LADO A LADO */
  .hero-cta{flex-wrap:nowrap;gap:10px}
  .hero-cta > *{flex:1 1 0;min-width:0;justify-content:center;text-align:center;white-space:nowrap;
    padding-left:8px;padding-right:8px;font-size:10px;letter-spacing:.3px}
  /* footer/grids */
  .foot-top{grid-template-columns:1fr 1fr;gap:30px 20px}
  .foot-top > :nth-child(1){grid-column:1/-1}   /* marca: largura total */
  .foot-top > :nth-child(4){grid-column:1/-1}   /* Fale Conosco: largura total */
  /* 4 números centralizados (grade 2×2) */
  .hero-meta{display:grid;grid-template-columns:1fr 1fr;gap:24px 12px;justify-items:center;text-align:center}
  .about-media .badge-float{left:0}
  .team-grid{grid-template-columns:1fr}
  /* Serviços e Projetos viram CARROSSEL (rolagem horizontal com snap) */
  .sol-grid,.port-grid{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;gap:14px;
    margin:0 -20px;padding:4px 20px 12px;-webkit-overflow-scrolling:touch;scroll-padding-left:20px}
  .sol-grid > *,.port-grid > *{flex:0 0 84%;scroll-snap-align:start}
  .sol-grid::-webkit-scrollbar,.port-grid::-webkit-scrollbar{height:0}
}
