/* ============================================================
   NET5 — Conectando Você
   Dark premium tech landing
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Saira:wght@300;400;500;600;700&family=Saira+Condensed:wght@500;600;700;800;900&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  /* palette */
  --bg:        #020817;
  --bg-2:      #0a1324;
  --panel:     #0F172A;
  --panel-2:   #0c1830;
  --card:      #0b1525;
  --blue:      #00A8FF;
  --blue-2:    #38BDF8;
  --blue-deep: #0066b3;
  --white:     #FFFFFF;
  --text:      #eaf1fb;
  --muted:     #8ba0be;
  --muted-2:   #5e718f;
  --line:      rgba(120,170,230,0.12);
  --line-2:    rgba(120,170,230,0.20);
  --glow:      rgba(0,168,255,0.45);

  /* type */
  --f-display: "Saira Condensed", "Arial Narrow", sans-serif;
  --f-body:    "Saira", system-ui, sans-serif;
  --f-mono:    "JetBrains Mono", ui-monospace, monospace;

  /* layout */
  --maxw: 1240px;
  --radius: 16px;
  --radius-lg: 22px;
  --header-h: 80px;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; scroll-padding-top:90px; }
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--f-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.no-scroll{ overflow:hidden; }

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
ul{ list-style:none; }
::selection{ background:var(--blue); color:#001022; }

/* scrollbar */
::-webkit-scrollbar{ width:11px; }
::-webkit-scrollbar-track{ background:var(--bg); }
::-webkit-scrollbar-thumb{ background:#1c2c47; border-radius:10px; border:3px solid var(--bg); }
::-webkit-scrollbar-thumb:hover{ background:#28395a; }

/* ---------- shared layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
section{ position:relative; }
.section-pad{ padding:120px 0; }
.section-pad-sm{ padding:88px 0; }

.eyebrow{
  font-family:var(--f-mono);
  font-size:12px;
  font-weight:500;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--blue-2);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:"";
  width:22px; height:1px;
  background:linear-gradient(90deg,transparent,var(--blue));
}
.eyebrow.center::before{ display:none; }

.h-sec{
  font-family:var(--f-display);
  font-weight:800;
  font-size:clamp(34px,5vw,60px);
  line-height:0.98;
  letter-spacing:-0.01em;
  text-transform:uppercase;
  margin:18px 0 0;
}
.h-sec .accent{ color:var(--blue-2); }
.sub-sec{
  color:var(--muted);
  font-size:18px;
  max-width:580px;
  margin-top:18px;
}
.sec-head{ margin-bottom:64px; }
.sec-head.center{ text-align:center; }
.sec-head.center .sub-sec{ margin-left:auto; margin-right:auto; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--f-body);
  font-weight:600;
  font-size:15px;
  letter-spacing:.02em;
  padding:15px 28px;
  border-radius:999px;
  transition:transform .25s ease, box-shadow .3s ease, background .3s ease, border-color .3s;
  white-space:nowrap;
}
.btn svg{ width:18px; height:18px; }
.btn-primary{
  background:linear-gradient(180deg,var(--blue-2),var(--blue));
  color:#02101f;
  box-shadow:0 8px 30px -8px var(--glow), inset 0 1px 0 rgba(255,255,255,.35);
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 14px 40px -8px var(--glow), inset 0 1px 0 rgba(255,255,255,.4); }
.btn-ghost{
  background:rgba(255,255,255,.03);
  border:1px solid var(--line-2);
  color:var(--text);
  backdrop-filter:blur(8px);
}
.btn-ghost:hover{ border-color:var(--blue); background:rgba(0,168,255,.08); transform:translateY(-2px); }
.btn-wa{
  background:rgba(255,255,255,.04);
  border:1px solid var(--line-2);
}
.btn-wa:hover{ border-color:#25d36688; background:rgba(37,211,102,.08); }
.btn-lg{ padding:18px 38px; font-size:17px; }
.btn-block{ width:100%; }

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  height:var(--header-h);
  display:flex; align-items:center;
  background:rgba(2,8,23,0.78);
  backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--line);
  box-shadow:0 10px 40px -20px #000;
}
.header .wrap{ display:flex; align-items:center; justify-content:space-between; gap:24px; }

/* logo */
.logo{ display:flex; align-items:center; gap:12px; }
.header .logo{ flex-direction:column; align-items:flex-start; gap:5px; }
.logo-img{ height:32px; width:auto; display:block; }
.logo-tag{ font-family:var(--f-mono); font-size:8.5px; letter-spacing:.345em; text-transform:uppercase; color:var(--muted); padding-left:3px; }
.foot-logo{ width:200px; max-width:60%; height:auto; display:block; }
/* legacy css wordmark (kept for reference) */
.logo .mark{
  position:relative; width:38px; height:38px;
  display:grid; place-items:center;
  border-radius:11px;
  background:linear-gradient(150deg,#0a2b4d,#06121f);
  border:1px solid var(--line-2);
  box-shadow:inset 0 0 18px rgba(0,168,255,.25), 0 4px 18px -6px var(--glow);
}
.logo .mark span{
  font-family:var(--f-display); font-weight:900; font-size:22px;
  color:var(--blue-2); line-height:1;
}
.logo .mark .ring{
  position:absolute; inset:-4px; border-radius:14px;
  border:1px solid rgba(0,168,255,.25);
}
.logo .word{ display:flex; flex-direction:column; line-height:1; }
.logo .word b{
  font-family:var(--f-display); font-weight:900; font-size:25px;
  letter-spacing:.04em; color:var(--white);
}
.logo .word b i{ color:var(--blue); font-style:normal; }
.logo .word small{
  font-family:var(--f-mono); font-size:8.5px; letter-spacing:.32em;
  color:var(--muted); text-transform:uppercase; margin-top:3px;
}

.nav{ display:flex; align-items:center; gap:6px; }
.nav a{
  font-size:15px; font-weight:500; color:var(--muted);
  padding:9px 16px; border-radius:9px;
  transition:color .2s, background .2s;
}
.nav a:hover{ color:var(--white); background:rgba(255,255,255,.04); }

.header-actions{ display:flex; align-items:center; gap:12px; }
.header-actions .btn{ padding:11px 20px; font-size:14px; }

.burger{ display:none; width:44px; height:44px; border-radius:10px; border:1px solid var(--line-2); }
.burger span{ display:block; width:18px; height:2px; background:var(--text); margin:3px auto; border-radius:2px; transition:.3s; }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:99;
  background:rgba(2,8,23,.96); backdrop-filter:blur(20px);
  display:flex; flex-direction:column; justify-content:center; gap:6px;
  padding:40px 32px;
  transform:translateY(-100%); opacity:0; pointer-events:none;
  transition:transform .4s cubic-bezier(.6,0,.2,1), opacity .3s;
}
.drawer.open{ transform:translateY(0); opacity:1; pointer-events:auto; }
.drawer a{ font-family:var(--f-display); font-weight:700; font-size:34px; text-transform:uppercase; padding:10px 0; border-bottom:1px solid var(--line); }
.drawer .btn{ margin-top:24px; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; height:100vh; min-height:720px;
  display:flex; align-items:center;
  overflow:hidden;
  background:radial-gradient(120% 90% at 78% 8%, rgba(0,80,150,.28), transparent 55%),
             radial-gradient(80% 70% at 12% 100%, rgba(0,40,90,.35), transparent 60%),
             var(--bg);
}
.hero-bg{ position:absolute; inset:0; z-index:0; overflow:hidden;
  transform:scale(1.06) translate3d(var(--px,0px), var(--py,0px), 0);
  transition:transform .5s cubic-bezier(.2,.7,.2,1); will-change:transform; }
.scene{ position:absolute; inset:0; opacity:0; visibility:hidden; transform:scale(1.07);
  background:linear-gradient(120deg,#0b1f38,#050d1a 65%);
  transition:opacity 1.1s ease, transform 7s ease, visibility 1.1s; }
.scene.active{ opacity:1; visibility:visible; transform:scale(1); }
.scene-photo{ background-size:cover; background-position:center; }
.scene .hv-stripes{ position:absolute; inset:0; background:repeating-linear-gradient(135deg, rgba(120,170,230,.05) 0 2px, transparent 2px 16px); }
.scene .hv-glow{ position:absolute; inset:0; background:radial-gradient(58% 75% at 72% 34%, rgba(0,168,255,.20), transparent 68%); }
.scene-num{ position:absolute; right:5%; top:12%; font-family:var(--f-display); font-weight:900; font-size:clamp(120px,22vw,300px); line-height:.8; color:rgba(120,170,230,.07); pointer-events:none; }
.scene-icon{ position:absolute; right:11%; top:52%; transform:translateY(-50%); width:clamp(130px,16vw,240px); height:auto; color:rgba(130,180,240,.13); pointer-events:none; }
.scene-tag{ position:absolute; right:28px; top:102px; display:flex; align-items:center; gap:9px; font-family:var(--f-mono); font-size:11px; letter-spacing:.12em; color:var(--muted); text-transform:uppercase; }
.scene-tag .dot{ width:7px; height:7px; border-radius:50%; background:var(--blue); box-shadow:0 0 10px var(--blue); flex:none; }
.scene--img{ background-size:contain; background-position:center; background-repeat:no-repeat; background-color:#020817; }
.hero--art .hero-grid{ display:none; }
.hero-scrim{ position:absolute; inset:0; z-index:3; pointer-events:none; transition:opacity .7s ease;
  background:
    linear-gradient(90deg, rgba(2,8,23,.95) 0%, rgba(2,8,23,.82) 30%, rgba(2,8,23,.46) 60%, rgba(2,8,23,.30) 100%),
    linear-gradient(0deg, rgba(2,8,23,.92) 0%, rgba(2,8,23,0) 40%); }
.hero-canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:2; opacity:.7; }
.hero-aura{ position:absolute; inset:0; z-index:4; pointer-events:none;
  background:radial-gradient(42% 52% at 72% 32%, rgba(0,168,255,.22), transparent 70%);
  mix-blend-mode:screen; opacity:.7;
  transform:translate3d(var(--gx,0px), var(--gy,0px), 0);
  transition:transform .6s ease; will-change:transform, opacity; }
@media (prefers-reduced-motion: no-preference){
  .hero-aura{ animation:auraPulse 6.5s ease-in-out infinite; }
}
@keyframes auraPulse{ 0%,100%{ opacity:.5; } 50%{ opacity:.92; } }
.hero--art .hero-scrim{ opacity:0; }
.hero--art .hero-canvas{ opacity:.35; }
.hero-content{ position:relative; z-index:5; width:100%; }
.hero-grid{
  position:absolute; inset:0; z-index:1;
  background-image:
    linear-gradient(rgba(120,170,230,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(120,170,230,.05) 1px, transparent 1px);
  background-size:60px 60px;
  -webkit-mask-image:radial-gradient(circle at 50% 40%, #000 10%, transparent 75%);
          mask-image:radial-gradient(circle at 50% 40%, #000 10%, transparent 75%);
}

.slides{ position:relative; min-height:430px; }
.slide{
  position:absolute; inset:0;
  opacity:0; visibility:hidden;
  transition:opacity .7s ease, visibility .7s;
}
.slide.active{ opacity:1; visibility:visible; }
@keyframes heroIn{ from{ opacity:0; transform:translateY(32px); filter:blur(4px); } to{ opacity:1; transform:none; filter:blur(0); } }
@media (prefers-reduced-motion: no-preference){
  .slide.active .eyebrow{ animation:heroIn .7s cubic-bezier(.2,.75,.25,1) both .15s; }
  .slide.active h1{ animation:heroIn .9s cubic-bezier(.2,.75,.25,1) both .30s; }
  .slide.active p{ animation:heroIn .8s cubic-bezier(.2,.75,.25,1) both .48s; }
  .slide.active .slide-cta{ animation:heroIn .8s cubic-bezier(.2,.75,.25,1) both .62s; }
}
.slide .eyebrow{ margin-bottom:22px; }
.slide h1{
  font-family:var(--f-display); font-weight:800;
  font-size:clamp(40px,5.6vw,72px); line-height:0.96;
  letter-spacing:-0.015em; text-transform:uppercase;
  margin-bottom:22px; max-width:14ch;
}
.slide h1 .gr{
  background:linear-gradient(120deg,var(--blue-2),var(--blue));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.slide p{ color:var(--muted); font-size:19px; max-width:46ch; margin-bottom:34px; }
.slide-cta{ display:flex; gap:14px; flex-wrap:wrap; }

/* hero controls */
.hero-foot{
  position:absolute; left:0; right:0; bottom:34px; z-index:4;
}
.hero-foot .wrap{ display:flex; align-items:center; justify-content:space-between; gap:20px; }
.dots{ display:flex; gap:10px; }
.dots button{ width:34px; height:4px; border-radius:4px; background:rgba(255,255,255,.16); overflow:hidden; position:relative; transition:background .3s; }
.dots button .fill{ position:absolute; inset:0; width:0; background:linear-gradient(90deg,var(--blue-2),var(--blue)); }
.dots button.active{ background:rgba(255,255,255,.22); }
.dots button.active .fill{ width:100%; transition:width 6s linear; }
.hero-arrows{ display:flex; gap:10px; }
.hero-arrows button{
  width:46px; height:46px; border-radius:50%; border:1px solid var(--line-2);
  display:grid; place-items:center; background:rgba(255,255,255,.03); backdrop-filter:blur(8px);
  transition:.25s;
}
.hero-arrows button:hover{ border-color:var(--blue); background:rgba(0,168,255,.1); }
.hero-arrows svg{ width:18px; height:18px; }
.scroll-cue{ font-family:var(--f-mono); font-size:11px; letter-spacing:.2em; color:var(--muted-2); text-transform:uppercase; }

/* ============================================================
   SLOGAN REVEAL
   ============================================================ */
.slogan{ padding:130px 0; text-align:center; overflow:hidden; }
.slogan-logo-wrap{ position:relative; display:inline-block; width:72%; max-width:780px; }
.slogan-logo-wrap::before{
  content:""; position:absolute; inset:-22% -14%; z-index:0;
  background:radial-gradient(50% 58% at 50% 48%, rgba(0,168,255,.20), transparent 70%);
  opacity:0; transition:opacity 1.3s ease .3s;
}
.slogan-logo{
  position:relative; z-index:1; width:100%; height:auto; display:block;
  opacity:0; transform:translateY(30px) scale(.96); filter:blur(6px);
  transition:opacity 1.1s ease, transform 1.2s cubic-bezier(.2,.7,.2,1), filter 1.1s;
}
.slogan-shine{
  position:absolute; inset:0; z-index:2; pointer-events:none;
  -webkit-mask-image:url('net5-logo.png'); mask-image:url('net5-logo.png');
  -webkit-mask-size:contain; mask-size:contain;
  -webkit-mask-repeat:no-repeat; mask-repeat:no-repeat;
  -webkit-mask-position:center; mask-position:center;
  background:linear-gradient(105deg, transparent 38%, rgba(255,255,255,.9) 50%, transparent 62%);
  background-size:260% 100%; background-position:170% 0;
  opacity:0; mix-blend-mode:screen;
}
.slogan.in .slogan-logo-wrap::before{ opacity:1; }
.slogan.in .slogan-logo{ opacity:1; transform:none; filter:blur(0); }
.slogan.in .slogan-shine{ opacity:1; animation:sweep 2.4s ease-in-out 1s; }
@keyframes sweep{ 0%{ background-position:170% 0; } 100%{ background-position:-70% 0; } }

/* ============================================================
   DIFERENCIAIS
   ============================================================ */
.feat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.feat{
  position:relative; padding:34px 30px;
  background:linear-gradient(180deg,var(--card),#070f1c);
  border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; transition:transform .3s, border-color .3s;
}
.feat::after{
  content:""; position:absolute; inset:0; border-radius:inherit;
  background:radial-gradient(120% 80% at 100% 0%, rgba(0,168,255,.10), transparent 60%);
  opacity:0; transition:opacity .3s;
}
.feat:hover{ transform:translateY(-4px); border-color:var(--line-2); }
.feat:hover::after{ opacity:1; }
.feat .ic{
  width:52px; height:52px; border-radius:13px; display:grid; place-items:center;
  background:rgba(0,168,255,.08); border:1px solid var(--line-2); color:var(--blue-2);
  margin-bottom:22px;
}
.feat .ic svg{ width:26px; height:26px; }
.feat h3{ font-family:var(--f-display); font-weight:700; font-size:23px; text-transform:uppercase; letter-spacing:.01em; margin-bottom:8px; }
.feat p{ color:var(--muted); font-size:15.5px; }
.feat .idx{ position:absolute; top:24px; right:26px; font-family:var(--f-mono); font-size:12px; color:var(--muted-2); }

/* ============================================================
   PLANOS
   ============================================================ */
.plans{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; align-items:stretch; }
.plan{
  position:relative; display:flex; flex-direction:column;
  padding:30px 26px 30px;
  background:linear-gradient(180deg,var(--card),#070f1c);
  border:1px solid var(--line); border-radius:var(--radius-lg);
  transition:transform .3s, border-color .3s;
}
.plan:hover{ transform:translateY(-4px); border-color:var(--line-2); }
.plan .tag{
  position:absolute; top:-12px; left:50%; transform:translateX(-50%);
  font-family:var(--f-mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase;
  padding:6px 14px; border-radius:999px; white-space:nowrap;
}
.plan .speed{ display:flex; align-items:baseline; gap:6px; margin-bottom:4px; }
.plan .speed b{ font-family:var(--f-display); font-weight:900; font-size:60px; line-height:.9; letter-spacing:-.02em; }
.plan .speed .u{ font-family:var(--f-display); font-weight:700; font-size:22px; color:var(--blue-2); }
.plan .speed .mb{ font-family:var(--f-mono); font-size:12px; color:var(--muted); letter-spacing:.1em; }
.plan .desc{ color:var(--muted); font-size:14.5px; min-height:42px; margin-bottom:20px; }
.plan ul{ display:flex; flex-direction:column; gap:11px; margin-bottom:26px; flex:1; }
.plan li{ display:flex; align-items:center; gap:11px; font-size:14.5px; color:#cdd9ea; }
.plan li svg{ width:16px; height:16px; color:var(--blue); flex:none; }
.plan .price{ font-family:var(--f-mono); font-size:13px; color:var(--muted); margin-bottom:18px; }
.plan .price b{ font-family:var(--f-display); font-size:30px; color:var(--white); font-weight:800; }

.plan.feature{
  border-color:rgba(0,168,255,.5);
  background:linear-gradient(180deg,#0a2036,#06101f);
  box-shadow:0 0 0 1px rgba(0,168,255,.25), 0 30px 70px -30px var(--glow), inset 0 0 60px rgba(0,168,255,.08);
  transform:scale(1.04);
  z-index:2;
}
.plan.feature:hover{ transform:scale(1.04) translateY(-4px); }
.plan.feature .tag{ background:linear-gradient(180deg,var(--blue-2),var(--blue)); color:#02101f; box-shadow:0 6px 20px -6px var(--glow); }
.plan.feature .speed b{ background:linear-gradient(120deg,var(--blue-2),var(--blue)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.plan .tag.ultra{ background:rgba(0,168,255,.12); color:var(--blue-2); border:1px solid var(--line-2); }
.plans-note{ text-align:center; margin-top:30px; font-family:var(--f-mono); font-size:12.5px; color:var(--muted-2); letter-spacing:.04em; }

/* ============================================================
   SPEED TEST
   ============================================================ */
.speed-sec .wrap{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.gauge-box{ position:relative; display:grid; place-items:center; padding:20px; }
.gauge{ width:100%; max-width:420px; }
.gauge .track{ fill:none; stroke:rgba(120,170,230,.10); stroke-width:14; stroke-linecap:round; }
.gauge .prog{ fill:none; stroke:url(#gg); stroke-width:14; stroke-linecap:round; filter:drop-shadow(0 0 8px var(--glow)); transition:stroke-dashoffset .1s linear; }
.gauge .needle{ stroke:var(--blue-2); stroke-width:3; stroke-linecap:round; }
.gauge-read{ position:absolute; top:54%; left:50%; transform:translate(-50%,-50%); text-align:center; }
.gauge-read .num{ font-family:var(--f-display); font-weight:900; font-size:72px; line-height:.9; }
.gauge-read .unit{ font-family:var(--f-mono); font-size:13px; letter-spacing:.2em; color:var(--blue-2); text-transform:uppercase; }
.gauge-read .stat{ font-family:var(--f-mono); font-size:11px; color:var(--muted-2); letter-spacing:.16em; text-transform:uppercase; margin-top:6px; min-height:14px; }
.speed-metrics{ display:flex; gap:26px; margin-top:14px; justify-content:center; }
.speed-metrics div{ text-align:center; }
.speed-metrics .v{ font-family:var(--f-display); font-weight:800; font-size:26px; }
.speed-metrics .l{ font-family:var(--f-mono); font-size:10px; letter-spacing:.16em; color:var(--muted-2); text-transform:uppercase; }

/* ============================================================
   COBERTURA
   ============================================================ */
.cover-card{
  position:relative; overflow:hidden;
  background:linear-gradient(160deg,var(--panel),#060f1d);
  border:1px solid var(--line-2); border-radius:var(--radius-lg);
  padding:64px; text-align:center;
}
.cover-card .hero-grid{ -webkit-mask-image:radial-gradient(circle at 50% 50%, #000, transparent 70%); mask-image:radial-gradient(circle at 50% 50%, #000, transparent 70%); }
.cep-form{ display:flex; gap:12px; max-width:560px; margin:30px auto 0; position:relative; z-index:2; }
.cep-form input{
  flex:1; padding:16px 20px; border-radius:999px; font-family:var(--f-body); font-size:16px;
  background:rgba(2,8,23,.7); border:1px solid var(--line-2); color:var(--text);
  transition:border-color .25s, box-shadow .25s;
}
.cep-form input::placeholder{ color:var(--muted-2); }
.cep-form input:focus{ outline:none; border-color:var(--blue); box-shadow:0 0 0 4px rgba(0,168,255,.12); }
.cep-result{ margin-top:22px; min-height:26px; font-family:var(--f-mono); font-size:14px; letter-spacing:.03em; position:relative; z-index:2; }
.cep-result.ok{ color:#3fe08a; }
.cep-result.searching{ color:var(--blue-2); }

/* ============================================================
   STREAMING
   ============================================================ */
.stream-sec{ text-align:center; }
.stream-row{ display:flex; flex-wrap:wrap; justify-content:center; gap:14px; margin-top:14px; }
.stream-chip{
  font-family:var(--f-display); font-weight:700; font-size:20px; letter-spacing:.01em;
  padding:14px 26px; border-radius:12px; color:#c4d2e6;
  background:rgba(255,255,255,.025); border:1px solid var(--line);
  transition:transform .25s, border-color .25s, color .25s;
}
.stream-chip:hover{ transform:translateY(-3px); border-color:var(--line-2); color:var(--white); }

/* ============================================================
   AREA DO CLIENTE
   ============================================================ */
.area-sec .wrap{ display:grid; grid-template-columns:1fr 1.1fr; gap:60px; align-items:center; }
.area-cards{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.area-card{
  padding:26px 24px; border-radius:var(--radius); border:1px solid var(--line);
  background:linear-gradient(180deg,var(--card),#070f1c); transition:transform .3s, border-color .3s;
}
.area-card:hover{ transform:translateY(-4px); border-color:var(--line-2); }
.area-card .ic{ width:44px; height:44px; border-radius:11px; display:grid; place-items:center; background:rgba(0,168,255,.08); border:1px solid var(--line-2); color:var(--blue-2); margin-bottom:16px; }
.area-card .ic svg{ width:22px; height:22px; }
.area-card h4{ font-family:var(--f-display); font-weight:700; font-size:19px; text-transform:uppercase; }
.area-card p{ color:var(--muted); font-size:13.5px; margin-top:4px; }

/* ============================================================
   EMPRESAS
   ============================================================ */
.emp-sec{ background:linear-gradient(180deg,transparent, rgba(10,30,60,.18), transparent); }
.emp-sec .wrap{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.emp-list{ display:flex; flex-direction:column; gap:2px; }
.emp-list li{ display:flex; align-items:center; gap:18px; padding:20px 4px; border-bottom:1px solid var(--line); }
.emp-list li .n{ font-family:var(--f-mono); font-size:12px; color:var(--blue-2); width:30px; }
.emp-list li .t{ font-family:var(--f-display); font-weight:700; font-size:22px; text-transform:uppercase; }
.emp-list li p{ color:var(--muted); font-size:14px; margin-left:auto; max-width:46%; text-align:right; }

/* ============================================================
   INSTITUCIONAL
   ============================================================ */
.inst{ text-align:center; }
.inst h2{ font-family:var(--f-display); font-weight:800; text-transform:uppercase; font-size:clamp(36px,6vw,72px); line-height:.98; letter-spacing:-.01em; }
.inst h2 .accent{ color:var(--blue-2); }
.inst p{ color:var(--muted); font-size:19px; max-width:680px; margin:26px auto 0; }
.inst-stats{ display:flex; justify-content:center; gap:64px; margin-top:56px; flex-wrap:wrap; }
.inst-stats .v{ font-family:var(--f-display); font-weight:900; font-size:54px; color:var(--white); line-height:1; font-variant-numeric:tabular-nums; }
.inst-stats .count{ display:inline-block; }
.inst-stats .v i{ color:var(--blue); font-style:normal; }
.inst-stats .l{ font-family:var(--f-mono); font-size:11px; letter-spacing:.16em; color:var(--muted); text-transform:uppercase; margin-top:8px; }

/* ============================================================
   DEPOIMENTOS
   ============================================================ */
.testi-track{ position:relative; overflow:hidden; }
.testi-rail{ display:flex; transition:transform .6s cubic-bezier(.2,.7,.2,1); }
.testi{
  flex:0 0 calc(33.333% - 16px); margin-right:24px;
  padding:32px 30px; border-radius:var(--radius);
  background:linear-gradient(180deg,var(--card),#070f1c); border:1px solid var(--line);
}
.testi .stars{ display:flex; gap:3px; color:var(--blue-2); margin-bottom:16px; }
.testi .stars svg{ width:16px; height:16px; }
.testi p{ font-size:16px; color:#d2dded; min-height:120px; }
.testi .who{ display:flex; align-items:center; gap:13px; margin-top:20px; }
.testi .av{ width:44px; height:44px; border-radius:50%; background:linear-gradient(150deg,#123, #06101f); border:1px solid var(--line-2); display:grid; place-items:center; font-family:var(--f-display); font-weight:800; color:var(--blue-2); }
.testi .who b{ font-weight:600; font-size:15px; display:block; }
.testi .who span{ font-family:var(--f-mono); font-size:11px; color:var(--muted-2); letter-spacing:.06em; }
.testi-nav{ display:flex; justify-content:space-between; align-items:center; margin-top:34px; }
.testi-dots{ display:flex; gap:9px; }
.testi-dots button{ width:9px; height:9px; border-radius:50%; background:rgba(255,255,255,.16); transition:.25s; }
.testi-dots button.active{ background:var(--blue); width:26px; border-radius:6px; }
.testi-arrows{ display:flex; gap:10px; }
.testi-arrows button{ width:46px; height:46px; border-radius:50%; border:1px solid var(--line-2); display:grid; place-items:center; transition:.25s; }
.testi-arrows button:hover{ border-color:var(--blue); background:rgba(0,168,255,.1); }
.testi-arrows svg{ width:18px; height:18px; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-sec .wrap{ display:grid; grid-template-columns:.8fr 1.2fr; gap:60px; align-items:start; }
.faq-list{ display:flex; flex-direction:column; gap:12px; }
.faq-item{ border:1px solid var(--line); border-radius:14px; background:linear-gradient(180deg,var(--card),#070f1c); overflow:hidden; transition:border-color .3s; }
.faq-item.open{ border-color:var(--line-2); }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:20px; padding:22px 26px; text-align:left; font-family:var(--f-display); font-weight:600; font-size:21px; text-transform:uppercase; letter-spacing:.005em; }
.faq-q .pm{ position:relative; width:18px; height:18px; flex:none; }
.faq-q .pm::before, .faq-q .pm::after{ content:""; position:absolute; background:var(--blue); border-radius:2px; transition:transform .3s; }
.faq-q .pm::before{ top:50%; left:0; right:0; height:2px; transform:translateY(-50%); }
.faq-q .pm::after{ left:50%; top:0; bottom:0; width:2px; transform:translateX(-50%); }
.faq-item.open .pm::after{ transform:translateX(-50%) scaleY(0); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .4s ease; }
.faq-a div{ padding:0 26px 24px; color:var(--muted); font-size:15.5px; }

/* ============================================================
   CTA FINAL
   ============================================================ */
.final{ text-align:center; padding:150px 0; position:relative; overflow:hidden; }
.final .glow{ position:absolute; left:50%; top:50%; width:900px; height:520px; transform:translate(-50%,-50%); background:radial-gradient(50% 50% at 50% 50%, rgba(0,168,255,.16), transparent 70%); z-index:0; }
.final .wrap{ position:relative; z-index:2; }
.final h2{ font-family:var(--f-display); font-weight:900; text-transform:uppercase; font-size:clamp(44px,8vw,96px); line-height:.92; letter-spacing:-.02em; }
.final h2 i{ color:var(--blue); font-style:normal; }
.final p{ color:var(--muted); font-size:20px; margin:18px 0 36px; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ border-top:1px solid var(--line); padding:72px 0 40px; background:var(--bg-2); }
.foot-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; }
.foot-brand p{ color:var(--muted); font-size:14.5px; margin-top:18px; max-width:30ch; }
.foot-social{ display:flex; gap:10px; margin-top:22px; }
.foot-social a{ width:42px; height:42px; border-radius:11px; border:1px solid var(--line-2); display:grid; place-items:center; color:var(--muted); transition:.25s; }
.foot-social a:hover{ color:var(--blue-2); border-color:var(--blue); background:rgba(0,168,255,.08); transform:translateY(-3px); }
.foot-social svg{ width:19px; height:19px; }
.foot-col h5{ font-family:var(--f-mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted-2); margin-bottom:18px; }
.foot-col a{ display:block; color:var(--muted); font-size:14.5px; padding:6px 0; transition:color .2s; }
.foot-col a:hover{ color:var(--blue-2); }
.foot-bot{ display:flex; align-items:center; justify-content:space-between; gap:20px; margin-top:56px; padding-top:28px; border-top:1px solid var(--line); flex-wrap:wrap; }
.foot-bot span{ font-family:var(--f-mono); font-size:12px; color:var(--muted-2); letter-spacing:.04em; }

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.wa-float{
  position:fixed; right:24px; bottom:24px; z-index:90;
  width:58px; height:58px; border-radius:50%;
  display:grid; place-items:center;
  background:#25D366; color:#04130a;
  box-shadow:0 12px 34px -8px rgba(37,211,102,.6);
  transition:transform .3s; animation:wapulse 2.6s ease-in-out infinite;
}
.wa-float:hover{ transform:scale(1.08); }
.wa-float svg{ width:30px; height:30px; }
@keyframes wapulse{ 0%,100%{ box-shadow:0 12px 34px -8px rgba(37,211,102,.6), 0 0 0 0 rgba(37,211,102,.4);} 50%{ box-shadow:0 12px 34px -8px rgba(37,211,102,.6), 0 0 0 14px rgba(37,211,102,0);} }

/* ============================================================
   REVEAL ON SCROLL
   ============================================================ */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1); }
.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; }
.reveal.d5{ transition-delay:.40s; }

@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; }
  .reveal{ opacity:1; transform:none; }
  .slogan-logo{ opacity:1; transform:none; filter:none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .feat-grid{ grid-template-columns:repeat(2,1fr); }
  .plans{ grid-template-columns:repeat(2,1fr); }
  .plan.feature{ transform:none; } .plan.feature:hover{ transform:translateY(-4px); }
  .testi{ flex-basis:calc(50% - 12px); }
  .foot-top{ grid-template-columns:1fr 1fr; }
}
@media (max-width:900px){
  .nav, .header-actions .desktop-only{ display:none; }
  .burger{ display:block; }
  .hero-visual{ display:none; }
  .slides{ min-height:380px; }
  .scene-tag{ display:none; }
  .speed-sec .wrap, .area-sec .wrap, .emp-sec .wrap, .faq-sec .wrap{ grid-template-columns:1fr; gap:40px; }
  .area-sec .wrap{ gap:36px; }
  .emp-list li p{ display:none; }
}
@media (max-width:620px){
  body{ font-size:16px; }
  .wrap{ padding:0 20px; }
  .section-pad{ padding:80px 0; }
  .feat-grid{ grid-template-columns:1fr; }
  .plans{ grid-template-columns:1fr; }
  .area-cards{ grid-template-columns:1fr; }
  .testi{ flex-basis:100%; margin-right:16px; }
  .cover-card{ padding:36px 22px; }
  .cep-form{ flex-direction:column; }
  .cep-form .btn{ width:100%; }
  .inst-stats{ gap:36px; }
  .foot-top{ grid-template-columns:1fr 1fr; gap:28px; }
  .slide-cta{ flex-direction:column; }
  .slide-cta .btn{ width:100%; }
  .hero-foot{ bottom:20px; }
  .scroll-cue{ display:none; }
}
