/* =====================================================================
   e3d solutions — landing page
   Tema: dark neon · gradiente azul→roxo→magenta→laranja
   ===================================================================== */

:root{
  --bg:        #05060d;
  --bg-2:      #090a16;
  --surface:   rgba(255,255,255,.035);
  --surface-2: rgba(255,255,255,.06);
  --line:      rgba(255,255,255,.10);

  --cyan:    #19d3ff;
  --blue:    #2f6bff;
  --purple:  #7c3aed;
  --magenta: #d633ff;
  --pink:    #ff3d9a;
  --orange:  #ff7a1a;
  --wa:      #22c55e;

  --text:  #eef0fb;
  --muted: #99a0c4;

  --grad: linear-gradient(100deg, var(--cyan), var(--blue) 32%, var(--purple) 55%, var(--magenta) 76%, var(--orange));
  --grad-soft: linear-gradient(100deg, rgba(25,211,255,.16), rgba(124,58,237,.16), rgba(255,122,26,.16));

  --radius: 18px;
  --radius-lg: 26px;
  --container: 1180px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --shadow: 0 30px 80px -30px rgba(0,0,0,.8);
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0 }
html{ scroll-behavior:smooth }
body{
  font-family:'Sora',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  cursor:auto;
}
body.loading{ overflow:hidden; height:100vh }
img,svg{ display:block; max-width:100% }
a{ color:inherit; text-decoration:none }
ul,ol{ list-style:none }
.mono{ font-family:'Orbitron','Space Grotesk',monospace; letter-spacing:.06em }

::selection{ background:rgba(214,51,255,.4); color:#fff }

/* ---------- helpers ---------- */
.container{ width:min(var(--container),92vw); margin-inline:auto }
.container--narrow{ width:min(820px,92vw) }
.grad{
  background:var(--grad);
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
}
.ico{ flex:none }
.sr-only{ position:absolute!important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0 }

/* =====================================================================
   FUNDO animado
   ===================================================================== */
.bg-aurora,.bg-grid{ position:fixed; inset:0; z-index:-2; pointer-events:none }
.bg-aurora{
  background:
    radial-gradient(60vw 60vw at 12% -5%, rgba(47,107,255,.20), transparent 60%),
    radial-gradient(55vw 55vw at 95% 8%, rgba(214,51,255,.16), transparent 60%),
    radial-gradient(50vw 50vw at 50% 110%, rgba(255,122,26,.14), transparent 60%);
  filter:blur(6px);
  animation:auroraShift 16s ease-in-out infinite alternate;
}
@keyframes auroraShift{ to{ transform:translateY(-3%) scale(1.05) } }
.bg-grid{
  z-index:-1;
  background-image:
    linear-gradient(rgba(120,140,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(120,140,255,.05) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(circle at 50% 25%, #000 0%, transparent 78%);
  animation:gridDrift 24s linear infinite;
}
@keyframes gridDrift{ to{ background-position:0 540px } }

/* =====================================================================
   PRELOADER
   ===================================================================== */
.preloader{
  position:fixed; inset:0; z-index:10000;
  display:grid; place-items:center;
  background:radial-gradient(circle at 50% 40%, #0b0d1c, #04050b 70%);
  transition:opacity .6s var(--ease),visibility .6s;
}
.preloader.done{ opacity:0; visibility:hidden }
.preloader__inner{ width:min(380px,80vw); text-align:center }
.preloader__logo{ display:flex; align-items:center; justify-content:center; margin-bottom:30px }
.preloader__full{ width:min(210px,58vw); height:auto; filter:drop-shadow(0 0 26px rgba(124,58,237,.5)); animation:logoFloat 3.4s var(--ease) infinite }
@keyframes logoFloat{ 50%{ transform:translateY(-8px) } }
.preloader__bar{
  height:6px; border-radius:99px; background:rgba(255,255,255,.08);
  overflow:hidden; position:relative;
}
.preloader__bar i{ position:absolute; inset:0 100% 0 0; background:var(--grad); border-radius:99px; box-shadow:0 0 18px rgba(214,51,255,.7); transition:right .2s linear }
.preloader__meta{ display:flex; justify-content:space-between; margin-top:14px; font-size:.82rem; color:var(--muted) }
#prePct{ color:var(--text) }

/* =====================================================================
   BOTÕES
   ===================================================================== */
.btn{
  --bw:1px;
  position:relative; display:inline-flex; align-items:center; gap:.6em;
  font-family:inherit; font-weight:700; font-size:.96rem; line-height:1;
  padding:.95em 1.5em; border-radius:99px; border:var(--bw) solid transparent;
  cursor:pointer; white-space:nowrap; transition:transform .25s var(--ease),box-shadow .25s,background .25s,color .25s;
  isolation:isolate;
}
.btn--lg{ padding:1.05em 1.8em; font-size:1.02rem }
.btn--xl{ padding:1.25em 2.4em; font-size:1.12rem }
.btn:active{ transform:translateY(1px) scale(.99) }

.btn--primary{ color:#0a0512; background:var(--grad); background-size:200% 100%; box-shadow:0 12px 34px -10px rgba(214,51,255,.6) }
.btn--primary:hover{ background-position:100% 0; transform:translateY(-3px); box-shadow:0 18px 44px -10px rgba(255,122,26,.65) }

.btn--outline{ color:var(--text); border-color:var(--line); background:var(--surface); backdrop-filter:blur(8px) }
.btn--outline:hover{ border-color:rgba(214,51,255,.6); color:#fff; transform:translateY(-3px); box-shadow:0 12px 30px -14px rgba(124,58,237,.7) }

.btn--ghost{ color:var(--text); background:transparent; border-color:var(--line); padding:.6em 1.1em; font-size:.9rem }
.btn--ghost:hover{ background:rgba(34,197,94,.12); border-color:var(--wa); color:#dcfce7 }
.btn--ghost .ico{ color:var(--wa) }

/* =====================================================================
   NAV
   ===================================================================== */
.nav{ position:fixed; top:0; inset-inline:0; z-index:900; transition:background .3s,backdrop-filter .3s,border-color .3s; border-bottom:1px solid transparent }
.nav.scrolled{ background:rgba(6,7,15,.72); backdrop-filter:blur(16px) saturate(140%); border-color:var(--line) }
.nav__row{ display:flex; align-items:center; justify-content:space-between; height:74px }
.logo{ display:flex; align-items:center; gap:11px; font-weight:800 }
.logo .brand-mark{ filter:drop-shadow(0 0 10px rgba(124,58,237,.5)) }
.brand-mark{ display:inline-flex }
.brand-mark img{ display:block; object-fit:contain }
.logo__word{ height:44px; width:auto; display:block }
.footer__brand .logo__word{ height:38px }
.logo__text{ font-size:1.3rem; letter-spacing:.01em }
.logo__text sup{ font-size:.55em }
.logo__text b{ font-weight:400; color:var(--muted); font-size:.62em; letter-spacing:.34em; text-transform:uppercase }

.nav__links{ display:flex; align-items:center; gap:30px }
.nav__links a:not(.btn){ position:relative; color:var(--muted); font-weight:500; font-size:.96rem; white-space:nowrap; transition:color .25s }
.nav__links a:not(.btn)::after{ content:""; position:absolute; left:0; bottom:-6px; height:2px; width:0; background:var(--grad); transition:width .3s var(--ease) }
.nav__links a:not(.btn):hover{ color:var(--text) }
.nav__links a:not(.btn):hover::after{ width:100% }

.nav__burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px }
.nav__burger span{ width:26px; height:2px; background:var(--text); border-radius:2px; transition:.3s }
.nav__burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg) }
.nav__burger[aria-expanded="true"] span:nth-child(2){ opacity:0 }
.nav__burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg) }

/* =====================================================================
   HERO
   ===================================================================== */
.hero{ position:relative; min-height:100vh; display:flex; align-items:center; padding:110px 0 60px; overflow:hidden }
.hero__filament{ position:absolute; inset:0; width:100%; height:100%; z-index:0; opacity:.8 }
.hero__grid{
  position:relative; z-index:2;
  display:grid; grid-template-columns:1.25fr .75fr; gap:48px; align-items:center;
}
.hero__grid>*{ min-width:0 } /* impede que palavra longa estoure o track */

.eyebrow{
  display:inline-flex; align-items:center; gap:.6em;
  font-size:.78rem; font-weight:600; letter-spacing:.28em; text-transform:uppercase;
  color:var(--cyan); padding:.5em 1em; border:1px solid var(--line); border-radius:99px;
  background:var(--surface);
}
.eyebrow .dot{ width:8px; height:8px; border-radius:50%; background:var(--cyan); box-shadow:0 0 10px var(--cyan); animation:pulse 1.6s infinite }
@keyframes pulse{ 50%{ opacity:.3; transform:scale(.7) } }

.hero__title{
  font-size:clamp(2.05rem,5vw,4.3rem); font-weight:800; line-height:1;
  letter-spacing:-.02em; margin:22px 0 20px; text-transform:uppercase;
  overflow-wrap:break-word;
}
.hero__title .line{ display:block }
.hero__title .grad{ filter:drop-shadow(0 4px 30px rgba(214,51,255,.35)) }

.hero__sub{ font-size:clamp(1rem,1.6vw,1.18rem); color:var(--muted); max-width:54ch; margin-bottom:32px }
.hero__sub strong{ color:var(--text); font-weight:600 }

.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:38px }

.hero__badges{ display:flex; flex-wrap:wrap; gap:14px }
.hero__badges li{
  flex:1; min-width:120px; padding:14px 18px; border-radius:var(--radius);
  border:1px solid var(--line); background:var(--surface); backdrop-filter:blur(6px);
}
.hero__badges b{ display:block; font-size:1.5rem; font-weight:800; line-height:1 }
.hero__badges b{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent }
.hero__badges span{ font-size:.84rem; color:var(--muted) }

/* ----- palco 3D ----- */
.hero__stage{ position:relative }
.stage__frame{
  position:relative; aspect-ratio:1/1.04; border-radius:var(--radius-lg);
  border:1px solid var(--line); overflow:hidden;
  background:
    radial-gradient(80% 60% at 50% 18%, rgba(124,58,237,.18), transparent 60%),
    linear-gradient(180deg, rgba(20,22,42,.6), rgba(6,7,15,.85));
  box-shadow:var(--shadow), inset 0 0 60px rgba(0,0,0,.5);
}
.stage__frame::before{ /* scanline glow */
  content:""; position:absolute; inset:0; z-index:3; pointer-events:none;
  background:linear-gradient(transparent 0%, rgba(25,211,255,.05) 50%, transparent 100%);
  background-size:100% 8px; mix-blend-mode:overlay; opacity:.5;
}
.stage__canvas{ position:absolute; inset:0; z-index:2 }
.stage__hud{
  position:absolute; left:14px; right:14px; bottom:14px; z-index:4;
  display:flex; justify-content:space-between; align-items:center;
  font-size:.74rem; color:var(--muted);
  padding:8px 14px; border-radius:12px;
  background:rgba(6,7,15,.55); border:1px solid var(--line); backdrop-filter:blur(8px);
}
.hud__live{ display:inline-flex; align-items:center; gap:.5em; color:var(--orange); font-weight:600; letter-spacing:.1em }
.hud__live i{ width:8px; height:8px; border-radius:50%; background:var(--orange); box-shadow:0 0 10px var(--orange); animation:pulse 1.2s infinite }

.stage__chips{ display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin-top:16px }
.stage__chips span{ font-size:.76rem; color:var(--muted); padding:.4em .9em; border:1px solid var(--line); border-radius:99px; background:var(--surface) }

/* fallback css */
.stage__fallback{ position:absolute; inset:0; z-index:1; display:none; place-items:center }
.no-webgl .stage__canvas{ display:none }
.no-webgl .stage__fallback{ display:grid }
.fb-vase{ display:flex; flex-direction:column-reverse; gap:6px; filter:drop-shadow(0 0 30px rgba(124,58,237,.6)) }
.fb-vase i{ height:22px; border-radius:8px; background:var(--grad); background-size:100% 600%; animation:fbBuild 3s var(--ease) infinite }
.fb-vase i:nth-child(1){ width:120px; animation-delay:0s }
.fb-vase i:nth-child(2){ width:150px; animation-delay:.2s }
.fb-vase i:nth-child(3){ width:170px; animation-delay:.4s }
.fb-vase i:nth-child(4){ width:140px; animation-delay:.6s }
.fb-vase i:nth-child(5){ width:100px; animation-delay:.8s }
.fb-vase i:nth-child(6){ width:120px; animation-delay:1s }
@keyframes fbBuild{ 0%{ opacity:0; transform:translateY(20px) scaleX(.4) } 30%,70%{ opacity:1; transform:none } 100%{ opacity:.85 } }

/* scroll cue */
.hero__scroll{
  position:absolute; left:50%; bottom:26px; z-index:3; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  font-size:.72rem; letter-spacing:.3em; text-transform:uppercase; color:var(--muted);
}
.hero__scroll span{ width:24px; height:38px; border:2px solid var(--line); border-radius:14px; position:relative }
.hero__scroll span::before{ content:""; position:absolute; left:50%; top:7px; width:4px; height:8px; border-radius:4px; background:var(--cyan); transform:translateX(-50%); animation:scrollDot 1.6s infinite }
@keyframes scrollDot{ 0%{ opacity:0; top:7px } 40%{ opacity:1 } 80%{ opacity:0; top:20px } }

/* =====================================================================
   MARQUEE
   ===================================================================== */
.marquee{ border-block:1px solid var(--line); background:linear-gradient(90deg,rgba(124,58,237,.06),rgba(255,122,26,.06)); overflow:hidden; padding:18px 0 }
.marquee__track{ display:flex; align-items:center; gap:26px; width:max-content; animation:marquee 34s linear infinite; font-weight:700; letter-spacing:.06em; text-transform:uppercase }
.marquee__track span{ color:var(--text); opacity:.85; font-size:1.05rem }
.marquee__track i{ color:var(--magenta); font-style:normal }
@keyframes marquee{ to{ transform:translateX(-50%) } }

/* =====================================================================
   SECTIONS genéricas
   ===================================================================== */
.section{ padding:clamp(70px,9vw,120px) 0; scroll-margin-top:80px; position:relative }
.section--idea{ background:
    radial-gradient(70% 50% at 50% 0%, rgba(47,107,255,.08), transparent 60%);
}
.sec-head{ max-width:680px; margin:0 auto 56px; text-align:center }
.kicker{ display:inline-block; font-size:.8rem; font-weight:700; letter-spacing:.26em; text-transform:uppercase; color:var(--magenta); margin-bottom:14px }
.sec-head h2{ font-size:clamp(1.9rem,4vw,3rem); font-weight:800; line-height:1.08; letter-spacing:-.02em; text-transform:uppercase }
.sec-head p{ color:var(--muted); margin-top:16px; font-size:1.05rem }

/* =====================================================================
   CARDS de serviço
   ===================================================================== */
.cards{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px }
/* hover simples e robusto (sem máscara/overflow/3D — compatível com Safari) */
.card{
  position:relative; padding:30px 26px 28px; border-radius:var(--radius-lg);
  background:var(--surface); border:1px solid var(--line);
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s,background .35s;
}
.card:hover{
  transform:translateY(-8px);
  border-color:rgba(214,51,255,.55); background:var(--surface-2);
  box-shadow:0 28px 55px -26px rgba(124,58,237,.6), 0 0 0 1px rgba(214,51,255,.35);
}
.card__ico{
  width:60px; height:60px; border-radius:16px; display:grid; place-items:center; margin-bottom:20px;
  color:var(--cyan); background:var(--grad-soft); border:1px solid var(--line);
  transition:transform .35s var(--ease),color .35s;
}
.card:hover .card__ico{ transform:translateY(-3px) rotate(-6deg) scale(1.06); color:#fff }
.card h3{ font-size:1.28rem; font-weight:700; margin-bottom:10px }
.card p{ color:var(--muted); font-size:.95rem }
.card__tag{ display:inline-block; margin-top:18px; font-size:.74rem; font-weight:600; letter-spacing:.05em; padding:.4em .9em; border-radius:99px; color:var(--text); background:var(--surface-2); border:1px solid var(--line) }

/* =====================================================================
   COMO FUNCIONA / IDEIA
   ===================================================================== */
.idea__inputs{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:14px }
.ibox{ text-align:center; padding:30px 22px; border-radius:var(--radius-lg); background:var(--surface); border:1px solid var(--line); transition:transform .3s var(--ease),border-color .3s }
.ibox:hover{ transform:translateY(-6px); border-color:rgba(25,211,255,.5) }
.ibox__ico{ width:62px; height:62px; margin:0 auto 16px; border-radius:50%; display:grid; place-items:center; color:var(--cyan); background:radial-gradient(circle,rgba(25,211,255,.18),transparent 70%); border:1px solid var(--line) }
.ibox h4{ font-size:1.12rem; margin-bottom:8px }
.ibox p{ color:var(--muted); font-size:.92rem }

.idea__bridge{ text-align:center; font-size:clamp(1.4rem,3vw,2.1rem); font-weight:800; margin:34px 0 50px; text-transform:uppercase; letter-spacing:-.01em }

.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; counter-reset:s }
.step{ position:relative; padding:28px 22px; border-radius:var(--radius); background:var(--surface); border:1px solid var(--line); overflow:hidden }
.step::before{ content:""; position:absolute; left:0; top:0; height:3px; width:100%; background:var(--grad); opacity:.7 }
.step__num{ font-size:2rem; font-weight:900; background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; display:block; margin-bottom:10px }
.step h4{ font-size:1.08rem; margin-bottom:6px }
.step p{ color:var(--muted); font-size:.9rem }

.idea__cta{ text-align:center; margin-top:48px }
.idea__note{ display:block; margin-top:14px; color:var(--muted); font-size:.9rem }

/* =====================================================================
   DIFERENCIAIS + STATS
   ===================================================================== */
.feats{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-bottom:60px }
.feat{ padding:30px 26px; border-radius:var(--radius-lg); background:var(--surface); border:1px solid var(--line); transition:transform .3s var(--ease),background .3s }
.feat:hover{ transform:translateY(-6px); background:var(--surface-2) }
.feat__ico{ width:56px; height:56px; border-radius:14px; display:grid; place-items:center; margin-bottom:18px; color:var(--orange); background:radial-gradient(circle,rgba(255,122,26,.16),transparent 70%); border:1px solid var(--line) }
.feat h3{ font-size:1.16rem; margin-bottom:8px }
.feat p{ color:var(--muted); font-size:.93rem }

.manifesto{
  display:grid; grid-template-columns:1.25fr .9fr; gap:34px; align-items:center;
  padding:40px; border-radius:var(--radius-lg);
  background:linear-gradient(120deg,rgba(47,107,255,.10),rgba(214,51,255,.10),rgba(255,122,26,.10));
  border:1px solid var(--line);
}
.manifesto .kicker{ margin-bottom:12px }
.manifesto h3{ font-size:clamp(1.6rem,3.2vw,2.3rem); font-weight:800; line-height:1.08; letter-spacing:-.01em }
.manifesto__main p{ color:var(--muted); margin-top:14px; font-size:1.04rem; max-width:48ch }
.manifesto__main strong{ color:var(--text); font-weight:600 }
.manifesto__pills{ display:grid; gap:12px }
.manifesto__pills li{ display:flex; align-items:center; gap:13px; padding:14px 18px; border-radius:14px; background:var(--surface); border:1px solid var(--line); font-weight:600; font-size:.96rem; transition:transform .25s var(--ease),border-color .25s }
.manifesto__pills li:hover{ transform:translateX(4px); border-color:rgba(25,211,255,.5) }
.manifesto__pills svg{ color:var(--cyan); flex:none }

/* =====================================================================
   FAQ
   ===================================================================== */
.faq{ display:grid; gap:14px }
.faq__item{ border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); overflow:hidden; transition:border-color .3s }
.faq__item[open]{ border-color:rgba(214,51,255,.45) }
.faq__item summary{ list-style:none; cursor:pointer; padding:20px 22px; font-weight:600; font-size:1.05rem; display:flex; align-items:center; justify-content:space-between; gap:16px }
.faq__item summary::-webkit-details-marker{ display:none }
.faq__plus{ position:relative; flex:none; width:20px; height:20px }
.faq__plus::before,.faq__plus::after{ content:""; position:absolute; inset:0; margin:auto; background:var(--magenta); border-radius:2px; transition:transform .3s }
.faq__plus::before{ width:16px; height:2px }
.faq__plus::after{ width:2px; height:16px }
.faq__item[open] .faq__plus::after{ transform:rotate(90deg); opacity:0 }
.faq__body{ padding:0 22px 22px; color:var(--muted) }
.faq__body a{ color:var(--cyan); text-decoration:underline }

/* =====================================================================
   LOCALIZAÇÃO (SEO local)
   ===================================================================== */
.section--local{ background:radial-gradient(70% 50% at 50% 0%, rgba(214,51,255,.07), transparent 60%) }
.local{ display:grid; grid-template-columns:1fr 1fr; gap:26px; align-items:stretch }
.local__info{ padding:34px; border-radius:var(--radius-lg); background:var(--surface); border:1px solid var(--line); display:flex; flex-direction:column }
.local__info address{ font-style:normal; display:flex; flex-direction:column; gap:18px }
.local__row{ display:flex; gap:14px; align-items:flex-start }
.local__row svg{ flex:none; color:var(--cyan); margin-top:2px }
.local__row b{ display:block; font-size:1.02rem }
.local__row span,.local__row a{ color:var(--muted); font-size:.95rem }
.local__row a:hover{ color:var(--cyan) }
.local__cta{ display:flex; flex-wrap:wrap; gap:12px; margin:26px 0 18px }
.local__area{ color:var(--muted); font-size:.9rem; margin-top:auto; padding-top:14px; border-top:1px solid var(--line) }
.local__area strong{ color:var(--text) }
.local__map{ position:relative; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); min-height:380px; background:#0a0c1a }
.local__map iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; filter:invert(.9) hue-rotate(180deg) brightness(.95) contrast(.95) }
.local__map::after{ content:""; position:absolute; inset:0; pointer-events:none; box-shadow:inset 0 0 60px rgba(0,0,0,.6); border-radius:inherit }

/* =====================================================================
   CTA FINAL
   ===================================================================== */
.cta{ position:relative; padding:clamp(80px,10vw,130px) 0; overflow:hidden }
.cta__spark{ position:absolute; inset:0; width:100%; height:100%; z-index:0 }
.cta__box{
  position:relative; z-index:2; text-align:center; max-width:760px; margin:0 auto;
  padding:clamp(40px,6vw,68px); border-radius:var(--radius-lg);
  background:radial-gradient(120% 120% at 50% 0%, rgba(124,58,237,.18), rgba(6,7,15,.6));
  border:1px solid var(--line); box-shadow:var(--shadow);
}
.cta__box h2{ font-size:clamp(2rem,5vw,3.4rem); font-weight:800; line-height:1.05; text-transform:uppercase; letter-spacing:-.02em }
.cta__box p{ color:var(--muted); margin:18px auto 32px; font-size:1.1rem; max-width:48ch }
.cta__contacts{ display:flex; flex-wrap:wrap; gap:10px 26px; justify-content:center; margin-top:30px }
.cta__contacts a{ display:inline-flex; align-items:center; gap:.5em; color:var(--muted); font-size:.95rem; transition:color .25s }
.cta__contacts a:hover{ color:var(--text) }
.cta__contacts .ico{ color:var(--cyan) }

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer{ border-top:1px solid var(--line); background:var(--bg-2); padding:60px 0 30px }
.footer__row{ display:grid; grid-template-columns:1.6fr 1fr 1.2fr; gap:40px; padding-bottom:40px; border-bottom:1px solid var(--line) }
.footer__brand p{ color:var(--muted); margin-top:16px; font-size:.94rem; max-width:42ch }
.footer__address{ font-style:normal; color:var(--muted); margin-top:16px; font-size:.92rem; line-height:1.7 }
.footer__address strong{ color:var(--text) }
.footer h5{ font-size:.82rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:16px }
.footer__nav,.footer__contact{ display:flex; flex-direction:column; gap:10px }
.footer__nav a,.footer__contact a{ color:var(--text); opacity:.82; font-size:.95rem; transition:opacity .25s,color .25s; width:fit-content }
.footer__nav a:hover,.footer__contact a:hover{ opacity:1; color:var(--cyan) }
.footer__bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; padding-top:24px; color:var(--muted); font-size:.84rem }
.footer__made{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; font-weight:600 }

/* =====================================================================
   WHATSAPP flutuante
   ===================================================================== */
.wa-float{
  position:fixed; right:22px; bottom:22px; z-index:800;
  width:60px; height:60px; border-radius:50%; display:grid; place-items:center;
  color:#fff; background:var(--wa);
  box-shadow:0 14px 30px -8px rgba(34,197,94,.7);
  transition:transform .3s var(--ease),box-shadow .3s;
}
.wa-float::before{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid var(--wa); animation:waPing 2.2s ease-out infinite }
@keyframes waPing{ 0%{ transform:scale(1); opacity:.7 } 100%{ transform:scale(1.8); opacity:0 } }
.wa-float:hover{ transform:scale(1.08) translateY(-2px) }
.wa-float__tip{
  position:absolute; right:74px; top:50%; transform:translateY(-50%) translateX(8px);
  white-space:nowrap; background:#0c1322; color:#fff; font-size:.82rem; font-weight:500;
  padding:.5em .9em; border-radius:10px; border:1px solid var(--line);
  opacity:0; pointer-events:none; transition:.3s;
}
.wa-float:hover .wa-float__tip{ opacity:1; transform:translateY(-50%) translateX(0) }

/* =====================================================================
   REVEAL (scroll)
   ===================================================================== */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .7s var(--ease),transform .7s var(--ease) }
.reveal.in{ opacity:1; transform:none }
.reveal.d1{ transition-delay:.08s } .reveal.d2{ transition-delay:.16s }
.reveal.d3{ transition-delay:.24s } .reveal.d4{ transition-delay:.32s }

/* =====================================================================
   RESPONSIVO
   ===================================================================== */
@media (max-width:1100px){
  .hero__grid{ grid-template-columns:1fr; gap:40px }
  .hero__stage{ max-width:460px; margin-inline:auto; order:-1; width:100% }
  .cards{ grid-template-columns:repeat(2,1fr) }
  .feats{ grid-template-columns:repeat(2,1fr) }
  .steps{ grid-template-columns:repeat(2,1fr) }
  .footer__row{ grid-template-columns:1fr 1fr }
  .footer__brand{ grid-column:1/-1 }
}
/* menu mobile aparece antes (evita aperto no tablet) */
@media (max-width:900px){
  .nav__links{
    position:fixed; inset:74px 0 auto 0; flex-direction:column; align-items:stretch; gap:0;
    background:rgba(6,7,15,.97); backdrop-filter:blur(18px); border-bottom:1px solid var(--line);
    padding:14px 22px 26px; transform:translateY(-130%); transition:transform .4s var(--ease); height:auto;
  }
  .nav__links.open{ transform:none }
  .nav__links a:not(.btn){ padding:16px 0; border-bottom:1px solid var(--line) }
  .nav__links a:not(.btn)::after{ display:none }
  .nav__cta{ margin-top:16px; justify-content:center }
  .nav__burger{ display:flex }
  .local{ grid-template-columns:1fr }
  .local__map{ min-height:300px }
  .manifesto{ grid-template-columns:1fr; gap:26px; padding:32px }
}

@media (max-width:680px){
  .idea__inputs{ grid-template-columns:1fr }
  .cta__contacts{ flex-direction:column; align-items:center; gap:14px }
  .hero__badges li{ min-width:calc(50% - 7px) }
  .footer__bottom{ flex-direction:column }
}
@media (max-width:440px){
  .cards{ grid-template-columns:1fr }
  .feats{ grid-template-columns:1fr }
  .steps{ grid-template-columns:1fr }
}

/* =====================================================================
   ACESSIBILIDADE / motion
   ===================================================================== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; scroll-behavior:auto !important }
  .reveal{ opacity:1; transform:none }
}
:focus-visible{ outline:2px solid var(--cyan); outline-offset:3px; border-radius:6px }
