/* ═══════════════════════════════════════════════════════════════
   QAAI NEXUS — main.css  (unified, all pages)
   Fonts : Inter (body) · Josefin Sans (headings)
   Tokens: --bg-*, --text-*, --border-*, --brand-* (all pages)
   ═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Josefin+Sans:wght@300;400;500;600;700&display=swap');

/* ══════════════════════════════════════════
   1. DESIGN TOKENS  (dark default)
   ══════════════════════════════════════════ */
:root {
  /* ── Brand accents ─────────────────────── */
  --brand-blue:   #2563EB;   /* primary action colour               */
  --brand-indigo: #4F46E5;
  --brand-violet: #7C3AED;
  --brand-cyan:   #0284C7;
  --brand-green:  #059669;
  --brand-amber:  #D97706;
  --brand-red:    #E11D48;
  --brand-yellow: #FEBC2E;

  /* ── Dark surfaces ─────────────────────── */
  --bg-void:    #0A0A0F;   /* page background                       */
  --bg-deep:    #111118;   /* footer / alt sections                 */
  --bg-surface: #17171F;   /* section-alt, navbar stuck, etc.       */
  --bg-card:    #1E1E28;   /* card background                       */
  --bg-card-hv: #252532;   /* card hover                            */
  --bg-elevat:  #2E2E3E;   /* elevated elements, inputs             */

  /* ── Dark borders ──────────────────────── */
  --border-sub:  rgba(255,255,255,.07);
  --border-med:  rgba(255,255,255,.13);
  --border-glow: rgba(37,99,235,.32);

  /* ── Dark text ─────────────────────────── */
  --text-primary:   #F1F1F8;
  --text-secondary: #8B8BA8;
  --text-muted:     #4A4A68;

  /* ── Gradients ─────────────────────────── */
  --grad-brand: linear-gradient(135deg,#2563EB 0%,#7C3AED 100%);
  --grad-cyan:  linear-gradient(135deg,#0284C7 0%,#2563EB 100%);
  --grad-hero:  radial-gradient(ellipse 90% 55% at 50% -5%,rgba(37,99,235,.18) 0%,transparent 72%);
  --grad-card:  linear-gradient(148deg,rgba(255,255,255,.032) 0%,rgba(255,255,255,.007) 100%);

  /* ── Shadows ────────────────────────────── */
  --shadow-card: 0 6px 32px rgba(0,0,0,.5), 0 1px 0 rgba(255,255,255,.055) inset;
  --shadow-blue: 0 0 40px rgba(37,99,235,.2);

  /* ── Radii ──────────────────────────────── */
  --radius-xs: 6px;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 20px;
  --radius-2xl:24px;
  --radius-3xl:32px;

  /* ── Typography ─────────────────────────── */
  --font-head: 'Josefin Sans', sans-serif;
  --font-body: 'Inter', sans-serif;

  /* ── Motion ─────────────────────────────── */
  --ease-fast: .15s ease;
  --ease-base: .25s cubic-bezier(.4,0,.2,1);
  --ease-slow: .42s cubic-bezier(.25,.8,.25,1);

  /* ── Layout ─────────────────────────────── */
  --nav-h:   64px;
  --sec-pad: 100px;
}

/* ── Light theme override ──────────────────── */
[data-theme="light"] {
  --bg-void:    #FAFAFA;
  --bg-deep:    #F0F0F5;
  --bg-surface: #FFFFFF;
  --bg-card:    #FFFFFF;
  --bg-card-hv: #F0F0F8;
  --bg-elevat:  #E6E6F0;
  --border-sub: rgba(0,0,0,.07);
  --border-med: rgba(0,0,0,.13);
  --border-glow:rgba(37,99,235,.22);
  --text-primary:   #111120;
  --text-secondary: #5A5A7A;
  --text-muted:     #9898B8;
  --shadow-card: 0 4px 24px rgba(0,0,0,.08);
  --grad-hero:   radial-gradient(ellipse 90% 55% at 50% -5%,rgba(37,99,235,.09) 0%,transparent 72%);
  --grad-card:   linear-gradient(148deg,rgba(0,0,0,.018) 0%,rgba(0,0,0,.004) 100%);
}

/* ══════════════════════════════════════════
   2. RESET
   ══════════════════════════════════════════ */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family:var(--font-body); font-size:16px; line-height:1.65;
  background:var(--bg-void); color:var(--text-primary);
  overflow-x:hidden; -webkit-font-smoothing:antialiased;
  transition:background var(--ease-slow),color var(--ease-slow);
}
a   { text-decoration:none; color:inherit; }
ul  { list-style:none; }
img { max-width:100%; display:block; }
button { cursor:pointer; font-family:inherit; border:none; background:none; }
::-webkit-scrollbar       { width:4px; height:4px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--bg-elevat); border-radius:2px; }
::selection               { background:rgba(37,99,235,.28); color:#fff; }

/* ══════════════════════════════════════════
   3. TYPOGRAPHY
   ══════════════════════════════════════════ */
h1,h2,h3,h4,h5,h6 {
  font-family:var(--font-head); line-height:1.1; letter-spacing:-.015em;
}
.h-display { font-size:clamp(2.6rem,5.2vw,4rem);   font-weight:700; letter-spacing:-.03em; }
.h-xl      { font-size:clamp(1.9rem,3.5vw,2.9rem); font-weight:700; letter-spacing:-.025em; }
.h-lg      { font-size:clamp(1.4rem,2.4vw,2.1rem); font-weight:600; }
.h-md      { font-size:1.1rem; font-weight:700; }

.text-grad {
  background:var(--grad-brand);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.text-grad-cyan {
  background:var(--grad-cyan);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
/* Plain accent text — no gradient, just brand blue */
.text-accent { color:#2563EB; }
[data-theme="dark"] .text-accent { color:#5B8FF9; }

.lead    { font-size:1.0625rem; line-height:1.75; color:var(--text-secondary); font-weight:400; }
.overline{ font-size:.6875rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--text-muted); }

/* ══════════════════════════════════════════
   4. LAYOUT
   ══════════════════════════════════════════ */
.container  { width:100%; max-width:1160px; margin:0 auto; padding:0 24px; }
.section    { padding:var(--sec-pad) 0; position:relative; }
.section-sm { padding:68px 0; position:relative; }
.section-alt{ background:var(--bg-surface); }

/* ══════════════════════════════════════════
   5. SECTION LABEL (two styles)
   ══════════════════════════════════════════ */
/* Style A — pill with dot (home, features, about, contact) */
.sec-label {
  display:inline-flex; align-items:center; gap:7px;
  padding:5px 13px; border-radius:100px;
  border:1px solid rgba(37,99,235,.22); background:rgba(37,99,235,.07);
  font-size:.6875rem; font-weight:600; letter-spacing:.10em; text-transform:uppercase;
  color:var(--brand-cyan); margin-bottom:18px;
 margin-top: 20px;}
.sec-label .pulse {
  width:5px; height:5px; background:#0284C7; border-radius:50%;
  animation:pulse 2.2s infinite;
}
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.35;transform:scale(.7)} }

/* Style B — ruled lines (pricing page) */
.sec-label-line {
  display:inline-flex; align-items:center;
  font-size:.7rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  color:var(--text-muted); margin-bottom:14px;
  gap:0;
}
.sec-label-line::before,
.sec-label-line::after {
  content:''; display:inline-block; width:18px; height:1px;
  background:var(--text-muted); margin:0 9px;
}

/* ══════════════════════════════════════════
   6. NAVBAR  (shared across all pages)
   ══════════════════════════════════════════ */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  height:var(--nav-h); display:flex; align-items:center;
  transition:background var(--ease-base),border-color var(--ease-base),box-shadow var(--ease-base);
}
.navbar.scrolled {
  background:rgba(10,10,15,.87);
  backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  border-bottom:1px solid var(--border-sub);
  box-shadow:0 4px 28px rgba(0,0,0,.3);
}
[data-theme="light"] .navbar.scrolled { background:rgba(250,250,250,.9); }

.nav-inner {
  display:flex; align-items:center; justify-content:space-between; width:100%; gap:20px;
}

/* Brand */
.nav-brand {
  display:flex; align-items:center; gap:9px;
  font-family:var(--font-head); font-weight:700; font-size:1.1rem;
  color:var(--text-primary); white-space:nowrap; flex-shrink:0;
}
.brand-icon {
  width:31px; height:31px; background:var(--brand-blue);
  border-radius:7px; display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.brand-icon svg { color:#fff; }

/* Nav links */
.nav-links { display:flex; align-items:center; gap:2px; flex:1; justify-content:center; }
.nav-link {
  padding:7px 13px; font-size:.85rem; font-weight:500; color:var(--text-secondary);
  border-radius:var(--radius-sm); transition:color var(--ease-fast),background var(--ease-fast);
  white-space:nowrap;
}
.nav-link:hover { color:var(--text-primary); background:var(--border-sub); }
.nav-link.active { color:var(--text-primary); }

/* Nav actions */
.nav-actions { display:flex; align-items:center; gap:7px; flex-shrink:0; }

/* Theme toggle — elegant dual-icon pill (replaces single-btn toggle) */
.theme-toggle {
  display:flex; align-items:center; gap:3px;
  background:var(--bg-card); border:1px solid var(--border-sub);
  border-radius:100px; padding:3px; cursor:pointer;
  transition:border-color var(--ease-fast);
}
.theme-toggle:hover { border-color:var(--border-med); }
.theme-ico {
  width:26px; height:26px; border-radius:100px;
  display:flex; align-items:center; justify-content:center;
  color:var(--text-muted); transition:all var(--ease-fast);
}
.theme-ico.on { background:var(--bg-surface); color:var(--text-primary); box-shadow:0 1px 4px rgba(0,0,0,.18); }

/* Legacy single-button theme toggle (.btn-theme used in blade templates) */
.btn-theme {
  width:31px; height:31px;
  display:flex; align-items:center; justify-content:center;
  background:var(--bg-card); border:1px solid var(--border-sub);
  border-radius:var(--radius-sm); color:var(--text-secondary);
  transition:all var(--ease-fast); cursor:pointer; flex-shrink:0;
}
.btn-theme:hover { color:var(--text-primary); border-color:var(--border-med); }
.btn-theme .icon-sun, .btn-theme .icon-moon { display:block; }
[data-theme="light"] .btn-theme .icon-moon { display:none !important; }
[data-theme="light"] .btn-theme .icon-sun  { display:block !important; }
[data-theme="dark"]  .btn-theme .icon-sun  { display:none !important; }
[data-theme="dark"]  .btn-theme .icon-moon { display:block !important; }

/* Hamburger */
.hamburger {
  display:none;
  flex-direction:column; gap:4.5px; width:31px; height:31px;
  align-items:center; justify-content:center;
  background:var(--bg-card); border:1px solid var(--border-sub);
  border-radius:var(--radius-sm); flex-shrink:0;
}
.hamburger span {
  display:block; width:14px; height:1.5px; background:var(--text-secondary);
  border-radius:2px; transition:all var(--ease-base);
}
.hamburger.open span:nth-child(1) { transform:translateY(6px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-6px) rotate(-45deg); }

/* Mobile drawer */
.mobile-nav {
  display:none; position:fixed; top:var(--nav-h); left:0; right:0;
  background:var(--bg-surface); border-bottom:1px solid var(--border-sub);
  padding:12px 22px 20px; flex-direction:column; gap:3px;
  z-index:999; box-shadow:0 10px 28px rgba(0,0,0,.25);
}
.mobile-nav.open { display:flex; }
.mobile-nav .nav-link { padding:11px 14px; font-size:.9rem; display:block; }
.m-divider { height:1px; background:var(--border-sub); margin:8px 0; }
.mobile-nav .nav-actions { flex-direction:column; gap:8px; margin-top:4px; }
.mobile-nav .btn { width:100%; justify-content:center; }

/* ══════════════════════════════════════════
   7. BUTTONS  (shared)
   ══════════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:7px;
  font-family:var(--font-body); font-size:.875rem; font-weight:600; letter-spacing:-.01em;
  padding:9px 18px; border-radius:var(--radius-sm); border:1px solid transparent;
  transition:all var(--ease-base); white-space:nowrap; cursor:pointer; text-decoration:none;
}
/* Primary — solid blue */
.btn-primary {
  background:var(--brand-blue); color:#fff; border-color:var(--brand-blue);
  box-shadow:0 1px 4px rgba(37,99,235,.28);
}
.btn-primary:hover { background:#1D4ED8; border-color:#1D4ED8; box-shadow:0 4px 16px rgba(37,99,235,.42); transform:translateY(-1px); color:#fff; }
/* Secondary — outlined */
.btn-secondary { background:transparent; color:var(--text-primary); border-color:var(--border-med); }
.btn-secondary:hover { background:var(--bg-card); border-color:var(--border-med); color:var(--text-primary); }
/* Ghost */
.btn-ghost { background:transparent; color:var(--text-secondary); border-color:transparent; padding:9px 13px; }
.btn-ghost:hover { color:var(--text-primary); background:var(--border-sub); }
/* Violet — for Pro plan */
.btn-violet { background:#4F46E5; color:#fff; border-color:#4F46E5; box-shadow:0 1px 4px rgba(79,70,229,.28); }
.btn-violet:hover { background:#4338CA; box-shadow:0 4px 16px rgba(79,70,229,.42); transform:translateY(-1px); color:#fff; }
/* Legacy gradient (used on other pages) */
.btn-brand { background:var(--grad-brand); color:#fff; box-shadow:0 2px 12px rgba(37,99,235,.3); }
.btn-brand:hover { box-shadow:0 6px 24px rgba(37,99,235,.5); transform:translateY(-1px); color:#fff; }

.btn-lg  { padding:12px 26px; font-size:.9375rem; border-radius:var(--radius-md); }
.btn-sm  { padding:7px 13px;  font-size:.8125rem; }
.btn-full{ width:100%; justify-content:center; }

/* Spinner inside button */
.btn-spin {
  width:15px; height:15px; border:2px solid rgba(255,255,255,.25); border-top-color:#fff;
  border-radius:50%; animation:spin .65s linear infinite; display:none;
}
@keyframes spin { to { transform:rotate(360deg); } }
.btn.busy .btn-spin { display:block; }
.btn.busy .btn-txt  { display:none; }
.btn:disabled { opacity:.55; cursor:not-allowed; transform:none !important; }

/* ══════════════════════════════════════════
   8. CARDS  (shared)
   ══════════════════════════════════════════ */
.card {
  background:var(--bg-card); border:1px solid var(--border-sub);
  border-radius:var(--radius-lg); padding:26px; position:relative; overflow:hidden;
  transition:border-color var(--ease-base),transform var(--ease-base),box-shadow var(--ease-base),background var(--ease-base);
 color: var(--text-secondary);
}
.card::before { content:''; position:absolute; inset:0; background:var(--grad-card); pointer-events:none; }
.card:hover { border-color:var(--border-med); background:var(--bg-card-hv); transform:translateY(-2px); box-shadow:var(--shadow-card); }
.card-glow:hover { border-color:var(--border-glow); box-shadow:var(--shadow-blue); }

/* Feature icon box */
.feat-icon { width:46px; height:46px; border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.feat-icon.blue   { background:rgba(37,99,235,.12);  color:#5B8FF9; }
.feat-icon.purple { background:rgba(79,70,229,.12);  color:#A78BFA; }
.feat-icon.cyan   { background:rgba(2,132,199,.12);  color:#38BDF8; }
.feat-icon.green  { background:rgba(5,150,105,.12);  color:#34D399; }
.feat-icon.orange { background:rgba(217,119,6,.12);  color:#FCD34D; }
.feat-icon.pink   { background:rgba(225,29,72,.12);  color:#FB7185; }

/* Badge / chip */
.badge { display:inline-flex; align-items:center; gap:4px; padding:3px 9px; border-radius:100px; font-size:.6875rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; }
.badge-blue   { background:rgba(37,99,235,.12);  color:#5B8FF9; border:1px solid rgba(37,99,235,.22); }
.badge-green  { background:rgba(5,150,105,.10);  color:#34D399;  border:1px solid rgba(5,150,105,.22); }
.badge-orange { background:rgba(217,119,6,.10);  color:#FCD34D;  border:1px solid rgba(217,119,6,.22); animation:badge-pulse 2.2s infinite; }
.badge-violet { background:rgba(79,70,229,.10);  color:#A78BFA;  border:1px solid rgba(79,70,229,.22); }
@keyframes badge-pulse { 0%,100%{box-shadow:none} 50%{box-shadow:0 0 10px rgba(217,119,6,.2)} }

/* ══════════════════════════════════════════
   9. HERO  (home page)
   ══════════════════════════════════════════ */
.hero {
  min-height:100vh; display:flex; align-items:center;
  padding-top:var(--nav-h); position:relative; overflow:hidden;
}
.hero-bg   { position:absolute; inset:0; background:var(--grad-hero); pointer-events:none; }
.hero-grid {
  position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.016) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.016) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(ellipse 75% 75% at 50% 50%,black 20%,transparent 100%);
  pointer-events:none;
}
.orb { position:absolute; border-radius:50%; filter:blur(90px); pointer-events:none; }
.orb-1 { width:620px;height:620px; background:radial-gradient(circle,rgba(37,99,235,.16) 0%,transparent 70%); top:-180px;left:-80px; }
.orb-2 { width:520px;height:520px; background:radial-gradient(circle,rgba(79,70,229,.12) 0%,transparent 70%); top:80px;right:-120px; }
.orb-3 { width:400px;height:400px; background:radial-gradient(circle,rgba(2,132,199,.09) 0%,transparent 70%); bottom:-60px;left:50%; }

/* ══════════════════════════════════════════
   10. DASHBOARD MOCKUP  (home)
   ══════════════════════════════════════════ */
.mockup-wrap { background:var(--bg-surface); border:1px solid var(--border-med); border-radius:var(--radius-xl); overflow:hidden; box-shadow:0 30px 80px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.055) inset; }
.mockup-bar  { background:var(--bg-card); border-bottom:1px solid var(--border-sub); padding:11px 18px; display:flex; align-items:center; gap:7px; }
.dot-r{width:9px;height:9px;border-radius:50%;background:#FF5F57;} .dot-y{width:9px;height:9px;border-radius:50%;background:#FEBC2E;} .dot-g{width:9px;height:9px;border-radius:50%;background:#28C840;}
.mockup-url-bar { flex:1; background:var(--bg-elevat); border:1px solid var(--border-sub); border-radius:5px; padding:4px 12px; font-size:.7rem; color:var(--text-muted); text-align:center; margin:0 10px; }
.mockup-body { display:grid; grid-template-columns:190px 1fr; gap:14px; padding:18px; min-height:290px; }
.mockup-sidebar { background:var(--bg-card); border-radius:var(--radius-md); padding:14px; display:flex; flex-direction:column; gap:6px; }
.m-nav { padding:7px 11px; border-radius:6px; font-size:.72rem; color:var(--text-muted); display:flex; align-items:center; gap:7px; }
.m-nav.active { background:rgba(37,99,235,.12); color:#5B8FF9; }
.m-dot { width:5px;height:5px;border-radius:50%;background:currentColor; }
.mockup-main { display:flex; flex-direction:column; gap:11px; }
.m-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:9px; }
.m-stat { background:var(--bg-card); border:1px solid var(--border-sub); border-radius:10px; padding:13px; }
.m-val  { font-family:var(--font-head); font-size:1.25rem; font-weight:700; line-height:1; }
.m-val.g{color:#34D399;} .m-val.b{color:#5B8FF9;} .m-val.r{color:#FB7185;}
.m-lbl  { font-size:.62rem; color:var(--text-muted); margin-top:2px; }
.m-chart{ background:var(--bg-card); border:1px solid var(--border-sub); border-radius:10px; padding:13px; flex:1; }
.m-bars { display:flex; align-items:flex-end; gap:5px; height:72px; }
.m-bar  { flex:1; border-radius:2px 2px 0 0; }
.m-bar.p{background:#34D399;opacity:.65;} .m-bar.f{background:#FB7185;opacity:.65;}
.m-table{ background:var(--bg-card); border:1px solid var(--border-sub); border-radius:10px; overflow:hidden; }
.m-row  { padding:7px 13px; display:flex; align-items:center; gap:9px; font-size:.68rem; border-bottom:1px solid var(--border-sub); }
.m-row:last-child{border-bottom:none;}
.m-status{padding:2px 7px;border-radius:4px;font-size:.58rem;font-weight:700;}
.m-status.p{background:rgba(52,211,153,.12);color:#34D399;} .m-status.f{background:rgba(251,113,133,.12);color:#FB7185;}

/* ══════════════════════════════════════════
   11. STATS GRID  (home)
   ══════════════════════════════════════════ */
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); border:1px solid var(--border-sub); border-radius:var(--radius-xl); overflow:hidden; gap:1px; background:var(--border-sub); }
.stat-cell { background:var(--bg-card); padding:38px 28px; text-align:center; transition:background var(--ease-fast); }
.stat-cell:hover { background:var(--bg-card-hv); }
.stat-num { font-family:var(--font-head); font-size:2.6rem; font-weight:700; line-height:1; margin-bottom:8px; }
.stat-lbl { font-size:.875rem; color:var(--text-secondary); }

/* ══════════════════════════════════════════
   12. FEATURE GRID
   ══════════════════════════════════════════ */
.feat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }

/* ══════════════════════════════════════════
   13. TESTIMONIALS
   ══════════════════════════════════════════ */
.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.testi-card { background:var(--bg-card); border:1px solid var(--border-sub); border-radius:var(--radius-lg); padding:26px; transition:all var(--ease-base); }
.testi-card:hover { border-color:var(--border-med); transform:translateY(-3px); box-shadow:var(--shadow-card); }
.stars { display:flex; gap:2px; margin-bottom:14px; color:#FEBC2E; font-size:.85rem; }
.testi-quote { font-size:.9375rem; line-height:1.75; color:var(--text-secondary); font-style:italic; margin-bottom:20px; }
.testi-author { display:flex; align-items:center; gap:11px; }
.avatar { width:42px; height:42px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--font-head); font-weight:700; font-size:.875rem; color:#fff; flex-shrink:0; }
.author-name  { font-weight:600; font-size:.875rem; }
.author-title { font-size:.775rem; color:var(--text-secondary); }

/* ══════════════════════════════════════════
   14. CTA BLOCK  (shared)
   ══════════════════════════════════════════ */
.cta-block {
  background:var(--bg-surface); border:1px solid var(--border-sub);
  border-radius:var(--radius-3xl); padding:80px 48px; text-align:center;
  position:relative; overflow:hidden;
}
.cta-block::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 50%,rgba(37,99,235,.07) 0%,transparent 65%); pointer-events:none; }

/* ══════════════════════════════════════════
   15. LOGOS STRIP  (home)
   ══════════════════════════════════════════ */
.logos-strip { display:flex; align-items:center; gap:44px; overflow:hidden; mask-image:linear-gradient(90deg,transparent,black 15%,black 85%,transparent); }
.logo-item { flex-shrink:0; opacity:.28; transition:opacity var(--ease-fast); font-family:var(--font-head); font-weight:700; font-size:1.05rem; color:var(--text-primary); }
.logo-item:hover { opacity:.6; }

/* ══════════════════════════════════════════
   16. FOOTER  (shared)
   ══════════════════════════════════════════ */
.footer { background:var(--bg-deep); border-top:1px solid var(--border-sub); padding:72px 0 36px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:44px; margin-bottom:56px; }
.footer-desc { font-size:.875rem; color:var(--text-secondary); line-height:1.75; margin:14px 0 20px; max-width:260px; }
.footer-socials { display:flex; gap:7px; }
.footer-soc { width:31px; height:31px; background:var(--bg-elevat); border:1px solid var(--border-sub); border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center; color:var(--text-secondary); transition:all var(--ease-fast); }
.footer-soc:hover { background:rgba(37,99,235,.1); border-color:rgba(37,99,235,.22); color:var(--brand-blue); }
.footer-col-title { font-family:var(--font-head); font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.09em; color:var(--text-muted); margin-bottom:16px; }
.footer-links { display:flex; flex-direction:column; gap:9px; }
.footer-link { font-size:.875rem; color:var(--text-secondary); transition:color var(--ease-fast); }
.footer-link:hover { color:var(--text-primary); }
.footer-bottom { padding-top:26px; border-top:1px solid var(--border-sub); display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.footer-copy { font-size:.78rem; color:var(--text-muted); }
.nl-form { display:flex; gap:7px; margin-top:12px; }
.nl-input { flex:1; background:var(--bg-elevat); border:1px solid var(--border-sub); border-radius:var(--radius-sm); padding:8px 12px; font-family:var(--font-body); font-size:.8rem; color:var(--text-primary); outline:none; transition:border-color var(--ease-fast); }
.nl-input::placeholder { color:var(--text-muted); }
.nl-input:focus { border-color:rgba(37,99,235,.42); }

/* ══════════════════════════════════════════
   17. COOKIE BAR  (shared)
   ══════════════════════════════════════════ */
.cookie-bar { position:fixed; bottom:20px; left:50%; transform:translateX(-50%); z-index:9998; background:var(--bg-card); border:1px solid var(--border-med); border-radius:var(--radius-lg); padding:16px 20px; max-width:470px; width:calc(100% - 40px); box-shadow:0 14px 44px rgba(0,0,0,.35); display:flex; align-items:flex-start; gap:13px; transition:all var(--ease-slow); }
.cookie-bar.gone { opacity:0; transform:translateX(-50%) translateY(16px); pointer-events:none; }
.ck-icon { font-size:1.3rem; flex-shrink:0; }
.ck-text { font-size:.8rem; color:var(--text-secondary); line-height:1.65; }
.ck-btns { display:flex; gap:7px; margin-top:9px; flex-wrap:wrap; }

/* ══════════════════════════════════════════
   18. FORMS  (auth, contact)
   ══════════════════════════════════════════ */
.auth-wrap  { min-height:100vh; display:grid; grid-template-columns:1fr 1fr; }
.auth-left  { background:var(--bg-surface); display:flex; align-items:center; justify-content:center; padding:60px 48px; position:relative; overflow:hidden; }
.auth-left::before { content:''; position:absolute; inset:0; background:var(--grad-hero); pointer-events:none; }
.auth-right { background:var(--bg-void); display:flex; align-items:center; justify-content:center; padding:60px 48px; }
.auth-box   { width:100%; max-width:390px; }
.auth-title { font-family:var(--font-head); font-size:1.65rem; font-weight:700; margin-bottom:7px; }
.auth-sub   { font-size:.875rem; color:var(--text-secondary); margin-bottom:28px; }

.form-group { margin-bottom:18px; }
.form-label { display:block; font-size:.8rem; font-weight:600; color:var(--text-secondary); margin-bottom:7px; }
.input-wrap { position:relative; }
.form-input { width:100%; background:var(--bg-elevat); border:1px solid var(--border-sub); border-radius:var(--radius-sm); padding:11px 15px; font-family:var(--font-body); font-size:.9rem; color:var(--text-primary); outline:none; transition:all var(--ease-fast); }
.form-input::placeholder { color:var(--text-muted); }
.form-input:focus { border-color:rgba(37,99,235,.45); background:var(--bg-card); box-shadow:0 0 0 3px rgba(37,99,235,.09); }
.form-input.err { border-color:rgba(225,29,72,.45); }
.form-err { font-size:.73rem; color:var(--brand-red); margin-top:4px; }
.pw-toggle { position:absolute; right:11px; top:50%; transform:translateY(-50%); background:none; border:none; color:var(--text-muted); cursor:pointer; display:flex; align-items:center; padding:3px; transition:color var(--ease-fast); }
.pw-toggle:hover { color:var(--text-primary); }
.divider { display:flex; align-items:center; gap:11px; margin:22px 0; color:var(--text-muted); font-size:.775rem; }
.divider::before,.divider::after { content:''; flex:1; height:1px; background:var(--border-sub); }
.social-grid { display:grid;  gap:9px; margin-bottom:22px; }
.social-btn { display:flex; align-items:center; justify-content:center; gap:8px; padding:10px 13px; background:var(--bg-elevat); border:1px solid var(--border-sub); border-radius:var(--radius-sm); font-size:.85rem; font-weight:500; color:var(--text-primary); cursor:pointer; transition:all var(--ease-fast); }
.social-btn:hover { background:var(--bg-card-hv); border-color:var(--border-med); }
.pw-strength { height:3px; background:var(--bg-elevat); border-radius:2px; margin-top:7px; overflow:hidden; }
.pw-bar { height:100%; border-radius:2px; width:0%; transition:width .3s,background .3s; }
.pw-label { font-size:.7rem; color:var(--text-muted); margin-top:3px; }

/* Contact */
.contact-grid { display:grid; grid-template-columns:1fr 1.45fr; gap:44px; align-items:start; }
.contact-info { background:var(--bg-card); border:1px solid var(--border-sub); border-radius:var(--radius-lg); padding:30px; }
.ci-item { display:flex; align-items:flex-start; gap:14px; padding:18px 0; border-bottom:1px solid var(--border-sub); }
.ci-item:last-child { border-bottom:none; }
.ci-icon { width:38px; height:38px; background:rgba(37,99,235,.09); border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center; color:var(--brand-blue); flex-shrink:0; }
.ci-label { font-size:.7rem; color:var(--text-muted); margin-bottom:3px; font-weight:600; text-transform:uppercase; letter-spacing:.07em; }
.ci-val { font-size:.9rem; color:var(--text-primary); }

/* Team / About */
.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.team-card { background:var(--bg-card); border:1px solid var(--border-sub); border-radius:var(--radius-lg); padding:26px; text-align:center; transition:all var(--ease-base); }
.team-card:hover { border-color:var(--border-med); transform:translateY(-3px); box-shadow:var(--shadow-card); }
.team-av { width:76px; height:76px; border-radius:50%; margin:0 auto 14px; display:flex; align-items:center; justify-content:center; font-family:var(--font-head); font-weight:700; font-size:1.4rem; color:#fff; }
.team-name { font-weight:600; font-size:.9375rem; margin-bottom:3px; }
.team-role { font-size:.8rem; color:var(--text-secondary); margin-bottom:10px; }
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }

/* ══════════════════════════════════════════
   19. PAGE HERO  (inner pages)
   ══════════════════════════════════════════ */
.page-hero { padding:148px 0 72px; text-align:center; position:relative; overflow:hidden; }
.page-hero::before { content:''; position:absolute; inset:0; background:var(--grad-hero); pointer-events:none; }

/* ══════════════════════════════════════════
   20. SCROLL REVEAL  (shared)
   ══════════════════════════════════════════ */
[data-reveal] { opacity:0; transform:translateY(20px); transition:opacity .6s ease,transform .6s ease; }
[data-reveal].revealed { opacity:1; transform:none; }
[data-reveal-delay="1"] { transition-delay:.08s; }
[data-reveal-delay="2"] { transition-delay:.16s; }
[data-reveal-delay="3"] { transition-delay:.24s; }
[data-reveal-delay="4"] { transition-delay:.32s; }
[data-reveal-delay="5"] { transition-delay:.40s; }

/* ══════════════════════════════════════════
   21. TOAST  (shared)
   ══════════════════════════════════════════ */
.toast-zone { position:fixed; top:20px; right:20px; z-index:9999; display:flex; flex-direction:column; gap:8px; pointer-events:none; }
.toast { background:var(--bg-card); border:1px solid var(--border-med); border-radius:var(--radius-md); padding:12px 16px; display:flex; align-items:center; gap:10px; font-size:.85rem; font-weight:500; color:var(--text-primary); max-width:320px; pointer-events:auto; box-shadow:0 8px 28px rgba(0,0,0,.3); animation:toast-in .22s ease; }
.toast.ok    { border-left:2px solid var(--brand-green); }
.toast.error { border-left:2px solid var(--brand-red); }
@keyframes toast-in  { from{opacity:0;transform:translateX(10px)} to{opacity:1;transform:none} }
@keyframes toast-out { to  {opacity:0;transform:translateX(10px)} }

/* ══════════════════════════════════════════
   22. UTILITIES
   ══════════════════════════════════════════ */
.text-center { text-align:center; } .text-left { text-align:left; }
.d-flex { display:flex; } .align-center { align-items:center; }
.justify-center { justify-content:center; } .justify-between { justify-content:space-between; }
.flex-wrap { flex-wrap:wrap; }
.gap-2{gap:8px;} .gap-3{gap:12px;} .gap-4{gap:16px;} .gap-5{gap:20px;} .gap-6{gap:24px;}
.mb-2{margin-bottom:8px;} .mb-3{margin-bottom:12px;} .mb-4{margin-bottom:16px;}
.mb-5{margin-bottom:20px;} .mb-6{margin-bottom:24px;} .mb-8{margin-bottom:32px;} .mb-12{margin-bottom:48px;}
.mt-4{margin-top:16px;} .mt-6{margin-top:24px;} .mt-8{margin-top:32px;}
.w-full{width:100%;} .mx-auto{margin-left:auto;margin-right:auto;}

/* ══════════════════════════════════════════
   23. PRICING PAGE — specific styles
       Uses same tokens as all other pages.
       Classes prefixed "pr-" to stay clear.
   ══════════════════════════════════════════ */

/* Billing toggle */
.pr-bill-ctrl {
  display:inline-flex; align-items:center;
  background:var(--bg-card); border:1px solid var(--border-sub);
  border-radius:100px; padding:4px; position:relative;
}
.pr-bill-pill {
  position:absolute; top:4px; bottom:4px;
  background:var(--brand-blue); border-radius:100px; z-index:0;
  transition:left var(--ease-base),width var(--ease-base);
  box-shadow:0 1px 8px rgba(37,99,235,.38);
}
.pr-bill-opt {
  position:relative; z-index:1; padding:8px 20px; border-radius:100px;
  font-family:var(--font-body); font-size:.85rem; font-weight:600;
  color:var(--text-muted); border:none; background:none; cursor:pointer;
  white-space:nowrap; transition:color var(--ease-fast);
}
.pr-bill-opt.on { color:#fff; }

.pr-save-tag {
  display:inline-flex; align-items:center; gap:4px;
  font-size:.7rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase;
  color:var(--brand-green); background:rgba(5,150,105,.1);
  border:1px solid rgba(5,150,105,.22); padding:4px 11px; border-radius:100px;
}

/* Plan cards grid */
.pr-plans { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; align-items:start; }

.pr-plan {
  background:var(--bg-card); border:1px solid var(--border-sub);
  border-radius:var(--radius-xl); padding:30px 26px;
  position:relative; overflow:hidden;
  transition:border-color var(--ease-base),transform var(--ease-base),box-shadow var(--ease-base);
}
.pr-plan:hover { border-color:var(--border-med); transform:translateY(-3px); box-shadow:var(--shadow-card); }

/* Plan identity colours on hover */
.pr-plan[data-plan="free"]:hover    { border-color:rgba(5,150,105,.32); }
.pr-plan[data-plan="tester"]        { border-color:rgba(37,99,235,.38); transform:translateY(-6px); box-shadow:0 0 0 1px rgba(37,99,235,.1),0 20px 48px rgba(0,0,0,.25); }
[data-theme="light"] .pr-plan[data-plan="tester"] { box-shadow:0 0 0 1px rgba(37,99,235,.1),0 12px 32px rgba(0,0,0,.1); }
.pr-plan[data-plan="tester"]:hover  { transform:translateY(-9px); }
.pr-plan[data-plan="pro"]:hover     { border-color:rgba(79,70,229,.36); }

/* Featured top line */
.pr-plan[data-plan="tester"]::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,#2563EB,#7C3AED); }

/* Card shimmer (dark mode hover) */
.pr-shimmer { position:absolute; inset:0; border-radius:var(--radius-xl); pointer-events:none; background:conic-gradient(from 0deg at 50% 50%,transparent 0deg,rgba(255,255,255,.025) 60deg,transparent 120deg); opacity:0; transition:opacity var(--ease-base); }
[data-theme="dark"] .pr-plan:hover .pr-shimmer { opacity:1; }

/* Popular badge */
.pr-pop-badge {
  position:absolute; top:-1px; left:50%; transform:translateX(-50%);
  background:var(--bg-card); border:1px solid rgba(37,99,235,.3);
  color:var(--brand-blue); font-size:.65rem; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
  padding:4px 14px; border-radius:0 0 var(--radius-md) var(--radius-md); white-space:nowrap;
}
[data-theme="dark"] .pr-pop-badge { color:#5B8FF9; border-color:rgba(91,143,249,.28); }

/* Plan identity dot */
.pr-dot { width:9px; height:9px; border-radius:50%; display:inline-block; flex-shrink:0; }
.pr-dot-row { display:flex; align-items:center; gap:8px; margin-bottom:16px; }
.pr-dot-label { font-size:.7rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; }

/* Plan text */
.pr-name { font-family:var(--font-head); font-size:1.15rem; font-weight:700; letter-spacing:-.018em; margin-bottom:6px; }
.pr-desc { font-size:.83rem; color:var(--text-secondary); line-height:1.68; min-height:52px; margin-bottom:22px; }

/* Price display */
.pr-price-row { display:flex; align-items:baseline; gap:2px; line-height:1; }
.pr-price-sym { font-family:var(--font-head); font-size:1.25rem; font-weight:700; color:var(--text-secondary); padding-bottom:5px; }
.pr-price-amt { font-family:var(--font-head); font-size:3.4rem; font-weight:700; letter-spacing:-.04em; line-height:1; transition:opacity .15s,transform .15s; }
.pr-price-mo  { font-size:.78rem; color:var(--text-muted); margin-left:3px; padding-bottom:6px; }
.pr-price-cycle { font-size:.78rem; color:var(--text-secondary); margin-top:4px; }
.pr-price-note  { font-size:.73rem; color:var(--brand-green); margin-top:3px; min-height:16px; }

.pr-sep { height:1px; background:var(--border-sub); margin:22px 0; }

/* Plan CTA buttons */
.pr-plan-btn {
  display:flex; align-items:center; justify-content:center; gap:8px;
  width:100%; padding:13px 18px; margin-bottom:22px;
  font-family:var(--font-body); font-size:.9rem; font-weight:700; letter-spacing:-.01em;
  border-radius:var(--radius-md); border:1px solid transparent;
  cursor:pointer; transition:all var(--ease-base);
}
.pr-plan-btn.pr-pf { background:transparent; color:var(--text-secondary); border-color:var(--border-med); }
.pr-plan-btn.pr-pf:hover { color:var(--text-primary); background:var(--bg-card-hv); }
.pr-plan-btn.pr-pb { background:var(--brand-blue); color:#fff; box-shadow:0 2px 12px rgba(37,99,235,.35); }
.pr-plan-btn.pr-pb:hover { background:#1D4ED8; box-shadow:0 6px 22px rgba(37,99,235,.5); transform:translateY(-1px); }
.pr-plan-btn.pr-pv { background:#4F46E5; color:#fff; box-shadow:0 2px 12px rgba(79,70,229,.35); }
.pr-plan-btn.pr-pv:hover { background:#4338CA; box-shadow:0 6px 22px rgba(79,70,229,.5); transform:translateY(-1px); }
.pr-plan-btn:disabled { opacity:.55; cursor:not-allowed; transform:none !important; }
.pr-plan-btn.busy .pr-spin { display:block; }
.pr-plan-btn.busy .pr-btxt { display:none; }
.pr-spin { width:15px; height:15px; border:2px solid rgba(255,255,255,.25); border-top-color:#fff; border-radius:50%; animation:spin .65s linear infinite; display:none; }

/* Feature list */
.pr-feat-list { display:flex; flex-direction:column; gap:10px; }
.pr-feat-row  { display:flex; align-items:flex-start; gap:9px; font-size:.84rem; color:var(--text-secondary); }
.pr-feat-row .pr-fy { color:var(--brand-green); flex-shrink:0; margin-top:2px; width:14px; height:14px; }
.pr-feat-row .pr-fn { color:var(--text-muted); opacity:.5; flex-shrink:0; margin-top:2px; width:14px; height:14px; }
.pr-feat-row .pr-ftag { margin-left:auto; font-size:.75rem; font-weight:600; white-space:nowrap; padding:2px 7px; border-radius:4px; background:var(--bg-elevat); color:var(--text-primary); }
.pr-feat-row.pr-dim { opacity:.5; }
.pr-expand-btn { display:flex; align-items:center; gap:5px; font-size:.78rem; font-weight:600; color:var(--text-muted); background:none; border:none; cursor:pointer; padding:0; margin-top:12px; transition:color var(--ease-fast); }
.pr-expand-btn:hover { color:var(--text-secondary); }
.pr-expand-btn svg { transition:transform var(--ease-fast); }
.pr-expand-btn.open svg { transform:rotate(180deg); }
.pr-feat-extra { display:none; flex-direction:column; gap:10px; margin-top:10px; }
.pr-feat-extra.open { display:flex; }

/* Trust strip */
.pr-trust { display:flex; align-items:center; justify-content:center; gap:26px; flex-wrap:wrap; padding-top:20px; border-top:1px solid var(--border-sub); margin-top:48px; }
.pr-trust-i { display:flex; align-items:center; gap:7px; font-size:.78rem; color:var(--text-muted); }

/* Live ticker */
.pr-ticker { background:var(--bg-surface); border-top:1px solid var(--border-sub); border-bottom:1px solid var(--border-sub); padding:13px 0; overflow:hidden; }
.pr-ticker-inner { display:flex; align-items:center; animation:pr-scroll 30s linear infinite; white-space:nowrap; width:max-content; }
.pr-ticker-inner:hover { animation-play-state:paused; }
.pr-tick-item { display:inline-flex; align-items:center; gap:8px; padding:0 38px; font-size:.79rem; font-weight:500; color:var(--text-secondary); border-right:1px solid var(--border-sub); }
.pr-tick-item:last-child { border-right:none; }
.pr-tick-dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; }
@keyframes pr-scroll { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* Cursor spotlight */
.pr-spotlight { position:fixed; width:380px; height:380px; border-radius:50%; pointer-events:none; z-index:0; background:radial-gradient(circle,rgba(37,99,235,.05) 0%,transparent 65%); transform:translate(-50%,-50%); transition:opacity .35s; }
[data-theme="light"] .pr-spotlight { background:radial-gradient(circle,rgba(37,99,235,.03) 0%,transparent 65%); }

/* Comparison table */
.pr-tbl-wrap { overflow-x:auto; border:1px solid var(--border-sub); border-radius:var(--radius-xl); }
.pr-ctbl { width:100%; min-width:640px; border-collapse:separate; border-spacing:0; }
.pr-ctbl th { background:var(--bg-card); padding:15px 22px; font-family:var(--font-head); font-size:.8rem; font-weight:700; text-align:left; color:var(--text-secondary); white-space:nowrap; border-bottom:1px solid var(--border-sub); position:sticky; top:0; z-index:2; }
.pr-ctbl th:first-child { color:var(--text-primary); }
.pr-ctbl th.pr-th-feat { color:var(--brand-blue); }
[data-theme="dark"] .pr-ctbl th.pr-th-feat { color:#5B8FF9; }
.pr-ctbl td { background:var(--bg-surface); padding:13px 22px; font-size:.845rem; color:var(--text-secondary); border-bottom:1px solid var(--border-sub); vertical-align:middle; }
.pr-ctbl tr:last-child td { border-bottom:none; }
.pr-ctbl td:first-child { color:var(--text-primary); font-weight:500; font-size:.82rem; }
.pr-ctbl tbody tr:not(.pr-cat-row):hover td { background:var(--bg-card); transition:background var(--ease-fast); }
.pr-cat-row td { background:var(--bg-card-hv) !important; padding:9px 22px; font-family:var(--font-head); font-size:.69rem; text-transform:uppercase; letter-spacing:.08em; color:var(--text-muted); font-weight:700; border-bottom:1px solid var(--border-sub); }
.pr-fc { background:rgba(37,99,235,.04) !important; }
[data-theme="dark"] .pr-fc { background:rgba(37,99,235,.06) !important; }
.pr-cy { color:var(--brand-green); font-weight:700; }
.pr-cn { color:var(--text-muted); opacity:.45; }
.pr-cv { color:var(--text-primary); font-weight:700; font-size:.81rem; }

/* Enterprise bar */
.pr-ent-bar { background:var(--bg-card); border:1px solid var(--border-sub); border-radius:var(--radius-2xl); padding:36px 44px; display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap; position:relative; overflow:hidden; }
.pr-ent-bar::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,#2563EB 0%,#7C3AED 42%,#059669 70%,#D97706 100%); }

/* Pricing FAQ (uses different structure from other pages FAQ) */
.pr-faq-grid { display:grid; grid-template-columns:1fr 1fr; border:1px solid var(--border-sub); border-radius:var(--radius-xl); overflow:hidden; }
.pr-faq-cell { border-bottom:1px solid var(--border-sub); }
.pr-faq-cell:nth-child(odd)        { border-right:1px solid var(--border-sub); }
.pr-faq-cell:nth-last-child(1),
.pr-faq-cell:nth-last-child(2)     { border-bottom:none; }
.pr-faq-q { width:100%; background:none; border:none; cursor:pointer; padding:22px 24px; text-align:left; display:flex; align-items:flex-start; justify-content:space-between; gap:14px; font-family:var(--font-body); font-size:.875rem; font-weight:600; color:var(--text-primary); transition:background var(--ease-fast),color var(--ease-fast); }
.pr-faq-q:hover { background:var(--bg-card); color:var(--brand-blue); }
[data-theme="dark"] .pr-faq-q:hover { color:#5B8FF9; }
.pr-faq-ico { width:22px; height:22px; min-width:22px; border-radius:50%; background:var(--bg-elevat); border:1px solid var(--border-sub); display:flex; align-items:center; justify-content:center; font-size:.85rem; color:var(--text-muted); margin-top:1px; transition:all var(--ease-base); }
.pr-faq-cell.open .pr-faq-ico { background:rgba(37,99,235,.1); border-color:rgba(37,99,235,.25); color:var(--brand-blue); transform:rotate(45deg); }
[data-theme="dark"] .pr-faq-cell.open .pr-faq-ico { color:#5B8FF9; background:rgba(91,143,249,.1); }
.pr-faq-a { overflow:hidden; max-height:0; transition:max-height var(--ease-slow),padding var(--ease-base); padding:0 24px; font-size:.855rem; color:var(--text-secondary); line-height:1.78; }
.pr-faq-cell.open .pr-faq-a { max-height:240px; padding:0 24px 22px; }

/* Pricing CTA */
.pr-cta { background:var(--bg-surface); border:1px solid var(--border-sub); border-radius:var(--radius-3xl); padding:80px 48px; text-align:center; position:relative; overflow:hidden; }
.pr-cta::before { content:''; position:absolute; inset:0; background-image:linear-gradient(var(--border-sub) 1px,transparent 1px),linear-gradient(90deg,var(--border-sub) 1px,transparent 1px); background-size:40px 40px; mask-image:radial-gradient(ellipse 60% 60% at 50% 50%,black 20%,transparent 80%); opacity:.5; pointer-events:none; }
.pr-cta::after { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent 10%,rgba(37,99,235,.28) 50%,transparent 90%); }

/* OK / success banner */
.pr-ok-banner { display:none; padding-top:calc(var(--nav-h) + 22px); }
.pr-ok-inner  { background:rgba(5,150,105,.08); border:1px solid rgba(5,150,105,.22); border-radius:var(--radius-lg); padding:16px 22px; display:flex; align-items:center; gap:14px; animation:toast-in .3s ease; }

/* Checkout overlay */
.pr-overlay { display:none; position:fixed; inset:0; z-index:9000; background:rgba(0,0,0,.72); backdrop-filter:blur(6px); align-items:center; justify-content:center; padding:20px; }
.pr-overlay.open { display:flex; }
.pr-overlay-modal { background:var(--bg-card); border:1px solid var(--border-med); border-radius:var(--radius-xl); max-width:440px; width:100%; padding:30px; position:relative; box-shadow:0 24px 64px rgba(0,0,0,.55); animation:modal-in .22s cubic-bezier(.4,0,.2,1); }
@keyframes modal-in { from{opacity:0;transform:scale(.96) translateY(8px)} to{opacity:1;transform:none} }
.pr-ov-close { position:absolute; top:14px; right:14px; width:26px; height:26px; border-radius:50%; background:var(--bg-elevat); border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--text-muted); font-size:13px; transition:all var(--ease-fast); }
.pr-ov-close:hover { background:var(--bg-card-hv); color:var(--text-primary); }
.pr-ov-row  { display:flex; align-items:center; justify-content:space-between; padding:11px 0; border-bottom:1px solid var(--border-sub); font-size:.875rem; }
.pr-ov-row:last-of-type { border-bottom:none; }
.pr-ov-lbl  { color:var(--text-secondary); }
.pr-ov-val  { color:var(--text-primary); font-weight:600; }
.pr-price-box { background:var(--bg-elevat); border-radius:var(--radius-md); padding:16px 18px; margin:18px 0; display:flex; align-items:center; justify-content:space-between; }
.pr-total-lbl { font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--text-secondary); }
.pr-total-amt { font-family:var(--font-head); font-size:2rem; font-weight:700; letter-spacing:-.03em; }
.pr-total-sub { font-size:.71rem; color:var(--text-muted); margin-top:2px; }
.pr-ov-proceed { width:100%; padding:14px; background:var(--brand-blue); color:#fff; border:none; border-radius:var(--radius-md); font-family:var(--font-body); font-size:.9375rem; font-weight:700; cursor:pointer; display:flex; align-items:center; justify-content:center; gap:8px; box-shadow:0 4px 14px rgba(37,99,235,.35); margin-bottom:8px; transition:all var(--ease-base); }
.pr-ov-proceed:hover { background:#1D4ED8; box-shadow:0 6px 22px rgba(37,99,235,.5); }
.pr-ov-cancel { width:100%; padding:10px; background:transparent; border:1px solid var(--border-sub); border-radius:var(--radius-sm); font-family:var(--font-body); font-size:.875rem; font-weight:500; color:var(--text-secondary); cursor:pointer; transition:all var(--ease-fast); }
.pr-ov-cancel:hover { background:var(--bg-card-hv); color:var(--text-primary); }
.pr-ov-trust { display:flex; align-items:center; justify-content:center; gap:16px; margin-top:14px; flex-wrap:wrap; }
.pr-ov-trust span { font-size:.71rem; color:var(--text-muted); }

/* ══════════════════════════════════════════
   24. RESPONSIVE
   ══════════════════════════════════════════ */
@media (max-width:991px) {
  :root { --sec-pad:72px; }
  .nav-links   { display:none !important; }
  .hamburger   { display:flex !important; }
  .nav-actions .btn-ghost { display:none; }
  .feat-grid   { grid-template-columns:repeat(2,1fr); }
  .testi-grid  { grid-template-columns:1fr; }
  .stats-grid  { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .team-grid   { grid-template-columns:repeat(2,1fr); }
  .values-grid { grid-template-columns:repeat(2,1fr); }
  .contact-grid{ grid-template-columns:1fr; }
  .auth-wrap   { grid-template-columns:1fr; }
  .auth-left   { display:none; }
  .mockup-body { grid-template-columns:1fr; }
  .mockup-sidebar { display:none; }
  /* Pricing */
  .pr-plans    { grid-template-columns:1fr; max-width:400px; margin:0 auto; }
  .pr-plan[data-plan="tester"] { transform:translateY(0); }
  .pr-plan[data-plan="tester"]:hover { transform:translateY(-3px); }
  .pr-faq-grid { grid-template-columns:1fr; }
  .pr-faq-cell:nth-child(odd) { border-right:none; }
  .pr-faq-cell:nth-last-child(2) { border-bottom:1px solid var(--border-sub); }
  .pr-ent-bar  { flex-direction:column; text-align:center; }
}
@media (max-width:767px) {
  :root { --sec-pad:56px; }
  .feat-grid  { grid-template-columns:1fr; }
  .cta-block  { padding:48px 22px; }
  .footer-grid{ grid-template-columns:1fr; gap:28px; }
  .footer-desc{ max-width:100%; }
  .team-grid  { grid-template-columns:1fr 1fr; }
  .values-grid{ grid-template-columns:1fr; }
  .orb-1,.orb-2,.orb-3 { display:none; }
  .page-hero  { padding:116px 0 52px; }
  /* Pricing */
  .pr-cta     { padding:48px 22px; }
  .pr-ent-bar { padding:26px 20px; }
  .pr-ctbl th,.pr-ctbl td { padding:11px 14px; font-size:.8rem; }
  .pr-trust   { gap:14px; }
}
@media (max-width:479px) {
  .stats-grid { grid-template-columns:1fr; }
  .team-grid  { grid-template-columns:1fr; }
  .social-grid{ grid-template-columns:1fr; }
  .pr-plans   { max-width:100%; }
}

/* ──────────────────────────────────────────────────────────
   HARMONIZE PRICING PAGE WITH MAIN SITE STYLING
   ────────────────────────────────────────────────────────── */

/* 1. Remove the mouse spotlight – it adds unwanted dark/light gradients */
.pr-spotlight {
    display: none !important;
}

/* 2. Make the live ticker use the same subtle background as other alt sections */
.pr-ticker {
    background: var(--bg-deep);
    border-top-color: var(--border-sub);
    border-bottom-color: var(--border-sub);
}
.pr-tick-item {
    color: var(--text-secondary);
    border-right-color: var(--border-sub);
}
.pr-tick-dot {
    background-color: var(--brand-green); /* fallback, but keep as is */
}

/* 3. Reset “featured” (AI Tester) plan to behave like a normal card 
   – no extra transform, shadow, or prominent border */
.pr-plan[data-plan="tester"] {
    transform: translateY(0);
    box-shadow: var(--shadow-card);
    border-color: var(--border-sub);
}
.pr-plan[data-plan="tester"]:hover {
    transform: translateY(-2px);
    border-color: var(--border-med);
    box-shadow: var(--shadow-card);
}
.pr-plan[data-plan="tester"]::before {
    display: none; /* removes the coloured top line */
}
.pr-pop-badge {
    background: var(--bg-card);
    color: var(--brand-blue);
    border-color: rgba(37,99,235,0.3);
}
[data-theme="dark"] .pr-pop-badge {
    color: #5B8FF9;
}

/* 4. Ensure plan cards use exactly the same background/glass as normal cards */
.pr-plan {
    background: var(--bg-card);
    backdrop-filter: blur(16px);
    border: 1px solid var(--border-sub);
    transition: all var(--ease-base);
}
.pr-plan:hover {
    background: var(--bg-card-hv);
    border-color: var(--border-med);
}

/* 5. Make the enterprise bar match the look of other CTA blocks */
.pr-ent-bar {
    background: var(--bg-surface);
    border: 1px solid var(--border-sub);
}
.pr-ent-bar::before {
    background: var(--grad-brand);
    opacity: 0.6;
}

/* 6. Comparison table: align backgrounds with normal tables */
.pr-ctbl td {
    background: var(--bg-surface);
}
.pr-ctbl tbody tr:not(.pr-cat-row):hover td {
    background: var(--bg-card);
}
.pr-cat-row td {
    background: var(--bg-deep) !important;
}
.pr-fc {
    background: rgba(37,99,235,0.04) !important;
}
[data-theme="dark"] .pr-fc {
    background: rgba(37,99,235,0.06) !important;
}

/* 7. Pricing FAQ cells – use same border and backgrounds as other FAQ sections */
.pr-faq-cell {
    border-bottom-color: var(--border-sub);
}
.pr-faq-cell:nth-child(odd) {
    border-right-color: var(--border-sub);
}
.pr-faq-q {
    color: var(--text-primary);
}
.pr-faq-q:hover {
    background: var(--bg-card);
}
.pr-faq-a {
    color: var(--text-secondary);
}

/* 8. CTA block inside pricing page – unify with main .cta-block */
.pr-cta {
    background: var(--bg-surface);
    border: 1px solid var(--border-sub);
}
.pr-cta::before {
    background-image: linear-gradient(var(--border-sub) 1px, transparent 1px),
                      linear-gradient(90deg, var(--border-sub) 1px, transparent 1px);
    opacity: 0.4;
}

/* 9. Remove the “shimmer” effect on cards (optional, keeps it consistent) */
.pr-shimmer {
    display: none;
}

/* 10. Checkout overlay – ensure same colour palette */
.pr-overlay-modal {
    background: var(--bg-card);
    border-color: var(--border-med);
}
.pr-price-box {
    background: var(--bg-elevat);
}
/* ── Feature Strip ─────────────────────────────── */


.feature-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid var(--border-sub);
}

/* Light theme base */
[data-theme="light"] .feature-strip {
  background: #ffffff;
  box-shadow: 0 4px 32px rgba(0, 0, 0, 0.06);
}

/* Dark theme base */
[data-theme="dark"] .feature-strip {
  background: var(--bg-card);
  box-shadow: 0 4px 32px rgba(0, 0, 0, 0.3);
}

.feature-item {
  padding: 56px 36px 52px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.feature-item:not(:last-child) {
  border-right: 1px solid var(--border-sub);
}

/* Icon wrap */
.feature-icon-wrap {
  width: 80px;
  height: 80px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 28px;
  flex-shrink: 0;
}

.feature-icon-wrap.blue {
  background: rgba(88, 101, 242, 0.1);
  color: #5865f2;
}

.feature-icon-wrap.cyan {
  background: rgba(88, 101, 242, 0.1);
  color: #5865f2;
}

.feature-icon-wrap.purple {
  background: rgba(139, 92, 246, 0.1);
  color: #8b5cf6;
}

[data-theme="dark"] .feature-icon-wrap.blue  { background: rgba(88, 101, 242, 0.15); }
[data-theme="dark"] .feature-icon-wrap.cyan  { background: rgba(88, 101, 242, 0.15); }
[data-theme="dark"] .feature-icon-wrap.purple{ background: rgba(139, 92, 246, 0.15); }

.feature-item h3 {
  font-size: 1.15rem;
  font-weight: 700;
  margin-bottom: 14px;
  color: var(--text-primary);
  letter-spacing: -0.01em;
}

.feature-item p {
  font-size: 0.92rem;
  color: var(--text-secondary);
  line-height: 1.85;
  max-width: 230px;
  margin: 0;
}

/* ── Stats Strip ───────────────────────────────── */
.stats-section {
  padding: 0 0 80px;
}

.stats-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid var(--border-sub);
}

[data-theme="light"] .stats-strip {
  background: #ffffff;
  box-shadow: 0 4px 32px rgba(0, 0, 0, 0.06);
}

[data-theme="dark"] .stats-strip {
  background: var(--bg-card);
  box-shadow: 0 4px 32px rgba(0, 0, 0, 0.3);
}

.stat-cell {
  padding: 48px 24px;
  text-align: center;
}

.stat-cell:not(:last-child) {
  border-right: 1px solid var(--border-sub);
}

.stat-number {
  font-size: 2.4rem;
  font-weight: 800;
  background: linear-gradient(135deg, #5865f2, #8b5cf6);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 10px;
  letter-spacing: -0.02em;
}

.stat-label {
  font-size: 0.88rem;
  color: var(--text-secondary);
  font-weight: 500;
}

/* ── Responsive ────────────────────────────────── */
@media (max-width: 991px) {

  .feature-strip,
  .stats-strip {
      grid-template-columns: repeat(2, 1fr);
      border-radius: 20px;
  }

  .feature-item:nth-child(odd):not(:nth-last-child(-n+2)) {
      border-bottom: 1px solid var(--border-sub);
  }

  .feature-item:nth-child(even):not(:last-child) {
      border-bottom: 1px solid var(--border-sub);
  }

  .feature-item:nth-child(odd) {
      border-right: 1px solid var(--border-sub);
  }

  .feature-item:not(:last-child) {
      border-right: none;
  }

  .stat-cell:nth-child(odd) {
      border-right: 1px solid var(--border-sub);
  }

  .stat-cell:not(:last-child) {
      border-right: none;
  }

  .stat-cell:nth-child(-n+2) {
      border-bottom: 1px solid var(--border-sub);
  }
}

@media (max-width: 575px) {

  .feature-strip,
  .stats-strip {
      grid-template-columns: 1fr;
      border-radius: 16px;
  }

  .feature-item,
  .stat-cell {
      border-right: none !important;
  }

  .feature-item:not(:last-child),
  .stat-cell:not(:last-child) {
      border-bottom: 1px solid var(--border-sub) !important;
  }

  .feature-item {
      padding: 36px 28px;
  }
}

/* ── Mission Problem Cards ─────────────────────── */
.mission-problem-card {
  padding: 24px 22px;
  border-radius: 18px;
  border: 1px solid var(--border-sub);
  height: 100%;
  transition: transform 0.22s ease, box-shadow 0.22s ease;
  position: relative;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

[data-theme="light"] .mission-problem-card {
  background: #ffffff;
  box-shadow: 0 2px 16px rgba(0,0,0,0.05);
}

[data-theme="dark"] .mission-problem-card {
  background: var(--bg-card);
  box-shadow: 0 2px 16px rgba(0,0,0,0.2);
}

.mission-problem-card::before {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.22s ease;
  border-radius: inherit;
}

.mission-problem-card:hover {
  transform: translateY(-3px);
}

[data-theme="light"] .mission-problem-card:hover {
  box-shadow: 0 8px 32px rgba(0,0,0,0.09);
}

[data-theme="dark"] .mission-problem-card:hover {
  box-shadow: 0 8px 32px rgba(0,0,0,0.35);
}

/* Icon pill */
.mpc-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  flex-shrink: 0;
}

.mpc-icon.red    { background: rgba(239,68,68,0.10);  color: #ef4444; }
.mpc-icon.orange { background: rgba(249,115,22,0.10); color: #f97316; }
.mpc-icon.purple { background: rgba(139,92,246,0.10); color: #8b5cf6; }
.mpc-icon.blue   { background: rgba(59,130,246,0.10); color: #3b82f6; }

[data-theme="dark"] .mpc-icon.red    { background: rgba(239,68,68,0.15);  }
[data-theme="dark"] .mpc-icon.orange { background: rgba(249,115,22,0.15); }
[data-theme="dark"] .mpc-icon.purple { background: rgba(139,92,246,0.15); }
[data-theme="dark"] .mpc-icon.blue   { background: rgba(59,130,246,0.15); }

/* Label */
.mpc-label {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 8px;
  letter-spacing: -0.01em;
}

/* Logo theme switching */
[data-theme="dark"]  .logo-light { display: none; }
[data-theme="dark"]  .logo-dark  { display: inline-block; }
[data-theme="light"] .logo-dark  { display: none; }
[data-theme="light"] .logo-light { display: inline-block; }

/* Collapsed sidebar hides full logo */
.sidebar.collapsed .sidebar-full-logo { display: none !important; }
/* Expanded sidebar hides mono icon */
.sidebar:not(.collapsed) .sidebar-icon-only { display: none !important; }


.pr-price-inr { font-size: 14px; color: #6b7280; margin-top: 2px; }