/* ==========================================================
   CLOUDESY v5 — Your Always-On Voice Team
   Inspired by NiCE product page design language
   ========================================================== */

/* ── Canvas particle background ── */
/* Video background */
#bg-video{
  position:fixed;top:50%;left:50%;
  min-width:100%;min-height:100%;
  width:auto;height:auto;
  transform:translate(-50%,-50%);
  pointer-events:none;
  z-index:0;
  object-fit:cover;
  opacity:.55;
}
/* Canvas fallback (hidden when video loads) */
#particle-canvas{
  position:fixed;top:0;left:0;
  width:100%;height:100%;
  pointer-events:none;
  z-index:0;
  display:block;
}
/* Ensure all page content layers sit above the canvas */
.rainbow-line,.page-hero,.section,.site-footer,
.hero,.modal-overlay,.modal{
  position:relative;
  z-index:1;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Palette — NiCE-inspired */
  --white:#fff;
  --black:#1a1a1a;
  --cream:#f5f0eb;
  --cream-dark:#ede7e0;
  --gray-50:#fafaf9;
  --gray-100:#f5f5f4;
  --gray-200:#e7e5e4;
  --gray-300:#d6d3d1;
  --gray-400:#a8a29e;
  --gray-500:#78716c;
  --gray-600:#57534e;
  --gray-700:#44403c;
  --gray-800:#292524;
  --gray-900:#1c1917;
  --accent:#6d28d9;
  --accent-light:#8b5cf6;
  --accent-blue:#3b82f6;
  --accent-cyan:#06b6d4;
  --footer-bg:#1c1917;
  /* Gradients */
  --grad-hero:linear-gradient(135deg,#0f0328 0%,#1e0645 20%,#2d1060 40%,#1a3a8f 70%,#0c4a9e 100%);
  --grad-cta:linear-gradient(135deg,#7c3aed 0%,#4f46e5 40%,#3b82f6 100%);
  --grad-feature-1:linear-gradient(135deg,#f0e6ff 0%,#c4b5fd 40%,#8b5cf6 100%);
  --grad-feature-2:linear-gradient(135deg,#dbeafe 0%,#93c5fd 40%,#3b82f6 100%);
  --grad-feature-3:linear-gradient(135deg,#ede9fe 0%,#a78bfa 30%,#ec4899 100%);
  /* Layout */
  --max-w:1240px;
  --nav-h:72px;
  --radius:12px;
  --radius-lg:20px;
  --radius-xl:28px;
  --radius-full:9999px;
  /* Shadows */
  --shadow-sm:0 1px 3px rgba(0,0,0,.05);
  --shadow-md:0 4px 16px rgba(0,0,0,.07);
  --shadow-lg:0 8px 32px rgba(0,0,0,.1);
  --shadow-xl:0 20px 50px rgba(0,0,0,.12);
  /* Transitions */
  --ease:cubic-bezier(.4,0,.2,1);
  --dur:.3s;
  --brand:var(--accent);
  /* ── Enlighten AI palette ── */
  --coral:#f03e3e;
  --coral-bright:#ff5252;
  --cyan-cta:#00cfff;
  --navy-card:#0a1628;
  --navy-border:rgba(124,58,237,.45);
  /* ── Premium dark palette ── */
  --dark-bg:#0a0b1e;
  --dark-bg-2:#13142c;   /* was #111228 — slightly more contrast vs dark-bg */

  /* Surfaces — use these for card/section backgrounds */
  --dark-surface-subtle:rgba(255,255,255,.04);  /* very faint tint (inactive states) */
  --dark-surface:rgba(255,255,255,.06);         /* default container bg */
  --dark-surface-high:rgba(255,255,255,.08);    /* elevated / hover-ready surface */
  --dark-card:rgba(255,255,255,.05);            /* legacy alias — prefer --dark-surface */
  --dark-card-hover:rgba(255,255,255,.09);      /* legacy alias — prefer --dark-surface-high */

  /* Borders — use these for dividers and outlines */
  --dark-border-subtle:rgba(255,255,255,.07);   /* hair-line dividers */
  --dark-border:rgba(255,255,255,.1);           /* default border */
  --dark-border-mid:rgba(255,255,255,.14);      /* medium-weight border */
  --dark-border-strong:rgba(255,255,255,.18);   /* prominent border */
  --dark-border-hover:rgba(255,255,255,.22);    /* hover / focus border */
  --dark-border-active:rgba(255,255,255,.28);   /* active / selected border */

  /* Text on dark backgrounds */
  --text-on-dark:rgba(255,255,255,.9);          /* body paragraphs */
  --text-on-dark-muted:rgba(255,255,255,.55);   /* secondary / helper text */
  --text-on-dark-dim:rgba(255,255,255,.38);     /* captions, timestamps, placeholders */
  /* ── Gradient text ── */
  --grad-text:linear-gradient(135deg,#a855f7 0%,#6366f1 40%,#3b82f6 70%,#06b6d4 100%);
  /* ── Richer hero gradient ── */
  /* ── Spacing scale ── */
  --sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;
  --sp-6:24px;--sp-8:32px;--sp-10:40px;--sp-12:48px;--sp-16:64px;
  /* ── Vertical rhythm ── */
  --section-py:clamp(40px,4.5vw,72px);      /* was clamp(24px,3vw,44px) — more breathing room */
  --section-inner-gap:clamp(28px,3.5vw,48px);
  /* ── Container ── */
  /* ── Z-index scale ── */
  --z-behind:    0;    /* backgrounds / decorative pseudo-elements */
  --z-base:      1;    /* default stacking context content */
  --z-nav:     100;    /* sticky site header */
  --z-skip:   9999;    /* skip-to-content link */
  --container-px:clamp(20px,4vw,32px);
}

html{scroll-behavior:smooth;font-size:16px;}
body{font-family:'Be Vietnam Pro','Inter',system-ui,-apple-system,sans-serif;color:var(--black);background:var(--dark-bg);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color var(--dur) var(--ease)}

/* ── Global typography baseline ── */
h1,h2,h3,h4,h5,h6{line-height:1.15;font-weight:700;margin-bottom:var(--sp-4)}
h1{font-size:clamp(2rem,4vw,3.2rem);font-weight:800;letter-spacing:-.03em;line-height:1.1}
h2{font-size:clamp(1.5rem,3vw,2.4rem);font-weight:800;letter-spacing:-.025em}
h3{font-size:clamp(1.2rem,2vw,1.8rem);font-weight:700;letter-spacing:-.02em}
h4{font-size:1.05rem;font-weight:700}
h5,h6{font-size:.9rem;font-weight:600}
p{margin-bottom:var(--sp-4);line-height:1.65}
p:last-child{margin-bottom:0}
ul,ol{margin-bottom:var(--sp-4);padding-left:var(--sp-5)}
li{margin-bottom:var(--sp-2)}

/* ── Layout utilities ── */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--container-px)}
.section{padding:var(--section-py) 0}

/* Scroll-snap removed — was causing sections to feel stuck */
main>section{}

/* ── Glass card — reusable section boundary ── */
.sec-glass{
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.14);
  border-radius:24px;
  overflow:hidden;
  padding:40px 48px;
  box-shadow:0 4px 24px rgba(0,0,0,.28);   /* depth lift; inset shimmer removed — was doubling the border */
}
/* Larger card inside page-hero sections */
.page-hero .sec-glass{
  padding:56px 64px;
}
@media(max-width:768px){
  .sec-glass{padding:28px 20px;border-radius:16px;}
  .page-hero .sec-glass{padding:36px 24px;}
}

/* ── Scroll Reveal ── */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.visible{opacity:1;transform:none}

/* ==========================================================
   NAVIGATION — NiCE style sticky white bar
   ========================================================== */
/* ── Header shell — slate glass across all pages ── */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:var(--z-nav);
  background:rgba(22,23,42,.88);
  backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  border-bottom:1px solid var(--dark-border);
  box-shadow:inset 0 -1px 0 rgba(255,255,255,.06);
  transition:transform .42s cubic-bezier(.16,1,.3,1),
             background .3s ease,
             box-shadow .3s ease;
}
.site-header.scrolled{
  background:rgba(22,23,42,.97);
  box-shadow:0 4px 30px rgba(0,0,0,.3),inset 0 -1px 0 rgba(255,255,255,.07);
  border-bottom-color:transparent;
}
/* Smart hide: slide up on scroll-down, back on scroll-up */
.site-header.nav-hidden{transform:translateY(-110%)}

.site-header nav .logo{justify-self:start}
.site-header nav .nav-pill{justify-self:center}
.site-header nav .nav-end{justify-self:end}
.site-header nav{
  max-width:var(--max-w);margin:0 auto;padding:0 32px;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  height:var(--nav-h);
}
/* ── Logo — voice bar wave + wordmark ── */
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-name{font-weight:800;font-size:1.35rem;color:#fff;letter-spacing:-.025em;line-height:1}
.logo-mark{display:none}
.logo-text{display:none}

/* Bar wave */
.logo-barwave{display:flex;align-items:center;gap:3px;height:26px}
.bw-bar{
  display:block;width:3px;height:4px;border-radius:3px;
  transform-origin:center;
  animation:bwPulse 1.2s ease-in-out infinite;
}
@keyframes bwPulse{
  0%,100%{transform:scaleY(1);opacity:.45}
  50%    {transform:scaleY(5.5);opacity:1}
}
.bw-bar:nth-child(1) {background:#7c3aed;animation-duration:1.1s;animation-delay:0s}
.bw-bar:nth-child(2) {background:#6b46f2;animation-duration:1.3s;animation-delay:.08s}
.bw-bar:nth-child(3) {background:#5a50f5;animation-duration:.90s;animation-delay:.16s}
.bw-bar:nth-child(4) {background:#4a5af8;animation-duration:1.2s;animation-delay:.24s}
.bw-bar:nth-child(5) {background:#3b82f6;animation-duration:1.0s;animation-delay:.32s}
.bw-bar:nth-child(6) {background:#20a0f7;animation-duration:1.4s;animation-delay:.40s}
.bw-bar:nth-child(7) {background:#0eb4f9;animation-duration:1.1s;animation-delay:.48s}
.bw-bar:nth-child(8) {background:#06b6d4;animation-duration:.95s;animation-delay:.56s}
.bw-bar:nth-child(9) {background:#0eb4f9;animation-duration:1.3s;animation-delay:.48s}
.bw-bar:nth-child(10){background:#20a0f7;animation-duration:1.0s;animation-delay:.40s}
.bw-bar:nth-child(11){background:#3b82f6;animation-duration:1.2s;animation-delay:.32s}
.bw-bar:nth-child(12){background:#4a5af8;animation-duration:.90s;animation-delay:.24s}
/* ── Nav — individual glassmorphism pills per link ── */
.nav-pill{
  display:flex;align-items:center;gap:8px;
  /* container only — no shared border/background */
}
.nav-links{display:flex;gap:8px;list-style:none;padding:0;margin:0}
.nav-links a{
  display:inline-flex;align-items:center;justify-content:center;
  font-size:.9rem;font-weight:500;color:#fff;
  padding:8px 20px 14px;
  border-radius:9999px;
  border:none;
  background:rgba(255,255,255,.07);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  white-space:nowrap;
  transition:background .2s ease,transform .15s ease;
  text-decoration:none;
  position:relative;
}
.nav-links a:hover{
  background:rgba(255,255,255,.15);
  transform:translateY(-1px);
}
.nav-links a.active{
  background:rgba(255,255,255,.14);
  font-weight:600;
}
/* Purple–blue dash pinned to bottom of each pill */
.nav-links a::after{
  content:'';
  position:absolute;
  bottom:5px;
  left:50%;
  transform:translateX(-50%);
  width:0;
  height:3px;
  border-radius:3px;
  background:linear-gradient(90deg,#7c3aed,#3b82f6);
  transition:width .25s ease;
}
.nav-links a.active::after{
  width:22px;
}
.nav-end{display:flex;align-items:center;gap:12px}
.nav-login{
  font-size:1rem;font-weight:500;color:#fff;
  transition:color .2s ease,background .2s ease;
  padding:7px 16px;border-radius:8px;
}
.nav-login:hover{color:#fff;background:rgba(255,255,255,.09)}

/* ── Buttons — NiCE style ── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:inherit;font-weight:600;font-size:.875rem;
  padding:12px 28px;border-radius:var(--radius-full);
  border:1.5px solid transparent;cursor:pointer;
  transition:all var(--dur) var(--ease);text-align:center;
  white-space:nowrap;
}
.btn-primary{
  background:linear-gradient(135deg,#7c3aed,#4f46e5,#3b82f6);
  color:var(--white);border-color:transparent;
  box-shadow:0 4px 18px rgba(99,102,241,.35);
}
.btn-primary:hover{
  background:linear-gradient(135deg,#6d28d9,#4338ca,#2563eb);
  box-shadow:0 6px 24px rgba(99,102,241,.45);transform:translateY(-1px);
}
.btn-outline{background:transparent;color:var(--black);border-color:var(--gray-300)}
.btn-outline:hover{border-color:var(--black)}
.btn-white{background:var(--white);color:var(--black);border-color:var(--white)}
.btn-white:hover{background:var(--cream);border-color:var(--cream)}
.btn-ghost{background:var(--black);color:var(--white);border-color:var(--black);font-size:.8rem;padding:10px 22px}
.btn-ghost:hover{background:var(--gray-800)}
.btn:focus-visible{outline:3px solid var(--accent);outline-offset:3px}
.btn-lg{padding:16px 36px;font-size:.95rem}
.btn-full-width{width:100%;justify-content:center}
.btn .arrow{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.15);margin-left:4px;transition:transform var(--dur) var(--ease)}
.btn:hover .arrow{transform:translateX(3px)}
.btn-get-started{
  background:linear-gradient(135deg,#7c3aed,#4f46e5,#3b82f6);
  color:var(--white);border-color:transparent;
  padding:12px 16px 12px 28px;
  box-shadow:0 3px 14px rgba(99,102,241,.3);
}
.btn-get-started:hover{
  background:linear-gradient(135deg,#6d28d9,#4338ca,#2563eb);
  box-shadow:0 5px 20px rgba(99,102,241,.4);
}

/* Hamburger */
.hamburger{display:none;background:none;border:none;cursor:pointer;width:32px;height:32px;padding:0}
.hamburger svg{width:100%;height:100%;stroke:#fff;stroke-width:2}

/* ==========================================================
   HERO — NiCE gradient hero
   ========================================================== */
.hero{
  padding-top:var(--nav-h);
  background:var(--dark-bg);
  min-height:100vh;
  min-height:100svh;
  position:relative;overflow:hidden;
}
/* Ambient glow orbs — slate #1e2030 base */
.hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    /* violet orb top-left */
    radial-gradient(ellipse 55% 65% at 10% 20%, rgba(124,58,237,.26) 0%,transparent 65%),
    /* cyan orb right */
    radial-gradient(ellipse 45% 55% at 90% 60%, rgba(34,211,238,.14) 0%,transparent 60%),
    /* indigo mid orb */
    radial-gradient(ellipse 60% 50% at 60% 50%, rgba(30,32,60,.9) 0%,transparent 70%),
    /* pink accent */
    radial-gradient(circle 200px at 80% 15%, rgba(236,72,153,.1) 0%,transparent 65%),
    /* bottom blue */
    radial-gradient(circle 180px at 25% 85%, rgba(99,102,241,.12) 0%,transparent 65%);
}
/* Dot-grid texture */
.hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:1;
  background-image:radial-gradient(rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:28px 28px;
}
/* Bottom fade to next section */
.hero-bottom-fade{
  position:absolute;bottom:0;left:0;right:0;
  height:200px;
  background:linear-gradient(to bottom,transparent,var(--dark-bg) 80%);
  z-index:2;
  pointer-events:none;
}
.hero .container{
  display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:48px;
  padding-top:clamp(80px,10vh,140px);padding-bottom:clamp(100px,12vh,180px);
  position:relative;z-index:3;
}
/* Hero content z-index above mesh and dot grid */
.hero .container{z-index:4}
.hero-content{max-width:600px}
.hero .eyebrow{
  display:inline-block;
  font-size:.75rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--cyan-cta);
  background:none;-webkit-text-fill-color:var(--cyan-cta);
  margin-bottom:16px;
}
.hero h1{
  font-size:clamp(2.8rem,5.5vw,5rem);font-weight:800;line-height:1.02;
  color:var(--white);
  margin-bottom:24px;letter-spacing:-.04em;
}
.hero .subtitle{
  font-size:1.05rem;line-height:1.75;color:#fff;
  margin-bottom:40px;max-width:480px;
}
.cta-group{display:flex;flex-wrap:wrap;gap:16px}
.hero .btn-primary{background:var(--black);border-color:var(--black)}
.hero .btn-outline{color:var(--white);border-color:rgba(255,255,255,.5)}
.hero .btn-outline:hover{border-color:var(--white);background:rgba(255,255,255,.1)}

/* ── Hero Visual — floating UI cards — full glassmorphism ── */
.hero-visual{position:relative;height:420px}
.hero-float-card{
  position:absolute;

  /* Slate-tinted glass surface */
  background:rgba(30,32,52,.55);
  backdrop-filter:blur(22px) saturate(1.5);
  -webkit-backdrop-filter:blur(22px) saturate(1.5);

  /* Glass edges */
  border:1px solid rgba(255,255,255,.18);
  border-radius:var(--radius-lg);

  box-shadow:
    /* top inset shimmer */
    inset 0 1px 0 rgba(255,255,255,.18),
    /* bottom inset depth */
    inset 0 -1px 0 rgba(0,0,0,.22),
    /* left/right micro-edges */
    inset 1px 0 0 rgba(255,255,255,.07),
    inset -1px 0 0 rgba(255,255,255,.04),
    /* outer drop */
    0 12px 40px rgba(0,0,0,.35),
    0 4px 14px rgba(0,0,0,.2),
    /* violet ambient glow */
    0 0 0 1px rgba(168,85,247,.08);

  padding:20px;
  animation:floatY 6s ease-in-out infinite;
  transition:box-shadow .3s ease, border-color .3s ease;
}
.hero-float-card:hover{
  border-color:rgba(255,255,255,.26);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.22),
    inset 0 -1px 0 rgba(0,0,0,.24),
    0 20px 60px rgba(0,0,0,.4),
    0 0 0 1px rgba(168,85,247,.18);
}
.hero-float-card.card-1{top:10%;right:5%;width:260px;animation-delay:0s}
.hero-float-card.card-2{top:45%;right:20%;width:280px;animation-delay:1.5s}
.hero-float-card.card-3{bottom:5%;right:0;width:240px;animation-delay:3s}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

.float-card-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.float-card-avatar{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,#a855f7,#6366f1);
  display:grid;place-items:center;color:var(--white);font-size:.8rem;font-weight:700;
  box-shadow:0 0 12px rgba(168,85,247,.4);
}
.float-card-name{font-weight:600;font-size:.85rem;color:#fff}
.float-card-label{font-size:.7rem;color:#fff}
.float-card-body{font-size:.8rem;color:#fff;line-height:1.55}
.float-card-tags{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.float-card-tag{
  font-size:.65rem;padding:3px 10px;
  border-radius:var(--radius-full);
  background:rgba(255,255,255,.1);
  color:#fff;
  font-weight:500;
  border:1px solid rgba(255,255,255,.18);
  /* glass edge on tags */
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12);
}
.float-card-stat{display:flex;gap:20px;margin-top:12px}
.float-card-stat div{text-align:center}
.float-card-stat .num{font-size:1.3rem;font-weight:800;color:#c4b5fd}
.float-card-stat .lbl{font-size:.65rem;color:#fff}

/* ==========================================================
   TRUSTED BY — Logo strip on cream
   ========================================================== */
.trusted-sec{background:var(--dark-bg-2);padding:var(--section-py) 0}
.trusted-sec .section-label{text-align:center;font-size:1rem;font-weight:600;color:#fff;letter-spacing:.08em;text-transform:uppercase;margin-bottom:32px}
.trusted-sec .section-label span{color:#fff}
.logo-row{display:flex;align-items:center;justify-content:center;gap:48px;flex-wrap:wrap}
.logo-row .partner-logo{
  font-size:.85rem;font-weight:600;color:#fff;letter-spacing:.02em;
  padding:14px 22px;background:rgba(255,255,255,.06);border-radius:var(--radius-full);
  border:1px solid rgba(255,255,255,.1);
  transition:color var(--dur) var(--ease),background var(--dur) var(--ease);
}
.logo-row .partner-logo:hover{color:#fff;background:rgba(255,255,255,.1)}

/* ==========================================================
   INTRO TEXT — Full width statement
   ========================================================== */
.intro-sec{padding:var(--section-py) 0;background:var(--dark-bg-2);text-align:center}
.intro-sec .container{max-width:760px}
.intro-statement{font-size:clamp(1.15rem,2.2vw,1.45rem);line-height:1.85;color:#fff;font-weight:400}

/* ==========================================================
   FEATURE BLOCKS — NiCE two-column alternating
   ========================================================== */
.feature-block{padding:var(--section-py) 0}
.feature-block .container{
  display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:64px;
}
.feature-block:nth-child(even) .container{direction:rtl}
.feature-block:nth-child(even) .container > *{direction:ltr}
.feature-text h3{font-size:clamp(1.5rem,2.5vw,2rem);font-weight:800;line-height:1.2;margin-bottom:16px;letter-spacing:-.02em}
.feature-text p{font-size:1rem;line-height:1.7;color:var(--gray-600);margin-bottom:24px;max-width:440px}
.feature-visual{
  border-radius:var(--radius-xl);overflow:hidden;
  min-height:360px;position:relative;
  display:flex;align-items:center;justify-content:center;
}
.feature-visual .gradient-bg{
  position:absolute;inset:0;border-radius:var(--radius-xl);
}
.feature-visual .float-pills{position:relative;z-index:1;display:flex;flex-direction:column;gap:16px;align-items:center;padding:40px}
.float-pill{
  display:inline-block;padding:14px 28px;border-radius:var(--radius-full);
  font-size:.9rem;font-weight:500;color:var(--white);
  background:rgba(255,255,255,.18);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.25);
  animation:floatY 5s ease-in-out infinite;
}
.float-pill:nth-child(2){animation-delay:1s}
.float-pill:nth-child(3){animation-delay:2s}
.float-pill:nth-child(4){animation-delay:3s}

/* ==========================================================
   STATS SECTION — Customer success metrics
   ========================================================== */
.stats-sec{padding:var(--section-py) 0;background:var(--dark-bg)}
.stats-sec .section-head{text-align:center;margin-bottom:var(--section-inner-gap)}
.stats-sec h2{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;letter-spacing:-.02em;color:var(--white)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.stat-card{text-align:center;padding:40px 24px;border-right:1px solid var(--dark-border-subtle)}
.stat-card:last-child{border-right:none}
.stat-card .stat-num{font-size:clamp(2.8rem,5.5vw,4.2rem);font-weight:800;color:var(--coral-bright);-webkit-text-fill-color:var(--coral-bright);margin-bottom:8px;display:block;letter-spacing:-.03em}
.stat-card .stat-label{font-size:.9rem;color:#fff;font-weight:400}

/* ==========================================================
   CUSTOMER STORY — NiCE-style case study card
   ========================================================== */
.story-sec{padding:var(--section-py) 0;background:var(--cream)}
.story-card{
  display:grid;grid-template-columns:1fr 1fr;
  border-radius:var(--radius-xl);overflow:hidden;
  background:var(--white);box-shadow:var(--shadow-lg);
}
.story-content{padding:48px;display:flex;flex-direction:column;justify-content:center}
.story-content .story-logo{font-size:1.5rem;font-weight:800;color:var(--gray-400);margin-bottom:24px}
.story-content h3{font-size:clamp(1.4rem,2.5vw,1.8rem);font-weight:800;line-height:1.3;margin-bottom:24px;letter-spacing:-.02em}
.story-stats{display:flex;gap:32px;margin-bottom:24px}
.story-stat{border-left:3px solid var(--accent-blue);padding-left:16px}
.story-stat .num{font-size:1.8rem;font-weight:800;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;display:block}
.story-stat .lbl{font-size:.8rem;color:var(--gray-500)}
.story-link{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.9rem;color:var(--black)}
.story-link:hover{gap:12px}
.story-link svg{width:20px;height:20px;transition:transform var(--dur) var(--ease)}
.story-link:hover svg{transform:translateX(4px)}
.story-image{background:var(--grad-hero);display:flex;align-items:center;justify-content:center;min-height:320px;position:relative;overflow:hidden}
.story-image .story-visual-text{font-size:3rem;opacity:.15;font-weight:800;color:var(--white);text-align:center;line-height:1.2}

/* ==========================================================
   TECH STACK — horizontal card row
   ========================================================== */
.tech-sec{padding:var(--section-py) 0;background:var(--dark-bg)}
.section-head{margin-bottom:var(--section-inner-gap)}
.section-head .eyebrow{
  display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.15em;
  text-transform:uppercase;
  background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  margin-bottom:12px;
}
.section-head h2{font-size:clamp(1.5rem,3vw,2.4rem);font-weight:800;letter-spacing:-.025em;margin-bottom:12px}
.section-head .subtitle{font-size:1rem;color:var(--gray-500);max-width:600px}
.section-head.centered{text-align:center}
.section-head.centered .subtitle{margin:0 auto}

.tech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tech-card{
  background:var(--navy-card);border-radius:var(--radius-lg);padding:32px;
  border:1px solid var(--navy-border);
  transition:border-color var(--dur) var(--ease),transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.tech-card:hover{
  border-color:rgba(124,58,237,.85);
  transform:translateY(-4px);box-shadow:0 0 0 1px rgba(124,58,237,.4),0 16px 40px rgba(124,58,237,.2);
}
.tech-card .tech-icon{font-size:2rem;margin-bottom:16px}
.tech-card h4{font-size:1.05rem;font-weight:700;margin-bottom:8px;color:#fff}
.tech-card p{font-size:.85rem;color:#fff;line-height:1.6}

/* ==========================================================
   PRICING — 3-column cards
   ========================================================== */
.pricing-sec{padding:var(--section-py) 0;background:var(--cream)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.price-card{
  background:var(--white);border-radius:var(--radius-xl);padding:40px 32px;
  border:1px solid var(--gray-200);
  transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease);
  display:flex;flex-direction:column;
}
.price-card.featured{border-color:transparent;box-shadow:0 0 0 2px var(--coral),0 12px 40px rgba(240,62,62,.15)}
.price-card .plan-name{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:8px}
.price-card.featured .plan-name{color:var(--coral)}
.price-card .plan-price{font-size:2.5rem;font-weight:800;color:var(--black);margin-bottom:4px}
.price-card .plan-price span{font-size:.9rem;font-weight:400;color:var(--gray-500)}
.price-card .plan-desc{font-size:.85rem;color:var(--gray-500);margin-bottom:24px}
.price-card ul{list-style:none;margin-bottom:32px;flex:1}
.price-card li{font-size:.85rem;color:var(--gray-600);padding:8px 0;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;gap:8px}
.price-card li::before{content:'✓';color:var(--accent);font-weight:700;font-size:.8rem}

/* ==========================================================
   FAQ — NiCE-style two-column
   ========================================================== */
.faq-sec{padding:var(--section-py) 0;background:var(--cream)}
.faq-layout{display:grid;grid-template-columns:1fr 2fr;gap:64px;align-items:start}
.faq-title h2{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;letter-spacing:-.02em;line-height:1.2}
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{
  background:var(--white);border-radius:var(--radius-lg);
  overflow:hidden;transition:box-shadow var(--dur) var(--ease);
}
.faq-item:hover{box-shadow:var(--shadow-sm)}
.faq-q{
  width:100%;background:none;border:none;cursor:pointer;
  padding:20px 24px;display:flex;align-items:center;justify-content:space-between;
  font-family:inherit;font-size:.95rem;font-weight:500;color:var(--gray-600);
  text-align:left;transition:color var(--dur) var(--ease);
}
.faq-q:hover{color:var(--black)}
.faq-q svg{width:20px;height:20px;flex-shrink:0;stroke:var(--gray-400);stroke-width:2;fill:none;transition:transform var(--dur) var(--ease)}
.faq-item.open .faq-q{color:var(--black);font-weight:600}
.faq-item.open .faq-q svg{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-item.open .faq-a{max-height:400px}
.faq-a-inner{padding:0 24px 20px;font-size:.9rem;color:var(--gray-600);line-height:1.7}

/* ==========================================================
   CTA BANNER — NiCE gradient
   ========================================================== */
.cta-banner{padding:var(--section-py) 0;background:var(--grad-cta);text-align:center;position:relative;overflow:hidden}
.final-cta{padding:var(--section-py) 0;background:var(--cream);text-align:center}
.final-cta h2{color:var(--black)}
.final-cta p{color:var(--gray-600);max-width:520px;margin-left:auto;margin-right:auto}
.cta-banner::before{content:'';position:absolute;top:-60%;right:-10%;width:500px;height:500px;border-radius:50%;background:rgba(255,255,255,.06)}
.cta-banner .eyebrow{color:#fff;display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;margin-bottom:12px}
.cta-banner h2{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:800;color:var(--white);margin-bottom:12px;letter-spacing:-.02em}
.cta-banner p{font-size:1rem;color:#fff;margin-bottom:32px;max-width:500px;margin-left:auto;margin-right:auto}
.cta-group-center{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}

/* ==========================================================
   RESOURCE CARDS — 3-column NiCE style
   ========================================================== */
.resources-sec{padding:var(--section-py) 0;background:var(--white)}
.resource-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.resource-card{
  border-radius:var(--radius-xl);overflow:hidden;
  background:var(--white);border:1px solid var(--gray-200);
  transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.resource-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.resource-card-img{
  height:200px;position:relative;overflow:hidden;
}
.resource-card-img .rc-gradient{position:absolute;inset:0}
.resource-card-img .rc-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:3rem;opacity:.3}
.resource-card-body{padding:24px}
.resource-card-body .rc-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--gray-500);margin-bottom:8px}
.resource-card-body h4{font-size:1.05rem;font-weight:700;line-height:1.4;margin-bottom:16px}
.resource-card-body .rc-arrow{
  width:40px;height:40px;border-radius:50%;background:var(--gray-100);
  display:inline-grid;place-items:center;transition:background var(--dur) var(--ease);
}
.resource-card:hover .rc-arrow{background:var(--gray-200)}
.rc-arrow svg{width:16px;height:16px;stroke:var(--black);stroke-width:2;fill:none}

/* ==========================================================
   FOOTER — NiCE dark footer
   ========================================================== */
.site-footer{background:var(--footer-bg);color:var(--gray-300);padding:var(--section-py) 0 var(--sp-8)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand .logo{color:var(--white);margin-bottom:16px}
.footer-brand .logo-mark{height:60px;width:auto;filter:none;}
.footer-brand p{font-size:.85rem;color:var(--gray-400);line-height:1.7;max-width:280px}
.footer-col h4{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--white);margin-bottom:20px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:12px}
.footer-col a{font-size:.85rem;color:var(--gray-400);transition:color var(--dur) var(--ease)}
.footer-col a:hover{color:var(--white)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:24px;display:flex;align-items:center;justify-content:space-between;
  font-size:.8rem;color:var(--gray-500);
}
.footer-bottom a{color:var(--gray-500)}
.footer-bottom a:hover{color:var(--white)}
.footer-social{display:flex;gap:12px}
.footer-social a{
  width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);
  display:inline-grid;place-items:center;
  transition:background var(--dur) var(--ease);
}
.footer-social a:hover{background:rgba(255,255,255,.15)}
.footer-social svg{width:18px;height:18px;fill:var(--gray-400)}

/* ==========================================================
   PAGE HERO — Services / Demo / Portal pages
   Compact hero: gradient visible instantly, scrolls away normally,
   next section visible above the fold on 1440×900+.
   ========================================================== */
.page-hero{
  padding:calc(var(--nav-h) + clamp(24px,3vw,40px)) 0 clamp(24px,3vw,40px);
  background:transparent;text-align:center;
  position:relative;z-index:1;
}
.page-hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:transparent;
}
/* Hero should never participate in the reveal fade — gradient must be instant */
.page-hero.reveal{opacity:1;transform:none}
.page-hero .eyebrow{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:#fff;margin-bottom:8px}
.page-hero h1,.page-hero h2{font-size:clamp(1.5rem,2.8vw,2.4rem);font-weight:800;color:var(--white);margin:4px 0 12px;letter-spacing:-.035em;line-height:1.1;white-space:nowrap}
.page-hero .subtitle{font-size:1rem;color:#fff;max-width:none;margin:0 auto;text-align:center;white-space:nowrap}

/* Ensure all content sections after .page-hero are opaque & stacked above the hero */
.page-hero ~ section,
.page-hero ~ .portal-wrap{position:relative;z-index:1}
/* First section directly after page-hero gets reduced top padding to close dead zone */
.page-hero + section,.page-hero + .pricing-sec,.page-hero + .section{
  padding-top:clamp(32px,4vw,56px);
}
.page-hero ~ section:not([class*="cta"]):not([class*="grad"]){
  background-color:var(--white);
}
/* Dark-video pages: override section backgrounds to semi-transparent */
body.has-particles .page-hero ~ section:not([class*="cta"]):not([class*="grad"]){
  background-color:rgba(10,11,30,0.78);
}
body.has-particles .pricing-sec{background:rgba(17,18,40,0.78)!important;}
body.has-particles .faq-sec{background:rgba(10,11,30,0.78)!important;}
body.has-particles .final-cta{background:rgba(10,8,24,0.78)!important;}
body.has-particles .final-cta h2{color:#fff!important;}
body.has-particles .final-cta p{color:#fff!important;}
body.has-particles .stats-sec{background:rgba(10,11,30,0.78)!important;}
body.has-particles .cta-banner{background:rgba(10,8,24,0.88)!important;}
body.has-particles .demo-sec{background:rgba(17,18,40,0.78)!important;}
body.has-particles .feat-slideshow-sec{background:rgba(10,11,30,0.78)!important;}
body.has-particles .scenarios-sec{background:rgba(17,18,40,0.78)!important;}

/* ==========================================================
   SERVICES DETAIL — Alternating sections
   ========================================================== */
.srv-detail-sec{padding:var(--section-py) 0;position:relative;z-index:1;background:var(--white)}
.srv-detail{
  display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:64px;
  padding:48px 0;
}
.srv-detail:nth-child(even){direction:rtl}
.srv-detail:nth-child(even) > *{direction:ltr}
.srv-detail-vis{
  border-radius:var(--radius-xl);overflow:hidden;min-height:320px;
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.srv-detail-vis .srv-gradient{position:absolute;inset:0;border-radius:var(--radius-xl)}
.srv-detail-vis .srv-icon{position:relative;z-index:1;font-size:4rem;opacity:.4}
.srv-detail-vis .srv-screenshot{width:100%;height:100%;object-fit:cover;display:block;border-radius:var(--radius-xl)}
.srv-detail-content h3{font-size:1.5rem;font-weight:800;margin-bottom:12px;letter-spacing:-.01em}
.srv-detail-content p{font-size:.95rem;color:var(--gray-600);line-height:1.7;margin-bottom:20px}
.feat-list{list-style:none;margin-bottom:24px}
.feat-list li{padding:6px 0;font-size:.87rem;color:var(--gray-600);display:flex;align-items:center;gap:8px}
.feat-list li::before{content:'→';color:var(--accent);font-weight:700}

/* ==========================================================
   DEMO PAGE — Experience card
   ========================================================== */
.demo-sec{padding:var(--section-py) 0;position:relative;z-index:1;background:var(--white)}
.experience-card{background:var(--white);border-radius:var(--radius-xl);padding:48px;border:1px solid var(--gray-200);margin-bottom:64px}
.experience-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}
.experience-header h3{font-size:1.5rem;font-weight:800}
.live-badge{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;color:var(--gray-600)}
.live-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;animation:pulse-dot 2s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}

.demo-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.demo-card{text-align:center}
.demo-card-visual{
  border-radius:var(--radius-xl);min-height:240px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:20px;padding:32px;position:relative;overflow:hidden;
  margin-bottom:12px;
}
.demo-icon{opacity:.3}
.start-btn{
  padding:12px 28px;border-radius:var(--radius-full);
  background:rgba(255,255,255,.85);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.6);
  font-family:inherit;font-weight:600;font-size:.85rem;color:var(--black);
  cursor:pointer;transition:all var(--dur) var(--ease);
}
.start-btn:hover{background:var(--white);box-shadow:var(--shadow-md)}
.demo-card span{font-size:.85rem;font-weight:600;color:var(--gray-700)}

/* Use Cases */
.demo-usecases{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:var(--section-inner-gap)}
.usecase-card{
  background:var(--gray-50);border-radius:var(--radius-lg);padding:32px;
  border:1px solid var(--gray-200);
  transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.usecase-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.uc-num{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:10px}
.usecase-card h4{font-size:1.1rem;font-weight:700;margin-bottom:8px}
.usecase-card p{font-size:.87rem;color:var(--gray-500);line-height:1.7}

/* Forms */
.form-wrap{background:var(--white);border-radius:var(--radius-xl);padding:40px;border:1px solid var(--gray-200)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--gray-700);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:12px 16px;border:1px solid var(--gray-200);border-radius:var(--radius);
  font-family:inherit;font-size:.9rem;color:var(--black);
  transition:border-color var(--dur) var(--ease);background:var(--white);
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}
.form-group textarea{resize:vertical}

/* ==========================================================
   HOW IT WORKS — Steps
   ========================================================== */
.how-sec{padding:var(--section-py) 0;background:var(--white)}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.step-card{text-align:center;padding:24px 16px}
.step-num{
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,#7c3aed,#3b82f6);color:var(--white);
  display:inline-grid;place-items:center;font-weight:800;font-size:1.1rem;
  margin-bottom:16px;box-shadow:0 4px 16px rgba(99,102,241,.35);
}
.step-card h4{font-size:1rem;font-weight:700;margin-bottom:8px}
.step-card p{font-size:.85rem;color:var(--gray-500);line-height:1.6}

/* ==========================================================
   RAINBOW ACCENT LINE — NiCE signature
   ========================================================== */
.rainbow-line{height:4px;background:linear-gradient(-90deg,#ff3e39,#fc2566,#8531e4,#1000fe,#05fcff);width:100%}

/* ==========================================================
   RESPONSIVE
   ========================================================== */
@media(max-width:1024px){
  .nav-links{gap:0}
  .nav-links a{font-size:.9rem;padding:6px 10px}
  .hero .container{grid-template-columns:1fr;text-align:center}
  .hero-content{max-width:100%}
  .hero .subtitle{margin-left:auto;margin-right:auto}
  .cta-group{justify-content:center}
  .hero-visual{display:none}
  .feature-block .container{grid-template-columns:1fr;gap:32px}
  .feature-block:nth-child(even) .container{direction:ltr}
  .faq-layout{grid-template-columns:1fr;gap:32px}
  .story-card{grid-template-columns:1fr}
  .story-image{min-height:200px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .pricing-grid{grid-template-columns:1fr}
  .pricing-grid .price-card{max-width:480px;margin:0 auto;width:100%}
  .tech-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .resource-grid{grid-template-columns:1fr}
  .srv-detail{grid-template-columns:1fr;gap:32px}
  .srv-detail:nth-child(even){direction:ltr}
}
@media(max-width:768px){
  /* nav pill becomes the mobile dropdown */
  .nav-pill{
    display:none;flex-direction:column;
    position:absolute;top:var(--nav-h);left:0;right:0;
    background:rgba(14,15,35,.97);
    backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border-bottom:1px solid rgba(255,255,255,.08);
    padding:16px 20px 24px;
    box-shadow:0 12px 40px rgba(0,0,0,.5);
    gap:0;
  }
  .nav-pill.open{display:flex}
  .nav-pill .nav-links{
    flex-direction:column;gap:6px;width:100%;
  }
  .nav-pill .nav-links a{
    border-radius:12px;padding:12px 20px;font-size:1rem;
    border:none;
  }
  .hamburger{display:block}
  .nav-login{display:none}
  .nav-end .btn-get-started{padding:10px 16px 10px 20px;font-size:.78rem}
  .hero{min-height:auto}
  .hero .container{padding-top:48px;padding-bottom:48px}
  .hero h1{font-size:2rem}
  .stats-grid{grid-template-columns:1fr 1fr;gap:16px}
  .demo-cards{grid-template-columns:1fr}
  .demo-usecases{grid-template-columns:1fr}
  .steps-grid{grid-template-columns:1fr 1fr;gap:16px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;gap:16px;text-align:center}
  .form-row{grid-template-columns:1fr}
}


/* ==========================================================
   FEATURE CAROUSEL
   ========================================================== */
.feature-carousel-sec{padding:var(--section-py) 0}

/* Wrapper — captures hover for pause */
.fc-wrap{position:relative}

/* Visible boundary */
.fc-track-outer{
  overflow:hidden;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  box-shadow:0 4px 24px rgba(0,0,0,.07);
}

/* Sliding track */
.fc-track{
  display:flex;
  transition:transform .55s cubic-bezier(.4,0,.2,1);
  will-change:transform;
}

/* Individual slide */
.fc-slide{
  min-width:100%;
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  gap:var(--section-inner-gap);
  padding:clamp(32px,5vw,64px);
}

/* Even slides: visual on left, text on right */
.fc-slide:nth-child(even){direction:rtl}
.fc-slide:nth-child(even)>*{direction:ltr}

/* Dot navigation */
.fc-dots{
  display:flex;
  justify-content:center;
  gap:10px;
  margin-top:var(--sp-6);
}

.fc-dot{
  width:10px;height:10px;
  border-radius:50%;
  border:none;
  background:rgba(0,0,0,.18);
  cursor:pointer;
  padding:0;
  transition:background .25s,transform .25s;
}

.fc-dot.active{
  background:var(--brand);
  transform:scale(1.3);
}

.fc-dot:hover:not(.active){background:rgba(0,0,0,.35)}

/* Responsive — stack on mobile */
@media(max-width:768px){
  .fc-slide{
    grid-template-columns:1fr;
    gap:24px;
    padding:clamp(24px,6vw,40px);
  }
  .fc-slide:nth-child(even){direction:ltr}
  /* On mobile show text first, visual second */
  .fc-slide .feature-visual{order:1}
  .fc-slide .feature-text{order:2}
}

/* ==========================================================
   UTILITY ADDITIONS — v5.1
   ========================================================== */

/* Sophie CTA button — neon purple pill, applied consistently across all pages */
.btn-sophie{
  display:inline-flex;align-items:center;gap:10px;
  background:linear-gradient(135deg,#9333ea 0%,#7c3aed 50%,#4f46e5 100%);
  color:#fff;
  border:1.5px solid rgba(168,85,247,.7);
  border-radius:var(--radius-full,9999px);
  padding:14px 28px;
  font-weight:700;font-size:.95rem;font-family:inherit;cursor:pointer;
  white-space:nowrap;text-decoration:none;
  box-shadow:0 0 0 1px rgba(139,92,246,.25),
             0 0 18px rgba(139,92,246,.5),
             0 0 36px rgba(139,92,246,.2);
  transition:transform .2s var(--ease),box-shadow .2s var(--ease),opacity .2s;
}
.btn-sophie:hover{
  opacity:1;transform:translateY(-2px);
  box-shadow:0 0 0 1px rgba(168,85,247,.45),
             0 0 24px rgba(139,92,246,.65),
             0 0 48px rgba(139,92,246,.3);
}
.btn-sophie:focus-visible{outline:3px solid #a855f7;outline-offset:3px}

/* Page hero inner layout — two-col (text + CTA button) */
.page-hero-inner{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:48px;
}
@media(max-width:768px){
  .page-hero-inner{
    grid-template-columns:1fr;
    gap:0;
  }
  .page-hero-inner .hero-cta-col{display:none}
}

/* White-outline button variant for dark/gradient backgrounds */
.btn-outline-white{
  color:var(--white)!important;
  border-color:rgba(255,255,255,.5)!important;
}
.btn-outline-white:hover{
  border-color:var(--white)!important;
  background:rgba(255,255,255,.1)!important;
}

/* Section utility with background */
.section-white{background:var(--white)}
.section-cream{background:var(--cream)}

/* ==========================================================
   DESIGN UPGRADE v6 — sarvam.ai + NiCE inspired
   ========================================================== */

/* Gradient text utility */
.grad-text{
  background:var(--grad-text);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  display:inline;
}

/* Dark section — text overrides for sections with dark backgrounds */
.dark-section{background:var(--dark-bg)}
.dark-section .section-head h2{color:var(--white)}
.dark-section .section-head .subtitle{color:#fff}
.dark-section .section-head .eyebrow{
  background:var(--grad-text);-webkit-background-clip:text;
  background-clip:text;-webkit-text-fill-color:transparent;
}

/* Scrolled state — text stays white on dark header */
.site-header.scrolled .nav-links a{color:#fff}
.site-header.scrolled .nav-links a:hover,
.site-header.scrolled .nav-links a.active{color:#fff}
.site-header.scrolled .logo-text{color:#fff}
.site-header.scrolled .nav-login{color:#fff}
.site-header.scrolled .nav-login:hover{color:#fff}
.site-header.scrolled .hamburger svg{stroke:#fff}

/* Hero content z-index above mesh */
.hero .container{position:relative;z-index:3}

/* Feature carousel on dark section */
.feature-carousel-sec{padding:var(--section-py) 0;background:var(--white)}
.fc-track-outer{
  overflow:hidden;
  border:1px solid var(--gray-200);
  border-radius:20px;
  box-shadow:0 8px 40px rgba(0,0,0,.08);
}

/* FC slide text */
.feature-text h3{
  font-size:clamp(1.5rem,2.5vw,2.1rem);font-weight:800;
  line-height:1.2;margin-bottom:16px;letter-spacing:-.02em;
}

/* How section upgrade — track connector line */
.how-sec{padding:var(--section-py) 0;background:var(--cream)}
.steps-grid{position:relative}
.steps-grid::before{
  content:'';position:absolute;top:24px;left:calc(12.5% + 24px);
  right:calc(12.5% + 24px);height:2px;
  background:linear-gradient(90deg,#7c3aed,#3b82f6);
  opacity:.25;
}
@media(max-width:768px){.steps-grid::before{display:none}}

/* Resource card upgrade */
.resource-card:hover{
  box-shadow:0 20px 60px rgba(99,102,241,.12),0 4px 16px rgba(0,0,0,.06);
  transform:translateY(-6px);
}

/* Story card upgrade */
.story-stat .lbl{font-size:.8rem;color:var(--gray-500)}

/* CTA banner — add glow ──────────────────────── */
.cta-banner{
  background:var(--dark-bg);
  position:relative;overflow:hidden;
}
.cta-banner::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 60% 80% at 50% 50%,rgba(124,58,237,.35) 0%,transparent 65%),
    radial-gradient(ellipse 40% 50% at 80% 20%,rgba(59,130,246,.2) 0%,transparent 55%);
}
.cta-banner .container{position:relative;z-index:1}

/* Pricing card feature list check marks */
.price-card li::before{
  content:'✓';
  background:var(--grad-text);-webkit-background-clip:text;
  background-clip:text;-webkit-text-fill-color:transparent;
  font-weight:700;font-size:.8rem;flex-shrink:0;
}

/* FAQ item — slim border accent on open */
.faq-item.open{
  border-left:3px solid transparent;
  border-image:var(--grad-text) 1;
}

/* Form focus glow */
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(124,58,237,.12);
}

/* Mobile nav — dark glass when open */
@media(max-width:768px){
  .nav-links{
    background:rgba(8,8,22,.97);
    backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border-top:1px solid rgba(255,255,255,.08);
    box-shadow:0 8px 30px rgba(0,0,0,.4);
  }
  .nav-links a{border-radius:10px;color:#fff}
  .nav-links a:hover{color:#fff;background:rgba(255,255,255,.09)}
}

/* ==========================================================
   ENLIGHTEN AI DESIGN LANGUAGE — v7
   ========================================================== */

/* ── Particle bokeh background (CSS-only) ── */
.particle-bg{position:relative;overflow:hidden}
.particle-bg::before{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    radial-gradient(circle 3px  at 12% 18%,rgba(0,180,255,.6) 0%,transparent 100%),
    radial-gradient(circle 2px  at 28% 42%,rgba(0,140,255,.5) 0%,transparent 100%),
    radial-gradient(circle 4px  at 7%  65%,rgba(0,160,255,.4) 0%,transparent 100%),
    radial-gradient(circle 2px  at 45% 12%,rgba(80,100,255,.5) 0%,transparent 100%),
    radial-gradient(circle 3px  at 72% 28%,rgba(0,180,255,.35) 0%,transparent 100%),
    radial-gradient(circle 2px  at 88% 55%,rgba(0,140,255,.4) 0%,transparent 100%),
    radial-gradient(circle 5px  at 55% 78%,rgba(0,100,200,.3) 0%,transparent 100%),
    radial-gradient(circle 2px  at 18% 88%,rgba(0,160,255,.45) 0%,transparent 100%),
    radial-gradient(circle 3px  at 93% 15%,rgba(80,80,255,.4) 0%,transparent 100%),
    radial-gradient(circle 2px  at 38% 92%,rgba(0,180,255,.35) 0%,transparent 100%),
    radial-gradient(circle 60px at 20% 45%,rgba(0,80,200,.08) 0%,transparent 100%),
    radial-gradient(circle 80px at 75% 60%,rgba(0,60,180,.07) 0%,transparent 100%),
    radial-gradient(circle 50px at 50% 20%,rgba(60,0,180,.07) 0%,transparent 100%);
}
.particle-bg > *{position:relative;z-index:1}

/* ── Circle-arrow CTA (Enlighten AI style) ── */
.btn-circle-arrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:.95rem;font-weight:600;color:var(--white);
  background:none;border:none;cursor:pointer;
  font-family:inherit;padding:0;
  transition:gap var(--dur) var(--ease);
}
.btn-circle-arrow:hover{gap:18px}
.btn-circle-arrow .circle{
  width:40px;height:40px;border-radius:50%;
  background:var(--cyan-cta);
  display:grid;place-items:center;flex-shrink:0;
  box-shadow:0 0 16px rgba(0,207,255,.4);
  transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.btn-circle-arrow:hover .circle{
  box-shadow:0 0 24px rgba(0,207,255,.6);
  transform:scale(1.08);
}
.btn-circle-arrow .circle svg{
  width:16px;height:16px;stroke:var(--black);stroke-width:2.5;fill:none;
}

/* Nav circle-arrow CTA */
.btn-get-started .circle{
  width:28px;height:28px;border-radius:50%;
  background:var(--cyan-cta);
  display:grid;place-items:center;
  box-shadow:0 0 10px rgba(0,207,255,.35);
}

/* ── Feature carousel on white ── */
.feature-carousel-sec{background:var(--white)}
.fc-track-outer{border-color:var(--gray-200)}

/* ── Resource cards — Enlighten AI card style ── */
.resource-card{
  background:var(--navy-card);
  border:1px solid var(--navy-border);
  color:var(--white);
}
.resource-card:hover{
  border-color:rgba(124,58,237,.8);
  box-shadow:0 0 0 1px rgba(124,58,237,.4),0 20px 60px rgba(0,0,0,.4);
}
.resource-card-body .rc-label{color:var(--cyan-cta)}
.resource-card-body h4{color:var(--white)}
.resource-card-body .rc-arrow{background:rgba(255,255,255,.08)}
.resource-card:hover .rc-arrow{background:var(--cyan-cta)}
.resource-card:hover .rc-arrow svg{stroke:var(--black)}

/* ── Intro sec — dark with particle ── */
.intro-sec{background:var(--dark-bg)}

/* ── Story stat border accent ── */
.story-stat{border-left:3px solid var(--cyan-cta)}

/* ── FAQ open border ── */
.faq-item.open{border-left:3px solid var(--coral);border-image:none}

/* ── CTA banner coral accent ── */
.cta-banner .btn-primary{
  background:var(--coral);
  box-shadow:0 4px 18px rgba(240,62,62,.4);
}
.cta-banner .btn-primary:hover{
  background:#d63535;
  box-shadow:0 6px 24px rgba(240,62,62,.5);
}

/* ── Section eyebrow on dark — cyan instead of gradient ── */
.dark-section .section-head .eyebrow{
  background:none;-webkit-text-fill-color:var(--cyan-cta);
  color:var(--cyan-cta);
}

/* ── Trusted logos — teal tint on hover ── */
.logo-row .partner-logo:hover{color:var(--cyan-cta);border-color:rgba(0,207,255,.3)}

/* ══════════════════════════════════════════════════════════
   DARK PARTICLE PAGES — services.html & demo.html
   <body class="has-particles"> — sections become transparent
   so the animated canvas background shines through.
   ══════════════════════════════════════════════════════════ */
body.has-particles{background:#000;color:#fff}

/* Nav → dark glass */
body.has-particles .site-header{
  background:rgba(0,0,0,.85)!important;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  box-shadow:0 1px 0 rgba(255,255,255,.07);
}
body.has-particles .site-header.scrolled{
  background:rgba(0,0,0,.93)!important;
  box-shadow:0 1px 0 rgba(255,255,255,.12);
}
body.has-particles .nav-links a,
body.has-particles .logo-text,
body.has-particles .nav-login{color:#fff}
body.has-particles .nav-links a:hover,
body.has-particles .nav-links a.active{color:#fff}
body.has-particles .hamburger svg{stroke:#fff}

/* Clear white/cream section backgrounds */
body.has-particles .srv-detail-sec,
body.has-particles .demo-sec,
body.has-particles section:not(.page-hero):not(.cta-banner){background:transparent!important}

/* Service detail blocks → glass cards */
body.has-particles .srv-detail{
  background:var(--dark-surface-subtle);
  border:1px solid var(--dark-surface-high);
  border-radius:20px;padding:40px;
  transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
body.has-particles .srv-detail:hover{
  background:var(--dark-border-subtle);
  border-color:var(--dark-border-mid);
}

/* Text on dark backgrounds */
body.has-particles .srv-detail-content h3{color:#fff}
body.has-particles .srv-detail-content p,
body.has-particles .feat-list li{color:#fff}
body.has-particles .feat-list li::before{color:var(--accent-cyan)}
body.has-particles h2,body.has-particles h3,body.has-particles h4{color:#fff}
body.has-particles p,body.has-particles li{color:#fff}
body.has-particles .lotus-label{color:#fff!important}
body.has-particles .lotus-meta{color:#fff!important}
body.has-particles .subtitle{color:#fff}

/* Ghost / outline buttons → visible on dark */
body.has-particles .btn-ghost{
  color:#fff;border-color:rgba(255,255,255,.28);background:transparent;
}
body.has-particles .btn-ghost:hover{
  background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.55);
}

/* Demo page — experience card */
body.has-particles .experience-card{
  background:var(--dark-surface-subtle)!important;
  border-color:var(--dark-card-hover)!important;
}
body.has-particles .experience-kicker{color:var(--accent-cyan)}
body.has-particles .experience-title,
body.has-particles .experience-header h3{color:#fff}

/* Demo cards */
body.has-particles .demo-card span,
body.has-particles .demo-card h4{color:#fff}
body.has-particles .live-badge{color:#fff}

/* Use-case cards */
body.has-particles .usecase-card{
  background:var(--dark-surface-subtle)!important;
  border-color:var(--dark-card-hover)!important;
}
body.has-particles .usecase-card:hover{
  background:var(--dark-surface-high)!important;
  box-shadow:0 0 0 1px var(--dark-border-strong);
  transform:translateY(-3px);
}

/* Dividers / borders inside dark sections */
body.has-particles hr{border-color:var(--dark-border)}

/* ── Pricing cards ── */
body.has-particles .price-card{
  background:var(--dark-card)!important;
  border:1px solid var(--dark-border)!important;
  color:#fff!important}
body.has-particles .price-card.featured{
  background:rgba(99,102,241,.14)!important;
  border-color:rgba(99,102,241,.38)!important}
body.has-particles .plan-name{color:#fff!important}
body.has-particles .plan-price{color:#fff!important}
body.has-particles .plan-price span{color:#fff!important}
body.has-particles .plan-desc,
body.has-particles .price-card ul li{color:#fff!important}
body.has-particles .price-card .btn-outline{
  border-color:var(--dark-border-active)!important;
  color:#fff!important}
body.has-particles .price-card .btn-outline:hover{
  background:var(--dark-surface-high)!important}

/* ── FAQ ── */
body.has-particles .faq-item{
  background:var(--dark-surface-subtle)!important;
  border-color:var(--dark-surface-high)!important}
body.has-particles .faq-q,
body.has-particles .faq-title h2{color:#fff!important}
body.has-particles .faq-a,
body.has-particles .faq-a-inner{color:#fff!important}
body.has-particles .faq-q svg{stroke:var(--text-on-dark-muted)!important}

/* ── Comparison table ── */
body.has-particles table th,
body.has-particles table td{
  color:#fff!important;
  border-color:var(--dark-surface-high)!important}
body.has-particles thead tr{border-bottom-color:var(--dark-border-mid)!important}

/* ── Contact / generic inline-color override ── */
body.has-particles .section h2,
body.has-particles .section h3{color:#fff!important}
body.has-particles .section p,
body.has-particles .section strong,
body.has-particles .usecase-card strong{color:#fff!important}
body.has-particles .section span:not(.eyebrow):not(.badge):not(.plan-price),
body.has-particles .usecase-card span{color:#fff!important}

/* ── Form inputs ── */
body.has-particles input[type="text"],
body.has-particles input[type="email"],
body.has-particles input[type="tel"],
body.has-particles textarea,
body.has-particles select{
  background:rgba(255,255,255,.07)!important;
  border:1px solid rgba(255,255,255,.15)!important;
  color:#fff!important}
body.has-particles input::placeholder,
body.has-particles textarea::placeholder{color:#fff!important}
body.has-particles label{color:#fff!important}
body.has-particles select option{background:#111;color:#fff}

/* ── Responsive: hero full-height on mobile ── */
@media(max-width:768px){
  .hero{min-height:100svh}
  .hero .container{padding-top:60px;padding-bottom:120px}
  .hero h1{font-size:clamp(2.2rem,8vw,3.2rem)}
}
/* ============================================================
   GLOBAL DARK THEME OVERRIDES
   Extends the slate #1e2030 glassmorphism palette to every page
   ============================================================ */

/* --- Section backgrounds: all light sections → dark slate --- */
.pricing-sec,
.faq-sec,
.final-cta,
.resources-sec,
.story-sec,
.how-sec,
.feature-carousel-sec,
.srv-detail-sec,
.demo-sec,
.section-white,
.section-cream {
  background: var(--dark-bg-2) !important;
}
/* Sections that follow a page-hero should be dark, not white */
.page-hero ~ section:not([class*="cta"]):not([class*="grad"]) {
  background-color: var(--dark-bg-2) !important;
}

/* --- CTA section text --- */
.final-cta h2 { color: #fff !important; }
.final-cta p  { color:#fff!important; }

/* --- Section headings & subtitles --- */
.section-head h2, .section-head h3 { color: #fff !important; }
.section-head .subtitle { color:#fff!important; }
.faq-title h2, .faq-title h3 { color: #fff !important; }
.step-card h4 { color:#fff!important; }
.step-card p  { color:#fff!important; }
.story-content h2, .story-content h3 { color: #fff !important; }
.story-content p { color:#fff!important; }
.srv-detail-content h3 { color: #fff !important; }
.srv-detail-content p  { color:#fff!important; }
.feat-list li  { color:#fff!important; }

/* --- Price cards → dark glass --- */
.price-card {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.14),
    inset 0 -1px 0 rgba(0,0,0,.18),
    0 4px 24px rgba(0,0,0,.28) !important;
}
.price-card.featured {
  border-color: rgba(168,85,247,.5) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.18),
    inset 0 -1px 0 rgba(0,0,0,.18),
    0 0 0 2px rgba(168,85,247,.4),
    0 12px 40px rgba(168,85,247,.22) !important;
}
.price-card .plan-price           { color: #fff !important; }
.price-card .plan-price span      { color:#fff!important; }
.price-card .plan-desc            { color:#fff!important; }
.price-card li                    { color:#fff!important; border-bottom-color: var(--dark-surface-high) !important; }
.price-card .btn-outline          { border-color: var(--dark-border-active) !important; color:#fff!important; }
.price-card .btn-outline:hover    { background: var(--dark-border) !important; }

/* --- FAQ → dark glass --- */
.faq-item {
  background: var(--dark-surface) !important;
  border: 1px solid var(--dark-border-mid) !important;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.faq-q                          { color:#fff!important; }
.faq-q:hover,
.faq-item.open .faq-q           { color: #fff !important; }
.faq-q svg                      { stroke: rgba(255,255,255,.4) !important; }
.faq-a-inner                    { color:#fff!important; }

/* --- Use-case / info cards → dark glass --- */
.usecase-card {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.14),
    inset 0 -1px 0 rgba(0,0,0,.18) !important;
}
.usecase-card h4     { color: #fff !important; }
.usecase-card p      { color:#fff!important; }
.usecase-card strong { color:#fff!important; }

/* --- Form wrap → dark glass --- */
.form-wrap {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.form-group label { color:#fff!important; }
.form-group input,
.form-group select,
.form-group textarea {
  background: rgba(255,255,255,.08) !important;
  border-color: rgba(255,255,255,.16) !important;
  color: #fff !important;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color:#fff!important; }

/* --- Resource cards → dark glass --- */
.resource-card {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.resource-card-body h4  { color: #fff !important; }
.resource-card-body .rc-label { color:#fff!important; }

/* --- Feature carousel track border --- */
.fc-track-outer { border-color: rgba(255,255,255,.1) !important; }

/* --- Story section --- */
.story-card {
  background: rgba(255,255,255,.06) !important;
  border-color: rgba(255,255,255,.12) !important;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

/* --- Demo page experience card --- */
.experience-card {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

/* --- Services detail --- */
.srv-detail-sec { background: var(--dark-bg-2) !important; }

/* --- Mobile nav → dark --- */
@media(max-width:768px){
  .nav-links {
    background: var(--dark-bg) !important;
    border-bottom: 1px solid rgba(255,255,255,.1) !important;
  }
  .nav-links a { color:#fff!important; }
}

/* ==========================================================
   APPLE GLASS DESIGN SYSTEM — Full-site override
   Vibrancy: blur(40px) saturate(180%) — Apple macOS / iOS
   ========================================================== */

/* ── Glass tokens ── */
:root{
  --glass-bg:rgba(28,28,34,.65);
  --glass-bg-light:rgba(255,255,255,.07);
  --glass-bg-hover:rgba(255,255,255,.11);
  --glass-border:rgba(255,255,255,.13);
  --glass-border-hover:rgba(255,255,255,.24);
  --glass-blur:blur(40px) saturate(180%);
  --glass-blur-sm:blur(20px) saturate(160%);
  --glass-shadow:inset 0 1px 0 rgba(255,255,255,.12),inset 0 -1px 0 rgba(0,0,0,.18),0 8px 32px rgba(0,0,0,.4),0 2px 8px rgba(0,0,0,.25);
  --glass-shadow-lg:inset 0 1px 0 rgba(255,255,255,.14),inset 0 -1px 0 rgba(0,0,0,.2),0 20px 60px rgba(0,0,0,.5),0 4px 16px rgba(0,0,0,.3);
  --glass-radius:18px;
  --glass-radius-sm:12px;
}

/* ── Shared glass mixin helper ── */
.glass{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border:1px solid var(--glass-border) !important;
  box-shadow:var(--glass-shadow) !important;
}

/* ══ NAV / HEADER ══════════════════════════════════════════ */
.site-header{
  background:rgba(10,11,30,.72) !important;
  backdrop-filter:blur(40px) saturate(200%) !important;
  -webkit-backdrop-filter:blur(40px) saturate(200%) !important;
  border-bottom:1px solid var(--dark-border) !important;
  box-shadow:inset 0 -1px 0 var(--dark-border-subtle),0 4px 30px rgba(0,0,0,.35) !important;
}
.site-header.scrolled{
  background:rgba(10,11,30,.88) !important;
  box-shadow:inset 0 -1px 0 rgba(255,255,255,.06),0 8px 40px rgba(0,0,0,.5) !important;
}
.nav-links a:hover,
.nav-login:hover{
  background:rgba(255,255,255,.1) !important;
  backdrop-filter:blur(10px) !important;
  border-radius:8px;
}

/* ══ ALL SECTION BACKGROUNDS ══════════════════════════════ */
.stats-sec,.trusted-sec,.intro-sec,.tech-sec,.resources-sec,
.stats-v2,.features-v2,.how-v2,.demo-v2,.pricing-v2,
.feature-block,.story-sec,.faq-sec,.final-cta,.ticker-sec,
.page-hero,.about-intro,.team-sec,.contact-sec,.careers-hero,
.blog-grid-sec,.privacy-sec,.terms-sec,.services-hero,
.demo-hero,.demo-features,.demo-cta,.demo-pricing-sec{
  background:var(--dark-bg) !important;
  color:#fff!important;
}
.stats-sec:nth-child(even),.tech-sec,.features-v2,.demo-v2,
.feature-block:nth-child(even),.faq-sec,.resources-sec,.intro-sec{
  background:var(--dark-bg-2) !important;
}

/* ══ EVERY CARD / BOX ══════════════════════════════════════ */

/* Stat cards */
.stat-card{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border:1px solid var(--glass-border) !important;
  border-right:1px solid rgba(255,255,255,.08) !important;
  border-radius:var(--glass-radius) !important;
  box-shadow:var(--glass-shadow) !important;
  transition:transform .3s ease,box-shadow .3s ease !important;
}
.stat-card:last-child{border-right:1px solid rgba(255,255,255,.08) !important}
.stat-card:hover{transform:translateY(-4px);box-shadow:var(--glass-shadow-lg) !important}

/* Tech cards */
.tech-card{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius) !important;
  box-shadow:var(--glass-shadow) !important;
}
.tech-card:hover{
  border-color:rgba(124,58,237,.6) !important;
  box-shadow:var(--glass-shadow-lg),0 0 0 1px rgba(124,58,237,.3) !important;
  transform:translateY(-6px);
}

/* Pricing cards */
.price-card{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius) !important;
  box-shadow:var(--glass-shadow) !important;
  color:#fff!important;
}
.price-card.featured{
  background:rgba(124,58,237,.25) !important;
  border-color:rgba(124,58,237,.5) !important;
  box-shadow:var(--glass-shadow-lg),0 0 0 1.5px rgba(124,58,237,.4),0 0 60px rgba(124,58,237,.2) !important;
}
.price-card .plan-price{color:var(--white) !important}
.price-card .plan-desc{color:#fff!important}
.price-card li{color:#fff!important;border-bottom-color:rgba(255,255,255,.08) !important}

/* FAQ items */
.faq-item{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius-sm) !important;
  box-shadow:var(--glass-shadow) !important;
}
.faq-item:hover{box-shadow:var(--glass-shadow-lg) !important;border-color:var(--glass-border-hover) !important}
.faq-q{color:#fff!important;background:transparent !important}
.faq-q:hover,.faq-item.open .faq-q{color:var(--white) !important}
.faq-q svg{stroke:rgba(255,255,255,.5) !important}
.faq-a-inner{color:#fff!important}

/* Resource cards */
.resource-card{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius) !important;
  box-shadow:var(--glass-shadow) !important;
}
.resource-card:hover{
  border-color:var(--glass-border-hover) !important;
  box-shadow:var(--glass-shadow-lg) !important;
  transform:translateY(-6px);
}
.resource-card-body h4{color:var(--white) !important}
.resource-card-body .rc-label{color:#fff!important}
.rc-arrow{background:rgba(255,255,255,.1) !important}
.resource-card:hover .rc-arrow{background:rgba(255,255,255,.18) !important}
.rc-arrow svg{stroke:rgba(255,255,255,.9) !important}

/* Story card */
.story-card{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius) !important;
  box-shadow:var(--glass-shadow-lg) !important;
}
.story-content{background:transparent !important}
.story-content h3{color:var(--white) !important}
.story-stat .lbl{color:#fff!important}
.story-link{color:#fff!important}

/* Feature visual blocks */
.feature-visual{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border:1px solid var(--glass-border) !important;
  box-shadow:var(--glass-shadow-lg) !important;
}
.feature-text h3{color:var(--white) !important}
.feature-text p{color:#fff!important}

/* Partner logos pill */
.logo-row .partner-logo{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur-sm) !important;
  -webkit-backdrop-filter:var(--glass-blur-sm) !important;
  border:1px solid var(--glass-border) !important;
  box-shadow:var(--glass-shadow) !important;
  color:#fff!important;
}
.logo-row .partner-logo:hover{
  border-color:var(--glass-border-hover) !important;
  color:#fff!important;
  background:rgba(255,255,255,.12) !important;
}

/* Float pills */
.float-pill{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur-sm) !important;
  -webkit-backdrop-filter:var(--glass-blur-sm) !important;
  border:1px solid var(--glass-border) !important;
  box-shadow:var(--glass-shadow) !important;
}

/* index.html v2 cards — stats, feature, how, demo, pricing */
.stat-box,.feature-card,.step-card,.demo-card,.plan-card,
.how-step,.convo-card,.demo-tab-panel,.scenario-card{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius) !important;
  box-shadow:var(--glass-shadow) !important;
}
.stat-box:hover,.feature-card:hover,.step-card:hover,.plan-card:hover{
  border-color:var(--glass-border-hover) !important;
  box-shadow:var(--glass-shadow-lg) !important;
  transform:translateY(-4px);
}

/* ══ DEMO TABS ═════════════════════════════════════════════ */
.demo-tab{
  background:var(--glass-bg-light) !important;
  backdrop-filter:var(--glass-blur-sm) !important;
  -webkit-backdrop-filter:var(--glass-blur-sm) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius-sm) !important;
  color:#fff!important;
  transition:all .25s ease !important;
}
.demo-tab:hover,.demo-tab.active{
  background:rgba(124,58,237,.3) !important;
  border-color:rgba(124,58,237,.5) !important;
  color:var(--white) !important;
  box-shadow:0 0 20px rgba(124,58,237,.25) !important;
}

/* ══ TICKER / SOCIAL PROOF ═════════════════════════════════ */
.ticker-item,.ticker-badge,.social-proof-item{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur-sm) !important;
  -webkit-backdrop-filter:var(--glass-blur-sm) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius-sm) !important;
  box-shadow:var(--glass-shadow) !important;
  color:#fff!important;
}

/* ══ ALL BUTTONS ═══════════════════════════════════════════ */

/* Outline / ghost buttons → glass */
.btn-outline,.btn-ghost,.btn-white,.btn-secondary{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur-sm) !important;
  -webkit-backdrop-filter:var(--glass-blur-sm) !important;
  border:1px solid var(--glass-border) !important;
  color:#fff!important;
  box-shadow:var(--glass-shadow) !important;
}
.btn-outline:hover,.btn-ghost:hover,.btn-white:hover,.btn-secondary:hover{
  background:rgba(255,255,255,.14) !important;
  border-color:var(--glass-border-hover) !important;
  color:var(--white) !important;
  box-shadow:var(--glass-shadow-lg) !important;
  transform:translateY(-2px);
}

/* Primary CTA buttons keep gradient but get glass glow */
.btn-primary,.btn-get-started{
  box-shadow:0 4px 20px rgba(124,58,237,.45),inset 0 1px 0 rgba(255,255,255,.2) !important;
}
.btn-primary:hover,.btn-get-started:hover{
  box-shadow:0 8px 32px rgba(124,58,237,.6),inset 0 1px 0 rgba(255,255,255,.25) !important;
  transform:translateY(-2px);
}

/* ══ CTA BANNER ════════════════════════════════════════════ */
.cta-banner,.final-cta{
  background:rgba(10,11,30,.85) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border-top:1px solid var(--glass-border) !important;
  border-bottom:1px solid var(--glass-border) !important;
}
.cta-banner h2,.final-cta h2{color:var(--white) !important}
.final-cta p{color:#fff!important}

/* ══ FOOTER ════════════════════════════════════════════════ */
.site-footer{
  background:rgba(5,6,15,.92) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border-top:1px solid var(--glass-border) !important;
}
.footer-bottom{
  border-top-color:rgba(255,255,255,.08) !important;
}

/* ══ PAGE HERO (inner pages) ═══════════════════════════════ */
.page-hero{
  background:transparent !important;
}
/* .page-hero-inner is a grid layout container only — card styling lives on .sec-glass */
.page-hero-inner{
  background:none !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
  border:none !important;
  border-radius:0 !important;
  box-shadow:none !important;
  padding:0 !important;
}

/* ══ CONTACT FORM ══════════════════════════════════════════ */
.contact-form,.contact-card,
input[type="text"],input[type="email"],input[type="tel"],
textarea,select,.form-group input,.form-group textarea{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur-sm) !important;
  -webkit-backdrop-filter:var(--glass-blur-sm) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius-sm) !important;
  color:#fff!important;
  box-shadow:var(--glass-shadow) !important;
}
input::placeholder,textarea::placeholder{color:#fff!important}
input:focus,textarea:focus,select:focus{
  border-color:rgba(124,58,237,.6) !important;
  box-shadow:0 0 0 3px rgba(124,58,237,.2),var(--glass-shadow) !important;
  outline:none !important;
}

/* ══ MODALS / OVERLAYS ═════════════════════════════════════ */
.modal,.modal-inner,.dialog-card{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius) !important;
  box-shadow:var(--glass-shadow-lg) !important;
}

/* ══ SECTION HEADINGS ══════════════════════════════════════ */
.section-head h2,.section-head .subtitle,
h2,h3,h4{color:var(--white)}
.section-head .subtitle,.intro-statement{color:#fff!important}
p{color:#fff}

/* ══ MISC ELEMENTS ═════════════════════════════════════════ */
.hero-badge{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur-sm) !important;
  -webkit-backdrop-filter:var(--glass-blur-sm) !important;
  border:1px solid var(--glass-border) !important;
  box-shadow:var(--glass-shadow) !important;
}
/* Eyebrow labels */
.eyebrow{color:var(--cyan-cta) !important;-webkit-text-fill-color:var(--cyan-cta) !important}

/* Scrollbar */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--dark-bg)}
::-webkit-scrollbar-thumb{background:rgba(124,58,237,.4);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(124,58,237,.7)}


/* ── v2 index section elements (additional specific selectors) ── */
.feat-card{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius) !important;
  box-shadow:var(--glass-shadow) !important;
}
.feat-card:hover{
  border-color:var(--glass-border-hover) !important;
  box-shadow:var(--glass-shadow-lg) !important;
  transform:translateY(-5px);
}

/* ── features-v2 section — all text bright white ── */
.features-v2 .section-title{color:#fff!important}
.features-v2 .section-sub{color:#fff!important}
.features-v2 .feat-card h3{color:#fff!important}
.features-v2 .feat-card p{color:#fff!important}
.features-v2 .feat-pill{
  color:#fff!important;
  background:rgba(255,255,255,.12)!important;
  border:1px solid rgba(255,255,255,.22)!important;
}

.stat-v2{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius) !important;
  box-shadow:var(--glass-shadow) !important;
}

.step-v2{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius) !important;
  box-shadow:var(--glass-shadow) !important;
}
.step-v2:hover{
  border-color:var(--glass-border-hover) !important;
  box-shadow:var(--glass-shadow-lg) !important;
  transform:translateY(-4px);
}

.plan-card{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius) !important;
  box-shadow:var(--glass-shadow) !important;
}
.plan-card.featured{
  background:rgba(109,40,217,.28) !important;
  border-color:rgba(124,58,237,.55) !important;
  box-shadow:var(--glass-shadow-lg),0 0 0 1.5px rgba(124,58,237,.4),0 0 50px rgba(124,58,237,.2) !important;
}
.plan-card:hover{
  border-color:var(--glass-border-hover) !important;
  box-shadow:var(--glass-shadow-lg) !important;
  transform:translateY(-5px);
}

/* Plan buttons (outline style inside pricing) */
.plan-btn-outline{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur-sm) !important;
  -webkit-backdrop-filter:var(--glass-blur-sm) !important;
  border:1px solid var(--glass-border) !important;
  color:#fff!important;
  box-shadow:var(--glass-shadow) !important;
}
.plan-btn-outline:hover{
  background:rgba(255,255,255,.12) !important;
  border-color:var(--glass-border-hover) !important;
  color:var(--white) !important;
}

/* Demo transcript / convo */
.demo-transcript,.demo-scenario{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius) !important;
  box-shadow:var(--glass-shadow) !important;
}

/* Demo tags */
.demo-tag{
  background:rgba(255,255,255,.08) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:99px !important;
  color:#fff!important;
  backdrop-filter:blur(10px) !important;
}

/* Ticker */
.ticker-item{
  background:var(--glass-bg) !important;
  backdrop-filter:var(--glass-blur-sm) !important;
  -webkit-backdrop-filter:var(--glass-blur-sm) !important;
  border:1px solid var(--glass-border) !important;
  border-radius:var(--glass-radius-sm) !important;
  box-shadow:var(--glass-shadow) !important;
  color:#fff!important;
}

/* CTA v2 */
.cta-v2{
  background:rgba(10,11,30,.85) !important;
  backdrop-filter:var(--glass-blur) !important;
  -webkit-backdrop-filter:var(--glass-blur) !important;
  border-top:1px solid var(--glass-border) !important;
  border-bottom:1px solid var(--glass-border) !important;
}
.cta-v2-h2{color:var(--white) !important}


/* ── Legal pages & blog/careers glass consistency ── */
.legal-page{
  max-width:800px;margin:0 auto;
  padding:clamp(32px,4vw,60px) clamp(24px,4vw,48px) clamp(48px,6vw,80px);
}
.legal-page h1{color:var(--white)!important}
.legal-page h2{color:#fff!important;margin-top:2rem}
.legal-page p,.legal-page li{color:#fff!important}
.legal-page a{color:var(--accent-light)!important}
.legal-meta{color:#fff!important;font-size:.85rem}

/* topic chips (blog) */
.topic-chip{
  background:var(--glass-bg)!important;
  backdrop-filter:var(--glass-blur-sm)!important;
  -webkit-backdrop-filter:var(--glass-blur-sm)!important;
  border:1px solid var(--glass-border)!important;
  color:#fff!important;
  border-radius:999px;padding:6px 14px;font-size:.85rem;font-weight:500;
  display:inline-block;
}


/* ==========================================================
   RESPONSIVE — ENHANCED
   Auto-arrange for all screen sizes / snap layouts
   ========================================================== */

/* ── Nav links text colour on dark pages ── */
body.has-particles .nav-links a{color:#fff!important}
body.has-particles .nav-links a:hover{color:#fff!important;background:rgba(255,255,255,.06);border-radius:8px;}
body.has-particles .nav-dropdown-menu{
  background:rgba(14,15,35,.97)!important;
  border:1px solid rgba(255,255,255,.09)!important;
}

/* ── Tablet (≤ 1024px) ── */
@media(max-width:1024px){
  .contact-grid{grid-template-columns:1fr!important;gap:32px!important;}
}

/* ── Mobile (≤ 768px) ── */
@media(max-width:768px){
  /* Page hero — allow wrapping on mobile */
  .page-hero h1,.page-hero h2{white-space:normal!important;font-size:clamp(1.4rem,5vw,2rem)!important;}
  .page-hero .subtitle{white-space:normal!important;}

  /* CTA button groups — stack vertically */
  .cta-group,.cta-group-center{
    flex-direction:column!important;
    align-items:center!important;
    gap:12px!important;
  }
  .cta-v2-btns{
    flex-direction:column!important;
    align-items:center!important;
    gap:12px!important;
  }
  .cta-v2-btns .btn,.cta-group .btn,.cta-group-center .btn{
    width:100%;max-width:300px;text-align:center;justify-content:center;
  }

  /* Stats on about page */
  .stats-grid{grid-template-columns:1fr 1fr!important;}

  /* Values & FAQ tab panels — make sure they stack */
  .val-grid{grid-template-columns:1fr!important;}
  .val-header{
    flex-direction:column!important;align-items:flex-start!important;
    padding:24px 20px!important;
  }
  .faq-header{
    flex-direction:column!important;align-items:flex-start!important;
    padding:24px 20px!important;
  }
  .faq-tab-wrap{grid-template-columns:1fr!important;}

  /* Pricing comparison table scrollable */
  .compare-table-wrap{overflow-x:auto!important;}

  /* Section title size */
  .section-title{font-size:clamp(1.6rem,5vw,2.2rem)!important;}
  .hero-title{font-size:clamp(1.8rem,6vw,2.5rem)!important;}
}

/* ── Small mobile (≤ 480px) ── */
@media(max-width:480px){
  /* Glass card padding tighter */
  .sec-glass{padding:20px 16px!important;border-radius:14px!important;}
  /* .page-hero-inner padding handled by parent .sec-glass on mobile */

  /* Stats grids — 1 column */
  .stats-v2-grid{grid-template-columns:1fr!important;}
  .stats-grid{grid-template-columns:1fr!important;}

  /* Button full-width */
  .btn,.btn-primary,.btn-secondary,.btn-outline,.btn-get-started{
    width:100%;max-width:300px;text-align:center;
  }
  /* Exceptions: nav button stays compact */
  .nav-end .btn-get-started{width:auto!important;max-width:none!important;}

  /* Val / FAQ headers */
  .val-header{padding:18px 14px!important;}
  .faq-header{padding:18px 14px!important;}

  /* How-it-works step connector line hidden (already handled in index.html but ensure) */
  .steps-v2::before{display:none!important;}

  /* Pricing card max-width */
  .plan-card,.price-card{max-width:100%!important;}

  /* Footer */
  .footer-links{flex-direction:column!important;align-items:center!important;gap:8px!important;}
}


/* ==========================================================
   PHASE 1 PERFORMANCE & CLARITY IMPROVEMENTS
   Applied: 2026-02-24
   ========================================================== */

/* ── Fix 1C: Remove backdrop-filter from cards on dark backgrounds ──────────
   These elements sit on #0a0b1e / #13142c — near-black backgrounds.
   There is nothing meaningful to blur through. The GPU cost is real;
   the visual benefit is zero. We replace with an opaque-enough solid tint.
   blur is KEPT on: .site-header, .convo-card, .hero-badge, .page-hero-inner
   ────────────────────────────────────────────────────────────────────────── */
.price-card,
.faq-item,
.resource-card,
.usecase-card,
.demo-card .demo-card-visual,
.stat-card,
.tech-card,
.story-card,
.experience-card,
.form-wrap,
.float-pill,
.feat-card,
.step-v2,
.stat-v2,
.plan-card,
.ticker-item,
.partner-logo {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* Restore a rich-enough solid background so they still look premium */
.price-card {
  background: rgba(26,27,48,.85) !important;
}
.faq-item {
  background: rgba(22,23,42,.80) !important;
}
.resource-card {
  background: rgba(16,17,36,.82) !important;
}
.usecase-card {
  background: rgba(22,23,42,.80) !important;
}
.stat-card {
  background: rgba(22,23,42,.80) !important;
}
.tech-card {
  background: rgba(16,17,36,.85) !important;
}
.story-card,
.experience-card,
.form-wrap {
  background: rgba(22,23,42,.80) !important;
}

/* Keep blur ONLY on nav hover (appropriate: content scrolls behind it) */
.nav-links a:hover,
.nav-login:hover {
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

/* Reduce main glass-blur variable — still premium, half the GPU cost */
/* Applied to: .site-header, .convo-card, .hero-badge, .page-hero-inner */
:root {
  --glass-blur: blur(24px) saturate(170%);     /* was blur(40px) saturate(180%) */
  --glass-blur-sm: blur(12px) saturate(150%);  /* was blur(20px) saturate(160%) */
}
/* Nav keeps stronger blur (it blurs real page content scrolling behind it) */
.site-header {
  backdrop-filter: blur(40px) saturate(200%) !important;
  -webkit-backdrop-filter: blur(40px) saturate(200%) !important;
}

/* ── Fix 1E: Section separators + visual rhythm ──────────────────────────── */

/* Add a hairline separator between every section */
main > section {
  border-top: 1px solid rgba(255,255,255,.05);
}
/* First section (hero) — no top border */
main > section:first-child,
.hero-v2,
.rainbow-line + section,
.page-hero {
  border-top: none !important;
}

/* Improve text contrast in dark sections — several classes were below AA */
.faq-a-inner          { color:#fff!important; }
.plan-desc,
.price-card .plan-desc { color:#fff!important; }
.stat-v2-lbl          { color:#fff!important; }
.tech-card p          { color:#fff!important; }
.step-card p          { color:#fff!important; }
.intro-statement      { color:#fff!important; }

/* ── Fix 1F: Mobile / touch device — disable heavy video + canvas ────────── */
@media (max-width: 768px) and (hover: none) {
  /* Stop the video element from loading / playing on touch devices */
  #bg-video {
    display: none;
  }
  /* Stop the canvas particle animation */
  #particle-canvas {
    display: none;
  }
  /* Gradient fallback so pages don't fall back to plain black */
  body {
    background:
      radial-gradient(ellipse 80% 55% at 20% 25%, rgba(124,58,237,.16) 0%, transparent 58%),
      radial-gradient(ellipse 60% 50% at 82% 72%, rgba(6,182,212,.09) 0%, transparent 55%),
      radial-gradient(ellipse 50% 40% at 55% 50%, rgba(99,102,241,.07) 0%, transparent 60%),
      var(--dark-bg);
    background-attachment: fixed;
  }
}

.logo-icon{width:34px;height:34px;border-radius:50%;display:block;flex-shrink:0}
.hero-particle-bg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:320px;height:320px;opacity:.18;pointer-events:none;z-index:0}
.hero-particle-bg img{width:100%;height:100%;display:block}

/* ── Skip navigation link (WCAG 2.4.1) ── */
.skip-link{
  position:absolute;top:-100%;left:16px;
  background:var(--accent);color:var(--white);
  padding:8px 16px;border-radius:var(--radius-sm);
  font-size:var(--text-sm);font-weight:600;
  text-decoration:none;z-index:var(--z-skip);
  transition:top .2s;
}
.skip-link:focus{top:16px;}

/* ── Visually hidden (screen-reader only) ── */
.visually-hidden{
  position:absolute;width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* ── Reduced motion (WCAG 2.3.3 advisory) ── */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
}

/* ── Fix 1B: video poster (services.html) ────────────────────────────────── */
/* poster attr added inline in services.html; no CSS needed */

/* ── Fix 2D: lazy loading ────────────────────────────────────────────────── */
/* loading="lazy" added to below-fold <img> in services.html; no CSS needed */

/* ── Fix 2C: Section accent radial gradients ─────────────────────────────── */
/* Subtle purple/cyan glows break up flat dark-section repetition            */

.story-sec,
.feature-carousel-sec,
.how-sec,
.tech-sec,
.resources-sec {
  position: relative;
  overflow: hidden;
}

/* Stats / story section — glow from top-left */
.story-sec::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 60% at 8% 20%, rgba(124,58,237,.13) 0%, transparent 65%);
  pointer-events: none;
  z-index: 0;
}

/* Feature carousel — glow from top-right */
.feature-carousel-sec::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 65% 55% at 92% 15%, rgba(124,58,237,.11) 0%, transparent 62%);
  pointer-events: none;
  z-index: 0;
}

/* How it works — glow from centre-left */
.how-sec::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 50% at 5% 50%, rgba(124,58,237,.10) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}

/* Tech section — cyan accent from bottom-right */
.tech-sec::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 55% 45% at 90% 85%, rgba(6,182,212,.10) 0%, transparent 58%);
  pointer-events: none;
  z-index: 0;
}

/* Resources — soft purple from centre */
.resources-sec::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 55% 60% at 50% 55%, rgba(124,58,237,.08) 0%, transparent 65%);
  pointer-events: none;
  z-index: 0;
}

/* Ensure child content sits above pseudo-element glows */
.story-sec > *,
.feature-carousel-sec > *,
.how-sec > *,
.tech-sec > *,
.resources-sec > * {
  position: relative;
  z-index: 1;
}

/* ══════════════════════════════════════════════
   Contact page — form field classes
   Replaces inline style= attributes on inputs,
   select, textarea, error spans, and status div.
   ══════════════════════════════════════════════ */
.cf-field {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid #d8deea;
  border-radius: 10px;
  font-size: .95rem;
  font-family: inherit;
  background: rgba(255,255,255,.08);
  color: #fff;
  box-sizing: border-box;
}
.cf-field--ghost {
  border-color: rgba(255,255,255,.18);
}
textarea.cf-field {
  resize: vertical;
}
.cf-err {
  display: none;
  color: #f87171;
  font-size: .82rem;
  padding-top: 4px;
}
#form-status {
  display: none;
  font-size: .95rem;
  font-weight: 500;
  padding: 10px 14px;
  border-radius: 8px;
}
