:root{
  --bg:#020814;
  --bg-2:#07111f;
  --bg-3:#0b1830;
  --surface:#0e1b35;
  --surface-2:#13274d;
  --surface-3:#1a3466;
  --glass:rgba(255,255,255,.07);
  --glass-2:rgba(255,255,255,.10);
  --glass-3:rgba(255,255,255,.14);
  --text:#f7fbff;
  --muted:#bfd0ec;
  --muted-2:#94a8cf;
  --title:#ffffff;
  --line:rgba(255,255,255,.10);
  --line-strong:rgba(255,255,255,.18);
  --primary:#62b0ff;
  --primary-2:#2563eb;
  --primary-3:#1d4ed8;
  --cyan:#22d3ee;
  --violet:#8b5cf6;
  --violet-2:#7c3aed;
  --green:#22c55e;
  --green-2:#16a34a;
  --gold:#f5b942;
  --shadow:0 34px 90px rgba(2,8,23,.56);
  --shadow-soft:0 16px 38px rgba(2,8,23,.32);
  --shadow-card:0 18px 44px rgba(2,8,23,.34);
  --glow-blue:0 0 0 1px rgba(96,165,250,.16), 0 24px 70px rgba(37,99,235,.22);
  --glow-cyan:0 0 0 1px rgba(34,211,238,.14), 0 24px 70px rgba(34,211,238,.18);
  --glow-violet:0 0 0 1px rgba(139,92,246,.16), 0 24px 70px rgba(124,58,237,.18);
  --glow-green:0 0 0 1px rgba(34,197,94,.12), 0 20px 50px rgba(34,197,94,.14);
  --radius:24px;
  --radius-lg:36px;
  --container:1240px;
}

*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  font-family:"Inter",sans-serif;
  background:
    radial-gradient(circle at 8% 0%, rgba(98,176,255,.24), transparent 28%),
    radial-gradient(circle at 92% 8%, rgba(34,211,238,.12), transparent 22%),
    radial-gradient(circle at 84% 28%, rgba(139,92,246,.10), transparent 20%),
    radial-gradient(circle at 20% 100%, rgba(34,197,94,.07), transparent 20%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 42%, var(--bg-3) 100%);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  letter-spacing:-.01em;
}

body.menu-open{
  overflow:hidden;
}

img{
  max-width:100%;
  display:block;
}

a{
  color:inherit;
  text-decoration:none;
}

button,
input,
select,
textarea{
  font:inherit;
}

.container{
  width:min(calc(100% - 32px), var(--container));
  margin:0 auto;
}

.skip-link{
  position:absolute;
  left:-9999px;
  top:auto;
}

.skip-link:focus{
  left:16px;
  top:16px;
  z-index:3000;
  background:#fff;
  color:#0f172a;
  padding:10px 14px;
  border-radius:12px;
}

#scroll-progress{
  position:fixed;
  top:0;
  left:0;
  width:0;
  height:3px;
  background:linear-gradient(90deg, var(--cyan), var(--primary), var(--violet), var(--green));
  z-index:9999;
}

.cursor-glow{
  position:fixed;
  left:0;
  top:0;
  width:320px;
  height:320px;
  border-radius:50%;
  pointer-events:none;
  z-index:0;
  opacity:.45;
  transform:translate(-50%,-50%);
  background:
    radial-gradient(circle, rgba(34,211,238,.16) 0%, rgba(98,176,255,.10) 25%, rgba(139,92,246,.08) 45%, transparent 72%);
  filter:blur(18px);
  transition:opacity .25s ease;
}

.site-loader{
  position:fixed;
  inset:0;
  background:
    radial-gradient(circle at top, rgba(98,176,255,.14), transparent 28%),
    linear-gradient(180deg, #020814 0%, #07111f 100%);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:18px;
  z-index:10000;
  transition:opacity .45s ease, visibility .45s ease;
}

.site-loader.hide{
  opacity:0;
  visibility:hidden;
}

.loader-ring{
  width:64px;
  height:64px;
  border-radius:50%;
  border:3px solid rgba(255,255,255,.12);
  border-top-color:#7dd3fc;
  animation:spin 1s linear infinite;
  box-shadow:0 0 30px rgba(34,211,238,.16);
}

.loader-text{
  color:#eaf2ff;
  font-weight:800;
  letter-spacing:.04em;
}

@keyframes spin{
  to{ transform:rotate(360deg); }
}

/* topbar */
.topbar{
  position:relative;
  z-index:10;
  background:linear-gradient(90deg, rgba(34,211,238,.14), rgba(98,176,255,.14), rgba(139,92,246,.12));
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow:0 8px 24px rgba(0,0,0,.16);
}

.topbar-inner{
  width:min(calc(100% - 32px), var(--container));
  margin:0 auto;
  min-height:48px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  color:#f4f8ff;
  font-size:.93rem;
  text-align:center;
}

.topbar-inner a{
  color:#a5f3fc;
  font-weight:800;
}

.topbar-close{
  border:none;
  background:transparent;
  color:#fff;
  cursor:pointer;
  font-size:1.1rem;
}

/* header */
.header{
  position:sticky;
  top:0;
  z-index:1000;
  width:100%;
  backdrop-filter:blur(18px);
  background:rgba(2,8,20,.56);
  border-bottom:1px solid transparent;
  transition:.28s ease;
}

.header.is-scrolled{
  background:rgba(2,8,20,.88);
  border-bottom-color:rgba(255,255,255,.08);
  box-shadow:0 14px 40px rgba(0,0,0,.24);
}

.header-inner{
  width:min(calc(100% - 32px), var(--container));
  margin:0 auto;
  min-height:88px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  flex-shrink:0;
  position:relative;
  z-index:2;
}

.brand-badge img{
  height:54px;
  width:auto;
  object-fit:contain;
  filter:drop-shadow(0 8px 20px rgba(0,0,0,.22));
}

.nav{
  display:flex;
  align-items:center;
  gap:24px;
}

.nav a{
  color:var(--text);
  font-weight:700;
  font-size:.95rem;
  opacity:.92;
  position:relative;
  transition:.2s ease;
}

.nav a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-7px;
  width:0;
  height:2px;
  border-radius:999px;
  background:linear-gradient(90deg, var(--cyan), var(--primary), var(--violet));
  transition:.25s ease;
}

.nav a:hover,
.nav a.is-active{
  opacity:1;
  color:#fff;
}

.nav a:hover::after,
.nav a.is-active::after{
  width:100%;
}

.header-ctas{
  display:flex;
  align-items:center;
  gap:12px;
}

/* botões */
.btn-outline-sm,
.btn-green-sm,
.btn-primary,
.btn-ghost-green,
.btn-ghost-white{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border-radius:999px;
  font-weight:800;
  transition:.28s ease;
  border:1px solid transparent;
  cursor:pointer;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}

.btn-outline-sm::before,
.btn-green-sm::before,
.btn-primary::before,
.btn-ghost-green::before,
.btn-ghost-white::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, rgba(255,255,255,.16), transparent 45%);
  opacity:0;
  transition:.28s ease;
  z-index:-1;
}

.btn-outline-sm:hover::before,
.btn-green-sm:hover::before,
.btn-primary:hover::before,
.btn-ghost-green:hover::before,
.btn-ghost-white:hover::before{
  opacity:1;
}

.btn-outline-sm,
.btn-green-sm{
  padding:12px 18px;
  font-size:.92rem;
}

.btn-outline-sm{
  color:#fff;
  border-color:rgba(255,255,255,.16);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  box-shadow:var(--shadow-soft);
}

.btn-outline-sm:hover{
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.06));
  transform:translateY(-1px);
}

.btn-green-sm{
  background:linear-gradient(135deg, var(--green), var(--green-2));
  color:#fff;
  box-shadow:0 14px 34px rgba(34,197,94,.28);
}

.btn-green-sm:hover{
  transform:translateY(-2px);
  box-shadow:0 20px 40px rgba(34,197,94,.34);
}

.btn-primary,
.btn-ghost-green,
.btn-ghost-white{
  padding:16px 24px;
  font-size:.98rem;
}

.btn-primary{
  background:linear-gradient(135deg, var(--primary), var(--primary-2));
  color:#fff;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 20px 46px rgba(37,99,235,.34);
}

.btn-primary:hover{
  transform:translateY(-2px) scale(1.01);
  box-shadow:0 28px 60px rgba(37,99,235,.42);
}

.btn-ghost-green{
  background:linear-gradient(180deg, rgba(34,197,94,.12), rgba(34,197,94,.06));
  border-color:rgba(34,197,94,.30);
  color:#e6fff0;
  box-shadow:var(--glow-green);
}

.btn-ghost-green:hover{
  background:linear-gradient(180deg, rgba(34,197,94,.16), rgba(34,197,94,.08));
  transform:translateY(-2px);
}

.btn-ghost-white{
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.05));
  border-color:rgba(255,255,255,.16);
  color:#fff;
  box-shadow:var(--shadow-soft);
}

.btn-ghost-white:hover{
  background:linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.08));
  transform:translateY(-2px);
}

.hamburger{
  width:48px;
  height:48px;
  border:none;
  background:rgba(255,255,255,.06);
  border-radius:14px;
  display:none;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
}

.hamburger span{
  width:20px;
  height:2px;
  background:#fff;
  border-radius:10px;
  display:block;
}

/* hero */
.hero{
  position:relative;
  padding:134px 0 110px;
  overflow:hidden;
}

.hero-tech{
  padding-top:142px;
  padding-bottom:114px;
}

.particles-canvas{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  pointer-events:none;
  z-index:0;
  opacity:.8;
}

.hero-bg{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:0;
}

.glow{
  position:absolute;
  border-radius:999px;
  filter:blur(100px);
  opacity:.8;
}

.g1{
  width:620px;
  height:620px;
  background:rgba(98,176,255,.22);
  top:-170px;
  left:-130px;
}

.g2{
  width:500px;
  height:500px;
  background:rgba(34,211,238,.10);
  right:-150px;
  top:-10px;
}

.g3{
  width:420px;
  height:420px;
  background:rgba(139,92,246,.10);
  right:18%;
  top:18%;
}

.grid-lines{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:42px 42px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.65), transparent 86%);
}

.hero-orbit{
  position:absolute;
  border-radius:999px;
  border:1px solid rgba(125,211,252,.10);
  box-shadow:0 0 80px rgba(34,211,238,.05) inset;
}

.hero-orbit-1{
  width:560px;
  height:560px;
  right:-150px;
  top:-30px;
}

.hero-orbit-2{
  width:390px;
  height:390px;
  right:-70px;
  top:60px;
}

.hero-orbit-3{
  width:220px;
  height:220px;
  right:10%;
  top:35%;
}

.hero-noise{
  position:absolute;
  inset:0;
  opacity:.06;
  background-image:radial-gradient(rgba(255,255,255,.6) .6px, transparent .6px);
  background-size:18px 18px;
  mix-blend-mode:soft-light;
}

.hero-content{
  position:relative;
  z-index:1;
  width:min(calc(100% - 32px), var(--container));
  margin:0 auto;
}

.hero-layout{
  display:grid;
  grid-template-columns:1.03fr .97fr;
  gap:36px;
  align-items:center;
}

.hero-kicker{
  color:#a5f3fc;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.79rem;
  font-weight:900;
  margin-bottom:12px;
}

.hero-badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  color:#e6f1ff;
  background:linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
  margin-bottom:18px;
  font-weight:800;
  font-size:.92rem;
  box-shadow:var(--shadow-soft);
  backdrop-filter:blur(10px);
}

.glass-pill{
  backdrop-filter:blur(14px);
}

.badge-pulse{
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--green);
  box-shadow:0 0 0 0 rgba(34,197,94,.45);
  animation:pulse 1.8s infinite;
}

@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(34,197,94,.45); }
  70%{ box-shadow:0 0 0 14px rgba(34,197,94,0); }
  100%{ box-shadow:0 0 0 0 rgba(34,197,94,0); }
}

.hero-text h1{
  font-size:clamp(3rem, 4.8vw, 5.5rem);
  line-height:.98;
  color:var(--title);
  letter-spacing:-.06em;
  margin-bottom:20px;
  max-width:11.5ch;
  text-shadow:0 12px 50px rgba(0,0,0,.30);
}

.text-gradient{
  background:linear-gradient(135deg, #ffffff 0%, #bfdbfe 26%, #7dd3fc 52%, #8b5cf6 78%, #a7f3d0 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.hero-text p{
  font-size:1.08rem;
  color:var(--muted);
  max-width:58ch;
}

.hero-btns{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:30px;
}

.hero-mini-banners{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:14px;
  margin-top:32px;
}

.mini-banner{
  border-radius:24px;
  padding:20px;
  position:relative;
  overflow:hidden;
  transition:.28s ease;
}

.neon-card{
  background:linear-gradient(180deg, rgba(255,255,255,.11), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.10);
  box-shadow:var(--shadow-soft), var(--glow-cyan);
  backdrop-filter:blur(12px);
}

.neon-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(120deg, rgba(255,255,255,.06), transparent 42%),
    radial-gradient(circle at 100% 0%, rgba(139,92,246,.08), transparent 24%);
  pointer-events:none;
}

.mini-banner:hover{
  transform:translateY(-4px);
}

.mini-banner strong{
  display:block;
  color:#fff;
  font-size:1.95rem;
  font-weight:900;
  line-height:1;
  margin-bottom:8px;
}

.mini-banner span{
  color:var(--muted);
  font-size:.94rem;
}

/* ultra pro light effect */
.light-card{
  position:relative;
  overflow:hidden;
}

.light-card::after{
  content:"";
  position:absolute;
  width:220px;
  height:220px;
  left:var(--mx, 50%);
  top:var(--my, 50%);
  transform:translate(-50%, -50%);
  background:radial-gradient(circle, rgba(255,255,255,.12), transparent 60%);
  opacity:0;
  transition:opacity .25s ease;
  pointer-events:none;
}

.light-card:hover::after{
  opacity:1;
}

.panel-light{
  position:absolute;
  inset:auto;
  width:360px;
  height:360px;
  right:-100px;
  top:-100px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(125,211,252,.12), transparent 65%);
  pointer-events:none;
}

/* painel */
.hero-visual{
  position:relative;
}

.premium-panel{
  background:
    radial-gradient(circle at top right, rgba(125,211,252,.16), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.11), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.11);
  border-radius:36px;
  padding:28px;
  box-shadow:var(--shadow), var(--glow-blue);
  backdrop-filter:blur(18px);
  position:relative;
  overflow:hidden;
  transform-style:preserve-3d;
}

.tech-panel::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(120deg, rgba(255,255,255,.06), transparent 42%),
    radial-gradient(circle at 100% 0%, rgba(34,211,238,.08), transparent 20%),
    radial-gradient(circle at 0% 100%, rgba(139,92,246,.06), transparent 24%);
  pointer-events:none;
}

.tech-panel::after{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:35px;
  border:1px solid rgba(255,255,255,.04);
  pointer-events:none;
}

.shimmer-line{
  position:absolute;
  top:0;
  left:-30%;
  width:30%;
  height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
  transform:skewX(-18deg);
  animation:shimmer 6s linear infinite;
  pointer-events:none;
}

@keyframes shimmer{
  0%{ left:-30%; }
  100%{ left:130%; }
}

.premium-panel-top{
  position:relative;
  z-index:1;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  margin-bottom:20px;
}

.panel-kicker{
  color:#a5f3fc;
  font-size:.79rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.16em;
  margin-bottom:6px;
}

.premium-panel-top h3{
  color:#fff;
  font-size:1.6rem;
  line-height:1.08;
}

.live-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#eafff2;
  font-size:.86rem;
  background:rgba(34,197,94,.12);
  border:1px solid rgba(34,197,94,.24);
  padding:8px 12px;
  border-radius:999px;
  white-space:nowrap;
  box-shadow:var(--glow-green);
}

.live-badge::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:#22c55e;
}

.premium-kpis{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}

.premium-kpi{
  padding:16px;
  border-radius:22px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
  transition:.25s ease;
}

.premium-kpi:hover{
  transform:translateY(-2px);
  box-shadow:var(--glow-blue);
}

.premium-kpi span{
  display:block;
  color:#d6e3fb;
  font-size:.9rem;
  margin-bottom:8px;
}

.premium-kpi strong{
  display:block;
  color:#fff;
  font-size:1.22rem;
  font-weight:800;
}

.premium-kpi small{
  color:#86efac;
  font-size:.84rem;
}

.premium-banner-chart{
  position:relative;
  z-index:1;
  margin-top:18px;
  padding:18px;
  border-radius:26px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
}

.banner-headline{
  color:#fff;
  font-weight:700;
  margin-bottom:14px;
}

.bars{
  display:flex;
  align-items:flex-end;
  gap:12px;
  height:156px;
}

.bar-wrap{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}

.bar{
  width:100%;
  max-width:36px;
  min-height:26px;
  border-radius:14px 14px 6px 6px;
  background:linear-gradient(180deg, #7dd3fc, #2563eb 70%, #1d4ed8 100%);
  box-shadow:0 12px 24px rgba(37,99,235,.28);
  position:relative;
  overflow:hidden;
}

.bar::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.28), transparent 45%);
}

.bar-wrap span{
  color:#9fb0d1;
  font-size:.8rem;
}

.premium-activity-banner{
  position:relative;
  z-index:1;
  margin-top:18px;
  padding:18px;
  border-radius:26px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  display:grid;
  gap:12px;
}

.activity-line{
  display:flex;
  justify-content:space-between;
  gap:12px;
  color:#e5efff;
  font-size:.92rem;
}

.activity-line small{
  color:#a5f3fc;
  white-space:nowrap;
}

.floating-badge{
  position:absolute;
  z-index:2;
  padding:10px 14px;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.12);
  color:#fff;
  font-size:.84rem;
  font-weight:800;
  box-shadow:var(--shadow-soft);
  backdrop-filter:blur(10px);
  animation:floaty 4.5s ease-in-out infinite;
}

.float-1{
  top:10%;
  right:1%;
}

.float-2{
  top:-8%;
  left:4%;
  right:auto;
  animation-delay:.8s;
}

.float-3{
  bottom:10%;
  left:-4%;
  animation-delay:1.4s;
}

@keyframes floaty{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-10px); }
}

/* sections */
.section{
  position:relative;
  padding:102px 0;
}

.section:nth-of-type(even){
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.008));
}

.section-head{
  text-align:center;
  max-width:840px;
  margin:0 auto 50px;
}

.eyebrow{
  color:#a5f3fc;
  font-weight:900;
  text-transform:uppercase;
  font-size:.78rem;
  letter-spacing:.2em;
  margin-bottom:12px;
}

.section-head h2{
  font-size:clamp(2.2rem, 3vw, 3.7rem);
  line-height:1.03;
  color:#fff;
  margin-bottom:14px;
  letter-spacing:-.03em;
  text-shadow:0 2px 20px rgba(0,0,0,.18);
}

.section-sub{
  color:var(--muted);
  font-size:1.04rem;
  max-width:68ch;
  margin-inline:auto;
}

/* banners */
.banner-stack{
  display:grid;
  gap:24px;
}

.feature-banner{
  display:grid;
  grid-template-columns:1.18fr .82fr;
  gap:26px;
  align-items:center;
  padding:40px;
  border-radius:36px;
  border:1px solid rgba(255,255,255,.11);
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
  transition:.28s ease;
  transform-style:preserve-3d;
}

.banner-tech::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(120deg, rgba(255,255,255,.06), transparent 44%),
    radial-gradient(circle at 100% 0%, rgba(34,211,238,.08), transparent 22%),
    radial-gradient(circle at 0% 100%, rgba(139,92,246,.06), transparent 24%);
  pointer-events:none;
}

.banner-blue{
  background:
    radial-gradient(circle at right top, rgba(96,165,250,.18), transparent 26%),
    linear-gradient(135deg, rgba(37,99,235,.24), rgba(255,255,255,.04));
}

.banner-green{
  background:
    radial-gradient(circle at right top, rgba(34,197,94,.16), transparent 24%),
    linear-gradient(135deg, rgba(22,163,74,.18), rgba(255,255,255,.04));
}

.banner-dark{
  background:
    radial-gradient(circle at right top, rgba(34,211,238,.10), transparent 24%),
    radial-gradient(circle at left bottom, rgba(139,92,246,.08), transparent 24%),
    linear-gradient(135deg, rgba(15,23,42,.48), rgba(255,255,255,.04));
}

.feature-banner-text,
.feature-banner-side{
  position:relative;
  z-index:1;
}

.feature-banner-text h2{
  color:#fff;
  font-size:clamp(2rem, 3vw, 3.3rem);
  line-height:1.05;
  letter-spacing:-.03em;
  margin-bottom:14px;
}

.feature-banner-text p:not(.eyebrow){
  color:var(--muted);
  font-size:1.02rem;
  max-width:58ch;
}

.banner-actions{
  margin-top:22px;
}

.feature-banner-side{
  display:flex;
  align-items:center;
  justify-content:center;
}

.chip-grid{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  justify-content:center;
}

.banner-chip{
  padding:12px 16px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.10);
  color:#fff;
  font-weight:700;
  box-shadow:var(--shadow-soft);
  backdrop-filter:blur(8px);
}

.chat-preview{
  width:100%;
  display:grid;
  gap:10px;
}

.tech-chat .chat-preview-line{
  box-shadow:var(--glow-cyan);
}

.chat-preview-line{
  padding:14px 16px;
  border-radius:18px;
  font-size:.94rem;
  max-width:100%;
  backdrop-filter:blur(8px);
}

.chat-preview-line.bot{
  background:rgba(255,255,255,.08);
  color:#eaf2ff;
}

.chat-preview-line.user{
  background:rgba(34,197,94,.18);
  color:#edfff4;
  margin-left:auto;
}

.support-metrics{
  width:100%;
  display:grid;
  gap:12px;
}

.support-box{
  padding:18px;
  border-radius:22px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow-soft);
  backdrop-filter:blur(10px);
}

.support-box strong{
  display:block;
  color:#fff;
  font-size:1.04rem;
  margin-bottom:6px;
}

.support-box span{
  color:var(--muted);
}

/* highlight */
.highlight-banner{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:24px;
  padding:38px;
  border-radius:36px;
  border:1px solid rgba(255,255,255,.11);
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
  transform-style:preserve-3d;
}

.tech-banner-glass{
  background:
    radial-gradient(circle at left top, rgba(98,176,255,.16), transparent 24%),
    radial-gradient(circle at right bottom, rgba(34,211,238,.08), transparent 20%),
    radial-gradient(circle at 70% 20%, rgba(139,92,246,.08), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
}

.tech-banner-glass::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, rgba(255,255,255,.06), transparent 42%);
  pointer-events:none;
}

.highlight-banner-left,
.highlight-banner-right{
  position:relative;
  z-index:1;
}

.highlight-banner-left h3{
  color:#fff;
  font-size:2.1rem;
  line-height:1.06;
  margin-bottom:12px;
}

.highlight-banner-left p{
  color:var(--muted);
}

.highlight-banner-right{
  display:grid;
  gap:14px;
}

.highlight-item{
  padding:18px;
  border-radius:22px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow-soft);
}

.highlight-item strong{
  display:block;
  color:#fff;
  margin-bottom:6px;
}

.highlight-item span{
  color:var(--muted);
}

/* solution banners */
.solution-banners{
  display:grid;
  gap:20px;
}

.solution-banner{
  padding:30px;
  border-radius:32px;
  background:linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.10);
  box-shadow:var(--shadow-soft);
  transition:.28s ease;
  transform-style:preserve-3d;
}

.solution-banner-head{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:18px;
}

.solution-index{
  width:52px;
  height:52px;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg, var(--cyan), var(--violet));
  color:#fff;
  font-weight:900;
  box-shadow:0 14px 28px rgba(34,211,238,.16);
}

.solution-banner-head h3{
  color:#fff;
  font-size:1.3rem;
}

.solution-banner-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

.solution-pill-card{
  display:block;
  padding:22px;
  border-radius:24px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  transition:.25s ease;
  box-shadow:var(--shadow-soft);
}

.solution-pill-card strong{
  display:block;
  color:#fff;
  margin-bottom:8px;
  font-size:1.02rem;
}

.solution-pill-card span{
  color:var(--muted);
  font-size:.95rem;
}

/* advantage */
.advantage-banner{
  display:grid;
  grid-template-columns:1.18fr .91fr .91fr;
  gap:18px;
  padding:32px;
  border-radius:36px;
  background:
    radial-gradient(circle at top left, rgba(34,211,238,.10), transparent 22%),
    radial-gradient(circle at right bottom, rgba(139,92,246,.08), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.11);
  box-shadow:var(--shadow);
  transform-style:preserve-3d;
}

.adv-col{
  padding:22px;
  border-radius:24px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow-soft);
}

.adv-main h3{
  color:#fff;
  font-size:1.6rem;
  line-height:1.06;
  margin-bottom:12px;
}

.adv-main p{
  color:var(--muted);
}

.adv-col strong{
  display:block;
  color:#fff;
  margin-bottom:10px;
  font-size:1.02rem;
}

.adv-col ul{
  list-style:none;
  display:grid;
  gap:10px;
}

.adv-col li{
  color:#dbeafe;
  padding-left:22px;
  position:relative;
}

.adv-col li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color:#a5f3fc;
  font-weight:900;
}

/* plan banners */
.plan-banner-list{
  display:grid;
  gap:20px;
}

.plan-banner{
  position:relative;
  padding:30px;
  border-radius:32px;
  background:linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.10);
  box-shadow:var(--shadow-soft);
  transition:.28s ease;
  transform-style:preserve-3d;
}

.plan-banner.featured{
  border-color:rgba(139,92,246,.24);
  background:
    radial-gradient(circle at right top, rgba(139,92,246,.12), transparent 24%),
    radial-gradient(circle at left bottom, rgba(34,211,238,.08), transparent 20%),
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  box-shadow:var(--shadow), 0 0 0 1px rgba(139,92,246,.08);
}

.featured-mark{
  position:absolute;
  top:18px;
  right:18px;
  background:rgba(139,92,246,.14);
  color:#ede9fe;
  border:1px solid rgba(139,92,246,.24);
  border-radius:999px;
  padding:8px 12px;
  font-size:.8rem;
  font-weight:800;
}

.plan-banner-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  margin-bottom:14px;
}

.plan-label{
  display:inline-block;
  color:#a5f3fc;
  font-size:.8rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.16em;
  margin-bottom:6px;
}

.plan-banner-top h3{
  color:#fff;
  font-size:1.72rem;
  line-height:1.05;
}

.plan-price-box{
  white-space:nowrap;
  padding:12px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  color:#fff;
  font-weight:800;
  box-shadow:var(--shadow-soft);
}

.plan-banner p{
  color:var(--muted);
  margin-bottom:18px;
}

.plan-tag-list{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:22px;
}

.plan-tag-list span{
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  color:#dbeafe;
  font-size:.92rem;
  font-weight:600;
}

/* faq */
.faq-grid{
  display:grid;
  gap:18px;
}

.faq-item{
  overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.10);
  border-radius:26px;
  box-shadow:var(--shadow-soft);
  transition:.25s ease;
}

.faq-item.active{
  box-shadow:var(--glow-cyan);
}

.faq-q{
  width:100%;
  border:none;
  background:transparent;
  color:#fff;
  text-align:left;
  padding:22px 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  cursor:pointer;
  font-weight:800;
  font-size:1rem;
}

.faq-icon{
  font-style:normal;
  font-size:1.3rem;
  color:#a5f3fc;
  transition:.25s ease;
}

.faq-a{
  max-height:0;
  overflow:hidden;
  padding:0 24px;
  transition:max-height .35s ease, padding .35s ease;
}

.faq-a p{
  color:var(--muted);
  font-size:.98rem;
  padding-bottom:22px;
}

.faq-item.active .faq-a{
  max-height:220px;
  padding:0 24px;
}

.faq-item.active .faq-icon{
  transform:rotate(45deg);
}

/* contato */
.contact-banner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  padding:38px;
  border-radius:36px;
  border:1px solid rgba(255,255,255,.11);
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
  transform-style:preserve-3d;
}

.tech-contact-banner{
  background:
    radial-gradient(circle at top left, rgba(98,176,255,.16), transparent 26%),
    radial-gradient(circle at bottom right, rgba(34,211,238,.10), transparent 24%),
    radial-gradient(circle at 70% 20%, rgba(139,92,246,.08), transparent 22%),
    linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
}

.tech-contact-banner::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, rgba(255,255,255,.06), transparent 42%);
  pointer-events:none;
}

.contact-banner-text,
.contact-banner-form{
  position:relative;
  z-index:1;
}

.contact-banner-text h2{
  color:#fff;
  font-size:clamp(2rem, 3vw, 3.3rem);
  line-height:1.04;
  margin-bottom:14px;
  letter-spacing:-.03em;
}

.contact-banner-text p{
  color:var(--muted);
  max-width:58ch;
}

.contact-inline-list{
  display:grid;
  gap:12px;
  margin-top:24px;
}

.contact-inline-list a,
.contact-inline-list span{
  color:#dbeafe;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow-soft);
}

.contact-banner-form{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:28px;
  padding:24px;
  box-shadow:var(--shadow-soft);
  backdrop-filter:blur(12px);
}

/* form */
form{
  width:100%;
}

.form-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:16px;
}

.form-group{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.form-group.full{
  grid-column:1 / -1;
}

label{
  color:#eef4ff;
  font-weight:700;
  font-size:.94rem;
}

input,
select,
textarea{
  width:100%;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.07);
  color:#fff;
  padding:15px 16px;
  outline:none;
  transition:.2s ease;
}

input::placeholder,
textarea::placeholder{
  color:#9eb0cf;
}

input:focus,
select:focus,
textarea:focus{
  border-color:rgba(96,165,250,.45);
  box-shadow:0 0 0 4px rgba(37,99,235,.12);
}

textarea{
  min-height:140px;
  resize:vertical;
}

.form-feedback{
  min-height:22px;
  color:#a7f3d0;
  font-size:.92rem;
  font-weight:700;
}

/* paginas internas */
.inner-hero{
  padding:178px 0 86px;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 18% 16%, rgba(34,211,238,.16), transparent 26%),
    radial-gradient(circle at 84% 12%, rgba(139,92,246,.13), transparent 24%),
    linear-gradient(180deg, rgba(15,23,42,.98), rgba(2,8,23,.96));
}

.inner-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size:52px 52px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.85), transparent);
  pointer-events:none;
}

.inner-hero .container,
.content-grid,
.legal-content{
  position:relative;
  z-index:1;
}

.inner-hero h1{
  max-width:980px;
  color:#fff;
  font-size:clamp(2.4rem, 5vw, 5.2rem);
  line-height:1;
  letter-spacing:-.04em;
  margin:14px 0 18px;
}

.inner-hero p{
  color:var(--muted);
  max-width:760px;
  font-size:1.08rem;
}

.content-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.15fr) minmax(280px, .85fr);
  gap:24px;
  align-items:start;
}

.content-panel{
  padding:30px;
  border-radius:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.09);
  box-shadow:var(--shadow-soft);
}

.content-panel h2,
.content-panel h3,
.legal-content h2{
  color:#fff;
  margin-bottom:14px;
}

.content-panel p,
.content-panel li,
.legal-content p,
.legal-content li{
  color:var(--muted);
}

.content-panel ul,
.legal-content ul{
  display:grid;
  gap:10px;
  padding-left:20px;
}

.content-panel + .content-panel{
  margin-top:20px;
}

.side-cta{
  position:sticky;
  top:110px;
}

.side-cta .btn-primary,
.side-cta .btn-ghost-white{
  width:100%;
  justify-content:center;
  margin-top:12px;
}

.legal-content{
  max-width:920px;
  display:grid;
  gap:22px;
}

/* featured links */
.links-featured{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:30px;
}

.featured-link{
  display:block;
  padding:26px;
  border-radius:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.09);
  color:#fff;
  font-weight:800;
  transition:.28s ease;
  box-shadow:var(--shadow-soft);
  position:relative;
  overflow:hidden;
  backdrop-filter:blur(10px);
}

.featured-link::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(120deg, rgba(255,255,255,.06), transparent 44%),
    radial-gradient(circle at 100% 0%, rgba(34,211,238,.08), transparent 24%),
    radial-gradient(circle at 0% 100%, rgba(139,92,246,.06), transparent 22%);
  pointer-events:none;
}

.featured-link:hover{
  transform:translateY(-4px);
  border-color:rgba(125,211,252,.28);
  box-shadow:0 26px 56px rgba(2,8,23,.38);
}

/* footer */
.footer{
  padding:92px 0 34px;
  position:relative;
}

.footer::before{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:180px;
  background:linear-gradient(180deg, transparent, rgba(34,211,238,.04));
  pointer-events:none;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr 1fr;
  gap:24px;
}

.footer-brand,
.footer-col{
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.08);
  border-radius:26px;
  padding:24px;
  box-shadow:var(--shadow-soft);
  backdrop-filter:blur(12px);
}

.footer-by{
  color:#fff;
  font-size:1.14rem;
  font-weight:900;
  margin-bottom:14px;
}

.footer-contacts{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.footer-col h4{
  color:#fff;
  margin-bottom:14px;
}

.footer-col ul{
  list-style:none;
  display:grid;
  gap:10px;
}

.footer-col a,
.footer-contacts a{
  color:var(--muted);
  transition:.2s ease;
}

.footer-col a:hover,
.footer-contacts a:hover{
  color:#fff;
}

.footer-bottom{
  margin-top:24px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.08);
  text-align:center;
}

.footer-copy{
  color:#b8c6e2;
}

/* whatsapp */
.wa-float{
  position:fixed;
  right:18px;
  bottom:18px;
  width:66px;
  height:66px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--green), var(--green-2));
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 20px 36px rgba(16,185,129,.30);
  z-index:999;
  transition:.25s ease;
}

.wa-float:hover{
  transform:translateY(-3px) scale(1.03);
}

.wa-float-tooltip{
  position:absolute;
  right:76px;
  white-space:nowrap;
  background:#0f172a;
  color:#fff;
  padding:10px 12px;
  border-radius:12px;
  font-size:.86rem;
  opacity:0;
  pointer-events:none;
  transform:translateY(4px);
  transition:.2s ease;
  border:1px solid rgba(255,255,255,.08);
}

.wa-float:hover .wa-float-tooltip{
  opacity:1;
  transform:translateY(0);
}

/* reveal */
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .7s ease, transform .7s ease;
}

.reveal.revealed{
  opacity:1;
  transform:none;
}

.reveal-soft{
  opacity:0;
  transform:translateY(16px);
  transition:opacity .6s ease, transform .6s ease;
}

.reveal-soft.revealed{
  opacity:1;
  transform:none;
}

/* hover geral */
.feature-banner:hover,
.highlight-banner:hover,
.solution-banner:hover,
.advantage-banner:hover,
.plan-banner:hover,
.solution-pill-card:hover,
.featured-link:hover{
  transform:translateY(-4px);
  border-color:rgba(191,219,254,.20);
  box-shadow:0 28px 60px rgba(2,8,23,.40);
}

.magnetic,
.tilt-card{
  will-change:transform;
}

p a{
  color:#bfdbfe;
}

p a:hover{
  color:#fff;
}

/* responsivo */
@media (max-width:1140px){
  .hero-layout,
  .feature-banner,
  .highlight-banner,
  .content-grid,
  .contact-banner{
    grid-template-columns:1fr;
  }

  .side-cta{
    position:relative;
    top:auto;
  }

  .premium-kpis,
  .solution-banner-grid,
  .links-featured{
    grid-template-columns:1fr;
  }

  .footer-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .advantage-banner{
    grid-template-columns:1fr;
  }

  .floating-badge{
    display:none;
  }
}

@media (max-width:920px){
  .cursor-glow,
  .particles-canvas{
    display:none;
  }

  .nav{
    position:fixed;
    top:86px;
    left:16px;
    right:16px;
    background:rgba(2,8,20,.98);
    border:1px solid rgba(255,255,255,.08);
    border-radius:24px;
    padding:18px;
    display:none;
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
    box-shadow:var(--shadow);
  }

  .nav.nav-open{
    display:flex;
  }

  .header-ctas{
    display:none;
  }

  .hamburger{
    display:flex;
  }

  .hero-mini-banners,
  .form-grid{
    grid-template-columns:1fr;
  }

  .plan-banner-top{
    flex-direction:column;
    align-items:flex-start;
  }

  .featured-mark{
    position:static;
    display:inline-flex;
    margin-bottom:14px;
  }

  .light-card::after{
    display:none;
  }
}

@media (max-width:640px){
  .topbar-inner{
    padding:10px 0;
    min-height:auto;
    font-size:.84rem;
    flex-wrap:wrap;
  }

  .header-inner{
    min-height:78px;
  }

  .brand-badge img{
    height:42px;
  }

  .hero{
    padding:108px 0 72px;
  }

  .inner-hero{
    padding:128px 0 64px;
  }

  .section{
    padding:76px 0;
  }

  .feature-banner,
  .highlight-banner,
  .solution-banner,
  .plan-banner,
  .contact-banner,
  .contact-banner-form,
  .content-panel,
  .premium-panel{
    padding:22px;
  }

  .hero-btns,
  .banner-actions{
    flex-direction:column;
  }

  .btn-primary,
  .btn-ghost-green,
  .btn-ghost-white{
    width:100%;
  }

  .bars{
    gap:8px;
    height:120px;
  }

  .wa-float{
    width:58px;
    height:58px;
    right:14px;
    bottom:14px;
  }

  .wa-float-tooltip{
    display:none;
  }

  .footer-grid{
    grid-template-columns:1fr;
  }
}
