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

/* ── Tokens ── */
:root {
  --bg:        #050709;
  --bg2:       #080c13;
  --surf:      rgba(11,15,26,.88);
  --surf2:     rgba(17,22,38,.72);
  --bdr:       rgba(90,120,200,.13);
  --bdr-h:     rgba(90,120,200,.28);
  --txt:       #e4e8f6;
  --txt2:      #a0adc4;
  --muted:     #5c6a82;
  --pri:       #0ea5e9;
  --pri2:      #14b8a6;
  --cyan:      #22d3ee;
  --pri-dim:   rgba(14,165,233,.14);
  --pri-glow:  rgba(14,165,233,.40);
  --ok:        #10b981;
  --ok-dim:    rgba(16,185,129,.15);
  --warn:      #f59e0b;
  --err:       #ef4444;
  --err-dim:   rgba(239,68,68,.13);
  --grad:      linear-gradient(135deg,#0ea5e9 0%,#14b8a6 55%,#f59e0b 100%);
  --grad-t:    linear-gradient(120deg,#67e8f9 0%,#2dd4bf 50%,#fbbf24 100%);
  --r:         14px;
  --r-lg:      20px;
  --font:      "Outfit",system-ui,-apple-system,sans-serif;
  --font-ar:   "Tajawal",system-ui,sans-serif;
  --glass:     blur(18px) saturate(160%);
  --nav-h:     64px;
  --ann-h:     40px;
}
[data-lang="ar"] { --font: var(--font-ar); }

/* ── Reset ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth }
body {
  background:var(--bg); color:var(--txt);
  font:15px/1.65 var(--font); -webkit-font-smoothing:antialiased;
  min-height:100vh; overflow-x:hidden;
}
[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 }

/* ── Gradient text ── */
.gradient-text {
  background:var(--grad-t);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* ══════════════════════════════════════════════════════
   ANNOUNCEMENT BAR
══════════════════════════════════════════════════════ */
.announce-bar {
  position:fixed; top:0; left:0; right:0; z-index:200;
  height:var(--ann-h);
  background:linear-gradient(90deg,#6366f1,#8b5cf6,#06b6d4);
  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; animation:iconPulse 3s ease-in-out infinite }
@keyframes iconPulse {
  0%,100% { filter:drop-shadow(0 0 5px rgba(99,102,241,.5)) }
  50%      { filter:drop-shadow(0 0 12px rgba(99,102,241,.9)) drop-shadow(0 0 22px rgba(139,92,246,.4)) }
}
.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 }

/* 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:rgba(255,255,255,.05) }
.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:hover, .nav-avatar-wrap:focus-within .nav-avatar { 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);
}
[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 }
.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:rgba(255,255,255,.06); 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:rgba(255,255,255,.07); 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:rgba(255,255,255,.05); 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:rgba(255,255,255,.05); 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:rgba(255,255,255,.05); 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(124,58,237,.12); color:#a78bfa; border-color:rgba(124,58,237,.35) }
.btn-push--off:hover { background:rgba(124,58,237,.22) }
.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(99,102,241,.35) 0%,transparent 70%); top:-180px; left:-150px; animation:orbA 18s ease-in-out infinite }
.o2 { width:500px; height:500px; background:radial-gradient(circle,rgba(139,92,246,.28) 0%,transparent 70%); bottom:0; right:-100px; animation:orbB 14s ease-in-out infinite }
.o3 { width:380px; height:380px; background:radial-gradient(circle,rgba(6,182,212,.22) 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(240,80,112,.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)} }
.grid-mesh { position:absolute; inset:0; background-image:linear-gradient(rgba(90,120,200,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(90,120,200,.04) 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:rgba(255,255,255,.07); 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,.12); 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,.6),0 0 0 1px rgba(255,255,255,.04); margin-top:0 }
.mockup-bar { background:rgba(255,255,255,.06); 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,.3); 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(16,185,129,.08); border:1px solid rgba(16,185,129,.3); 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(99,102,241,.08); border:1px solid rgba(99,102,241,.3); 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(99,102,241,.35); background:linear-gradient(135deg,rgba(99,102,241,.08),rgba(139,92,246,.06)) }
.highlight-card:hover { border-color:rgba(99,102,241,.6); box-shadow:0 12px 40px rgba(99,102,241,.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(99,102,241,.05),rgba(6,182,212,.03)) }
.spotlight-inner { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center }
.spotlight-code { background:rgba(0,0,0,.6); 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(99,102,241,.08) !important; border-left:2px solid rgba(99,102,241,.4); border-right:2px solid rgba(99,102,241,.4) }
.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:rgba(255,255,255,.06); 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(16,185,129,.2); 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 .2s,transform .2s,box-shadow .2s;
}
.pricing-card:hover { border-color:var(--bdr-h); transform:translateY(-4px); box-shadow:0 16px 48px rgba(0,0,0,.3) }
.pricing-card.featured { border-color:rgba(99,102,241,.5); background:linear-gradient(135deg,rgba(99,102,241,.1),rgba(139,92,246,.07)) }
.pricing-card.featured:hover { box-shadow:0 20px 60px rgba(99,102,241,.2) }
.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(99,102,241,.25) }
.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(99,102,241,.12); border-color:rgba(99,102,241,.3); color:var(--pri) }
.manual-cta { max-width:700px; margin:0 auto; background:linear-gradient(135deg,rgba(99,102,241,.1),rgba(6,182,212,.07)); border:1px solid rgba(99,102,241,.3); 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(99,102,241,.04) 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(99,102,241,.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(99,102,241,.55);  box-shadow:0 14px 32px rgba(99,102,241,.18) }
.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(99,102,241,.15);  border-color:rgba(99,102,241,.3) }
.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:#c4b5fd; background:rgba(139,92,246,.12);  border-color:rgba(139,92,246,.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(99,102,241,.35) }
.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:rgba(255,255,255,.07); 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,.12); 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(--accent,#7c3aed); 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-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:rgba(255,255,255,.04); 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(99,102,241,.12),rgba(6,182,212,.08)); border:1px solid rgba(99,102,241,.3); 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,.75); backdrop-filter:blur(6px); 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 }
.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 #8b5cf6;
  border-radius:20px; color:#a78bfa; 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:#8b5cf6; 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) }

/* ══════════════════════════════════════════════════════
   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 }
}
