/* ============================================
   CREXZ — style.css v3
   ============================================ */

:root {
  --green: #00c853;
  --green-light: #69f0ae;
  --green-dark: #009940;
  --green-mid: #00a846;
  --green-glow: rgba(0,200,83,0.22);
  --green-glow-strong: rgba(0,200,83,0.42);

  --bg:       #050508;
  --bg-2:     #0b0b11;
  --bg-3:     #111118;
  --surface:  #0f0f18;
  --surface-2:#161622;
  --surface-3:#1d1d2c;
  --border:   rgba(255,255,255,0.065);
  --text:     #eeeef8;
  --text-2:   #9090b4;
  --text-3:   #505080;
  --shadow:   rgba(0,0,0,0.7);
  --nav-bg:   rgba(5,5,8,0.82);
  --input-bg: #13131f;
}

[data-theme="light"] {
  --bg:       #f6f8fd;
  --bg-2:     #edf0f9;
  --bg-3:     #e4e8f4;
  --surface:  #ffffff;
  --surface-2:#f2f4fb;
  --surface-3:#eaecf6;
  --border:   rgba(0,0,0,0.07);
  --text:     #0c0c1e;
  --text-2:   #383858;
  --text-3:   #747498;
  --shadow:   rgba(0,0,0,0.09);
  --nav-bg:   rgba(246,248,253,0.90);
  --input-bg: #f0f2fb;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }

body {
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  background:var(--bg); color:var(--text);
  overflow-x:hidden;
  transition:background .4s,color .4s;
  -webkit-font-smoothing:antialiased;
}

/* ─── Scroll progress ─── */
#scrollProgress {
  position:fixed; top:0; left:0; height:2px;
  background:linear-gradient(90deg,var(--green),var(--green-light));
  z-index:9999; width:0%;
  box-shadow:0 0 12px var(--green-glow);
}

/* ─── Cursor glow ─── */
#cursorGlow {
  position:fixed; width:500px; height:500px; border-radius:50%;
  background:radial-gradient(circle,rgba(0,200,83,0.045) 0%,transparent 70%);
  pointer-events:none; z-index:0;
  transform:translate(-50%,-50%);
  will-change:left,top;
}

/* ─── Background canvas ─── */
#bgCanvas {
  position:fixed; top:0; left:0;
  width:100%; height:100%; z-index:0; pointer-events:none;
}

/* ─── NAVBAR ─── */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:var(--nav-bg);
  backdrop-filter:blur(28px); -webkit-backdrop-filter:blur(28px);
  border-bottom:1px solid var(--border);
  transition:all .35s ease;
}
.navbar.scrolled { box-shadow:0 2px 40px rgba(0,0,0,.5); border-bottom-color:rgba(0,200,83,.1); }

.nav-container {
  max-width:1320px; margin:0 auto; padding:0 32px;
  height:70px; display:flex; align-items:center;
  justify-content:space-between; gap:32px;
}

.nav-logo { display:flex; align-items:center; gap:9px; text-decoration:none; flex-shrink:0; }

.logo-img {
  height:32px; width:auto;
  filter:brightness(0) invert(1) saturate(10) hue-rotate(75deg);
}
[data-theme="light"] .logo-img {
  filter:brightness(0) saturate(100%) invert(45%) sepia(80%) saturate(500%) hue-rotate(100deg);
}

.logo-text {
  font-size:21px; font-weight:900; letter-spacing:-.3px;
  background:linear-gradient(135deg,var(--green),var(--green-light));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

.nav-links { display:flex; align-items:center; gap:0; flex:1; justify-content:center; }

.nav-link {
  text-decoration:none; color:var(--text-2);
  font-size:14px; font-weight:500; letter-spacing:.1px;
  padding:8px 18px; border-radius:8px; transition:all .2s;
  position:relative;
}
.nav-link::after {
  content:''; position:absolute; bottom:3px; left:50%; right:50%;
  height:1.5px; background:var(--green); border-radius:2px; transition:all .25s;
}
.nav-link:hover::after,.nav-link.active::after { left:18px; right:18px; }
.nav-link:hover,.nav-link.active { color:var(--text); background:rgba(0,200,83,0.05); }

.nav-actions { display:flex; align-items:center; gap:10px; flex-shrink:0; }

.theme-toggle {
  width:38px; height:38px; border:1px solid var(--border); border-radius:9px;
  background:var(--surface); color:var(--text-2); cursor:pointer;
  display:flex; align-items:center; justify-content:center; font-size:16px; transition:all .25s;
}
.theme-toggle:hover { border-color:var(--green); color:var(--green); }
.theme-icon { display:none; }
[data-theme="dark"] .theme-icon.sun { display:block; }
[data-theme="light"] .theme-icon.moon { display:block; }

/* ─── Buttons ─── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 26px; border-radius:10px; font-size:14.5px; font-weight:600;
  cursor:pointer; text-decoration:none; border:none; transition:all .3s;
  white-space:nowrap; position:relative; overflow:hidden; letter-spacing:.1px;
}
.btn::before {
  content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);
  transition:left .5s;
}
.btn:hover::before { left:100%; }

.btn-primary {
  background:linear-gradient(135deg,var(--green),var(--green-dark));
  color:#fff; box-shadow:0 4px 20px var(--green-glow);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 10px 36px var(--green-glow-strong); }

.btn-outline {
  background:transparent; color:var(--green);
  border:1.5px solid rgba(0,200,83,.4);
}
.btn-outline:hover {
  background:rgba(0,200,83,.07); border-color:var(--green);
  transform:translateY(-2px); box-shadow:0 8px 24px var(--green-glow);
}

.btn-ghost {
  background:var(--surface-2); color:var(--text);
  border:1px solid var(--border);
}
.btn-ghost:hover { background:var(--surface-3); border-color:rgba(0,200,83,.2); transform:translateY(-2px); }

.btn-lg { padding:14px 34px; font-size:15.5px; border-radius:11px; }

/* Hamburger */
.hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:4px;
}
.hamburger span {
  display:block; width:22px; height:1.5px;
  background:var(--text); border-radius:2px; transition:all .3s;
}
.hamburger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }

.mobile-menu {
  position:fixed; top:70px; left:0; right:0;
  background:var(--bg-2); border-bottom:1px solid var(--border);
  z-index:999; padding:16px 24px 24px;
  display:none; flex-direction:column; gap:2px;
  box-shadow:0 20px 60px var(--shadow);
}
.mobile-menu.open { display:flex; }
.mobile-link {
  text-decoration:none; color:var(--text-2); font-size:16px; font-weight:500;
  padding:13px 16px; border-radius:10px; transition:all .2s;
}
.mobile-link:hover { color:var(--text); background:rgba(0,200,83,.06); }

/* ─── Page container ─── */
#pageContainer { position:relative; z-index:1; min-height:100vh; padding-top:70px; }
.page { animation:pageFadeUp .55s cubic-bezier(.22,1,.36,1) forwards; }
@keyframes pageFadeUp {
  from { opacity:0; transform:translateY(20px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ─── Reveal system ─── */
.reveal-card {
  opacity:0; transform:translateY(44px) scale(.98);
  transition:opacity .75s cubic-bezier(.22,1,.36,1), transform .75s cubic-bezier(.22,1,.36,1);
}
.reveal-card.visible { opacity:1; transform:translateY(0) scale(1); }

.reveal-left {
  opacity:0; transform:translateX(-52px);
  transition:opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1);
}
.reveal-left.visible { opacity:1; transform:translateX(0); }

.reveal-right {
  opacity:0; transform:translateX(52px);
  transition:opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1);
}
.reveal-right.visible { opacity:1; transform:translateX(0); }

.reveal-scale {
  opacity:0; transform:scale(.85);
  transition:opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1);
}
.reveal-scale.visible { opacity:1; transform:scale(1); }

.reveal-up {
  opacity:0; transform:translateY(36px);
  transition:opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1);
}
.reveal-up.visible { opacity:1; transform:translateY(0); }

.d1  { transition-delay:.05s; }
.d2  { transition-delay:.13s; }
.d3  { transition-delay:.21s; }
.d4  { transition-delay:.29s; }
.d5  { transition-delay:.37s; }
.d6  { transition-delay:.45s; }
.d7  { transition-delay:.53s; }
.d8  { transition-delay:.61s; }
.d9  { transition-delay:.69s; }
.d10 { transition-delay:.77s; }
.d11 { transition-delay:.85s; }
.d12 { transition-delay:.93s; }

/* ─── Section commons ─── */
.section { padding:100px 32px; max-width:1320px; margin:0 auto; }
.section-label {
  display:inline-block; color:var(--green); font-size:11.5px; font-weight:700;
  text-transform:uppercase; letter-spacing:2.8px; margin-bottom:18px;
}
.section-title {
  font-size:clamp(32px,4.5vw,54px); font-weight:900; letter-spacing:-2px;
  line-height:1.06; margin-bottom:16px; color:var(--text);
}
.section-sub { font-size:17px; color:var(--text-2); line-height:1.8; max-width:520px; }

.glow-divider {
  width:100%; height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,200,83,.18),transparent);
}

.text-center { text-align:center; }
.green { color:var(--green); }

/* ─── Hero ─── */
.hero {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  padding:100px 32px 60px; text-align:center; position:relative; overflow:hidden;
}

.hero-orb {
  position:absolute; border-radius:50%; filter:blur(100px);
  pointer-events:none; animation:orbFloat 10s ease-in-out infinite;
}
.hero-orb-1 {
  width:600px; height:600px;
  background:radial-gradient(circle,rgba(0,200,83,.09),transparent 65%);
  top:5%; left:50%; transform:translateX(-50%);
}
.hero-orb-2 {
  width:280px; height:280px;
  background:radial-gradient(circle,rgba(0,150,60,.06),transparent 65%);
  top:55%; right:8%; animation-delay:-4s;
}
.hero-orb-3 {
  width:220px; height:220px;
  background:radial-gradient(circle,rgba(105,240,174,.05),transparent 65%);
  bottom:15%; left:6%; animation-delay:-7s;
}
@keyframes orbFloat {
  0%,100% { transform:translateY(0) scale(1); }
  40%  { transform:translateY(-28px) scale(1.04); }
  70%  { transform:translateY(14px) scale(.97); }
}

.hero-content { max-width:800px; position:relative; z-index:1; }

.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(0,200,83,.07); border:1px solid rgba(0,200,83,.2);
  color:var(--green); padding:6px 16px; border-radius:100px;
  font-size:11px; font-weight:700; letter-spacing:1.8px; text-transform:uppercase;
  margin-bottom:36px;
  opacity:0; animation:badgePop .8s cubic-bezier(.34,1.56,.64,1) .15s forwards;
}
.badge-dot { width:5px; height:5px; background:var(--green); border-radius:50%; animation:pulseDot 2s infinite; }
@keyframes badgePop { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
@keyframes pulseDot { 0%,100%{box-shadow:0 0 0 0 var(--green-glow)} 50%{box-shadow:0 0 0 5px transparent} }

.hero-headline {
  font-size:clamp(48px,8vw,96px); font-weight:900;
  line-height:1.01; letter-spacing:-4px; color:var(--text); margin-bottom:26px;
}
.hero-headline .word { display:inline-block; overflow:hidden; margin-right:.16em; }
.hero-headline .word-inner {
  display:inline-block; opacity:0; transform:translateY(105%);
  animation:wordUp .85s cubic-bezier(.22,1,.36,1) forwards;
}
.hero-headline .w1 .word-inner { animation-delay:.25s; }
.hero-headline .w2 .word-inner { animation-delay:.38s; }
.hero-headline .w3 .word-inner { animation-delay:.51s; }
.hero-headline .w4 .word-inner { animation-delay:.64s; }
.hero-headline .w5 .word-inner { animation-delay:.77s; }
.hero-headline .w6 .word-inner { animation-delay:.90s; }
.hero-headline .w7 .word-inner { animation-delay:1.03s; }
@keyframes wordUp { from{opacity:0;transform:translateY(105%)} to{opacity:1;transform:translateY(0)} }

.hl {
  background:linear-gradient(120deg,var(--green) 0%,var(--green-light) 55%,var(--green) 100%);
  background-size:200% auto;
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  animation:shimmer 4s linear 1.5s infinite;
}
@keyframes shimmer { from{background-position:0 center} to{background-position:200% center} }

.hero-sub {
  font-size:clamp(16px,2vw,20px); color:var(--text-2); line-height:1.72;
  max-width:540px; margin:0 auto 44px;
  opacity:0; animation:fadeUp .9s ease 1s forwards;
}
@keyframes fadeUp { from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:translateY(0)} }

.hero-cta-row {
  display:flex; align-items:center; justify-content:center;
  gap:12px; flex-wrap:wrap; margin-bottom:56px;
  opacity:0; animation:fadeUp .9s ease 1.2s forwards;
}

.hero-stats {
  display:flex; align-items:center; justify-content:center;
  gap:36px; flex-wrap:wrap; padding:24px 36px;
  background:var(--surface); border:1px solid var(--border); border-radius:16px;
  position:relative; overflow:hidden;
  opacity:0; animation:fadeUp .9s ease 1.4s forwards;
}
.hero-stats::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--green),transparent);
}
.stat-item { text-align:center; }
.stat-num { display:block; font-size:28px; font-weight:900; color:var(--green); letter-spacing:-1px; }
.stat-label { display:block; font-size:11px; color:var(--text-3); margin-top:3px; text-transform:uppercase; letter-spacing:.8px; }
.stat-div { width:1px; height:32px; background:var(--border); }

/* ─── Marquee ─── */
.marquee-section {
  padding:22px 0; overflow:hidden;
  background:var(--surface); border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  position:relative; z-index:1;
}
.marquee-track {
  display:flex; gap:44px; width:max-content;
  animation:marquee 26s linear infinite;
}
.marquee-track:hover { animation-play-state:paused; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.marquee-item {
  display:flex; align-items:center; gap:10px;
  color:var(--text-3); font-size:13px; font-weight:600; white-space:nowrap; letter-spacing:.3px;
}
.marquee-item .m-ico { font-size:15px; }
.marquee-item .m-sep { color:var(--green); font-size:8px; opacity:.5; }

/* ─── PHONE MOCKUP SECTION ─── */
.phone-section {
  display:grid; grid-template-columns:1fr 1fr;
  gap:80px; align-items:center;
  max-width:1320px; margin:0 auto; padding:100px 32px;
}

.phone-copy { }
.phone-copy .section-label { }
.phone-copy h2 { font-size:clamp(30px,3.8vw,50px); font-weight:900; letter-spacing:-2px; margin-bottom:20px; line-height:1.06; }
.phone-copy > p { font-size:17px; color:var(--text-2); line-height:1.8; margin-bottom:40px; }

.phone-features { display:flex; flex-direction:column; gap:14px; }
.phone-feat {
  display:flex; align-items:flex-start; gap:16px;
  padding:18px 20px; background:var(--surface); border:1px solid var(--border);
  border-radius:14px; cursor:pointer; transition:all .3s;
}
.phone-feat.active, .phone-feat:hover {
  border-color:rgba(0,200,83,.28); background:var(--surface-2);
}
.phone-feat-ico {
  width:42px; height:42px; border-radius:11px;
  background:rgba(0,200,83,.08); border:1px solid rgba(0,200,83,.14);
  display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0;
  transition:all .3s;
}
.phone-feat.active .phone-feat-ico { background:rgba(0,200,83,.15); box-shadow:0 0 20px rgba(0,200,83,.15); }
.phone-feat-text h4 { font-size:15px; font-weight:700; margin-bottom:3px; }
.phone-feat-text p { font-size:13px; color:var(--text-2); line-height:1.6; }

/* Phone frame */
.phone-visual { display:flex; justify-content:center; align-items:center; position:relative; }

.phone-frame {
  width:260px; height:530px; position:relative;
  background:linear-gradient(160deg,#1a1a2e,#0f0f1a);
  border-radius:42px;
  border:2px solid rgba(255,255,255,.12);
  box-shadow:
    0 0 0 1px rgba(0,0,0,.4),
    0 40px 80px rgba(0,0,0,.6),
    0 0 60px rgba(0,200,83,.08),
    inset 0 1px 0 rgba(255,255,255,.08);
  overflow:hidden;
}

/* Notch */
.phone-notch {
  position:absolute; top:12px; left:50%; transform:translateX(-50%);
  width:90px; height:24px; background:#050508; border-radius:12px; z-index:10;
}
.phone-notch-dot {
  position:absolute; right:18px; top:50%; transform:translateY(-50%);
  width:8px; height:8px; border-radius:50%; background:#1a1a2e;
  border:1px solid rgba(255,255,255,.1);
}

.phone-screen {
  position:absolute; inset:0; display:flex; flex-direction:column;
  overflow:hidden; border-radius:40px;
}

/* Screen slides */
.app-screen {
  position:absolute; inset:0;
  display:flex; flex-direction:column;
  padding:52px 0 0;
  opacity:0; transform:translateX(30px);
  transition:opacity .6s ease, transform .6s cubic-bezier(.22,1,.36,1);
  pointer-events:none;
}
.app-screen.active {
  opacity:1; transform:translateX(0); pointer-events:auto;
}
.app-screen.prev { opacity:0; transform:translateX(-30px); }

/* Screen — Home */
.as-header { padding:10px 18px 8px; display:flex; align-items:center; justify-content:space-between; }
.as-greeting { font-size:11px; color:rgba(255,255,255,.4); }
.as-name { font-size:14px; font-weight:700; color:#fff; }
.as-avatar { width:28px; height:28px; border-radius:50%; background:linear-gradient(135deg,#00c853,#009940); display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; color:#fff; }

.as-balance-card {
  margin:8px 14px; padding:16px; border-radius:18px;
  background:linear-gradient(135deg,rgba(0,200,83,.18),rgba(0,100,40,.2));
  border:1px solid rgba(0,200,83,.2);
}
.as-balance-label { font-size:9px; color:rgba(255,255,255,.4); text-transform:uppercase; letter-spacing:1.2px; margin-bottom:4px; }
.as-balance-num { font-size:26px; font-weight:900; color:#fff; letter-spacing:-1px; }
.as-balance-sub { font-size:9px; color:rgba(0,200,83,.7); margin-top:2px; }

.as-quick { display:flex; gap:6px; padding:10px 14px; }
.as-q-btn {
  flex:1; display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:10px 6px; border-radius:12px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.06);
  font-size:9px; color:rgba(255,255,255,.55); font-weight:600; cursor:pointer;
}
.as-q-btn span { font-size:16px; }

.as-section-title { padding:4px 14px; font-size:10px; font-weight:700; color:rgba(255,255,255,.35); text-transform:uppercase; letter-spacing:1.2px; }

.as-txn-list { padding:0 14px; display:flex; flex-direction:column; gap:6px; }
.as-txn {
  display:flex; align-items:center; gap:10px;
  padding:8px 10px; background:rgba(255,255,255,.04);
  border-radius:10px; border:1px solid rgba(255,255,255,.04);
}
.as-txn-ico { width:28px; height:28px; border-radius:8px; background:rgba(0,200,83,.12); display:flex; align-items:center; justify-content:center; font-size:13px; flex-shrink:0; }
.as-txn-info { flex:1; }
.as-txn-name { font-size:10px; font-weight:600; color:#fff; }
.as-txn-date { font-size:8px; color:rgba(255,255,255,.3); }
.as-txn-amt { font-size:11px; font-weight:700; }
.as-txn-amt.neg { color:#ff5b5b; }
.as-txn-amt.pos { color:#00c853; }

/* Screen — Gift Cards */
.as-gc-grid { display:grid; grid-template-columns:1fr 1fr; gap:6px; padding:0 14px; }
.as-gc-card {
  border-radius:12px; padding:10px;
  aspect-ratio:1.6; display:flex; flex-direction:column; justify-content:flex-end;
  font-size:9px; font-weight:700; color:#fff; position:relative; overflow:hidden;
}
.as-gc-card::before { content:''; position:absolute; inset:0; background:inherit; opacity:.9; }
.as-gc-card span { position:relative; z-index:1; }
.as-gc-name { font-size:11px; font-weight:800; position:relative; z-index:1; }
.gc-amazon { background:linear-gradient(135deg,#1a1a1a,#333); }
.gc-netflix { background:linear-gradient(135deg,#8b0000,#e50914); }
.gc-spotify { background:linear-gradient(135deg,#006d32,#1db954); }
.gc-google { background:linear-gradient(135deg,#1a73e8,#4285f4); }

/* Screen — Bill Pay */
.as-bill-list { padding:0 14px; display:flex; flex-direction:column; gap:6px; }
.as-bill {
  display:flex; align-items:center; gap:10px;
  padding:10px; background:rgba(255,255,255,.04); border-radius:10px; border:1px solid rgba(255,255,255,.04);
}
.as-bill-ico { width:30px; height:30px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:14px; flex-shrink:0; }
.as-bill-info { flex:1; }
.as-bill-name { font-size:10px; font-weight:600; color:#fff; }
.as-bill-due { font-size:8px; color:rgba(255,255,255,.3); }
.as-pay-btn { font-size:9px; font-weight:700; color:#00c853; background:rgba(0,200,83,.1); padding:4px 9px; border-radius:6px; white-space:nowrap; }

/* Screen — Analytics */
.as-chart-area { padding:10px 14px; }
.as-chart { background:rgba(255,255,255,.03); border-radius:12px; padding:12px; border:1px solid rgba(255,255,255,.05); }
.as-chart-title { font-size:9px; color:rgba(255,255,255,.35); margin-bottom:8px; text-transform:uppercase; letter-spacing:1px; }
.as-chart-bars { display:flex; align-items:flex-end; gap:4px; height:50px; }
.as-bar { flex:1; border-radius:3px 3px 0 0; background:rgba(0,200,83,.2); animation:barGrow 1.2s ease forwards; }
@keyframes barGrow { from{transform:scaleY(0);transform-origin:bottom} to{transform:scaleY(1);transform-origin:bottom} }
.as-chart-labels { display:flex; gap:4px; margin-top:4px; }
.as-chart-labels span { flex:1; text-align:center; font-size:7px; color:rgba(255,255,255,.25); }

.as-pie-row { display:flex; gap:8px; padding:8px 14px; }
.as-pie-legend { flex:1; display:flex; flex-direction:column; gap:5px; justify-content:center; }
.as-pie-item { display:flex; align-items:center; gap:5px; font-size:8px; color:rgba(255,255,255,.5); }
.as-pie-dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; }

/* Phone glow ring */
.phone-glow {
  position:absolute; inset:-20px; border-radius:62px;
  background:transparent;
  box-shadow:0 0 60px rgba(0,200,83,.1);
  pointer-events:none; animation:phoneGlow 4s ease-in-out infinite;
}
@keyframes phoneGlow {
  0%,100%{box-shadow:0 0 50px rgba(0,200,83,.08)}
  50%{box-shadow:0 0 100px rgba(0,200,83,.16)}
}

/* Floating badges around phone */
.phone-float {
  position:absolute; background:var(--surface-2);
  border:1px solid var(--border); border-radius:14px;
  padding:10px 14px; white-space:nowrap;
  box-shadow:0 12px 40px rgba(0,0,0,.4);
  animation:floatBadge 4s ease-in-out infinite;
}
.phone-float-1 { top:12%; right:-20px; animation-delay:0s; }
.phone-float-2 { bottom:22%; left:-28px; animation-delay:-2s; }
.phone-float-3 { top:50%; right:-30px; animation-delay:-1s; }
@keyframes floatBadge {
  0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)}
}
.pf-label { font-size:9px; color:var(--text-3); text-transform:uppercase; letter-spacing:.8px; }
.pf-val { font-size:14px; font-weight:800; color:var(--text); }
.pf-val.green { color:var(--green); }
.pf-ico { font-size:18px; }

/* ─── STEP CARDS ─── */
.steps-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:16px; margin-top:56px;
}
.step-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:18px; padding:32px 26px;
  position:relative; overflow:hidden; transition:all .4s ease; cursor:default;
}
.step-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--green),var(--green-light));
  transform:scaleX(0); transform-origin:left; transition:transform .4s ease;
}
.step-card::after {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 0%,rgba(0,200,83,.05) 0%,transparent 65%);
  opacity:0; transition:opacity .4s;
}
.step-card:hover { transform:translateY(-8px); border-color:rgba(0,200,83,.22); box-shadow:0 24px 70px rgba(0,200,83,.1),0 8px 24px rgba(0,0,0,.2); }
.step-card:hover::before { transform:scaleX(1); }
.step-card:hover::after { opacity:1; }

.step-num { font-size:10px; font-weight:700; color:var(--green); text-transform:uppercase; letter-spacing:2px; margin-bottom:16px; }
.step-icon {
  width:56px; height:56px; background:rgba(0,200,83,.08); border:1px solid rgba(0,200,83,.14);
  border-radius:16px; display:flex; align-items:center; justify-content:center;
  font-size:24px; margin-bottom:18px; transition:all .4s;
}
.step-card:hover .step-icon { transform:scale(1.08); box-shadow:0 0 24px rgba(0,200,83,.18); }
.step-card h3 { font-size:17px; font-weight:700; margin-bottom:10px; }
.step-card p { font-size:13.5px; color:var(--text-2); line-height:1.75; }

/* ─── FEATURE CARDS ─── */
.features-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr));
  gap:16px; max-width:1320px; margin:0 auto; padding:0 32px 100px;
}
.feature-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:18px; padding:32px 26px;
  transition:all .4s; position:relative; overflow:hidden;
}
.feature-card::after {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 30% 0%,rgba(0,200,83,.06) 0%,transparent 55%);
  opacity:0; transition:opacity .4s;
}
.feature-card:hover { transform:translateY(-7px); border-color:rgba(0,200,83,.25); box-shadow:0 24px 60px rgba(0,200,83,.09); }
.feature-card:hover::after { opacity:1; }
.feature-icon {
  width:58px; height:58px; border-radius:16px;
  background:linear-gradient(135deg,rgba(0,200,83,.1),rgba(0,200,83,.03));
  border:1px solid rgba(0,200,83,.15); display:flex; align-items:center;
  justify-content:center; font-size:26px; margin-bottom:18px; transition:all .4s;
}
.feature-card:hover .feature-icon { transform:scale(1.1) rotate(-4deg); box-shadow:0 0 24px rgba(0,200,83,.18); }
.feature-card h3 { font-size:17px; font-weight:700; margin-bottom:9px; }
.feature-card p { font-size:13.5px; color:var(--text-2); line-height:1.78; }
.feature-tag {
  display:inline-block; margin-top:16px; padding:3px 11px;
  background:rgba(0,200,83,.07); color:var(--green);
  border-radius:100px; font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.8px;
}

/* ─── TESTIMONIALS ─── */
.testimonials-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:16px; margin-top:56px;
}
.testimonial-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:18px; padding:30px; transition:all .4s;
}
.testimonial-card:hover { border-color:rgba(0,200,83,.18); transform:translateY(-5px); box-shadow:0 20px 50px rgba(0,200,83,.07); }
.t-stars { color:var(--green); font-size:13px; letter-spacing:1px; margin-bottom:14px; }
.t-text { font-size:15px; color:var(--text-2); line-height:1.82; margin-bottom:20px; font-style:italic; }
.t-author { display:flex; align-items:center; gap:12px; }
.t-avatar {
  width:42px; height:42px; border-radius:50%;
  background:linear-gradient(135deg,var(--green),var(--green-dark));
  display:flex; align-items:center; justify-content:center;
  font-size:15px; font-weight:800; color:#fff; flex-shrink:0;
}
.t-name { font-size:14px; font-weight:700; }
.t-role { font-size:12px; color:var(--text-3); margin-top:2px; }

/* ─── TRUST / SECURITY SECTION ─── */
.trust-section {
  background:var(--surface);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.trust-inner {
  max-width:1320px; margin:0 auto; padding:80px 32px;
  display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center;
}
.trust-badges { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.trust-badge {
  background:var(--surface-2); border:1px solid var(--border);
  border-radius:16px; padding:22px; transition:all .3s;
  display:flex; flex-direction:column; align-items:flex-start; gap:10px;
}
.trust-badge:hover { border-color:rgba(0,200,83,.22); }
.trust-badge-ico { font-size:26px; }
.trust-badge h4 { font-size:14px; font-weight:700; }
.trust-badge p { font-size:12px; color:var(--text-2); line-height:1.6; }

/* ─── STATS BAND ─── */
.stats-band {
  background:var(--surface-2);
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
.stats-inner {
  max-width:1320px; margin:0 auto; padding:56px 32px;
  display:grid; grid-template-columns:repeat(4,1fr); gap:32px; text-align:center;
}
.stats-stat-num {
  font-size:42px; font-weight:900; color:var(--green);
  letter-spacing:-2px; display:block; margin-bottom:6px;
}
.stats-stat-label { font-size:13px; color:var(--text-2); line-height:1.5; }

/* ─── DOWNLOAD CTA ─── */
.download-cta {
  position:relative; overflow:hidden;
  background:var(--surface); border:1px solid var(--border);
  border-radius:28px; padding:80px 48px; text-align:center;
  max-width:1256px; margin:0 32px 100px; margin-left:auto; margin-right:auto;
  isolation:isolate;
}
.download-cta::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 0%,rgba(0,200,83,.07) 0%,transparent 55%);
}
.download-cta::after {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--green),transparent);
}
.download-cta h2 { font-size:clamp(28px,4vw,50px); font-weight:900; letter-spacing:-1.5px; margin-bottom:16px; }
.download-cta > p { font-size:17px; color:var(--text-2); margin-bottom:40px; line-height:1.7; max-width:520px; margin-left:auto; margin-right:auto; }

.store-buttons { display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; }
.store-btn {
  display:flex; align-items:center; gap:13px; padding:15px 26px;
  background:var(--text); color:var(--bg); border-radius:14px;
  text-decoration:none; font-weight:600; transition:all .3s;
}
.store-btn:hover { transform:translateY(-3px); box-shadow:0 14px 40px var(--shadow); }
.store-btn svg { width:24px; height:24px; flex-shrink:0; }
.store-btn-sub { display:block; font-size:9.5px; opacity:.55; text-transform:uppercase; letter-spacing:.7px; }
.store-btn-main { display:block; font-size:17px; font-weight:800; }

/* ─── ABOUT PAGE ─── */
.about-hero {
  padding:72px 32px 80px; max-width:1320px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center;
}
.about-text h1 { font-size:clamp(36px,4.5vw,60px); font-weight:900; letter-spacing:-2.5px; line-height:1.04; margin-bottom:22px; }
.about-text p { font-size:16.5px; color:var(--text-2); line-height:1.85; margin-bottom:18px; }
.about-visual { background:var(--surface); border:1px solid var(--border); border-radius:24px; padding:32px; }
.about-stat { padding:20px; background:var(--bg-2); border-radius:14px; border:1px solid var(--border); margin-bottom:12px; transition:all .3s; }
.about-stat:last-child { margin-bottom:0; }
.about-stat:hover { border-color:rgba(0,200,83,.2); transform:translateX(5px); }
.about-stat .num { font-size:40px; font-weight:900; color:var(--green); letter-spacing:-2px; }
.about-stat .lbl { font-size:13px; color:var(--text-2); margin-top:4px; }
.values-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(250px,1fr)); gap:16px; max-width:1320px; margin:0 auto; padding:0 32px 80px; }
.value-card { background:var(--surface); border:1px solid var(--border); border-radius:18px; padding:28px; transition:all .35s; }
.value-card:hover { border-color:rgba(0,200,83,.22); transform:translateY(-5px); box-shadow:0 18px 44px rgba(0,200,83,.07); }
.value-icon { font-size:32px; margin-bottom:14px; display:block; }
.value-card h3 { font-size:17px; font-weight:700; margin-bottom:8px; }
.value-card p { font-size:13.5px; color:var(--text-2); line-height:1.78; }
.team-section { max-width:1320px; margin:0 auto; padding:0 32px 100px; }
.team-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:16px; margin-top:44px; }
.team-card { background:var(--surface); border:1px solid var(--border); border-radius:20px; padding:28px 22px; text-align:center; transition:all .35s; position:relative; overflow:hidden; }
.team-card::before { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--green),var(--green-light)); transform:scaleX(0); transition:transform .35s; }
.team-card:hover { border-color:rgba(0,200,83,.22); transform:translateY(-7px); box-shadow:0 18px 44px rgba(0,200,83,.08); }
.team-card:hover::before { transform:scaleX(1); }
.team-avatar { width:76px; height:76px; border-radius:50%; background:linear-gradient(135deg,var(--green),var(--green-dark)); display:flex; align-items:center; justify-content:center; font-size:26px; font-weight:900; color:#fff; margin:0 auto 14px; box-shadow:0 8px 20px rgba(0,200,83,.25); transition:transform .3s; }
.team-card:hover .team-avatar { transform:scale(1.07); }
.team-card h4 { font-size:15px; font-weight:700; margin-bottom:4px; }
.team-card p { font-size:12.5px; color:var(--green); font-weight:600; }

/* ─── LEGAL PAGE ─── */
.page-hero { padding:70px 32px 56px; text-align:center; max-width:680px; margin:0 auto; }
.legal-container { max-width:1320px; margin:0 auto; padding:40px 32px 100px; display:grid; grid-template-columns:260px 1fr; gap:48px; align-items:start; }
.legal-nav { position:sticky; top:90px; background:var(--surface); border:1px solid var(--border); border-radius:18px; padding:22px; }
.legal-nav h3 { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--text-3); margin-bottom:14px; }
.legal-nav-link { display:flex; align-items:center; gap:8px; padding:10px 13px; border-radius:10px; text-decoration:none; color:var(--text-2); font-size:13.5px; font-weight:500; margin-bottom:3px; transition:all .2s; }
.legal-nav-link::before { content:''; width:5px; height:5px; border-radius:50%; background:var(--border); transition:background .2s; flex-shrink:0; }
.legal-nav-link:hover, .legal-nav-link.active { background:rgba(0,200,83,.07); color:var(--green); }
.legal-nav-link:hover::before, .legal-nav-link.active::before { background:var(--green); }
.legal-doc-header { margin-bottom:28px; padding-bottom:22px; border-bottom:1px solid var(--border); display:flex; align-items:flex-start; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.legal-doc-header h1 { font-size:clamp(24px,3vw,36px); font-weight:900; letter-spacing:-.5px; }
.legal-doc-meta { font-size:12px; color:var(--text-3); margin-top:6px; }
.legal-download { display:flex; align-items:center; gap:8px; padding:10px 18px; background:var(--surface-2); border:1px solid var(--border); border-radius:10px; text-decoration:none; color:var(--text-2); font-size:13px; font-weight:600; white-space:nowrap; transition:all .25s; cursor:pointer; }
.legal-download:hover { border-color:var(--green); color:var(--green); }
.legal-content h2 { font-size:18px; font-weight:700; margin:32px 0 10px; }
.legal-content h3 { font-size:15px; font-weight:600; margin:20px 0 8px; color:var(--text); }
.legal-content p { font-size:14.5px; color:var(--text-2); line-height:1.88; margin-bottom:14px; }
.legal-content ul { margin:0 0 14px; padding-left:20px; }
.legal-content li { font-size:14.5px; color:var(--text-2); line-height:1.88; margin-bottom:8px; }
.legal-highlight { background:rgba(0,200,83,.04); border-left:3px solid var(--green); border-radius:0 12px 12px 0; padding:16px 20px; margin:14px 0; }
.legal-highlight p { margin:0; font-size:13.5px; }

/* ─── CONTACT PAGE ─── */
.contact-container { max-width:1320px; margin:0 auto; padding:40px 32px 100px; }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start; margin-top:56px; }
.contact-info h2 { font-size:30px; font-weight:800; margin-bottom:14px; letter-spacing:-.5px; }
.contact-info > p { font-size:15.5px; color:var(--text-2); line-height:1.8; margin-bottom:32px; }
.contact-channels { display:flex; flex-direction:column; gap:12px; }
.contact-channel { display:flex; align-items:center; gap:15px; padding:18px 20px; background:var(--surface); border:1px solid var(--border); border-radius:14px; text-decoration:none; color:var(--text); transition:all .3s; position:relative; overflow:hidden; }
.contact-channel::before { content:''; position:absolute; left:0; top:0; bottom:0; width:2px; background:var(--green); transform:scaleY(0); transition:transform .3s; transform-origin:bottom; }
.contact-channel:hover { border-color:rgba(0,200,83,.22); transform:translateX(5px); }
.contact-channel:hover::before { transform:scaleY(1); }
.channel-icon { width:46px; height:46px; background:rgba(0,200,83,.07); border:1px solid rgba(0,200,83,.12); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; transition:transform .3s; }
.contact-channel:hover .channel-icon { transform:scale(1.08); }
.channel-info h4 { font-size:14px; font-weight:700; margin-bottom:2px; }
.channel-info p { font-size:12.5px; color:var(--text-2); }
.contact-form-wrapper { background:var(--surface); border:1px solid var(--border); border-radius:22px; padding:40px; position:relative; overflow:hidden; }
.contact-form-wrapper::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--green),var(--green-light)); }
.contact-form-wrapper h3 { font-size:20px; font-weight:700; margin-bottom:24px; }
.form-group { margin-bottom:18px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-group label { display:block; font-size:12px; font-weight:600; color:var(--text-2); margin-bottom:7px; text-transform:uppercase; letter-spacing:.5px; }
.form-group input, .form-group select, .form-group textarea { width:100%; padding:13px 16px; background:var(--input-bg); border:1.5px solid var(--border); border-radius:10px; color:var(--text); font-size:14.5px; font-family:'Inter',sans-serif; outline:none; transition:all .25s; appearance:none; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--green); box-shadow:0 0 0 3px rgba(0,200,83,.1); background:var(--surface); }
.form-group textarea { height:120px; resize:vertical; }
.form-success { display:none; text-align:center; padding:28px; }
.form-success-icon { width:68px; height:68px; background:rgba(0,200,83,.1); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:32px; margin:0 auto 18px; animation:popIn .6s cubic-bezier(.34,1.56,.64,1) forwards; }
@keyframes popIn { from{transform:scale(0)} to{transform:scale(1)} }
.form-success h4 { font-size:20px; font-weight:800; margin-bottom:8px; }
.form-success p { color:var(--text-2); font-size:14px; }
.faq-section { margin-top:72px; }
.faq-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(360px,1fr)); gap:12px; margin-top:36px; }
.faq-item { background:var(--surface); border:1px solid var(--border); border-radius:14px; padding:20px 22px; cursor:pointer; transition:all .25s; }
.faq-item:hover { border-color:rgba(0,200,83,.18); }
.faq-item.open { border-color:rgba(0,200,83,.28); background:var(--surface-2); }
.faq-q { font-size:14.5px; font-weight:600; display:flex; align-items:center; justify-content:space-between; gap:12px; color:var(--text); }
.faq-toggle { color:var(--green); font-size:20px; flex-shrink:0; transition:transform .3s cubic-bezier(.34,1.56,.64,1); line-height:1; }
.faq-item.open .faq-toggle { transform:rotate(45deg); }
.faq-answer { font-size:13.5px; color:var(--text-2); line-height:1.78; max-height:0; overflow:hidden; transition:max-height .4s ease,padding .3s; padding-top:0; }
.faq-item.open .faq-answer { max-height:180px; padding-top:12px; }

/* ─── FOOTER ─── */
.footer { position:relative; z-index:1; background:var(--bg-2); border-top:1px solid var(--border); }
.footer::before { content:''; display:block; height:1px; background:linear-gradient(90deg,transparent,rgba(0,200,83,.22),transparent); }
.footer-container { max-width:1320px; margin:0 auto; padding:60px 32px 28px; }
.footer-top { display:grid; grid-template-columns:1fr 2fr; gap:60px; margin-bottom:44px; }
.footer-logo-row { display:flex; align-items:center; gap:9px; margin-bottom:12px; }
.footer-logo { height:28px; width:auto; filter:brightness(0) invert(1) saturate(10) hue-rotate(75deg); }
[data-theme="light"] .footer-logo { filter:brightness(0) saturate(100%) invert(45%) sepia(80%) saturate(500%) hue-rotate(100deg); }
.footer-brand-name { font-size:19px; font-weight:900; background:linear-gradient(135deg,var(--green),var(--green-light)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.footer-tagline { font-size:13.5px; color:var(--text-3); line-height:1.65; margin-bottom:18px; }
.footer-social { display:flex; gap:8px; }
.social-link { width:36px; height:36px; background:var(--surface); border:1px solid var(--border); border-radius:9px; display:flex; align-items:center; justify-content:center; color:var(--text-3); text-decoration:none; transition:all .25s; }
.social-link:hover { border-color:var(--green); color:var(--green); transform:translateY(-2px); }
.footer-links-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:28px; }
.footer-col h4 { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:var(--text-3); margin-bottom:16px; }
.footer-col a { display:block; text-decoration:none; color:var(--text-2); font-size:13.5px; margin-bottom:10px; transition:all .2s; }
.footer-col a:hover { color:var(--green); transform:translateX(3px); }
.footer-bottom { border-top:1px solid var(--border); padding-top:22px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:8px; }
.footer-bottom p { font-size:12.5px; color:var(--text-3); }
.footer-badges { display:flex; gap:8px; }
.f-badge { font-size:10px; color:var(--text-3); border:1px solid var(--border); padding:3px 10px; border-radius:100px; font-weight:600; }

/* ─── TOAST ─── */
.toast {
  position:fixed; bottom:28px; right:28px;
  background:var(--surface); border:1px solid var(--border);
  border-left:3px solid var(--green); border-radius:12px;
  padding:14px 18px; box-shadow:0 16px 50px var(--shadow);
  z-index:9999; display:flex; align-items:center; gap:11px;
  min-width:260px; max-width:360px;
  transform:translateY(110px) scale(.9); opacity:0;
  transition:all .4s cubic-bezier(.34,1.56,.64,.9);
}
.toast.show { transform:translateY(0) scale(1); opacity:1; }
.toast-icon { font-size:18px; flex-shrink:0; }
.toast-text { font-size:13.5px; font-weight:600; }

.count-up { display:inline-block; }
.pill { display:inline-flex; align-items:center; padding:3px 11px; border-radius:100px; font-size:11px; font-weight:700; }
.pill-green { background:rgba(0,200,83,.08); color:var(--green); }

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){
  .about-hero { grid-template-columns:1fr; gap:36px; }
  .legal-container { grid-template-columns:1fr; }
  .legal-nav { position:relative; top:auto; }
  .footer-top { grid-template-columns:1fr; gap:36px; }
  .footer-links-grid { grid-template-columns:repeat(2,1fr); }
  .stats-inner { grid-template-columns:repeat(2,1fr); }
  .trust-inner { grid-template-columns:1fr; gap:36px; }
  .phone-section { grid-template-columns:1fr; gap:48px; }
  .phone-visual { order:-1; }
}

@media(max-width:768px){
  .nav-links,.nav-cta { display:none; }
  .hamburger { display:flex; }
  .contact-grid { grid-template-columns:1fr; gap:28px; }
  .form-row { grid-template-columns:1fr; }
  .hero-stats { gap:16px; padding:18px; }
  .stat-div { display:none; }
  .footer-links-grid { grid-template-columns:repeat(2,1fr); }
  .faq-grid { grid-template-columns:1fr; }
  .download-cta { padding:52px 24px; margin:0 16px 80px; }
  .contact-form-wrapper { padding:26px; }
  .section { padding:64px 20px; }
  .stats-inner { grid-template-columns:repeat(2,1fr); gap:20px; }
}

@media(max-width:480px){
  .hero-headline { letter-spacing:-2px; }
  .footer-links-grid { grid-template-columns:1fr 1fr; gap:16px; }
  .trust-badges { grid-template-columns:1fr; }
  .phone-float { display:none; }
}
