﻿/* ═══════════════════════════════════════════════════════════════════════════
   FILLAI – Dark glassmorphism · Bilingual (EN/AR) · v2
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Tokens ── */
:root {
  --bg:        #030905;
  --bg2:       #08140d;
  --surf:      rgba(6,18,11,.76);
  --surf2:     rgba(12,28,18,.66);
  --bdr:       rgba(178,255,211,.12);
  --bdr-h:     rgba(220,255,235,.22);
  --txt:       #f6fff8;
  --txt2:      #b9d8c2;
  --muted:     #789684;
  --pri:       #2ee66e;
  --pri2:      #169a53;
  --cyan:      #92ffbf;
  --pri-dim:   rgba(46,230,110,.12);
  --pri-glow:  rgba(46,230,110,.28);
  --ok:        #2ee66e;
  --ok-dim:    rgba(46,230,110,.16);
  --warn:      #f59e0b;
  --err:       #ef4444;
  --err-dim:   rgba(239,68,68,.13);
  --grad:      linear-gradient(135deg,#ebfff2 0%,#72ff9b 18%,#2ee66e 48%,#0f7f42 100%);
  --grad-t:    linear-gradient(120deg,#ffffff 0%,#b9ffd0 24%,#43ee81 58%,#0f7f42 100%);
  --r:         8px;
  --r-lg:      12px;
  --font:      "Outfit",system-ui,-apple-system,sans-serif;
  --font-ar:   "Tajawal",system-ui,sans-serif;
  --glass:     blur(20px) saturate(180%);
  --nav-h:     64px;
  --ann-h:     40px;
  --wash:      rgba(255,255,255,.06);
  --wash-strong: rgba(255,255,255,.12);
  --shadow-soft: 0 24px 80px rgba(0,0,0,.28);
}
[data-lang="ar"] { --font: var(--font-ar); }

[data-theme="light"] {
  --bg:        #f4fff6;
  --bg2:       #deffe9;
  --surf:      rgba(255,255,255,.76);
  --surf2:     rgba(243,255,247,.9);
  --bdr:       rgba(4,51,27,.12);
  --bdr-h:     rgba(4,51,27,.22);
  --txt:       #08150d;
  --txt2:      #285439;
  --muted:     #5c7665;
  --pri:       #0d8a49;
  --pri2:      #076a37;
  --cyan:      #49bf76;
  --pri-dim:   rgba(13,138,73,.12);
  --pri-glow:  rgba(13,138,73,.18);
  --ok:        #0d8a49;
  --ok-dim:    rgba(13,138,73,.14);
  --grad:      linear-gradient(135deg,#06170d 0%,#0d8a49 35%,#45d580 72%,#ffffff 100%);
  --grad-t:    linear-gradient(120deg,#04140b 0%,#0d8a49 35%,#44c67a 70%,#dcffe8 100%);
  --wash:      rgba(6,44,22,.05);
  --wash-strong: rgba(6,44,22,.1);
  --shadow-soft: 0 24px 80px rgba(8,44,20,.14);
}

/* ── Reset ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth }
body {
  background:
    radial-gradient(circle at 14% 18%, rgba(121,255,165,.18) 0%, transparent 28%),
    radial-gradient(circle at 84% 10%, rgba(255,255,255,.12) 0%, transparent 24%),
    linear-gradient(180deg,var(--bg) 0%, var(--bg2) 46%, var(--bg) 100%);
  color:var(--txt);
  font:15px/1.65 var(--font); -webkit-font-smoothing:antialiased;
  min-height:100vh; overflow-x:hidden;
}
body::before,
body::after {
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
}
body::before {
  background:
    radial-gradient(circle at 24% 32%, rgba(86,255,148,.14) 0%, transparent 30%),
    radial-gradient(circle at 76% 22%, rgba(255,255,255,.08) 0%, transparent 24%),
    radial-gradient(circle at 50% 100%, rgba(22,154,83,.16) 0%, transparent 38%);
  filter:blur(12px);
}
body::after {
  opacity:.35;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:72px 72px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.9), rgba(0,0,0,.15));
}
[data-theme="light"] body::after {
  opacity:.22;
  background-image:
    linear-gradient(rgba(4,51,27,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(4,51,27,.05) 1px, transparent 1px);
}
[data-lang="ar"] body, [data-lang="ar"] { direction:rtl }
a { color:inherit; text-decoration:none }
ul { list-style:none }
button { font:inherit; cursor:pointer; border:none; background:none }
img { display:block; max-width:100% }
details { cursor:pointer }
strong { font-weight:700 }

/* ── Layout ── */
.container { width:100%; max-width:1140px; margin:0 auto; padding:0 24px }
.hidden { display:none !important }
.section { padding:100px 0 }

.motion-ready .reveal-section {
  opacity:0;
  transform:translate3d(0,44px,0) scale(.985);
  filter:blur(12px);
  transition:
    opacity .78s cubic-bezier(.22,1,.36,1),
    transform .78s cubic-bezier(.22,1,.36,1),
    filter .78s cubic-bezier(.22,1,.36,1),
    box-shadow .35s ease;
  transition-delay:var(--reveal-delay, 0ms);
  will-change:opacity, transform, filter;
}

.motion-ready .reveal-section.is-visible {
  opacity:1;
  transform:translate3d(0,0,0) scale(1);
  filter:blur(0);
}

.motion-ready .reveal-section-pop {
  transform:translate3d(0,52px,0) scale(.965);
}

.motion-ready .reveal-section-pop.is-visible {
  box-shadow:0 28px 90px rgba(16,185,129,.18);
}

/* ── Gradient text (animated shimmer) ── */
.gradient-text {
  background: linear-gradient(
    100deg,
    #22c55e 0%, #16a34a 25%, #4ade80 45%,
    #bbf7d0 55%, #4ade80 65%, #16a34a 75%, #22c55e 100%
  );
  background-size: 200% auto;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: gradShimmer 4s linear infinite;
}
@keyframes gradShimmer {
  0%   { background-position: 0% center }
  100% { background-position: 200% center }
}

@media (prefers-reduced-motion:reduce) {
  .motion-ready .reveal-section,
  .motion-ready .reveal-section.is-visible,
  .motion-ready .reveal-section-pop,
  .motion-ready .reveal-section-pop.is-visible {
    opacity:1;
    transform:none;
    filter:none;
    transition:none;
  }
}

/* ══════════════════════════════════════════════════════
   ANNOUNCEMENT BAR
══════════════════════════════════════════════════════ */
.announce-bar {
  position:fixed; top:0; left:0; right:0; z-index:200;
  height:var(--ann-h);
  background:linear-gradient(90deg,#15803d,#22c55e,#16a34a);
  display:flex; align-items:center; justify-content:center; gap:16px;
  font-size:13px; font-weight:500; color:#fff;
  padding:0 40px;
}
.announce-close {
  position:absolute; right:16px; top:50%; transform:translateY(-50%);
  color:rgba(255,255,255,.8); font-size:14px;
  transition:color .15s;
}
.announce-close:hover { color:#fff }
.announce-bar.hidden { display:none !important }

/* ══════════════════════════════════════════════════════
   NAV
══════════════════════════════════════════════════════ */
.nav {
  position:fixed; top:var(--ann-h); left:0; right:0; z-index:100;
  height:var(--nav-h); transition:background .3s,box-shadow .3s;
}
.announce-bar.hidden ~ .nav { top:0 }
.nav.nav-scrolled {
  background:var(--surf); backdrop-filter:var(--glass);
  -webkit-backdrop-filter:var(--glass); box-shadow:0 1px 0 var(--bdr);
}
.nav-inner { height:var(--nav-h); display:flex; align-items:center; gap:24px }
.brand { display:flex; align-items:center; gap:7px; font-weight:800; font-size:17px; letter-spacing:-.4px; flex-shrink:0 }
.brand-icon { font-size:19px; display:inline-block; animation:brandBoltFlash 4s ease-in-out infinite }
@keyframes brandBoltFlash {
  0%,60%,100% { color:#f59e0b; filter:drop-shadow(0 0 6px rgba(245,158,11,.5)) }
  70%  { color:#fff;    filter:drop-shadow(0 0 20px #fff) drop-shadow(0 0 40px #fff); transform:scale(1.25) }
  80%  { color:#22c55e; filter:drop-shadow(0 0 14px rgba(34,197,94,.9)) drop-shadow(0 0 28px rgba(34,197,94,.5)) }
  90%  { color:#16a34a; filter:drop-shadow(0 0 10px rgba(22,163,74,.8)) }
}
.nav-links { display:flex; align-items:center; gap:4px; flex:1 }
.nav-link { padding:6px 12px; border-radius:8px; font-size:14px; font-weight:500; color:var(--txt2); transition:color .15s,background .15s }
.nav-link:hover { color:var(--txt); background:rgba(255,255,255,.06) }
.nav-actions { margin-left:auto; display:flex; align-items:center; gap:10px }
[data-lang="ar"] .nav-actions { margin-left:0; margin-right:auto }
.nav-group { display:flex; align-items:center; gap:8px }
.nav-controls { display:flex; align-items:center; gap:8px }

.theme-toggle {
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:4px 8px;
  min-width:78px;
  border-radius:999px;
  border:1px solid var(--bdr);
  background:var(--wash);
  color:var(--txt2);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  transition:border-color .18s, background .18s, transform .18s, box-shadow .18s;
}
.theme-toggle:hover {
  border-color:var(--bdr-h);
  background:var(--wash-strong);
  transform:translateY(-1px);
}
.theme-toggle-icon {
  position:relative;
  z-index:1;
  width:18px;
  text-align:center;
  font-size:12px;
  font-weight:700;
}
.theme-toggle-thumb {
  position:absolute;
  top:4px;
  left:4px;
  width:30px;
  height:26px;
  border-radius:999px;
  background:var(--grad);
  box-shadow:0 10px 30px var(--pri-glow);
  transition:transform .24s cubic-bezier(.22,1,.36,1);
}
.theme-toggle[data-theme="light"] .theme-toggle-thumb { transform:translateX(40px) }
.mobile-controls .theme-toggle { min-width:84px; justify-content:space-between }

/* Language / currency toggle */
.lang-toggle, .currency-toggle {
  display:flex; align-items:center; gap:5px;
  padding:4px 10px; border-radius:20px; font-size:12px; font-weight:600;
  border:1px solid var(--bdr); color:var(--txt2);
  transition:border-color .15s, background .15s;
}
.lang-toggle:hover, .currency-toggle:hover { border-color:var(--bdr-h); background:var(--wash) }
.lang-sep, .curr-sep { color:var(--muted) }
.lang-opt, .curr-opt { transition:color .15s }
.lang-opt.active, .curr-opt.active { color:var(--txt); font-weight:700 }

/* Nav avatar */
.nav-avatar-wrap { position:relative }
.nav-avatar { width:32px; height:32px; border-radius:50%; border:2px solid var(--bdr); cursor:pointer; transition:border-color .2s; object-fit:cover }
.nav-avatar.hidden { display:none }
.nav-avatar-fallback { width:32px; height:32px; border-radius:50%; border:2px solid var(--bdr); cursor:pointer; transition:border-color .2s; display:flex; align-items:center; justify-content:center; background:var(--grad); color:#fff; font-weight:700; font-size:14px; text-transform:uppercase; user-select:none }
.nav-avatar-fallback.hidden { display:none }
.nav-avatar:hover, .nav-avatar-fallback:hover, .nav-avatar-wrap:focus-within .nav-avatar, .nav-avatar-wrap:focus-within .nav-avatar-fallback { border-color:var(--pri) }
.nav-dropdown {
  position:absolute; top:calc(100% + 10px); right:0; min-width:200px;
  background:var(--surf); backdrop-filter:var(--glass); -webkit-backdrop-filter:var(--glass);
  border:1px solid var(--bdr); border-radius:var(--r); padding:8px;
  opacity:0; pointer-events:none; transform:translateY(-6px);
  transition:opacity .2s,transform .2s; box-shadow:0 16px 40px rgba(0,0,0,.5);
}
/* Invisible bridge fills the gap so hover is maintained while moving mouse to dropdown */
.nav-dropdown::before {
  content:''; position:absolute; top:-10px; left:0; right:0; height:10px;
}
[data-lang="ar"] .nav-dropdown { right:auto; left:0 }
.nav-avatar-wrap:hover .nav-dropdown,
.nav-avatar-wrap:focus-within .nav-dropdown { opacity:1; pointer-events:all; transform:translateY(0) }
.dropdown-user { padding:6px 8px 10px; font-size:13px; color:var(--txt2); font-weight:500 }
.dropdown-div { height:1px; background:var(--bdr); margin:6px 0 }
.dropdown-item { width:100%; text-align:left; padding:7px 10px; border-radius:8px; font-size:13px; font-weight:500; color:var(--txt2); transition:background .15s,color .15s }
.dropdown-item:hover { background:rgba(255,255,255,.07); color:var(--txt) }
.item-danger:hover { background:var(--err-dim); color:var(--err) }

/* Hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; padding:6px; margin-left:auto }
[data-lang="ar"] .hamburger { margin-left:0; margin-right:auto }
.hamburger span { width:22px; height:2px; background:var(--txt2); border-radius:2px; transition:all .2s }
.mobile-menu { background:var(--surf); backdrop-filter:var(--glass); -webkit-backdrop-filter:var(--glass); border-top:1px solid var(--bdr); padding:12px 24px 20px; display:flex; flex-direction:column; gap:4px; box-shadow:var(--shadow-soft) }
.mobile-controls { display:flex; gap:8px; padding:8px 0 12px; border-bottom:1px solid var(--bdr); margin-bottom:8px }
.mobile-link { padding:10px 12px; border-radius:8px; font-size:15px; font-weight:500; color:var(--txt2); transition:background .15s,color .15s }
.mobile-link:hover { background:var(--wash); color:var(--txt) }
.mobile-cta { margin-top:8px; background:var(--pri-dim); color:var(--pri); text-align:center }

/* ══════════════════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════════════════ */
.btn-ghost-sm { padding:6px 14px; border-radius:8px; font-size:13px; font-weight:500; color:var(--txt2); border:1px solid var(--bdr); transition:background .15s,color .15s,border-color .15s }
.btn-ghost-sm:hover { background:var(--wash-strong); color:var(--txt); border-color:var(--bdr-h) }
.btn-primary-sm { padding:6px 16px; border-radius:8px; font-size:13px; font-weight:600; background:var(--grad); color:#fff; box-shadow:0 2px 16px var(--pri-glow); transition:opacity .15s,transform .15s,box-shadow .2s }
.btn-primary-sm:hover { opacity:.88; transform:translateY(-1px); box-shadow:0 5px 22px var(--pri-glow) }
.btn-outline-sm { padding:7px 18px; border-radius:8px; font-size:13px; font-weight:500; border:1px solid var(--bdr); color:var(--txt2); transition:background .15s,color .15s,border-color .15s }
.btn-outline-sm:hover { background:var(--wash); color:var(--txt); border-color:var(--bdr-h) }
.btn-primary-lg { display:inline-flex; align-items:center; gap:6px; padding:13px 28px; border-radius:12px; font-size:15px; font-weight:700; background:var(--grad); color:#fff; box-shadow:0 4px 24px var(--pri-glow); transition:opacity .15s,transform .15s,box-shadow .2s }
.btn-primary-lg:hover { opacity:.88; transform:translateY(-2px); box-shadow:0 8px 32px var(--pri-glow) }
.btn-outline-lg { display:inline-flex; align-items:center; gap:6px; padding:13px 28px; border-radius:12px; font-size:15px; font-weight:600; border:1px solid var(--bdr-h); color:var(--txt2); transition:background .15s,color .15s,border-color .2s }
.btn-outline-lg:hover { background:var(--wash); color:var(--txt); border-color:var(--pri) }
.btn-primary-full { width:100%; padding:13px; border-radius:11px; font-size:14px; font-weight:700; background:var(--grad); color:#fff; box-shadow:0 3px 20px var(--pri-glow); transition:opacity .15s,transform .15s }
.btn-primary-full:hover { opacity:.88; transform:translateY(-1px) }
.btn-outline-full { width:100%; padding:12px; border-radius:11px; font-size:14px; font-weight:600; border:1px solid var(--bdr-h); color:var(--txt2); text-align:center; display:block; transition:background .15s,color .15s,border-color .2s }
.btn-outline-full:hover { background:var(--wash); color:var(--txt); border-color:var(--pri) }
.btn-danger-ghost { color:var(--err); border-color:rgba(239,68,68,.25) !important }
.btn-danger-ghost:hover { background:var(--err-dim) !important }
.btn-push { display:inline-block; padding:10px 20px; border-radius:8px; font-size:13px; font-weight:600; cursor:pointer; border:1px solid; transition:background .15s,color .15s }
.btn-push--off { background:rgba(34,197,94,.10); color:#4ade80; border-color:rgba(34,197,94,.30) }
.btn-push--off:hover { background:rgba(34,197,94,.18) }
.btn-push--on  { background:rgba(74,222,128,.1); color:#4ade80; border-color:rgba(74,222,128,.3) }
.btn-push--on:hover  { background:rgba(74,222,128,.18) }

/* ══════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════ */
.hero {
  position:relative; min-height:100vh; display:flex; align-items:center;
  padding:calc(var(--ann-h) + var(--nav-h) + 48px) 0 80px; overflow:hidden;
}
.hero-bg, .dash-bg { position:absolute; inset:0; pointer-events:none; z-index:0; overflow:hidden }
.orb { position:absolute; border-radius:50%; filter:blur(80px); will-change:transform }
.o1 { width:600px; height:600px; background:radial-gradient(circle,rgba(46,230,110,.22) 0%,transparent 70%); top:-180px; left:-150px; animation:orbA 18s ease-in-out infinite }
.o2 { width:500px; height:500px; background:radial-gradient(circle,rgba(15,127,66,.22) 0%,transparent 70%); bottom:0; right:-100px; animation:orbB 14s ease-in-out infinite }
.o3 { width:380px; height:380px; background:radial-gradient(circle,rgba(255,255,255,.14) 0%,transparent 70%); bottom:200px; left:20%; animation:orbA 20s ease-in-out infinite reverse }
.o4 { width:250px; height:250px; background:radial-gradient(circle,rgba(146,255,191,.16) 0%,transparent 70%); top:40%; right:15%; animation:orbB 16s ease-in-out infinite reverse }
@keyframes orbA { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(30px,-40px) scale(1.08)} 66%{transform:translate(-20px,18px) scale(.94)} }
@keyframes orbB { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(-28px,-22px) scale(1.12)} }

/* ── Lightning bolt ──────────────────────────────────────── */
.hero-bolt {
  position:absolute; width:min(500px,52vw); aspect-ratio:120/200;
  top:50%; left:50%; transform:translate(-44%,-50%);
  opacity:.09; pointer-events:none; z-index:0;
  animation:boltFloat 7s ease-in-out infinite, boltGlow 3.6s ease-in-out infinite;
  will-change:transform,opacity;
}
.bolt-body {
  fill:url(#boltGrad);
  filter:drop-shadow(0 0 24px rgba(255,255,255,.16)) drop-shadow(0 0 56px rgba(46,230,110,.34));
}
@keyframes boltFloat {
  0%,100%{transform:translate(-44%,-50%) scale(1)}
  33%{transform:translate(-44%,-52%) scale(1.025)}
  66%{transform:translate(-42%,-49%) scale(.975)}
}
@keyframes boltGlow {
  0%,100%{opacity:.07} 50%{opacity:.20}
}
.hero-bolt.discharge { animation:boltDischarge .4s ease-out forwards }
@keyframes boltDischarge {
  0%  {opacity:.07;filter:brightness(1)}
  15% {opacity:1;  filter:brightness(4)}
  45% {opacity:.6; filter:brightness(2.5)}
  100%{opacity:.17;filter:brightness(1)}
}

/* ── Mouse spotlight (radial follows cursor via JS --sx/--sy) ─────────── */
.hero-spotlight {
  position:absolute; inset:0; pointer-events:none; z-index:1;
  background: radial-gradient(
    700px circle at var(--sx, 50%) var(--sy, 50%),
    rgba(255,255,255,.12) 0%,
    rgba(46,230,110,.11) 38%,
    transparent 68%
  );
  opacity:0; transition:opacity .55s;
}
.hero-spotlight.active { opacity:1 }

/* ── Noise texture (premium dark-UI grain) ────────────────────────────── */
.hero-noise {
  position:absolute; inset:0; pointer-events:none; z-index:1;
  opacity:.028;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  background-size: 200px 200px;
}

/* ── Custom cursor glow ring ──────────────────────────────────────────── */
.hero-cursor {
  position:fixed; top:0; left:0; pointer-events:none; z-index:9990;
  width:42px; height:42px; border-radius:50%;
  border:1.5px solid rgba(146,255,191,.7);
  background:radial-gradient(circle, rgba(146,255,191,.18) 0%, transparent 70%);
  transform:translate(-50%,-50%) scale(1);
  opacity:0; transition:opacity .4s, width .25s, height .25s, transform .25s;
  mix-blend-mode:screen;
  will-change:transform;
}
.hero-cursor.vis   { opacity:1 }
.hero-cursor.click { transform:translate(-50%,-50%) scale(.72); opacity:.7 }
.hero-cursor.hover { width:58px; height:58px; border-color:rgba(255,255,255,.82); background:radial-gradient(circle, rgba(255,255,255,.15) 0%, transparent 70%) }

/* ── Hero-pill animated border glow ─────────────────────────────────── */
.hero-pill {
  position:relative;
}
.hero-pill::before {
  content:''; position:absolute; inset:-1px; border-radius:100px; padding:1px;
  background:conic-gradient(from var(--pill-angle,0deg), rgba(255,255,255,.55), rgba(46,230,110,.62), rgba(15,127,66,.62), rgba(255,255,255,.55));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  animation:pillBorderSpin 5s linear infinite;
  pointer-events:none;
}
@keyframes pillBorderSpin { to { --pill-angle:360deg } }
@property --pill-angle { syntax:'<angle>'; initial-value:0deg; inherits:false }

/* ── Primary CTA button shimmer ──────────────────────────────────────── */
.btn-primary-lg, .btn-primary-sm {
  position:relative; overflow:hidden;
}
.btn-primary-lg::after, .btn-primary-sm::after {
  content:''; position:absolute; top:0; left:-120%; width:55%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);
  animation:btnShimmer 3.8s ease-in-out infinite;
  pointer-events:none;
}
@keyframes btnShimmer {
  0%  { left:-120% }
  40% { left:170% }
  100%{ left:170% }
}

/* ── Hero mockup 3D perspective tilt ────────────────────────────────── */
.hero-mockup {
  transform-style:preserve-3d;
  transition:transform .14s cubic-bezier(.22,1,.36,1), box-shadow .14s;
  will-change:transform;
}

/* ── Stat counter fade-in ────────────────────────────────────────────── */
.stat-num { transition:opacity .5s }
.stat-num.counting { animation:statPop .35s cubic-bezier(.34,1.56,.64,1) }
@keyframes statPop { 0%{transform:scale(.8);opacity:0} 100%{transform:scale(1);opacity:1} }

/* ── Reduce motion fallback ──────────────────────────────────────────── */
@media (prefers-reduced-motion:reduce) {
  .animate-up, .hero-bolt, .hero-beam::before, .orb,
  .hero-cursor, .gradient-text, .btn-primary-lg::after,
  .btn-primary-sm::after, .hero-pill::before, .pill-dot
  { animation:none!important; transition:none!important;
    opacity:1!important; transform:none!important }
}

/* ── Spark canvas ────────────────────────────────────────── */
.hero-sparks { position:absolute; inset:0; width:100%; height:100%; pointer-events:none; z-index:0 }

/* ── Beam sweep ──────────────────────────────────────────── */
.hero-beam { position:absolute; inset:0; pointer-events:none; z-index:0; overflow:hidden }
.hero-beam::before {
  content:''; position:absolute; top:0; left:-60%; width:40%; height:100%;
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.08) 30%,rgba(46,230,110,.06) 50%,transparent 100%);
  animation:beamSweep 9s ease-in-out infinite;
}
@keyframes beamSweep {
  0%  {transform:translateX(0)}
  45% {transform:translateX(370%)}
  100%{transform:translateX(370%)}
}

/* ── Hero entrance (Framer-style fade-up) ────────────────── */
.animate-up {
  animation:heroFadeUp .72s cubic-bezier(.22,1,.36,1) both;
  animation-delay:var(--d,0s);
}
@keyframes heroFadeUp {
  from{opacity:0;transform:translateY(30px)}
  to  {opacity:1;transform:translateY(0)}
}

.grid-mesh { position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px); background-size:60px 60px }
.hero-content { position:relative; z-index:1; display:flex; flex-direction:column; align-items:center; text-align:center }
.hero-pill { display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:500; color:var(--txt2); border:1px solid var(--bdr-h); border-radius:100px; padding:5px 14px; background:var(--surf2); backdrop-filter:blur(8px); margin-bottom:28px }
.pill-dot { width:7px; height:7px; border-radius:50%; background:var(--ok); box-shadow:0 0 8px var(--ok); animation:dotPulse 2s ease-in-out infinite }
@keyframes dotPulse { 0%,100%{opacity:.6;transform:scale(.8)} 50%{opacity:1;transform:scale(1.25)} }
.hero-title { font-size:clamp(40px,7vw,78px); font-weight:900; line-height:1.08; letter-spacing:-2px; margin-bottom:24px }
.hero-sub { font-size:clamp(15px,2vw,18px); color:var(--txt2); max-width:580px; margin-bottom:32px; line-height:1.7 }
.hero-cta { display:flex; align-items:center; gap:14px; flex-wrap:wrap; justify-content:center; margin-bottom:18px }
.hero-footnote { font-size:13px; color:var(--muted); margin-bottom:28px }

/* Store badges */
.store-badges { display:flex; align-items:center; gap:12px; flex-wrap:wrap; justify-content:center; margin-bottom:48px }
.store-badge {
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 16px; border-radius:10px;
  background:var(--wash-strong); border:1px solid var(--bdr-h);
  font-size:13px; font-weight:600; color:var(--txt2);
  transition:background .15s,border-color .2s,color .15s;
}
.store-badge:hover { background:rgba(255,255,255,.16); border-color:var(--pri); color:var(--txt) }
.badge-fb { display:flex; align-items:center; gap:8px }

/* Stats */
.hero-stats { display:flex; align-items:center; gap:20px; flex-wrap:wrap; justify-content:center; margin-bottom:60px }
.stat-item { text-align:center }
.stat-num { font-size:24px; font-weight:800; background:var(--grad-t); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent }
.stat-lbl { font-size:12px; color:var(--muted); margin-top:2px }
.stat-sep { width:1px; height:36px; background:var(--bdr) }

/* Mockup */
.hero-mockup { width:100%; max-width:760px; border-radius:16px; overflow:hidden; border:1px solid var(--bdr); box-shadow:0 40px 120px rgba(0,0,0,.45),0 0 0 1px rgba(255,255,255,.06); margin-top:0 }
.mockup-bar { background:rgba(255,255,255,.08); display:flex; align-items:center; gap:7px; padding:10px 16px }
.dot { width:10px; height:10px; border-radius:50% }
.dot.red{background:#ff5f57}.dot.yellow{background:#ffbd2e}.dot.green{background:#28c940}
.url-bar { flex:1; background:rgba(0,0,0,.28); border-radius:5px; padding:3px 10px; font-size:12px; color:var(--muted); text-align:center; margin:0 12px }
.mockup-body { display:grid; grid-template-columns:1fr 300px; min-height:220px }
.mockup-page { padding:20px; background:rgba(255,255,255,.02); border-right:1px solid var(--bdr) }
.form-row-m { display:flex; align-items:center; gap:10px; margin-bottom:12px }
.form-row-m label { font-size:11px; color:var(--txt2); width:48px; flex-shrink:0; text-align:right }
[data-lang="ar"] .form-row-m label { text-align:left }
.input-filled { flex:1; background:rgba(34,197,94,.08); border:1px solid rgba(34,197,94,.25); border-radius:6px; padding:5px 10px; font-size:12px; display:flex; justify-content:space-between; align-items:center }
.chk-inline { color:var(--ok); font-size:11px }
.input-typing { flex:1; background:rgba(34,197,94,.06); border:1px solid rgba(255,255,255,.1); border-radius:6px; padding:5px 10px; font-size:12px }
.cursor-blink { animation:blink 1s steps(1) infinite }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }
.mockup-sidebar { background:rgba(0,0,0,.4); padding:14px; display:flex; flex-direction:column; gap:8px }
.sb-header { display:flex; align-items:center; gap:8px; padding-bottom:8px; border-bottom:1px solid var(--bdr) }
.sb-icon { font-size:14px }
.sb-title { font-size:13px; font-weight:700; flex:1 }
.sb-status { font-size:10px; color:var(--ok); font-weight:600 }
.sb-msg { font-size:11px; padding:6px 10px; border-radius:8px; max-width:90%; line-height:1.5 }
.sb-user { background:var(--pri-dim); color:var(--txt2); align-self:flex-end; border-radius:8px 8px 2px 8px }
.sb-ai   { background:rgba(255,255,255,.06); color:var(--txt2); border-radius:8px 8px 8px 2px }
.sb-input-row { display:flex; gap:6px; margin-top:auto }
.sb-input { flex:1; background:rgba(255,255,255,.06); border-radius:6px; padding:5px 10px; font-size:11px; color:var(--muted) }
.sb-send { background:var(--pri); border-radius:6px; padding:5px 8px; font-size:11px; color:#fff }

/* ══════════════════════════════════════════════════════
   SECTIONS SHARED
══════════════════════════════════════════════════════ */
.section-eyebrow { font-size:12px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--pri); margin-bottom:12px }
.section-title { font-size:clamp(28px,4.5vw,44px); font-weight:800; letter-spacing:-1px; line-height:1.12; margin-bottom:16px }
.section-sub { font-size:16px; color:var(--txt2); max-width:560px; margin:0 auto 56px; text-align:center; line-height:1.7 }

/* ══════════════════════════════════════════════════════
   FEATURES
══════════════════════════════════════════════════════ */
.features-section .container { text-align:center }
.features-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:20px; text-align:left }
.feature-card {
  background:var(--surf); border:1px solid var(--bdr); border-radius:var(--r-lg);
  padding:24px; position:relative; overflow:hidden;
  transition:border-color .2s,transform .2s,box-shadow .2s;
}
.feature-card:hover { border-color:var(--bdr-h); transform:translateY(-3px); box-shadow:0 12px 40px rgba(0,0,0,.3) }
.highlight-card { border-color:rgba(34,197,94,.35); background:linear-gradient(135deg,rgba(34,197,94,.08),rgba(22,163,74,.05)) }
.highlight-card:hover { border-color:rgba(34,197,94,.6); box-shadow:0 12px 40px rgba(34,197,94,.15) }
.f-badge { position:absolute; top:14px; right:14px; font-size:10px; font-weight:700; letter-spacing:1px; background:var(--grad); color:#fff; padding:2px 8px; border-radius:20px }
[data-lang="ar"] .f-badge { right:auto; left:14px }
.f-icon { font-size:28px; margin-bottom:12px }
.feature-card h3 { font-size:15px; font-weight:700; margin-bottom:8px }
.feature-card p { font-size:13px; color:var(--txt2); line-height:1.6 }

/* ══════════════════════════════════════════════════════
   SPOTLIGHT (Browser Controller)
══════════════════════════════════════════════════════ */
.spotlight-section { background:linear-gradient(135deg,rgba(46,230,110,.05),rgba(255,255,255,.03) 45%,rgba(15,127,66,.04)) }
.spotlight-inner { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center }
.spotlight-code { background:rgba(1,10,6,.62); border:1px solid var(--bdr); border-radius:var(--r-lg); overflow:hidden; font-family:monospace }
.code-header { display:flex; align-items:center; gap:7px; padding:12px 16px; background:rgba(255,255,255,.04); border-bottom:1px solid var(--bdr) }
.code-dot { width:10px; height:10px; border-radius:50% }
.code-dot.red{background:#ff5f57}.code-dot.yellow{background:#ffbd2e}.code-dot.green{background:#28c940}
.code-title { font-size:12px; color:var(--muted); margin-left:8px }
.code-body { padding:20px; font-size:13px; line-height:2 }
.code-line { white-space:pre }
.c-cmt { color:#5c7282 }
.c-key { color:#818cf8 }
.c-str { color:#86efac }
.c-op  { color:#94a3b8 }
.c-grn { color:#86efac }
.spotlight-text { padding:8px 0 }
.spotlight-title { font-size:clamp(28px,4vw,42px); font-weight:800; letter-spacing:-1px; line-height:1.12; margin:12px 0 20px }
.spotlight-text p { font-size:15px; color:var(--txt2); line-height:1.7; margin-bottom:16px }
.spot-list { list-style:none; display:flex; flex-direction:column; gap:10px; margin-top:24px }
.spot-list li { font-size:14px; color:var(--txt2) }
.spot-list li::marker { content:none }

/* ══════════════════════════════════════════════════════
   HOW IT WORKS
══════════════════════════════════════════════════════ */
.how-section { text-align:center }
.steps-grid { display:flex; align-items:center; justify-content:center; gap:16px; flex-wrap:wrap; margin-top:48px }
.step-card { background:var(--surf); border:1px solid var(--bdr); border-radius:var(--r-lg); padding:28px 24px; width:220px; text-align:center; transition:border-color .2s,transform .2s }
.step-card:hover { border-color:var(--bdr-h); transform:translateY(-3px) }
.step-num { font-size:36px; font-weight:900; background:var(--grad-t); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; margin-bottom:12px }
.step-card h3 { font-size:15px; font-weight:700; margin-bottom:8px }
.step-card p { font-size:13px; color:var(--txt2); line-height:1.6 }
.step-arrow { font-size:24px; color:var(--pri); flex-shrink:0 }
[data-lang="ar"] .step-arrow { transform:scaleX(-1) }

/* ══════════════════════════════════════════════════════
   COMPETITOR TABLE
══════════════════════════════════════════════════════ */
.compare-section { text-align:center }
.compare-section .section-sub { margin-bottom:36px }
.table-scroll { overflow-x:auto; -webkit-overflow-scrolling:touch; border-radius:var(--r-lg); border:1px solid var(--bdr) }
.compare-table { width:100%; border-collapse:collapse; min-width:700px }
.compare-table th, .compare-table td { padding:12px 14px; text-align:center; font-size:13px; border-bottom:1px solid var(--bdr) }
.compare-table th { background:rgba(255,255,255,.04); font-weight:700; color:var(--txt2); font-size:12px; position:sticky; top:0 }
.compare-table td:first-child { text-align:left; font-weight:500; color:var(--txt); padding-left:20px }
[data-lang="ar"] .compare-table td:first-child { text-align:right; padding-left:14px; padding-right:20px }
.compare-table tr:last-child td { border-bottom:none }
.col-us { background:rgba(34,197,94,.07) !important; border-left:2px solid rgba(34,197,94,.35); border-right:2px solid rgba(34,197,94,.35) }
.th-price { font-size:10px; font-weight:600; color:var(--muted); margin-top:3px }
.chk { font-size:14px; font-weight:700 }
.chk.yes     { color:var(--ok) }
.chk.partial { color:var(--warn) }
.chk.no      { color:var(--muted) }
.row-price td { background:rgba(255,255,255,.03); font-weight:600 }
.row-price .col-us { color:var(--pri) }
.compare-note { margin-top:20px; font-size:12px; color:var(--muted); text-align:center }

/* ══════════════════════════════════════════════════════
   PRICING
══════════════════════════════════════════════════════ */
.pricing-section { text-align:center }
.pricing-controls { display:flex; justify-content:center; margin-bottom:48px }
.billing-toggle { display:flex; background:var(--wash); border:1px solid var(--bdr); border-radius:100px; padding:4px; gap:4px }
.bill-btn { padding:7px 20px; border-radius:100px; font-size:13px; font-weight:600; color:var(--txt2); display:flex; align-items:center; gap:8px; transition:background .2s,color .2s }
.bill-btn.active { background:var(--grad); color:#fff; box-shadow:0 2px 12px var(--pri-glow) }
.badge-save { font-size:10px; background:rgba(34,197,94,.18); color:var(--ok); padding:2px 7px; border-radius:100px; font-weight:700 }
.pricing-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:24px; max-width:900px; margin:0 auto 32px; text-align:left }
.pricing-grid-4 { max-width:1200px; grid-template-columns:repeat(4,1fr); gap:20px }
@media (max-width:1100px) { .pricing-grid-4 { grid-template-columns:repeat(2,1fr) } }
@media (max-width:520px) { .pricing-grid-4 { grid-template-columns:1fr } }
.pricing-card {
  background:var(--surf); border:1px solid var(--bdr); border-radius:var(--r-lg);
  padding:28px; position:relative; display:flex; flex-direction:column; gap:24px;
  transition:border-color .3s ease, box-shadow .3s ease, transform .55s cubic-bezier(.34,1.56,.64,1);
}
.pricing-card:hover { border-color:var(--bdr-h); transform:translateY(-12px) scale(1.028); box-shadow:0 28px 72px rgba(0,0,0,.45) }
.pricing-card.featured { border-color:rgba(34,197,94,.45); background:linear-gradient(135deg,rgba(34,197,94,.09),rgba(22,163,74,.06)) }
.pricing-card.featured:hover { box-shadow:0 20px 60px rgba(34,197,94,.18) }
.pricing-card-enterprise { border-color:rgba(245,158,11,.4); background:linear-gradient(135deg,rgba(245,158,11,.08),rgba(251,191,36,.05)) }
.pricing-card-enterprise:hover { border-color:rgba(245,158,11,.7); box-shadow:0 20px 60px rgba(245,158,11,.15) }
.p-badge { position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--grad); color:#fff; font-size:11px; font-weight:700; letter-spacing:.5px; padding:4px 16px; border-radius:100px; white-space:nowrap }
.p-header { display:flex; flex-direction:column; gap:6px }
.plan-name { font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--txt2) }
.plan-price { display:flex; align-items:flex-end; gap:8px; flex-wrap:wrap }
.price-num { font-size:38px; font-weight:900; letter-spacing:-1.5px; color:var(--txt); line-height:1; white-space:nowrap }
.price-currency { font-size:13px; font-weight:700; color:var(--txt2); letter-spacing:.8px; text-transform:uppercase; margin-bottom:6px }
.price-per { font-size:13px; color:var(--muted); margin-bottom:6px; white-space:nowrap }
[data-lang="ar"] .plan-price { direction:ltr }
.plan-yr-note { font-size:12px; color:var(--ok); font-weight:500 }
.plan-desc { font-size:13px; color:var(--txt2); line-height:1.6 }
.plan-feats { display:flex; flex-direction:column; gap:10px; flex:1 }
.feat-yes, .feat-no { font-size:13px; display:flex; align-items:center; gap:8px }
.feat-yes::before { content:"✓"; color:var(--ok); font-weight:700; flex-shrink:0 }
.feat-no::before  { content:"✗"; color:var(--muted); flex-shrink:0 }
.feat-no { color:var(--muted) }
.pricing-footnote { font-size:13px; color:var(--muted); max-width:560px; margin:0 auto; line-height:1.8 }

/* ══════════════════════════════════════════════════════
   PAYMENT METHODS
══════════════════════════════════════════════════════ */
.payment-section { text-align:center }
.payment-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:20px; max-width:860px; margin:0 auto 40px }
.payment-card {
  background:var(--surf); border:1px solid var(--bdr); border-radius:var(--r-lg);
  padding:24px; text-align:left; display:flex; flex-direction:column; gap:10px;
  transition:border-color .2s,transform .2s;
}
.payment-card:hover { border-color:var(--bdr-h); transform:translateY(-3px) }
.pay-card-eg { border-color:rgba(34,197,94,.22) }
.pay-logo { height:36px; display:flex; align-items:center }
/* ── Payment logos ── */
.instapay-badge { display:inline-block; background:linear-gradient(90deg,#008545,#00BFA5); color:#fff; font-size:14px; font-weight:800; padding:5px 14px; border-radius:8px; letter-spacing:-.3px }
.vf-badge { display:inline-block; background:#E60000; color:#fff; font-size:14px; font-weight:800; padding:5px 14px; border-radius:8px; letter-spacing:-.3px }
/* Vodafone Cash logo wrap */
.vf-logo-wrap { display:flex; align-items:center; gap:10px }
.vf-cash-text { display:flex; flex-direction:column; line-height:1.1 }
.vf-name { font-size:12px; font-weight:700; color:#E60000 }
.vf-sub  { font-size:16px; font-weight:900; color:#E60000; letter-spacing:-.3px }
/* Supported bank badges row */
.pay-banks-row { display:flex; gap:6px; margin-top:6px; flex-wrap:wrap }
.bank-badge { font-size:10px; font-weight:700; color:#fff; padding:2px 8px; border-radius:4px }
.cib-badge  { background:linear-gradient(90deg,#003087,#005cb2) }
.nbe-badge  { background:linear-gradient(90deg,#006633,#009944) }
.payment-card h3 { font-size:15px; font-weight:700 }
.payment-card p { font-size:13px; color:var(--txt2); line-height:1.6 }
.pay-logos-row { display:flex; align-items:center; gap:12px; flex-wrap:wrap }
.pay-logos-row img { filter:brightness(0) invert(.6) }
.pay-tag { display:inline-block; font-size:11px; font-weight:600; background:rgba(255,255,255,.08); border:1px solid var(--bdr); border-radius:20px; padding:3px 10px; color:var(--txt2) }
.pay-tag-eg { background:rgba(34,197,94,.12); border-color:rgba(34,197,94,.3); color:var(--pri) }
.manual-cta { max-width:700px; margin:0 auto; background:linear-gradient(135deg,rgba(46,230,110,.1),rgba(255,255,255,.04)); border:1px solid rgba(46,230,110,.25); border-radius:var(--r-lg); padding:24px }
.mc-inner { display:flex; align-items:center; gap:16px; flex-wrap:wrap }
.mc-flag { font-size:32px; flex-shrink:0 }
.mc-text { flex:1; text-align:left }
.mc-text strong { font-size:15px }
.mc-text p { font-size:13px; color:var(--txt2); margin-top:4px }

/* ══════════════════════════════════════════════════════
   INTEGRATIONS
══════════════════════════════════════════════════════ */
.integrations-section { text-align:center; background:linear-gradient(180deg,transparent,rgba(46,230,110,.035) 40%,transparent) }
.integrations-section .section-sub { margin-bottom:52px }
.integ-categories { display:flex; flex-direction:column; gap:36px; text-align:left }

/* ── category header ───────────────────────────────────── */
.integ-cat-header { display:flex; align-items:center; gap:10px; margin-bottom:18px; padding-bottom:14px; border-bottom:1px solid var(--bdr) }
.integ-cat-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0 }
.integ-cat--ai     .integ-cat-dot { background:var(--pri);  box-shadow:0 0 10px rgba(34,197,94,.7) }
.integ-cat--social .integ-cat-dot { background:#f472b6;      box-shadow:0 0 10px rgba(244,114,182,.7) }
.integ-cat--devops .integ-cat-dot { background:#f59e0b;      box-shadow:0 0 10px rgba(245,158,11,.7) }
.integ-cat--export .integ-cat-dot { background:#06b6d4;      box-shadow:0 0 10px rgba(6,182,212,.7) }
.integ-cat-title { font-size:12px; font-weight:700; letter-spacing:.9px; text-transform:uppercase; color:var(--txt2); margin:0 }
.integ-cat-count { margin-left:auto; font-size:11px; font-weight:600; color:var(--muted); letter-spacing:.3px }

/* ── grid ──────────────────────────────────────────────── */
.integ-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(195px,1fr)); gap:12px }

/* ── card ──────────────────────────────────────────────── */
.integ-card {
  background:var(--surf); border:1px solid var(--bdr); border-radius:var(--r-lg);
  padding:16px; display:flex; align-items:center; gap:12px;
  position:relative; overflow:hidden;
  transition:border-color .2s,transform .22s,box-shadow .22s;
}
.integ-card::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.035),transparent 60%);
  pointer-events:none;
}
.integ-card:hover { transform:translateY(-3px) }
.integ-cat--ai     .integ-card:hover { border-color:rgba(34,197,94,.50);   box-shadow:0 14px 32px rgba(34,197,94,.16) }
.integ-cat--social .integ-card:hover { border-color:rgba(244,114,182,.55); box-shadow:0 14px 32px rgba(244,114,182,.18) }
.integ-cat--devops .integ-card:hover { border-color:rgba(245,158,11,.55);  box-shadow:0 14px 32px rgba(245,158,11,.18) }
.integ-cat--export .integ-card:hover { border-color:rgba(6,182,212,.55);   box-shadow:0 14px 32px rgba(6,182,212,.18) }

/* ── icon ──────────────────────────────────────────────── */
.integ-icon {
  width:38px; height:38px; border-radius:10px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-size:18px; font-style:normal; font-weight:700; line-height:1;
  border:1px solid transparent;
}
.integ-cat--ai     .integ-icon { background:rgba(34,197,94,.12);  border-color:rgba(34,197,94,.25) }
.integ-cat--social .integ-icon { background:rgba(244,114,182,.15); border-color:rgba(244,114,182,.3) }
.integ-cat--devops .integ-icon { background:rgba(245,158,11,.15);  border-color:rgba(245,158,11,.3) }
.integ-cat--export .integ-icon { background:rgba(6,182,212,.15);   border-color:rgba(6,182,212,.3) }

/* ── name ──────────────────────────────────────────────── */
.integ-name { font-size:13px; font-weight:600; color:var(--txt); flex:1; line-height:1.4; min-width:0 }

/* ── plan badge ────────────────────────────────────────── */
.integ-tag {
  margin-left:auto; flex-shrink:0;
  font-size:10px; font-weight:700; letter-spacing:.3px;
  border-radius:999px; padding:3px 9px; border:1px solid transparent;
}
.integ-all { color:#86efac; background:rgba(34,197,94,.12);  border-color:rgba(34,197,94,.3) }
.integ-pro { color:#93c5fd; background:rgba(59,130,246,.12);  border-color:rgba(59,130,246,.3) }
.integ-adv { color:#86efac; background:rgba(34,197,94,.12);  border-color:rgba(34,197,94,.3) }
.integ-biz { color:#fcd34d; background:rgba(245,158,11,.12); border-color:rgba(245,158,11,.3) }

/* ── RTL ───────────────────────────────────────────────── */
[data-lang="ar"] .integ-categories { text-align:right }
[data-lang="ar"] .integ-cat-count  { margin-left:0; margin-right:auto }
[data-lang="ar"] .integ-tag        { margin-left:0; margin-right:auto }

/* ── responsive ─────────────────────────────────────────── */
@media (max-width:860px) {
  .integ-grid { grid-template-columns:repeat(auto-fill,minmax(165px,1fr)) }
}
@media (max-width:520px) {
  .integ-categories { gap:28px }
  .integ-grid { grid-template-columns:repeat(2,1fr); gap:8px }
  .integ-card { padding:12px; gap:8px }
  .integ-icon { width:32px; height:32px; font-size:15px; border-radius:8px }
  .integ-name { font-size:12px }
  .integ-tag  { font-size:9px; padding:2px 7px }
}

/* ══════════════════════════════════════════════════════
   FAQ
══════════════════════════════════════════════════════ */
.faq-section { text-align:center }
.faq-container { max-width:700px }
.faq-list { display:flex; flex-direction:column; gap:8px; text-align:left; margin-top:48px }
.faq-item { background:var(--surf); border:1px solid var(--bdr); border-radius:var(--r); overflow:hidden; transition:border-color .2s }
.faq-item:hover { border-color:var(--bdr-h) }
.faq-item[open] { border-color:rgba(34,197,94,.30) }
.faq-item summary { padding:16px 20px; font-size:15px; font-weight:600; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:12px }
.faq-item summary::after { content:"＋"; font-size:18px; color:var(--muted); flex-shrink:0; transition:transform .2s }
.faq-item[open] summary::after { transform:rotate(45deg); color:var(--pri) }
.faq-item p { padding:0 20px 16px; font-size:14px; color:var(--txt2); line-height:1.75 }

/* ══════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════ */
.footer { border-top:1px solid var(--bdr); padding:60px 0 32px; margin-top:0 }
.footer-top { display:grid; grid-template-columns:260px 1fr; gap:48px; margin-bottom:40px }
.footer-brand { display:flex; flex-direction:column; gap:12px }
.footer-tagline { font-size:13px; color:var(--muted); line-height:1.6 }
.footer-stores { display:flex; gap:8px; flex-wrap:wrap; margin-top:4px }
.ft-store-btn { display:inline-flex; align-items:center; gap:6px; padding:6px 12px; border-radius:8px; background:var(--wash-strong); border:1px solid var(--bdr); font-size:12px; font-weight:600; color:var(--txt2); transition:background .15s,border-color .15s,color .15s }
.ft-store-btn:hover { background:rgba(255,255,255,.16); border-color:var(--bdr-h); color:var(--txt) }
.footer-cols { display:flex; gap:48px; flex-wrap:wrap }
.footer-col { display:flex; flex-direction:column; gap:10px }
.footer-col-title { font-size:12px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--muted) }
.footer-col a { font-size:13px; color:var(--txt2); transition:color .15s }
.footer-col a:hover { color:var(--txt) }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; border-top:1px solid var(--bdr); padding-top:24px }
.footer-left { display:flex; flex-direction:column; gap:3px }
.footer-copy { font-size:12px; color:var(--muted) }
.footer-reg { font-size:11px; color:var(--pri); font-weight:600; opacity:.85; letter-spacing:.2px }
.footer-reg strong { font-weight:800 }
.footer-pay { display:flex; align-items:center; gap:10px }
.footer-pay img { filter:brightness(0) invert(.4); opacity:.7 }
.fp-txt { font-size:10px; font-weight:700; color:var(--muted); border:1px solid var(--bdr); padding:2px 7px; border-radius:4px }
.fp-badge { font-size:10px; font-weight:700; color:#fff; padding:2px 8px; border-radius:4px; letter-spacing:-.2px }
.fp-ip { background:linear-gradient(90deg,#008545,#00BFA5) }
.fp-vf { background:#E60000 }

/* ══════════════════════════════════════════════════════
   DASHBOARD
══════════════════════════════════════════════════════ */
.dash-wrap { position:relative; min-height:100vh; padding:calc(var(--ann-h) + var(--nav-h) + 40px) 0 80px; overflow:hidden }
.dash-container { position:relative; z-index:1 }
.dash-header { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; margin-bottom:32px; padding:28px; background:var(--surf); border:1px solid var(--bdr); border-radius:var(--r-lg) }
.dash-user-info { display:flex; align-items:center; gap:14px }
.dash-avatar { width:52px; height:52px; border-radius:50%; border:2px solid var(--bdr); object-fit:cover }
.dash-avatar.hidden { display:none }
.dash-avatar-fallback { width:52px; height:52px; border-radius:50%; border:2px solid var(--bdr); display:flex; align-items:center; justify-content:center; background:var(--grad); color:#fff; font-weight:700; font-size:22px; text-transform:uppercase; user-select:none }
.dash-avatar-fallback.hidden { display:none }
.dash-name  { font-size:18px; font-weight:700 }
.dash-email { font-size:13px; color:var(--txt2); margin-top:2px }
.sub-badge { font-size:12px; font-weight:700; padding:5px 14px; border-radius:100px; border:1px solid }
.badge-success { color:var(--ok); border-color:rgba(16,185,129,.3); background:var(--ok-dim) }
.badge-danger  { color:var(--err); border-color:rgba(239,68,68,.3); background:var(--err-dim) }
.badge-muted   { color:var(--muted); border-color:var(--bdr); background:rgba(255,255,255,.04) }
.dash-tabs { display:flex; gap:4px; margin-bottom:24px; background:var(--wash); border:1px solid var(--bdr); border-radius:12px; padding:4px }
.dash-tab { flex:1; padding:8px 16px; border-radius:9px; font-size:13px; font-weight:600; color:var(--txt2); transition:background .15s,color .15s }
.dash-tab.active { background:var(--grad); color:#fff; box-shadow:0 2px 12px var(--pri-glow) }
.dash-panel { background:var(--surf); border:1px solid var(--bdr); border-radius:var(--r-lg); padding:28px }
.overview-cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:16px; margin-bottom:24px }
.ov-card { background:var(--surf2); border:1px solid var(--bdr); border-radius:var(--r); padding:18px; display:flex; align-items:center; gap:14px }
.ov-icon { font-size:22px }
.ov-label { font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.5px; margin-bottom:4px }
.ov-value { font-size:16px; font-weight:700 }
.upgrade-banner { background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(46,230,110,.12)); border:1px solid rgba(46,230,110,.26); border-radius:var(--r); padding:16px 20px; display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap }
.upgrade-text { font-size:14px; color:var(--txt2) }
/* ── Usage bars ─────────────────────────────────────────────────────────── */
.usage-section { display:flex; flex-direction:column; gap:14px; margin-top:4px }
.usage-row { display:flex; flex-direction:column; gap:6px }
.usage-labels { display:flex; justify-content:space-between; align-items:center }
.usage-label { font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:.4px }
.usage-count { font-size:12px; font-weight:600; color:var(--txt2) }
.usage-track { height:6px; border-radius:99px; background:rgba(255,255,255,.07); overflow:hidden }
.usage-fill { height:100%; border-radius:99px; transition:width .6s ease, background .3s }
.token-wrap { display:flex; flex-direction:column; gap:16px }
.token-title { font-size:18px; font-weight:700 }
.token-desc { font-size:14px; color:var(--txt2); line-height:1.7 }
.token-status { font-size:13px; color:var(--txt2) }
.token-box { background:rgba(0,0,0,.4); border:1px solid var(--bdr); border-radius:var(--r); padding:16px 20px; display:flex; align-items:center; gap:16px; flex-wrap:wrap }
.token-code { font-family:monospace; font-size:14px; flex:1; letter-spacing:1px; color:var(--txt2); word-break:break-all }
.token-btns { display:flex; gap:8px; flex-shrink:0 }
.token-warn { font-size:12px; color:var(--warn); line-height:1.6 }
.billing-wrap { display:flex; flex-direction:column; gap:16px }
.billing-wrap h3 { font-size:18px; font-weight:700 }
.billing-desc { font-size:14px; color:var(--txt2); line-height:1.7 }
.billing-actions { display:flex; gap:12px }
.billing-upgrade { margin-top:8px }
.billing-or { font-size:13px; color:var(--muted); text-align:center; margin-bottom:16px }
.billing-plan-btns { display:flex; gap:10px; flex-wrap:wrap }

/* ══════════════════════════════════════════════════════
   MODAL
══════════════════════════════════════════════════════ */
.modal-overlay { position:fixed; inset:0; z-index:500; background:rgba(0,0,0,.6); backdrop-filter:blur(10px); display:flex; align-items:center; justify-content:center; padding:20px }
.modal-card { background:var(--bg2); border:1px solid var(--bdr); border-radius:var(--r-lg); padding:32px; max-width:540px; width:100%; max-height:90vh; overflow-y:auto; position:relative; box-shadow:0 40px 100px rgba(0,0,0,.7) }
.modal-close { position:absolute; top:16px; right:16px; font-size:16px; color:var(--muted); transition:color .15s }
[data-lang="ar"] .modal-close { right:auto; left:16px }
.modal-close:hover { color:var(--txt) }
.modal-title { font-size:20px; font-weight:800; margin-bottom:8px }
.modal-desc  { font-size:13px; color:var(--txt2); line-height:1.7; margin-bottom:20px }
.modal-pay-boxes { display:flex; gap:12px; margin-bottom:20px; flex-wrap:wrap }
.mpb { flex:1; background:rgba(255,255,255,.05); border:1px solid var(--bdr); border-radius:var(--r); padding:14px; min-width:160px }
.mpb-label { font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:1px; margin-bottom:6px }
.mpb-val { font-size:18px; font-weight:800; color:var(--txt); letter-spacing:1px }
.modal-amounts { background:rgba(255,255,255,.03); border:1px solid var(--bdr); border-radius:var(--r); padding:16px; margin-bottom:20px }
.ma-title { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--muted); margin-bottom:12px }
.ma-row { display:flex; justify-content:space-between; align-items:center; font-size:13px; padding:6px 0; border-bottom:1px solid rgba(255,255,255,.04) }
.ma-row:last-child { border-bottom:none }

[data-theme="light"] .announce-bar {
  color:#04130a;
  background:linear-gradient(90deg,#b7ffd0,#42db81,#f2fff6);
}
[data-theme="light"] .announce-close { color:rgba(4,19,10,.7) }
[data-theme="light"] .nav.nav-scrolled,
[data-theme="light"] .mobile-menu,
[data-theme="light"] .feature-card,
[data-theme="light"] .step-card,
[data-theme="light"] .pricing-card,
[data-theme="light"] .payment-card,
[data-theme="light"] .integ-card,
[data-theme="light"] .faq-item,
[data-theme="light"] .dash-header,
[data-theme="light"] .dash-panel,
[data-theme="light"] .ov-card,
[data-theme="light"] .modal-card,
[data-theme="light"] .spotlight-code,
[data-theme="light"] .token-box,
[data-theme="light"] .table-scroll,
[data-theme="light"] .hero-pill,
[data-theme="light"] .store-badge,
[data-theme="light"] .billing-toggle {
  box-shadow:var(--shadow-soft);
}
[data-theme="light"] .mockup-bar {
  background:rgba(5,38,20,.06);
}
[data-theme="light"] .url-bar {
  background:rgba(5,38,20,.08);
  color:var(--txt2);
}
[data-theme="light"] .mockup-page {
  background:rgba(255,255,255,.46);
}
[data-theme="light"] .mockup-sidebar {
  background:linear-gradient(180deg,#082113,#123a22);
}
[data-theme="light"] .spotlight-code {
  background:rgba(6,25,14,.94);
}
[data-theme="light"] .code-header,
[data-theme="light"] .compare-table th,
[data-theme="light"] .row-price td,
[data-theme="light"] .dash-tabs,
[data-theme="light"] .usage-track,
[data-theme="light"] .modal-amounts,
[data-theme="light"] .mpb {
  background:rgba(8,44,20,.05);
}
[data-theme="light"] .hero-mockup {
  border-color:rgba(4,51,27,.14);
}
[data-theme="light"] .grid-mesh {
  background-image:linear-gradient(rgba(4,51,27,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(4,51,27,.05) 1px,transparent 1px);
}
[data-theme="light"] .hero-noise {
  opacity:.018;
}
[data-theme="light"] .nav-link:hover,
[data-theme="light"] .dropdown-item:hover,
[data-theme="light"] .mobile-link:hover,
[data-theme="light"] .btn-ghost-sm:hover,
[data-theme="light"] .btn-outline-sm:hover,
[data-theme="light"] .btn-outline-lg:hover,
[data-theme="light"] .btn-outline-full:hover {
  background:rgba(5,38,20,.06);
}
.ma-row strong { color:var(--ok) }
.modal-form { display:flex; flex-direction:column; gap:14px }
.form-row { display:flex; flex-direction:column; gap:6px }
.form-row label { font-size:12px; font-weight:600; color:var(--txt2) }
.form-row input, .form-row select {
  padding:10px 14px; background:rgba(255,255,255,.06); border:1px solid var(--bdr);
  border-radius:8px; color:var(--txt); font:inherit; font-size:14px;
  transition:border-color .15s,box-shadow .15s;
}
.form-row input:focus, .form-row select:focus { outline:none; border-color:var(--pri); box-shadow:0 0 0 3px var(--pri-dim) }
.form-row select option { background:var(--bg2) }
.form-note { font-size:12px; color:var(--muted); text-align:center; line-height:1.6 }

/* ══════════════════════════════════════════════════════
   TOASTS
══════════════════════════════════════════════════════ */
.toast-container { position:fixed; bottom:24px; right:24px; z-index:600; display:flex; flex-direction:column; gap:10px; max-width:340px }
[data-lang="ar"] .toast-container { right:auto; left:24px }
.toast { padding:12px 18px; border-radius:10px; font-size:13px; font-weight:500; box-shadow:0 6px 28px rgba(0,0,0,.5); opacity:0; transform:translateY(12px); transition:all .28s; line-height:1.5; border:1px solid var(--bdr) }
.toast.toast-show { opacity:1; transform:translateY(0) }
.toast-info    { background:var(--surf); color:var(--txt) }
.toast-success { background:rgba(16,185,129,.15); border-color:rgba(16,185,129,.3); color:#6ee7b7 }
.toast-error   { background:rgba(239,68,68,.15); border-color:rgba(239,68,68,.3); color:#fca5a5 }

/* ══════════════════════════════════════════════════════
   RTL TWEAKS
══════════════════════════════════════════════════════ */
[data-lang="ar"] .hero-title,
[data-lang="ar"] .section-title,
[data-lang="ar"] .spotlight-title { letter-spacing:0 }
[data-lang="ar"] .feat-yes::before,
[data-lang="ar"] .feat-no::before { margin-left:0; margin-right:0 }
[data-lang="ar"] .announce-bar .announce-close { right:auto; left:16px }
[data-lang="ar"] .mc-text { text-align:right }

/* ══════════════════════════════════════════════════════
   SOCIAL MEDIA SPOTLIGHT
══════════════════════════════════════════════════════ */
.social-spotlight { background:linear-gradient(135deg,rgba(139,92,246,.05),rgba(99,102,241,.03)) }
.spotlight-inner.reverse { direction:ltr }
.spotlight-inner.reverse .spotlight-text { order:1 }
.spotlight-inner.reverse .spotlight-demo { order:2 }

.demo-phone {
  background:rgba(0,0,0,.6); border:1px solid var(--bdr); border-radius:var(--r-lg);
  overflow:hidden; max-width:340px; margin:0 auto;
}
.demo-phone-header {
  display:flex; align-items:center; gap:7px; padding:12px 16px;
  background:rgba(255,255,255,.04); border-bottom:1px solid var(--bdr);
}
.demo-phone-header .demo-dot { width:8px; height:8px; border-radius:50%; background:var(--muted) }
.demo-phone-header .demo-dot:first-child { background:#ff5f57 }
.demo-phone-header .demo-dot:nth-child(2) { background:#ffbd2e }
.demo-phone-header .demo-dot:nth-child(3) { background:#28c940 }
.demo-title { font-size:12px; color:var(--muted); margin-left:8px; font-weight:600 }
.demo-phone-body { padding:12px }

.demo-social-card {
  display:flex; align-items:center; gap:12px; padding:10px 14px;
  border-radius:10px; margin-bottom:6px; transition:background .2s;
  border:1px solid transparent;
}
.demo-social-card:hover { background:rgba(99,102,241,.08); border-color:var(--bdr) }
.demo-social-icon {
  width:32px; height:32px; border-radius:8px; display:flex; align-items:center; justify-content:center;
  font-size:14px; font-weight:700; background:var(--pri-dim); color:var(--pri);
}
.demo-social-card[data-platform="linkedin"] .demo-social-icon { background:rgba(10,102,194,.15); color:#0a66c2 }
.demo-social-card[data-platform="twitter"] .demo-social-icon { background:rgba(255,255,255,.1); color:#fff }
.demo-social-card[data-platform="instagram"] .demo-social-icon { background:rgba(225,48,108,.15); color:#e1306c }
.demo-social-card[data-platform="tiktok"] .demo-social-icon { background:rgba(255,0,80,.15); color:#ff0050 }
.demo-social-card[data-platform="youtube"] .demo-social-icon { background:rgba(255,0,0,.15); color:#ff0000 }
.demo-social-card[data-platform="facebook"] .demo-social-icon { background:rgba(24,119,242,.15); color:#1877f2 }
.demo-social-name { flex:1; font-size:13px; font-weight:600; color:var(--txt) }
.demo-social-status { font-size:11px; font-weight:600; padding:3px 10px; border-radius:20px }
.demo-social-status.connected { background:var(--ok-dim); color:#6ee7b7 }
.demo-social-status.pending { background:rgba(245,158,11,.12); color:#fbbf24 }

/* ══════════════════════════════════════════════════════
   API SPOTLIGHT
══════════════════════════════════════════════════════ */
.api-spotlight { background:linear-gradient(135deg,rgba(6,182,212,.05),rgba(99,102,241,.03)) }

/* ══════════════════════════════════════════════════════
   MARKETING DEMO SECTION
══════════════════════════════════════════════════════ */
.marketing-demo-section { text-align:center }

.marketing-actions-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:12px; margin:40px 0 48px; text-align:center;
}
.mkt-action-card {
  background:var(--surf); border:1px solid var(--bdr); border-radius:var(--r);
  padding:18px 12px; cursor:pointer; transition:border-color .2s, transform .2s, box-shadow .2s;
}
.mkt-action-card:hover { border-color:var(--bdr-h); transform:translateY(-2px) }
.mkt-action-card.active {
  border-color:var(--pri); box-shadow:0 0 0 2px rgba(99,102,241,.25);
  transform:translateY(-2px);
}
.mkt-icon { font-size:24px; margin-bottom:8px }
.mkt-label { font-size:12px; font-weight:600; color:var(--txt2) }

/* Marketing audience tabs */
.mkt-tabs {
  display:flex; gap:8px; justify-content:center; flex-wrap:wrap;
  margin:0 0 12px;
}
.mkt-tab {
  background:var(--surf); border:1px solid var(--bdr); border-radius:40px;
  padding:8px 22px; font-size:13px; font-weight:600; color:var(--txt2);
  cursor:pointer; transition:all .18s; font-family:inherit;
}
.mkt-tab:hover { border-color:var(--bdr-h); color:var(--txt); }
.mkt-tab.active { background:var(--pri); border-color:var(--pri); color:#fff; }

/* Personal sub-tabs (US / Franco-EG) */
.mkt-subtabs {
  display:flex; align-items:center; gap:8px; justify-content:center;
  flex-wrap:wrap; margin:0 0 28px;
}
.mkt-subtab {
  background:transparent; border:1.5px solid rgba(255,255,255,.15);
  border-radius:20px; color:var(--txt2); cursor:pointer;
  font-size:12px; font-weight:600; padding:4px 14px;
  font-family:inherit; transition:all .18s;
}
.mkt-subtab:hover { border-color:var(--pri); color:var(--pri) }
.mkt-subtab.active { background:var(--pri); border-color:var(--pri); color:#fff }
.mkt-script-toggle {
  background:transparent; border:1.5px solid rgba(34,197,94,.5);
  border-radius:20px; color:#4ade80; cursor:pointer;
  font-size:11px; font-weight:700; padding:3px 12px;
  font-family:inherit; transition:all .18s; margin-left:6px;
}
.mkt-script-toggle:hover { background:rgba(34,197,94,.2); color:#fff }

/* Browser control badge in demo header */
.mkt-browser-ctrl {
  display:flex; align-items:center; gap:5px; margin-left:auto; flex-shrink:0;
}
.mkt-ctrl-label {
  font-size:10px; font-weight:700; color:var(--txt3); text-transform:uppercase;
  letter-spacing:.05em;
}
.mkt-ctrl-dot {
  width:7px; height:7px; border-radius:50%; background:#22c55e; flex-shrink:0;
  animation:ctrlPulse 1.8s ease-in-out infinite;
}
.mkt-ctrl-dot.off { background:#6b7280; animation:none }
@keyframes ctrlPulse {
  0%,100% { opacity:1; transform:scale(1) }
  50% { opacity:.5; transform:scale(1.35) }
}
.mkt-ctrl-toggle {
  background:#22c55e; border:none; border-radius:10px; color:#fff;
  cursor:pointer; font-size:10px; font-weight:800; letter-spacing:.06em;
  padding:3px 9px; transition:all .2s;
}
.mkt-ctrl-toggle.off { background:#4b5563 }
.mkt-ctrl-toggle:hover { filter:brightness(1.12) }

/* ── Demo split panel ── */
.mkt-content-demo {
  margin:0 auto; text-align:left;
  background:rgba(0,0,0,.5); border:1px solid var(--bdr); border-radius:var(--r-lg);
  overflow:hidden;
}
.mkt-demo-header {
  display:flex; align-items:center; gap:10px; padding:13px 20px; flex-wrap:wrap;
  background:rgba(255,255,255,.03); border-bottom:1px solid var(--bdr);
}
.mkt-demo-badge {
  font-size:10px; font-weight:700; letter-spacing:1px; padding:3px 10px;
  border-radius:20px; background:var(--ok-dim); color:#6ee7b7; flex-shrink:0;
}
.mkt-demo-title { font-size:13px; font-weight:700; color:var(--txt) }
.mkt-demo-meta {
  font-size:12px; color:var(--txt2); margin-left:auto;
  display:flex; align-items:center; gap:5px;
}
.mkt-demo-meta strong { color:var(--txt) }
.mkt-demo-sep { color:var(--muted) }
/* Split layout */
.mkt-demo-split { display:grid; grid-template-columns:.95fr 1.05fr 1.15fr; min-height:320px; }
@media (max-width:760px) { .mkt-demo-split { grid-template-columns:1fr } }
.demo-panel { padding:20px; display:flex; flex-direction:column; }
.demo-panel-request,
.demo-panel-output { border-right:1px solid var(--bdr) }
@media (max-width:760px) {
  .demo-panel-request,
  .demo-panel-output { border-right:none; border-bottom:1px solid var(--bdr) }
}
.demo-panel-hd {
  display:flex; align-items:center; gap:8px; margin-bottom:12px;
}
.demo-panel-icon { font-size:14px }
.demo-panel-label {
  font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:.08em; color:var(--txt2);
}
.demo-live-badge {
  margin-left:auto; font-size:10px; font-weight:700; color:var(--ok);
  animation:livePulse 1.6s ease infinite;
}
@keyframes livePulse { 0%,100%{opacity:1} 50%{opacity:.35} }
.demo-topic-chip {
  display:inline-block; background:var(--pri-dim);
  border:1px solid rgba(99,102,241,.22); border-radius:6px;
  padding:3px 10px; font-size:12px; color:#a5b4fc; margin-bottom:12px;
}
.demo-block-label {
  display:block; margin-bottom:8px; font-size:10px; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase; color:var(--txt2);
}
.mkt-demo-request,
.demo-summary-card,
.mkt-demo-output {
  background:rgba(99,102,241,.06); border:1px solid rgba(99,102,241,.15);
  border-radius:10px; padding:16px; flex:1; overflow-y:auto; max-height:260px;
}
.demo-summary-card {
  background:rgba(255,255,255,.04); border-color:rgba(255,255,255,.08);
  flex:0 0 auto; overflow:visible; max-height:none; margin-bottom:14px;
}
.demo-request-text { color:var(--txt) }
.demo-summary-headline {
  margin:0 0 12px; font-size:15px; line-height:1.45; color:var(--txt);
  font-weight:600;
}
.demo-summary-list { display:flex; flex-direction:column; gap:10px; }
.demo-summary-item { display:flex; align-items:flex-start; gap:9px; }
.demo-summary-dot {
  color:#a5b4fc; font-size:14px; line-height:1.1; flex-shrink:0; margin-top:1px;
}
.demo-summary-point {
  font-size:12.5px; line-height:1.55; color:var(--txt2);
}
.mkt-demo-text {
  font-size:13px; color:var(--txt2); line-height:1.75; white-space:pre-line;
  animation:typing-reveal .4s ease-out forwards;
}
@keyframes typing-reveal {
  0% { opacity:0; transform:translateY(6px) }
  100% { opacity:1; transform:translateY(0) }
}
/* Execution steps (right panel) */
.demo-steps-list { display:flex; flex-direction:column; flex:1; }
.demo-steps-empty {
  font-size:12px; color:var(--muted); padding:32px 0;
  text-align:center; line-height:1.6;
}
.demo-step {
  display:flex; align-items:flex-start; gap:10px;
  padding:9px 0; border-bottom:1px solid rgba(255,255,255,.04);
  opacity:0; transform:translateY(8px);
  animation:stepFadeIn .35s ease forwards;
}
.demo-step:last-child { border-bottom:none }
@keyframes stepFadeIn { to { opacity:1; transform:translateY(0) } }
.demo-step-icon {
  font-size:14px; flex-shrink:0; width:20px;
  text-align:center; margin-top:1px;
}
.demo-step-body { flex:1; min-width:0 }
.demo-step-text {
  font-size:12.5px; line-height:1.45; color:var(--txt2);
  display:block;
}
.demo-step-text.s-done { color:var(--ok) }
.demo-step-text.s-active { color:var(--txt); font-weight:500 }
.demo-step-tick {
  font-size:12px; color:var(--ok); flex-shrink:0;
  padding-left:4px; margin-top:2px;
}
.demo-step-spin {
  flex-shrink:0; width:13px; height:13px; border-radius:50%;
  border:2px solid rgba(99,102,241,.3); border-top-color:var(--pri);
  animation:spin .7s linear infinite; margin-top:2px;
}
@keyframes spin { to { transform:rotate(360deg) } }

/* ══════════════════════════════════════════════════════
   BROWSER TUNNEL SPOTLIGHT
══════════════════════════════════════════════════════ */
.spotlight-inner-rev { direction:ltr }
@media (min-width:901px) {
  .spotlight-inner-rev { grid-template-columns:1fr 1fr }
  .spotlight-inner-rev .spotlight-text { order:1 }
  .spotlight-inner-rev .tunnel-demo { order:2 }
}

.tunnel-demo {
  display:flex; flex-direction:column; gap:16px; align-items:center;
}
.tunnel-diagram {
  display:flex; flex-direction:column; align-items:center; gap:0;
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r); padding:32px 24px; width:100%;
}
.tunnel-node {
  display:flex; flex-direction:column; align-items:center; gap:6px;
  padding:16px 24px; border-radius:12px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1);
  min-width:180px; text-align:center; transition:border-color .3s;
}
.tunnel-node:hover { border-color:var(--pri) }
.tunnel-node-icon { font-size:28px }
.tunnel-node-label { font-size:13px; color:var(--txt2); font-weight:500 }
.tunnel-line {
  display:flex; flex-direction:column; align-items:center;
  height:40px; position:relative; width:2px;
  background:linear-gradient(to bottom, var(--pri), var(--pri2));
}
.tunnel-pulse {
  position:absolute; width:8px; height:8px; border-radius:50%;
  background:var(--cyan); top:0;
  animation:tunnel-pulse-anim 2s ease-in-out infinite;
}
@keyframes tunnel-pulse-anim {
  0% { top:0; opacity:1 }
  100% { top:32px; opacity:.3 }
}
.tunnel-line-label {
  position:absolute; left:12px; top:50%; transform:translateY(-50%);
  font-size:10px; color:var(--txt3); white-space:nowrap; text-transform:uppercase;
  letter-spacing:.5px;
}
.tunnel-status-bar {
  display:flex; align-items:center; gap:8px;
  background:rgba(34,197,94,.08); border:1px solid rgba(34,197,94,.2);
  border-radius:8px; padding:8px 16px; font-size:13px; color:#22c55e;
}
.tunnel-status-dot {
  width:8px; height:8px; border-radius:50%; background:#22c55e;
  animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%,100% { box-shadow:0 0 0 0 rgba(34,197,94,.4) }
  50% { box-shadow:0 0 0 6px rgba(34,197,94,0) }
}

/* ══════════════════════════════════════════════════════
   DASHBOARD – TUNNEL TAB
══════════════════════════════════════════════════════ */
.tunnel-tab-wrap { display:flex; flex-direction:column; gap:20px }
.tunnel-tab-desc { color:var(--txt2); font-size:14px; margin:0 }
.tunnel-conn-status {
  display:flex; align-items:center; gap:10px;
  padding:12px 16px; border-radius:var(--r);
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08);
  font-size:14px; color:var(--txt2);
}
.tunnel-conn-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0 }
.dot-on  { background:#22c55e; box-shadow:0 0 8px rgba(34,197,94,.5) }
.dot-off { background:#ef4444; box-shadow:0 0 8px rgba(239,68,68,.3) }
.tunnel-tokens-section { display:flex; flex-direction:column; gap:12px }
.tunnel-tokens-header {
  display:flex; justify-content:space-between; align-items:center;
}
.tunnel-tokens-header h4 { margin:0; font-size:15px; color:var(--txt) }
.tunnel-token-form {
  display:flex; gap:8px; flex-wrap:wrap; align-items:flex-end;
  padding:12px; background:rgba(255,255,255,.03); border-radius:var(--r);
  border:1px solid rgba(255,255,255,.08);
}
.tunnel-token-form input {
  flex:1; min-width:160px; padding:8px 12px; border-radius:8px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12);
  color:var(--txt); font-size:13px; outline:none;
}
.tunnel-token-form input:focus { border-color:var(--pri) }
.tunnel-token-form-actions { display:flex; gap:6px }
.tunnel-tokens-list { display:flex; flex-direction:column; gap:8px }
.tunnel-tokens-empty { color:var(--txt3); font-size:13px; padding:12px 0 }
.tunnel-token-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:12px 16px; border-radius:var(--r);
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08);
  flex-wrap:wrap; gap:8px;
}
.tunnel-token-info { display:flex; flex-direction:column; gap:4px; min-width:0 }
.tunnel-token-val {
  font-size:12px; color:var(--cyan); word-break:break-all;
  background:rgba(6,182,212,.08); padding:2px 6px; border-radius:4px;
}
.tunnel-token-ips { font-size:11px; color:var(--txt3) }
.tunnel-token-actions { display:flex; gap:6px; flex-shrink:0 }

/* ══════════════════════════════════════════════════════
   DASHBOARD – PRESETS TAB
══════════════════════════════════════════════════════ */
.presets-tab-wrap { display:flex; flex-direction:column; gap:16px }
.presets-tab-desc { color:var(--txt2); font-size:14px; margin:0 }
.presets-filter { display:flex; gap:6px }
.preset-filter-btn {
  padding:6px 14px; border-radius:8px; border:1px solid rgba(255,255,255,.1);
  background:transparent; color:var(--txt2); font-size:13px; cursor:pointer;
  transition:all .2s;
}
.preset-filter-btn.active,
.preset-filter-btn:hover {
  background:var(--pri); color:#fff; border-color:var(--pri);
}
.presets-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
  gap:12px;
}
.presets-loading { color:var(--txt3); font-size:13px; grid-column:1/-1; padding:16px 0 }
.preset-card {
  display:flex; flex-direction:column; gap:8px;
  padding:16px; border-radius:var(--r);
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08);
  transition:border-color .2s, transform .2s;
}
.preset-card:hover { border-color:var(--pri); transform:translateY(-2px) }
.preset-icon { font-size:24px }
.preset-name { font-size:14px; font-weight:600; color:var(--txt) }
.preset-desc { font-size:12px; color:var(--txt3); line-height:1.5 }
.preset-meta { display:flex; align-items:center; gap:8px; margin-top:auto }
.preset-badge-sys {
  font-size:10px; padding:2px 8px; border-radius:4px;
  background:rgba(99,102,241,.15); color:var(--pri); text-transform:uppercase;
  letter-spacing:.5px; font-weight:600;
}
.preset-badge-custom {
  font-size:10px; padding:2px 8px; border-radius:4px;
  background:rgba(34,197,94,.12); color:#22c55e; text-transform:uppercase;
  letter-spacing:.5px; font-weight:600;
}
.preset-steps { font-size:11px; color:var(--txt3) }

/* ═══════════════════════════════════════════════════════════════════════════
   HERO CYCLING TEXT
═══════════════════════════════════════════════════════════════════════════ */
.hero-cycle-wrap { display:inline-block; position:relative; }
.hero-cycle      { display:inline-block; }
.hero-cycle.cycle-out {
  opacity:0;
  transform:translateY(-18px) skewX(3deg);
  filter:blur(5px);
  transition:opacity .25s ease, transform .28s ease, filter .25s ease;
}
@keyframes heroCycleIn {
  from { opacity:0; transform:translateY(22px) skewX(-3deg); filter:blur(7px); }
  to   { opacity:1; transform:translateY(0)    skewX(0);     filter:blur(0);   }
}
.hero-cycle.cycle-in { animation:heroCycleIn .42s cubic-bezier(.22,1,.36,1) forwards; }

/* ═══════════════════════════════════════════════════════════════════════════
   PIPELINE DEMO SECTION
═══════════════════════════════════════════════════════════════════════════ */
.pipeline-section {
  background:radial-gradient(ellipse 80% 50% at 50% 0%, rgba(34,197,94,.04) 0%, transparent 70%);
}

/* --- Demo action cards row ------------------------------------------------ */
.pipe-demo-row {
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:12px;
  margin:48px 0 36px;
}
@media(max-width:960px){ .pipe-demo-row{ grid-template-columns:repeat(3,1fr); } }
@media(max-width:520px) { .pipe-demo-row{ grid-template-columns:repeat(2,1fr); } }

.pipe-demo-card {
  position:relative;
  background:var(--surf);
  border:1px solid var(--bdr);
  border-radius:var(--r-lg);
  padding:14px 12px 12px;
  overflow:hidden;
  opacity:.4;
  transform:translateY(5px);
  transition:opacity .38s, transform .38s, border-color .38s, box-shadow .38s;
}
.pipe-demo-card.active {
  opacity:1;
  transform:translateY(0);
  border-color:rgba(34,197,94,.4);
  box-shadow:0 0 22px rgba(34,197,94,.18), 0 4px 24px rgba(0,0,0,.35);
}
.pipe-demo-card.done {
  opacity:.72;
  border-color:rgba(34,197,94,.18);
}
.pdc-highlight {
  background:linear-gradient(135deg,rgba(34,197,94,.09) 0%,var(--surf) 65%);
}
.pdc-badge {
  position:absolute; top:7px; right:8px;
  font-size:9px; font-weight:700; letter-spacing:.08em;
  color:var(--pri); background:var(--pri-dim);
  padding:2px 6px; border-radius:4px;
}
.pdc-icon   { font-size:22px; margin-bottom:7px; }
.pdc-title  { font-size:11px; font-weight:600; color:var(--txt); margin-bottom:4px; }
.pdc-status {
  font-size:10px; color:var(--txt2); line-height:1.45;
  min-height:28px; font-family:'IBM Plex Mono',monospace;
  white-space:pre-wrap;
}
.pdc-bar    { height:2px; background:var(--bdr); border-radius:1px; margin-top:10px; overflow:hidden; }
.pdc-fill   { height:100%; width:0%; background:var(--grad); border-radius:1px; }
.pipe-demo-card.active .pdc-fill { animation:pipeBarFill 2.6s ease forwards; }
@keyframes pipeBarFill { from{width:0%} to{width:100%} }

.pdc-pulse {
  position:absolute; inset:0; border-radius:inherit;
  background:radial-gradient(circle at 50% 50%,rgba(34,197,94,.07),transparent 70%);
  opacity:0; pointer-events:none;
}
.pipe-demo-card.active .pdc-pulse { opacity:1; animation:pdcPulse 1.1s ease infinite alternate; }
@keyframes pdcPulse { from{opacity:.35} to{opacity:.85} }

/* --- Pipeline flow nodes -------------------------------------------------- */
.pipeline-flow {
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  row-gap:10px;
  margin-top:6px;
}
.pipe-node {
  display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:10px 16px;
  border-radius:var(--r);
  background:var(--surf);
  border:1px solid var(--bdr);
  transition:border-color .35s, box-shadow .35s, transform .35s;
}
.pipe-node.active {
  border-color:var(--pri);
  box-shadow:0 0 18px rgba(34,197,94,.32);
  transform:scale(1.07);
}
.pipe-node.done   { border-color:rgba(34,197,94,.28); }
.pipe-node-ai {
  background:linear-gradient(135deg,rgba(34,197,94,.1),var(--surf));
  border-color:rgba(34,197,94,.22);
}
.pn-icon  { font-size:18px; }
.pn-label {
  font-size:10px; font-weight:600; color:var(--txt2);
  letter-spacing:.05em; text-transform:uppercase;
}
.pipe-node.active .pn-label { color:var(--pri); }
.pipe-node.done   .pn-label { color:rgba(34,197,94,.65); }

.pipe-connector {
  display:flex; align-items:center; padding:0 2px;
}
.pipe-line {
  width:30px; height:1px;
  background:rgba(34,197,94,.2);
  transition:background .35s, box-shadow .35s;
}
.pipe-arrow-head {
  font-size:20px; line-height:1; color:rgba(34,197,94,.4);
  transform:scaleX(1.5); transition:color .35s;
}
.pipe-connector.active .pipe-line {
  background:var(--pri);
  box-shadow:0 0 8px rgba(34,197,94,.55);
}
.pipe-connector.active .pipe-arrow-head { color:var(--pri); }

/* ══════════════════════════════════════════════════════════════════
   HERO DOWNLOAD BUTTONS  (Windows + Chrome)
══════════════════════════════════════════════════════════════════ */
.hero-dl-row {
  display:flex; gap:14px; flex-wrap:wrap; justify-content:center;
  margin-bottom:6px;
}
.btn-dl {
  display:inline-flex; align-items:center; gap:14px;
  padding:13px 22px; border-radius:16px;
  border:1.5px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  text-decoration:none; color:var(--txt); cursor:pointer;
  position:relative; overflow:hidden;
  transition: transform .5s cubic-bezier(.34,1.56,.64,1),
              box-shadow .3s ease, border-color .3s ease;
}
.btn-dl::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(120deg,transparent 35%,rgba(255,255,255,.07) 50%,transparent 65%);
  transform:translateX(-100%);
  transition:transform .55s ease;
}
.btn-dl:hover::before { transform:translateX(100%) }
.btn-dl:hover { transform:translateY(-4px) scale(1.03); border-color:rgba(255,255,255,.28); box-shadow:0 14px 44px rgba(0,0,0,.32) }
.btn-dl-win:hover  { border-color:rgba(0,173,239,.55); box-shadow:0 14px 44px rgba(0,173,239,.22) }
.btn-dl-chrome:hover { border-color:rgba(66,133,244,.55); box-shadow:0 14px 44px rgba(66,133,244,.22) }
.dl-os-icon { width:30px; height:30px; flex-shrink:0 }
.dl-text    { display:flex; flex-direction:column; text-align:left }
.dl-label   { font-size:14px; font-weight:700; color:#fff; line-height:1.2 }
.dl-sub     { font-size:11px; color:rgba(255,255,255,.5); margin-top:3px }
.dl-old-price {
  text-decoration:line-through;
  text-decoration-thickness:1.5px;
  color:rgba(255,255,255,.42);
  margin-right:6px;
}
.dl-bolt    { font-size:20px; opacity:.35; transition:opacity .2s, transform .35s }
.btn-dl:hover .dl-bolt { opacity:1; animation:boltShake .45s ease }

@keyframes boltShake {
  0%   { transform:rotate(0)    scale(1)   }
  25%  { transform:rotate(-18deg) scale(1.35) }
  55%  { transform:rotate(12deg)  scale(1.2)  }
  80%  { transform:rotate(-6deg)  scale(1.08) }
  100% { transform:rotate(0)    scale(1)   }
}

/* ══════════════════════════════════════════════════════════════════
   LIFETIME BANNER  (5th pricing tier)
══════════════════════════════════════════════════════════════════ */
@keyframes ltBoltPulse {
  0%,100% { opacity:.08; transform:translateY(-50%) rotate(-8deg) scale(1)   }
  50%     { opacity:.18; transform:translateY(-50%) rotate(-8deg) scale(1.06) }
}
@keyframes ltBoltFlash {
  0%,100% { opacity:0;   transform:scale(.75) }
  40%,60% { opacity:1;   transform:scale(1.25) }
}
@keyframes ltBorderGlow {
  0%,100% { border-color:rgba(16,185,129,.35) }
  50%     { border-color:rgba(16,185,129,.75) }
}

.lifetime-banner {
  position:relative; overflow:hidden;
  background:linear-gradient(135deg,rgba(16,185,129,.11),rgba(5,150,105,.06),rgba(0,0,0,0));
  border:1.5px solid rgba(16,185,129,.38);
  border-radius:22px; padding:38px 44px;
  display:flex; align-items:center; gap:44px; flex-wrap:wrap;
  margin-top:32px;
  animation:ltBorderGlow 3.5s ease-in-out infinite;
  transition:transform .55s cubic-bezier(.34,1.56,.64,1), box-shadow .35s ease;
}
.lifetime-banner:hover {
  transform:translateY(-8px);
  box-shadow:0 28px 90px rgba(16,185,129,.22);
}
.lt-bg-bolt {
  position:absolute; font-size:280px; right:-30px; top:50%;
  transform:translateY(-50%) rotate(-8deg);
  opacity:.08; pointer-events:none; line-height:1;
  animation:ltBoltPulse 3.5s ease-in-out infinite;
  filter:drop-shadow(0 0 50px #10b981);
  user-select:none;
}
.lt-left    { flex:0 0 auto; min-width:220px }
.lt-eyebrow { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:#10b981; margin-bottom:10px }
.lt-name    { font-size:30px; font-weight:800; color:#fff; margin-bottom:10px; letter-spacing:-.5px }
.lt-name-animated {
  font-size:64px;
  line-height:.95;
  letter-spacing:-1.4px;
  margin-bottom:14px;
  background:linear-gradient(120deg,#ecfdf5 0%,#34d399 30%,#10b981 60%,#6ee7b7 100%);
  background-size:220% auto;
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  animation:ltFillosGlow 4.2s linear infinite;
}
.lt-price   { display:flex; align-items:baseline; gap:10px; margin-bottom:12px }
.lt-price-old {
  font-size:24px;
  font-weight:700;
  color:rgba(255,255,255,.48);
  text-decoration:line-through;
  text-decoration-thickness:2px;
}
.lt-price-stack { flex-direction:column; align-items:flex-start; gap:4px }
.lt-price-kicker {
  font-size:11px;
  font-weight:700;
  letter-spacing:1.2px;
  text-transform:uppercase;
  color:rgba(255,255,255,.55);
}
.lt-price-num {
  font-size:44px; font-weight:800; letter-spacing:-1px;
  background:linear-gradient(135deg,#10b981,#34d399,#6ee7b7);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.lt-price-note {
  display:block;
  margin-bottom:12px;
  font-size:13px;
  color:rgba(255,255,255,.62);
  font-weight:600;
}
.lt-desc { font-size:13px; color:rgba(255,255,255,.55); max-width:240px; line-height:1.5 }

@keyframes ltFillosGlow {
  0% { background-position:0% center; filter:drop-shadow(0 0 0 rgba(16,185,129,0)); }
  50% { background-position:100% center; filter:drop-shadow(0 0 22px rgba(16,185,129,.35)); }
  100% { background-position:220% center; filter:drop-shadow(0 0 0 rgba(16,185,129,0)); }
}

.lt-feats {
  list-style:none; padding:0; margin:0; flex:1;
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:10px 28px; min-width:240px;
}
.lt-feats li {
  font-size:13px; color:#d1fae5; display:flex;
  align-items:center; gap:8px; line-height:1.4;
}
.lt-feats li::before { content:'⚡'; font-size:11px; color:#10b981; flex-shrink:0 }

.btn-lifetime {
  flex-shrink:0; display:inline-flex; align-items:center; gap:10px;
  padding:17px 34px; border-radius:14px; font-size:15px; font-weight:700;
  background:linear-gradient(135deg,#10b981,#059669); color:#fff;
  box-shadow:0 4px 28px rgba(16,185,129,.45); cursor:pointer;
  border:none; white-space:nowrap;
  transition:transform .5s cubic-bezier(.34,1.56,.64,1), box-shadow .3s ease;
}
.btn-lifetime:hover {
  transform:translateY(-4px) scale(1.05);
  box-shadow:0 10px 48px rgba(16,185,129,.65);
}
.lt-bolt-anim { font-size:18px; display:inline-block; animation:ltBoltFlash 2s ease-in-out infinite }

.desktop-lead-banner {
  align-items:flex-start;
}

.lt-form {
  flex:1 1 340px;
  min-width:320px;
  background:rgba(2, 6, 23, .34);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  padding:20px;
}

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

.lt-label {
  display:flex;
  flex-direction:column;
  gap:8px;
  font-size:12px;
  font-weight:700;
  color:#d1fae5;
}

.lt-label-full {
  grid-column:1 / -1;
}

.lt-input {
  width:100%;
  border:1px solid rgba(255,255,255,.14);
  border-radius:12px;
  background:rgba(255,255,255,.05);
  color:#fff;
  padding:12px 14px;
  font:inherit;
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.lt-input::placeholder {
  color:rgba(255,255,255,.4);
}

.lt-input:focus {
  outline:none;
  border-color:rgba(16,185,129,.8);
  box-shadow:0 0 0 3px rgba(16,185,129,.12);
  background:rgba(255,255,255,.07);
}

.lt-textarea {
  min-height:110px;
  resize:vertical;
}

.lt-form-actions {
  display:flex;
  align-items:center;
  gap:16px;
  justify-content:space-between;
  margin-top:16px;
  flex-wrap:wrap;
}

.lt-form-note {
  flex:1;
  min-width:200px;
  font-size:12px;
  color:rgba(255,255,255,.52);
  line-height:1.5;
}

.lt-form-status {
  margin-top:14px;
  border-radius:14px;
  padding:12px 14px;
  font-size:13px;
  font-weight:600;
  line-height:1.5;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.04);
}

.lt-form-status.is-success {
  color:#d1fae5;
  border-color:rgba(16,185,129,.38);
  background:rgba(16,185,129,.13);
}

.lt-form-status.is-error {
  color:#fee2e2;
  border-color:rgba(248,113,113,.34);
  background:rgba(127,29,29,.24);
}

.lt-success-card {
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:14px 16px;
  border-radius:14px;
  border:1px solid rgba(16,185,129,.38);
  background:rgba(16,185,129,.13);
  color:#d1fae5;
  min-width:260px;
}

.lt-success-card strong {
  font-size:13px;
  font-weight:800;
}

.lt-success-card span {
  font-size:12px;
  line-height:1.5;
  color:rgba(209,250,229,.92);
}

@media (max-width:768px) {
  .lifetime-banner { flex-direction:column; padding:28px 24px; gap:28px }
  .lt-name-animated { font-size:50px }
  .lt-feats        { grid-template-columns:1fr }
  .lt-bg-bolt      { font-size:160px; right:-10px }
  .lt-form         { min-width:100%; width:100% }
  .lt-form-grid    { grid-template-columns:1fr }
  .lt-form-actions { align-items:stretch }
  .lt-form-actions .btn-lifetime { width:100%; justify-content:center }
}

/* ══════════════════════════════════════════════════════════════════
   PRICING CARD — spring featured + enterprise hover overrides
══════════════════════════════════════════════════════════════════ */
.pricing-card.featured:hover      { transform:translateY(-12px) scale(1.028); box-shadow:0 28px 72px rgba(34,197,94,.22) }
.pricing-card-enterprise:hover    { transform:translateY(-12px) scale(1.028); box-shadow:0 28px 72px rgba(245,158,11,.2) }

.pipe-caption {
  text-align:center; margin-top:28px;
  color:var(--txt2); font-size:13px;
}
.pipe-link { color:var(--pri); text-decoration:none; font-weight:500; }
.pipe-link:hover { text-decoration:underline; }

/* ══════════════════════════════════════════════════════
   DASHBOARD – SOCIAL ACCOUNTS TAB
══════════════════════════════════════════════════════ */
.social-tab-wrap { display:flex; flex-direction:column; gap:16px }
.social-tab-desc { color:var(--txt2); font-size:14px; margin:0 }
.social-loading { color:var(--txt3); font-size:13px; padding:16px 0 }
.social-platforms-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));
  gap:12px;
}
.social-platform-card {
  display:flex; flex-direction:column; gap:10px;
  padding:16px; border-radius:var(--r);
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-top:3px solid var(--plat-color, var(--pri));
  transition:border-color .2s, transform .2s;
}
.social-platform-card:hover { transform:translateY(-2px) }
.social-plat-header { display:flex; align-items:center; gap:10px }
.social-plat-icon { font-size:22px }
.social-plat-name { font-size:15px; font-weight:600; color:var(--txt); flex:1 }
.social-plat-status { font-size:12px; font-weight:500 }
.sps-on  { color:#22c55e }
.sps-off { color:var(--txt3) }
.social-plat-scopes { font-size:11px; color:var(--txt3); line-height:1.5 }
.social-plat-actions { display:flex; gap:8px; flex-wrap:wrap; margin-top:auto }

/* ══════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════ */
@media (max-width:900px) {
  .spotlight-inner { grid-template-columns:1fr; gap:32px }
  .spotlight-code { order:2 }
  .spotlight-text { order:1 }
  .spotlight-inner.reverse .spotlight-demo { order:2 }
  .spotlight-inner.reverse .spotlight-text { order:1 }
  .spotlight-inner-rev .tunnel-demo { order:2 }
  .spotlight-inner-rev .spotlight-text { order:1 }
  .footer-top { grid-template-columns:1fr }
}
@media (max-width:768px) {
  .nav-links, .nav-controls { display:none }
  .hamburger { display:flex }
  .mockup-body { grid-template-columns:1fr }
  .mockup-sidebar { display:none }
  .steps-grid { flex-direction:column; align-items:stretch }
  .step-arrow { transform:rotate(90deg); text-align:center }
  .section { padding:64px 0 }
  .hero { padding:calc(var(--ann-h) + var(--nav-h) + 32px) 0 60px }
}
@media (max-width:520px) {
  .pricing-grid { grid-template-columns:1fr }
  .overview-cards { grid-template-columns:1fr 1fr }
  .hero-title { letter-spacing:-1px }
  .payment-grid { grid-template-columns:1fr }
  .billing-plan-btns { flex-direction:column }
  .announce-bar { font-size:11px }
  .marketing-actions-grid { grid-template-columns:repeat(3,1fr) }
  .mkt-demo-input-row { flex-direction:column }
  .presets-grid { grid-template-columns:1fr }
  .social-platforms-grid { grid-template-columns:1fr }
  .dash-tabs { flex-wrap:wrap }
  .tunnel-token-row { flex-direction:column; align-items:flex-start }
}

/* Homepage live demo (standalone 4-card flow) */
.hld-nav {
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
  margin:18px auto 20px;
}
.hld-pill {
  border:1px solid var(--bdr);
  background:rgba(255,255,255,.04);
  color:var(--txt2);
  padding:9px 14px;
  border-radius:999px;
  font:600 12px/1 var(--font);
  letter-spacing:.02em;
}
.hld-pill.active,
.hld-pill:hover {
  border-color:rgba(34,197,94,.45);
  background:rgba(34,197,94,.12);
  color:var(--txt);
}
.hld-task-rail {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:center;
  margin:0 auto 18px;
}
.hld-task-pill {
  font-size:11px;
  padding:7px 11px;
  opacity:.92;
}
.hld-shell {
  border:1px solid var(--bdr);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(10,11,15,.96), rgba(8,9,12,.96));
  overflow:hidden;
  box-shadow:0 18px 40px rgba(0,0,0,.35);
}
.hld-top {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:14px 18px;
  border-bottom:1px solid var(--bdr);
  background:rgba(0,0,0,.3);
}
.hld-top-left,
.hld-top-mid,
.hld-top-right {
  display:flex;
  align-items:center;
  gap:8px;
}
.hld-badge {
  border:1px solid rgba(34,197,94,.35);
  color:var(--ok);
  background:rgba(34,197,94,.12);
  border-radius:999px;
  padding:4px 8px;
  font:700 11px/1 var(--font);
}
.hld-title { font:700 14px/1 var(--font); color:var(--txt); }
.hld-muted { color:var(--txt2); font-size:12px; }
.hld-dot { color:var(--muted); }
.hld-switch {
  border-radius:999px;
  background:var(--ok);
  color:#06220f;
  padding:3px 9px;
  font:700 11px/1 var(--font);
}
.hld-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  padding:18px;
}
.hld-card {
  position:relative;
  border:1px solid var(--bdr);
  border-radius:12px;
  background:rgba(255,255,255,.02);
  padding:16px;
  text-align:left;
  transition:opacity .25s ease, transform .25s ease;
}
.hld-card.hld-fade {
  opacity:.35;
  transform:translateY(3px);
}
.hld-card header {
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:10px;
}
.hld-card h4 {
  margin:0;
  font:700 12px/1 var(--font);
  letter-spacing:.06em;
  color:var(--txt2);
  text-transform:uppercase;
}
.hld-chip {
  border:1px solid rgba(34,197,94,.28);
  background:rgba(34,197,94,.08);
  color:#cbf7db;
  border-radius:8px;
  padding:10px;
  margin-bottom:10px;
  font-weight:600;
}
.hld-box {
  border:1px solid rgba(74,222,128,.18);
  background:rgba(12,18,14,.72);
  border-radius:10px;
  padding:12px;
}
.hld-label {
  display:block;
  color:var(--txt2);
  font:700 11px/1 var(--font);
  letter-spacing:.06em;
  margin-bottom:8px;
}
.hld-box p,
.hld-summary h5,
.hld-summary li,
.hld-step {
  margin:0;
  color:var(--txt);
}
.hld-summary h5 {
  font:600 22px/1.25 var(--font);
  margin:0 0 8px;
}
.hld-summary ul {
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.hld-summary li {
  color:var(--txt2);
  font-size:14px;
  line-height:1.45;
}
.hld-summary li.hld-highlight { color:var(--txt); }
.hld-ai pre {
  margin:0;
  border:1px solid var(--bdr);
  border-radius:10px;
  background:rgba(4,6,8,.7);
  color:#d7e0e9;
  font:500 13px/1.5 "IBM Plex Mono", ui-monospace, monospace;
  min-height:215px;
  padding:12px;
  white-space:pre-wrap;
}
.hld-split { justify-content:space-between; }
.hld-split div {
  display:flex;
  align-items:center;
  gap:8px;
}
.hld-split strong {
  color:var(--ok);
  font-size:11px;
  letter-spacing:.06em;
}
#hld-steps {
  display:flex;
  flex-direction:column;
  gap:8px;
}
.hld-step {
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--txt2);
  border-bottom:1px dashed var(--bdr);
  padding:9px 0;
}
.hld-step:last-child { border-bottom:none; }
.hld-step .hld-check {
  margin-left:auto;
  color:var(--ok);
  opacity:0;
  transform:scale(.6);
  transition:all .2s ease;
}
.hld-step.hld-active { color:var(--txt); }
.hld-step.hld-done .hld-check {
  opacity:1;
  transform:scale(1);
}
.hld-arrow {
  position:absolute;
  width:26px;
  height:26px;
  border-radius:999px;
  background:var(--ok);
  color:#05200f;
  display:grid;
  place-items:center;
  font-size:13px;
  font-weight:700;
  box-shadow:0 0 0 4px rgba(34,197,94,.12);
}
.hld-ar-right { top:50%; right:-13px; transform:translateY(-50%); }
.hld-ar-down { bottom:-13px; left:50%; transform:translateX(-50%) rotate(90deg); }
.hld-ar-left { top:50%; left:-13px; transform:translateY(-50%) rotate(180deg); }
.hld-progress {
  height:3px;
  background:rgba(255,255,255,.06);
}
.hld-progress span {
  display:block;
  width:0;
  height:100%;
  background:linear-gradient(90deg, #22c55e, #86efac);
}

@media (max-width:920px) {
  .hld-grid { grid-template-columns:1fr; }
  .hld-arrow { display:none; }
  .hld-top-mid { display:none; }
}
