/* ============================================================
   ZAPLYX — Design System
   Dark, premium, 2026. Brand DNA: WhatsApp-green bubble,
   green→cyan→electric-blue gradient accent.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=Manrope:wght@400;500;600;700&display=swap');

:root{
  /* surfaces */
  --bg:        #060D1A;
  --bg-2:      #08111F;
  --elev:      #0C1830;
  --elev-2:    #0F2040;
  --glass:     rgba(255,255,255,.045);
  --glass-2:   rgba(255,255,255,.07);

  /* ink */
  --ink:       #EDF2FF;
  --ink-dim:   #8FA8CC;
  --ink-faint: #4F6A90;

  /* lines */
  --line:        rgba(11,97,255,.18);
  --line-strong: rgba(11,97,255,.34);

  /* brand */
  --green:   #25D366;
  --green-d: #1AAE54;
  --mint:    #5CF29A;
  --teal:    #00C2B2;
  --blue:    #0b61ff;
  --blue-d:  #0052d4;
  --glow:    #2BE57E;

  --grad: linear-gradient(118deg, #25D366 0%, #00C2B2 46%, #0b61ff 100%);
  --grad-soft: linear-gradient(118deg, #25D366 0%, #00C2B2 50%, #0b61ff 100%);

  /* type */
  --display: 'Sora', system-ui, sans-serif;
  --body: 'Manrope', system-ui, sans-serif;

  /* radii */
  --r-xs: 10px; --r-sm: 14px; --r: 20px; --r-lg: 28px; --r-xl: 38px; --pill: 999px;

  /* layout */
  --maxw: 1200px;
  --gutter: clamp(20px, 5vw, 64px);

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  font-size:17px;
}
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; }
::selection{ background:rgba(43,229,126,.28); color:#fff; }

/* ---- ambient page glow ---- */
.page-bg{ position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden; }
.page-bg .orb{ position:absolute; border-radius:50%; filter:blur(90px); opacity:.5; }
.page-bg .o1{ width:620px;height:620px; top:-180px; left:-120px; background:radial-gradient(circle,#1FAE58,transparent 70%); }
.page-bg .o2{ width:520px;height:520px; top:36%; right:-160px; background:radial-gradient(circle,#0b61ff,transparent 70%); opacity:.28; }
.page-bg .o3{ width:480px;height:480px; bottom:-160px; left:30%; background:radial-gradient(circle,#00C2B2,transparent 70%); opacity:.25; }
.grain{ position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

/* ---- layout helpers ---- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); position:relative; z-index:2; }
section{ position:relative; z-index:2; }
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--display); font-weight:600; font-size:13px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--mint);
}
.eyebrow::before{ content:''; width:22px; height:1.5px; background:linear-gradient(90deg,var(--mint),transparent); }
.eyebrow.center::after{ content:''; width:22px; height:1.5px; background:linear-gradient(90deg,transparent,var(--mint)); }
.eyebrow.center{ justify-content:center; }

h1,h2,h3,h4{ font-family:var(--display); font-weight:700; line-height:1.05; letter-spacing:-.02em; }
.h-sec{ font-size:clamp(30px,4.4vw,52px); font-weight:700; letter-spacing:-.03em; }
.lead{ color:var(--ink-dim); font-size:clamp(16px,1.7vw,19px); line-height:1.65; max-width:62ch; }
.grad-text{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.center{ text-align:center; }
.sec-head{ max-width:760px; }
.sec-head.mx{ margin-inline:auto; }

/* ---- buttons ---- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--display); font-weight:600; font-size:15px;
  padding:14px 24px; border-radius:var(--pill); position:relative;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), background .3s;
  white-space:nowrap;
}
.btn svg{ width:17px; height:17px; }
.btn-primary{ background:var(--grad); color:#04140B; box-shadow:0 8px 30px -8px rgba(37,211,102,.6), inset 0 1px 0 rgba(255,255,255,.3); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 14px 40px -8px rgba(37,211,102,.7), inset 0 1px 0 rgba(255,255,255,.35); }
.btn-ghost{ background:var(--glass); color:var(--ink); border:1px solid var(--line-strong); backdrop-filter:blur(8px); }
.btn-ghost:hover{ background:var(--glass-2); transform:translateY(-2px); border-color:var(--mint); }
.btn-lg{ padding:17px 30px; font-size:16px; }
.btn-block{ width:100%; }

/* generic glass card */
.card{
  background:linear-gradient(170deg, var(--glass-2), var(--glass));
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  backdrop-filter:blur(14px);
}

/* =============================================================
   NAV
   ============================================================= */
.nav{ position:fixed; top:0; left:0; right:0; z-index:50; transition:all .4s var(--ease); }
.nav-inner{
  max-width:1280px; margin-inline:auto; margin-top:16px;
  display:flex; align-items:center; gap:18px;
  padding:11px 14px 11px 20px;
  border-radius:var(--pill);
  border:1px solid transparent;
  transition:all .4s var(--ease);
}
.nav.scrolled .nav-inner{
  background:rgba(8,18,13,.72); backdrop-filter:blur(18px) saturate(160%);
  border-color:var(--line); box-shadow:0 10px 40px -16px rgba(0,0,0,.7);
}
.brand{ display:flex; align-items:center; gap:10px; font-family:var(--display); font-weight:700; font-size:21px; letter-spacing:-.02em; }
.brand img{ width:34px; height:34px; filter:drop-shadow(0 4px 10px rgba(37,211,102,.4)); }
.brand .x{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.nav-links{ display:flex; gap:4px; margin-left:auto; }
.nav-links a{ font-size:14.5px; font-weight:500; color:var(--ink-dim); padding:9px 14px; border-radius:var(--pill); transition:all .25s; position:relative; }
.nav-links a:hover{ color:var(--ink); background:var(--glass); }
.nav-cta{ display:flex; align-items:center; gap:10px; }
.nav-cta .link{ font-size:14.5px; font-weight:600; color:var(--ink); padding:9px 12px; display:flex; align-items:center; gap:7px; }
.nav-cta .link:hover{ color:var(--mint); }
.burger{ display:none; width:42px; height:42px; border-radius:12px; border:1px solid var(--line); align-items:center; justify-content:center; }
.burger span{ display:block; width:18px; height:2px; background:var(--ink); position:relative; transition:.3s; }
.burger span::before,.burger span::after{ content:''; position:absolute; left:0; width:18px; height:2px; background:var(--ink); transition:.3s; }
.burger span::before{ top:-6px; } .burger span::after{ top:6px; }

/* mobile menu */
.mobile-menu{ position:fixed; inset:0; z-index:49; background:rgba(6,13,10,.96); backdrop-filter:blur(20px);
  display:flex; flex-direction:column; padding:100px var(--gutter) 40px; gap:6px;
  opacity:0; pointer-events:none; transform:translateY(-12px); transition:.4s var(--ease); }
.mobile-menu.open{ opacity:1; pointer-events:auto; transform:none; }
.mobile-menu a{ font-family:var(--display); font-size:24px; font-weight:600; padding:14px 0; border-bottom:1px solid var(--line); }
.mobile-menu .btn{ margin-top:24px; }

/* =============================================================
   HERO
   ============================================================= */
.hero{ position:relative; padding:132px 0 80px; min-height:100vh; display:flex; align-items:center; overflow:hidden; }
#hero-canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:1; opacity:.95; }
.hero-grid{ display:grid; grid-template-columns:1.06fr .94fr; gap:clamp(30px,4vw,68px); align-items:center; }
.hero-copy{ position:relative; z-index:3; max-width:600px; }
.badge{
  display:inline-flex; align-items:center; gap:9px; padding:7px 15px 7px 9px; border-radius:var(--pill);
  background:var(--glass); border:1px solid var(--line-strong); backdrop-filter:blur(8px);
  font-size:13.5px; font-weight:600; color:var(--ink-dim); margin-bottom:26px;
}
.badge .dot{ width:22px; height:22px; border-radius:50%; background:var(--grad); display:grid; place-items:center; }
.badge .dot svg{ width:13px; height:13px; }
.badge b{ color:var(--ink); font-weight:600; }
.hero h1{ font-size:clamp(29px,3.4vw,44px); font-weight:800; letter-spacing:-.03em; line-height:1.08; margin-bottom:20px; }
.hero h1 .grad-text{ display:inline; }
.hero .lead{ font-size:clamp(16px,1.6vw,18.5px); margin-bottom:30px; }
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:32px; }
.social-proof{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.avatars{ display:flex; }
.avatars .av{ width:40px; height:40px; border-radius:50%; border:2px solid var(--bg-2); margin-left:-12px; display:grid; place-items:center;
  font-family:var(--display); font-weight:700; font-size:15px; color:#04140B; }
.avatars .av:first-child{ margin-left:0; }
.proof-text .stars{ color:#FFC83D; font-size:14px; letter-spacing:2px; }
.proof-text small{ display:block; color:var(--ink-dim); font-size:13.5px; font-weight:600; margin-top:2px; }

/* floating chat card in hero */
.hero-visual{ position:relative; z-index:3; perspective:1400px; }
.chat-card{
  position:relative; border-radius:26px; overflow:hidden;
  background:linear-gradient(165deg,#0E1B14,#0A140F);
  border:1px solid var(--line-strong);
  box-shadow:0 40px 90px -30px rgba(0,0,0,.8), 0 0 0 1px rgba(255,255,255,.03), inset 0 1px 0 rgba(255,255,255,.06);
  transform:rotateY(-9deg) rotateX(4deg);
  transition:transform .6s var(--ease-out);
  will-change:transform;
}
.chat-head{ display:flex; align-items:center; gap:12px; padding:16px 18px; background:rgba(37,211,102,.08); border-bottom:1px solid var(--line); }
.chat-head .ava{ width:42px; height:42px; border-radius:50%; background:var(--grad); display:grid; place-items:center; }
.chat-head .ava img{ width:26px; height:26px; }
.chat-head h4{ font-size:15px; font-weight:700; }
.chat-head .status{ font-size:12px; color:var(--mint); display:flex; align-items:center; gap:6px; }
.chat-head .status::before{ content:''; width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 8px var(--green); }
.chat-head .menu{ margin-left:auto; color:var(--ink-faint); }
.chat-body{ padding:20px 18px; display:flex; flex-direction:column; gap:12px; min-height:300px;
  background-image:radial-gradient(rgba(255,255,255,.018) 1px, transparent 1px); background-size:18px 18px; }
.chat-day{ align-self:center; font-size:11px; color:var(--ink-faint); background:var(--glass); padding:4px 12px; border-radius:var(--pill); }
.bubble{ max-width:78%; padding:11px 15px; font-size:14.5px; line-height:1.45; border-radius:16px; position:relative; }
.bubble .t{ font-size:10px; color:var(--ink-faint); margin-top:5px; display:block; text-align:right; }
.bubble.in{ align-self:flex-start; background:var(--elev-2); border-bottom-left-radius:5px; }
.bubble.out{ align-self:flex-end; background:linear-gradient(135deg,#1FAE58,#15936f); color:#EAFBF0; border-bottom-right-radius:5px; }
.bubble.out .t{ color:rgba(255,255,255,.6); }
.bubble.bot{ align-self:flex-start; border-bottom-left-radius:5px;
  background:linear-gradient(135deg, rgba(110,108,242,.16), rgba(18,183,166,.14)); border:1px solid var(--line); }
.bubble.bot .tag{ font-size:10px; font-weight:700; color:var(--mint); display:flex; align-items:center; gap:5px; margin-bottom:4px; text-transform:uppercase; letter-spacing:.06em; }
.chat-input{ display:flex; align-items:center; gap:10px; padding:12px 16px; border-top:1px solid var(--line); background:rgba(0,0,0,.2); }
.chat-input .field{ flex:1; color:var(--ink-faint); font-size:13.5px; }
.chat-input .send{ width:36px; height:36px; border-radius:50%; background:var(--grad); display:grid; place-items:center; }
.chat-input .send svg{ width:16px; height:16px; }
.typing{ display:inline-flex; gap:4px; padding:13px 16px; align-self:flex-start; background:var(--elev-2); border-radius:16px; border-bottom-left-radius:5px; }
.typing i{ width:7px; height:7px; border-radius:50%; background:var(--ink-faint); animation:typing 1.3s infinite; }
.typing i:nth-child(2){ animation-delay:.2s; } .typing i:nth-child(3){ animation-delay:.4s; }
@keyframes typing{ 0%,60%,100%{ transform:translateY(0); opacity:.5; } 30%{ transform:translateY(-5px); opacity:1; } }

/* floating mini stats around card */
.float-chip{ position:absolute; z-index:4; display:flex; align-items:center; gap:10px; padding:11px 15px;
  background:rgba(12,24,18,.86); border:1px solid var(--line-strong); border-radius:16px; backdrop-filter:blur(12px);
  box-shadow:0 16px 40px -16px rgba(0,0,0,.7); }
.float-chip .ic{ width:34px; height:34px; border-radius:10px; display:grid; place-items:center; font-size:17px; }
.float-chip .v{ font-family:var(--display); font-weight:800; font-size:17px; line-height:1; }
.float-chip .l{ font-size:11px; color:var(--ink-dim); }
.fc-1{ top:-22px; left:-30px; animation:floaty 5s ease-in-out infinite; }
.fc-2{ bottom:36px; right:-34px; animation:floaty 6s ease-in-out infinite .8s; }
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }

.hero-logos{ margin-top:70px; text-align:center; }
.hero-logos p{ font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:18px; }
.logo-row{ display:flex; flex-wrap:wrap; justify-content:center; gap:14px 44px; opacity:.6; }
.logo-row span{ font-family:var(--display); font-weight:700; font-size:20px; color:var(--ink-dim); letter-spacing:-.02em; }

/* =============================================================
   GENERIC SECTION SPACING
   ============================================================= */
.section{ padding:clamp(80px,11vh,140px) 0; }
.section-head{ margin-bottom:56px; }

/* =============================================================
   FEATURES
   ============================================================= */
.feature-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.feature{
  padding:30px; border-radius:var(--r-lg); position:relative; overflow:hidden;
  background:linear-gradient(170deg, var(--glass-2), rgba(255,255,255,.02));
  border:1px solid var(--line); transition:transform .4s var(--ease), border-color .4s, box-shadow .4s;
  transform-style:preserve-3d;
}
.feature::before{ content:''; position:absolute; inset:0; border-radius:inherit; padding:1px;
  background:var(--grad); -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:0; transition:opacity .4s; }
.feature:hover{ transform:translateY(-6px); box-shadow:0 30px 60px -30px rgba(0,0,0,.7); }
.feature:hover::before{ opacity:.7; }
.feature .ic{ width:54px; height:54px; border-radius:15px; display:grid; place-items:center; font-size:25px; margin-bottom:20px;
  background:linear-gradient(135deg, rgba(37,211,102,.18), rgba(110,108,242,.14)); border:1px solid var(--line-strong); }
.feature h3{ font-size:21px; margin-bottom:10px; }
.feature p{ color:var(--ink-dim); font-size:15px; margin-bottom:18px; }
.feature ul{ list-style:none; display:flex; flex-direction:column; gap:9px; margin-bottom:20px; }
.feature li{ display:flex; align-items:flex-start; gap:10px; font-size:14px; color:var(--ink); }
.feature li svg{ width:18px; height:18px; flex-shrink:0; margin-top:1px; color:var(--mint); }
.feature .more{ font-family:var(--display); font-weight:600; font-size:14px; color:var(--mint); display:inline-flex; align-items:center; gap:6px; transition:gap .3s; }
.feature:hover .more{ gap:11px; }

/* =============================================================
   STEPS
   ============================================================= */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; position:relative; }
.steps::before{ content:''; position:absolute; top:38px; left:14%; right:14%; height:1px;
  background:linear-gradient(90deg,transparent,var(--line-strong),transparent); }
.step{ position:relative; text-align:left; }
.step .num{ width:76px; height:76px; border-radius:22px; display:grid; place-items:center; font-family:var(--display); font-weight:800; font-size:30px;
  background:var(--bg-2); border:1px solid var(--line-strong); color:var(--mint); margin-bottom:24px; position:relative; }
.step .num::after{ content:''; position:absolute; inset:-1px; border-radius:inherit; background:var(--grad); opacity:.14; }
.step h3{ font-size:22px; margin-bottom:12px; }
.step p{ color:var(--ink-dim); font-size:15px; }

/* =============================================================
   DEMO (live chat "video")
   ============================================================= */
.demo-grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:48px; align-items:center; }
.demo-points{ display:flex; flex-direction:column; gap:8px; margin-top:34px; }
.demo-point{ display:flex; gap:16px; padding:18px; border-radius:var(--r); transition:background .3s; }
.demo-point:hover{ background:var(--glass); }
.demo-point .ic{ width:46px; height:46px; flex-shrink:0; border-radius:13px; display:grid; place-items:center; font-size:21px;
  background:linear-gradient(135deg, rgba(37,211,102,.16), rgba(110,108,242,.12)); border:1px solid var(--line); }
.demo-point h4{ font-size:17px; margin-bottom:5px; }
.demo-point p{ color:var(--ink-dim); font-size:14.5px; }
.demo-stage{ position:relative; perspective:1500px; }
.replay{ position:absolute; bottom:-14px; left:50%; transform:translateX(-50%); z-index:6;
  display:inline-flex; align-items:center; gap:8px; padding:9px 18px; border-radius:var(--pill);
  background:rgba(12,24,18,.9); border:1px solid var(--line-strong); backdrop-filter:blur(10px);
  font-family:var(--display); font-size:13px; font-weight:600; color:var(--ink-dim); opacity:0; transition:.3s; }
.demo-stage.done .replay{ opacity:1; }
.replay:hover{ color:var(--mint); border-color:var(--mint); }

/* =============================================================
   CASES
   ============================================================= */
.case-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.case{ padding:30px; border-radius:var(--r-lg); background:linear-gradient(170deg, var(--glass-2), rgba(255,255,255,.02));
  border:1px solid var(--line); transition:transform .4s var(--ease), border-color .4s; overflow:hidden; position:relative; }
.case:hover{ transform:translateY(-6px); border-color:var(--line-strong); }
.case .tag{ font-size:12px; font-weight:600; color:var(--ink-dim); margin-bottom:18px; }
.case .stat{ font-family:var(--display); font-weight:800; font-size:40px; letter-spacing:-.03em; margin-bottom:6px; }
.case h3{ font-size:19px; margin-bottom:12px; }
.case p{ color:var(--ink-dim); font-size:14.5px; }
.case .ribbon{ position:absolute; top:24px; right:-2px; width:54px; height:54px; opacity:.12; }

/* =============================================================
   TESTIMONIALS (marquee)
   ============================================================= */
.marquee{ overflow:hidden; position:relative; -webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee-track{ display:flex; gap:20px; width:max-content; animation:marquee 48s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
@keyframes marquee{ to{ transform:translateX(-50%); } }
.tcard{ width:380px; flex-shrink:0; padding:28px; border-radius:var(--r-lg); background:linear-gradient(170deg, var(--glass-2), rgba(255,255,255,.02)); border:1px solid var(--line); }
.tcard .stars{ color:#FFC83D; letter-spacing:2px; font-size:14px; margin-bottom:14px; }
.tcard p{ font-size:15.5px; line-height:1.6; margin-bottom:20px; }
.tcard .who{ display:flex; align-items:center; gap:12px; }
.tcard .who .ava{ width:44px; height:44px; border-radius:50%; background:var(--grad); display:grid; place-items:center; font-family:var(--display); font-weight:700; color:#04140B; }
.tcard .who h5{ font-size:15px; font-weight:700; }
.tcard .who small{ color:var(--ink-dim); font-size:13px; }

/* =============================================================
   BLOG
   ============================================================= */
.blog-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.post{ display:grid; grid-template-columns:auto 1fr; gap:0; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line);
  background:linear-gradient(170deg, var(--glass-2), rgba(255,255,255,.02)); transition:transform .4s var(--ease), border-color .4s; }
.post:hover{ transform:translateY(-5px); border-color:var(--line-strong); }
.post .thumb{ width:130px; background:var(--grad); display:grid; place-items:center; font-size:42px; position:relative; overflow:hidden; }
.post .thumb::after{ content:''; position:absolute; inset:0; background:linear-gradient(135deg,transparent,rgba(0,0,0,.3)); }
.post .pbody{ padding:26px; }
.post .ptag{ display:inline-block; font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--mint); margin-bottom:12px; }
.post h3{ font-size:19px; line-height:1.25; margin-bottom:10px; }
.post p{ color:var(--ink-dim); font-size:14px; margin-bottom:16px; }
.post .more{ font-family:var(--display); font-weight:600; font-size:13.5px; color:var(--mint); display:inline-flex; gap:6px; }

/* =============================================================
   PRICING
   ============================================================= */
.price-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; align-items:stretch; }
.plan{ display:flex; flex-direction:column; padding:34px 28px; border-radius:var(--r-lg); position:relative;
  background:linear-gradient(170deg, var(--glass-2), rgba(255,255,255,.02)); border:1px solid var(--line); transition:transform .4s var(--ease); }
.plan.popular{ border-color:transparent; background:linear-gradient(170deg, rgba(37,211,102,.1), rgba(110,108,242,.06)); transform:scale(1.03); z-index:2; }
.plan.popular::before{ content:''; position:absolute; inset:0; border-radius:inherit; padding:1.5px; background:var(--grad);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; }
.plan:hover{ transform:translateY(-6px); } .plan.popular:hover{ transform:scale(1.03) translateY(-6px); }
.pop-tag{ position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--grad); color:#04140B;
  font-family:var(--display); font-weight:700; font-size:12px; padding:6px 16px; border-radius:var(--pill); box-shadow:0 8px 20px -6px rgba(37,211,102,.6); }
.plan .pname{ font-family:var(--display); font-weight:700; font-size:21px; margin-bottom:6px; }
.plan .pdesc{ color:var(--ink-dim); font-size:13.5px; min-height:42px; margin-bottom:18px; }
.plan .pprice{ display:flex; align-items:flex-end; gap:4px; margin-bottom:4px; }
.plan .pprice .cur{ font-size:18px; font-weight:600; color:var(--ink-dim); margin-bottom:8px; }
.plan .pprice .amt{ font-family:var(--display); font-weight:800; font-size:48px; letter-spacing:-.03em; line-height:1; }
.plan .pprice .per{ color:var(--ink-dim); font-size:14px; margin-bottom:8px; }
.plan .pprice .custom{ font-family:var(--display); font-weight:800; font-size:32px; }
.plan .btn{ margin:22px 0; }
.plan .feats{ list-style:none; display:flex; flex-direction:column; gap:13px; border-top:1px solid var(--line); padding-top:22px; }
.plan .feats li{ display:flex; gap:11px; font-size:13.5px; }
.plan .feats li svg{ width:18px; height:18px; flex-shrink:0; color:var(--mint); margin-top:1px; }
.plan .feats li.off{ color:var(--ink-faint); } .plan .feats li.off svg{ color:var(--ink-faint); }
.plan .feats li b{ display:block; font-weight:700; color:var(--ink); font-size:14px; }
.plan .feats li span{ color:var(--ink-dim); }
.annual-note{ margin-top:30px; text-align:center; padding:16px 24px; border-radius:var(--r); background:linear-gradient(135deg, rgba(37,211,102,.1),rgba(110,108,242,.06)); border:1px solid var(--line); font-size:14.5px; color:var(--ink); }

/* =============================================================
   FAQ
   ============================================================= */
.faq-list{ max-width:820px; margin-inline:auto; display:flex; flex-direction:column; gap:12px; }
.faq-item{ border:1px solid var(--line); border-radius:var(--r); background:var(--glass); overflow:hidden; transition:border-color .3s; }
.faq-item.open{ border-color:var(--line-strong); }
.faq-q{ width:100%; display:flex; align-items:center; gap:16px; padding:22px 24px; text-align:left; font-family:var(--display); font-weight:600; font-size:17px; }
.faq-q .pm{ margin-left:auto; width:26px; height:26px; flex-shrink:0; position:relative; }
.faq-q .pm::before,.faq-q .pm::after{ content:''; position:absolute; top:50%; left:50%; background:var(--mint); transition:.3s; }
.faq-q .pm::before{ width:14px; height:2px; transform:translate(-50%,-50%); }
.faq-q .pm::after{ width:2px; height:14px; transform:translate(-50%,-50%); }
.faq-item.open .pm::after{ transform:translate(-50%,-50%) scaleY(0); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.faq-a p{ padding:0 24px 24px; color:var(--ink-dim); font-size:15px; }

/* =============================================================
   CTA BAND
   ============================================================= */
.cta-band{ position:relative; overflow:hidden; border-radius:var(--r-xl); padding:clamp(48px,7vw,84px); text-align:center;
  background:linear-gradient(135deg, rgba(37,211,102,.14), rgba(110,108,242,.1)); border:1px solid var(--line-strong); }
.cta-band::before{ content:''; position:absolute; width:500px; height:500px; background:radial-gradient(circle,rgba(37,211,102,.35),transparent 70%); top:-200px; left:-100px; filter:blur(40px); }
.cta-band::after{ content:''; position:absolute; width:500px; height:500px; background:radial-gradient(circle,rgba(110,108,242,.3),transparent 70%); bottom:-220px; right:-100px; filter:blur(40px); }
.cta-band .inner{ position:relative; z-index:2; }
.cta-band h2{ font-size:clamp(30px,4.6vw,52px); margin-bottom:18px; }
.cta-band p{ color:var(--ink-dim); font-size:18px; max-width:54ch; margin:0 auto 32px; }
.cta-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* =============================================================
   CONTACT
   ============================================================= */
.contact-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:48px; align-items:start; }
.contact-info{ display:flex; flex-direction:column; gap:18px; margin-top:30px; }
.cinfo{ display:flex; gap:16px; align-items:center; padding:18px; border-radius:var(--r); border:1px solid var(--line); background:var(--glass); }
.cinfo .ic{ width:48px; height:48px; border-radius:13px; display:grid; place-items:center; font-size:21px; background:linear-gradient(135deg, rgba(37,211,102,.16), rgba(110,108,242,.12)); border:1px solid var(--line); }
.cinfo small{ display:block; color:var(--ink-dim); font-size:12px; text-transform:uppercase; letter-spacing:.08em; }
.cinfo b{ font-size:16px; font-family:var(--display); font-weight:600; }
.form{ padding:34px; border-radius:var(--r-lg); border:1px solid var(--line); background:linear-gradient(170deg, var(--glass-2), rgba(255,255,255,.02)); }
.form h3{ font-size:22px; margin-bottom:24px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.fg{ margin-bottom:16px; }
.fg label{ display:block; font-size:13px; font-weight:600; color:var(--ink-dim); margin-bottom:7px; }
.fg label .req{ color:var(--mint); }
.fg input,.fg select,.fg textarea{ width:100%; padding:13px 15px; border-radius:12px; background:var(--bg-2); border:1px solid var(--line); color:var(--ink); font-family:var(--body); font-size:14.5px; transition:border-color .25s, box-shadow .25s; }
.fg textarea{ resize:vertical; min-height:96px; }
.fg input:focus,.fg select:focus,.fg textarea:focus{ outline:none; border-color:var(--mint); box-shadow:0 0 0 3px rgba(37,211,102,.12); }
.fg input::placeholder,.fg textarea::placeholder{ color:var(--ink-faint); }
.fg select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2393AB9D' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 15px center; }

/* =============================================================
   FOOTER
   ============================================================= */
.footer{ position:relative; z-index:2; border-top:1px solid var(--line); margin-top:40px; padding:70px 0 0; }
.foot-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; padding-bottom:50px; }
.foot-brand p{ color:var(--ink-dim); font-size:14px; margin:18px 0; max-width:34ch; }
.foot-social{ display:flex; gap:10px; }
.foot-social a{ width:40px; height:40px; border-radius:11px; border:1px solid var(--line); display:grid; place-items:center; color:var(--ink-dim); transition:.3s; }
.foot-social a:hover{ color:var(--mint); border-color:var(--mint); transform:translateY(-2px); }
.foot-col h5{ font-family:var(--display); font-size:14px; font-weight:700; margin-bottom:18px; }
.foot-col a{ display:block; color:var(--ink-dim); font-size:14px; padding:6px 0; transition:color .25s; }
.foot-col a:hover{ color:var(--ink); }
.foot-bottom{ border-top:1px solid var(--line); padding:26px 0; display:flex; flex-wrap:wrap; gap:8px 24px; justify-content:space-between; align-items:center; }
.foot-bottom p{ font-size:12.5px; color:var(--ink-faint); }
.foot-legal{ display:flex; gap:20px; }
.foot-legal a{ font-size:12.5px; color:var(--ink-faint); }

/* floating whatsapp button */
.wa-float{ position:fixed; bottom:26px; right:26px; z-index:45; width:60px; height:60px; border-radius:50%;
  background:linear-gradient(135deg,#25D366,#15936f); display:grid; place-items:center;
  box-shadow:0 12px 30px -6px rgba(37,211,102,.6); transition:transform .3s; }
.wa-float:hover{ transform:scale(1.08); }
.wa-float svg{ width:30px; height:30px; }
.wa-float::after{ content:''; position:absolute; inset:0; border-radius:50%; border:2px solid var(--green); animation:pulse 2.2s infinite; }
@keyframes pulse{ 0%{ transform:scale(1); opacity:.7; } 100%{ transform:scale(1.6); opacity:0; } }

/* =============================================================
   SCROLL REVEAL
   ============================================================= */
.js .reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease-out), transform .8s var(--ease-out); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; } .reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; } .reveal[data-d="4"]{ transition-delay:.32s; } .reveal[data-d="5"]{ transition-delay:.4s; }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}

/* =============================================================
   RESPONSIVE
   ============================================================= */
@media (max-width:1024px){
  .nav-links{ display:none; }
  .burger{ display:flex; margin-left:auto; }
  .nav-cta .link{ display:none; }
  .hero-grid{ grid-template-columns:1fr; gap:60px; }
  .hero-visual{ max-width:440px; margin-inline:auto; }
  .demo-grid,.contact-grid{ grid-template-columns:1fr; gap:40px; }
  .feature-grid,.case-grid,.price-grid{ grid-template-columns:repeat(2,1fr); }
  .plan.popular{ transform:none; } .plan.popular:hover{ transform:translateY(-6px); }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:30px; }
}
@media (max-width:680px){
  body{ font-size:16px; }
  .feature-grid,.case-grid,.price-grid,.blog-grid,.steps{ grid-template-columns:1fr; }
  .steps::before{ display:none; }
  .field-row{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr; }
  .post{ grid-template-columns:1fr; } .post .thumb{ width:100%; height:90px; }
  .float-chip{ display:none; }
  .chat-card{ transform:none; }
  .nav-inner{ margin-top:8px; }
  .hero{ padding-top:120px; }

  /* Hero mobile — canvas menos agressivo, texto mais legível */
  #hero-canvas{ opacity:.18 !important; }
  .hero .lead{ color:var(--ink); }
}

/* =============================================================
   URGENCY BAR
   ============================================================= */
.urgency-bar{
  position:fixed; top:0; left:0; right:0; z-index:60;
  background:linear-gradient(90deg,#1aae54,#0b8c3f);
  color:#fff; text-align:center; font-size:13.5px; font-weight:500;
  padding:9px 48px 9px 16px; line-height:1.4;
}
.urgency-bar a{ color:#fff; font-weight:700; text-decoration:underline; text-underline-offset:2px; }
.urgency-bar a:hover{ opacity:.85; }
.ub-close{
  position:absolute; right:14px; top:50%; transform:translateY(-50%);
  background:none; border:none; color:#fff; font-size:16px; cursor:pointer; opacity:.7; line-height:1;
}
.ub-close:hover{ opacity:1; }
/* empurra o nav para baixo quando barra visível */
body:has(.urgency-bar:not([style*="none"])) .nav{ top:38px; }
@media (max-width:680px){
  .urgency-bar{ font-size:12px; padding:8px 40px 8px 12px; }
  body:has(.urgency-bar:not([style*="none"])) .nav{ top:36px; }
}

/* =============================================================
   EXIT-INTENT POPUP
   ============================================================= */
.popup-overlay{
  position:fixed; inset:0; z-index:200;
  background:rgba(6,13,10,.85); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; transition:opacity .35s;
}
.popup-overlay.open{ opacity:1; pointer-events:auto; }
.popup-box{
  width:100%; max-width:480px; margin:20px;
  background:linear-gradient(160deg,#0e1b14,#0a130e);
  border:1px solid var(--line-strong); border-radius:var(--r-xl);
  padding:clamp(28px,5vw,48px); position:relative;
  transform:translateY(24px); transition:transform .35s var(--ease-out);
}
.popup-overlay.open .popup-box{ transform:none; }
.popup-close{
  position:absolute; top:16px; right:18px;
  background:var(--glass); border:1px solid var(--line); border-radius:50%;
  width:32px; height:32px; display:grid; place-items:center;
  font-size:15px; color:var(--ink-dim); cursor:pointer; transition:.25s;
}
.popup-close:hover{ color:var(--ink); border-color:var(--line-strong); }
.popup-box .eyebrow{ margin-bottom:14px; }
.popup-box h2{ font-size:clamp(20px,3vw,26px); margin-bottom:10px; }
.popup-box p{ color:var(--ink-dim); font-size:15px; margin-bottom:24px; }
.popup-form{ display:flex; flex-direction:column; gap:12px; }
.popup-form input{
  width:100%; padding:13px 15px; border-radius:12px;
  background:var(--bg-2); border:1px solid var(--line); color:var(--ink);
  font-family:var(--body); font-size:14.5px; transition:border-color .25s;
}
.popup-form input:focus{ outline:none; border-color:var(--mint); box-shadow:0 0 0 3px rgba(37,211,102,.12); }
.popup-form input::placeholder{ color:var(--ink-faint); }
.popup-msg{ font-size:13.5px; font-weight:600; text-align:center; display:none; margin-top:8px; }
.popup-msg.ok{ color:var(--mint); }
.popup-msg.err{ color:#ff8a8a; }
