/* ============================================
   MAE CORTEX — Component styles
   ============================================ */

/* ====== HEADER ====== */
.header {
  position: fixed;
  top: 16px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
  width: calc(100% - 32px);
  max-width: 1520px;
  transition: top var(--dur-mid) var(--ease-out);
}
.header-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
  padding: 10px 14px 10px 20px;
  border-radius: var(--r-pill);
  background: oklch(0.1 0.02 280 / 0.6);
  border: 1px solid var(--hairline);
  backdrop-filter: blur(30px) saturate(160%);
  -webkit-backdrop-filter: blur(30px) saturate(160%);
  box-shadow: 0 20px 60px -30px rgba(0,0,0,0.6);
}
[data-theme="light"] .header-inner { background: oklch(1 0 0 / 0.6); }

.brand {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -0.02em;
  font-size: 1.05rem;
  color: var(--text-1);
}
.brand-mark {
  width: 28px; height: 28px;
  display: grid; place-items: center;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--acc-bright), var(--acc-deep));
  box-shadow: 0 0 18px var(--acc-glow), inset 0 1px 0 rgba(255,255,255,0.3);
  position: relative;
}
.brand-mark svg { width: 16px; height: 16px; }
.brand-name { display: inline-flex; align-items: center; gap: 8px; }
.brand-name small {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  color: var(--text-3);
  border-left: 1px solid var(--hairline-strong);
  padding-left: 8px;
  text-transform: uppercase;
}

.nav { display: flex; justify-content: center; gap: 6px; }
.nav a {
  position: relative;
  padding: 8px 14px;
  border-radius: var(--r-pill);
  font-size: 0.88rem;
  color: var(--text-2);
  transition: color var(--dur-fast), background var(--dur-fast);
}
.nav a.is-active { color: var(--text-1); background: var(--surf-2); }
.nav a:hover { color: var(--text-1); }

.header-actions { display: flex; gap: 8px; align-items: center; }

/* Orb icon button (per reference): top-lit glass sphere · luminous rim ring ·
   accent ambient halo that blooms on hover. No movement. */
.icon-btn {
  position: relative;
  width: 38px; height: 38px;
  display: grid; place-items: center;
  border-radius: 50%;
  border: 0;
  color: var(--text-2);
  isolation: isolate;
  background:
    radial-gradient(120% 120% at 50% 24%,
      oklch(0.46 0.05 var(--btn-h) / 0.55),
      oklch(0.16 0.04 var(--btn-h) / 0.78) 72%);
  backdrop-filter: blur(12px) saturate(150%);
  -webkit-backdrop-filter: blur(12px) saturate(150%);
  box-shadow:
    inset 0 1px 0 oklch(1 0 0 / 0.28),                 /* top specular */
    inset 0 -7px 12px -9px oklch(0 0 0 / 0.7),
    0 6px 16px -10px oklch(0 0 0 / 0.6);
  transition: color var(--dur-fast), box-shadow var(--dur-mid) var(--ease-out);
}
/* luminous rim ring */
.icon-btn::before {
  content: "";
  position: absolute; inset: 0;
  border-radius: 50%;
  padding: 1px;
  background: linear-gradient(150deg, oklch(0.85 0.13 var(--btn-h) / 0.85), oklch(0.50 0.08 var(--btn-h) / 0.18));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
}
/* accent ambient halo — subtle at rest, blooms on hover */
.icon-btn::after {
  content: "";
  position: absolute; inset: -4px;
  border-radius: 50%;
  background: radial-gradient(closest-side, transparent 52%, var(--btn-glow) 78%, transparent 100%);
  opacity: 0.35;
  filter: blur(5px);
  z-index: -1;
  pointer-events: none;
  transition: opacity var(--dur-mid) var(--ease-out);
}
.icon-btn:hover { color: var(--text-1); }
.icon-btn:hover::after { opacity: 0.95; }
.icon-btn svg { width: 16px; height: 16px; }

.lang-switch {
  display: inline-flex;
  border: 1px solid var(--hairline);
  border-radius: var(--r-pill);
  padding: 3px;
  background: var(--surf-1);
}
.lang-switch button {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  padding: 5px 10px;
  border-radius: var(--r-pill);
  color: var(--text-3);
  transition: color var(--dur-fast), background var(--dur-fast);
}
.lang-switch button.is-active { color: white; background: var(--acc); }

/* ====== HERO — orb-on-top composition (TGPT-style) ====== */
.hero {
  position: relative;
  min-height: 100vh;
  padding-top: 140px;
  padding-bottom: 80px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  overflow: hidden;
  isolation: isolate;
}
.hero-glows { position: absolute; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.hero-glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(120px);
  opacity: 0.65;
  mix-blend-mode: screen;
}
/* Studio key-light from top-left — bright white core fading to violet */
.hero-glow.g1 {
  width: 720px; height: 720px;
  background: radial-gradient(circle,
    oklch(0.98 0.02 var(--acc-h) / 0.88) 0%,
    oklch(0.88 0.12 var(--acc-h) / 0.55) 14%,
    oklch(0.68 0.22 var(--acc-h) / 0.32) 32%,
    oklch(0.5 0.22 var(--acc-h) / 0.12) 52%,
    transparent 72%);
  top: -260px; left: -160px;
}
/* Studio key-light from top-right — mirrored, slightly cooler */
.hero-glow.g2 {
  width: 780px; height: 780px;
  background: radial-gradient(circle,
    oklch(0.98 0.02 220 / 0.82) 0%,
    oklch(0.86 0.14 230 / 0.5) 14%,
    oklch(0.62 0.22 240 / 0.28) 34%,
    oklch(0.45 0.2 250 / 0.1) 52%,
    transparent 72%);
  top: -280px; right: -200px;
}
/* Soft floor reflection at bottom */
.hero-glow.g3 {
  width: 900px; height: 380px;
  background: radial-gradient(ellipse,
    oklch(0.7 0.18 var(--acc-h) / 0.32) 0%,
    oklch(0.5 0.22 var(--acc-h) / 0.12) 35%,
    transparent 70%);
  bottom: -240px; left: 50%; transform: translateX(-50%);
  opacity: 0.42;
}

/* Vertical light beams — quieter for minimalist look */
.hero-beams { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
.beam {
  position: absolute;
  top: -10%;
  width: 200px;
  height: 120%;
  background: linear-gradient(180deg, oklch(0.78 0.25 var(--acc-h) / 0.28) 0%, transparent 70%);
  filter: blur(36px);
  transform-origin: top center;
  mix-blend-mode: screen;
}
.beam.b1 { left: 8%; transform: rotate(-12deg); opacity: 0.42; }
.beam.b2 { left: 38%; transform: rotate(6deg); width: 140px; opacity: 0.32; }
.beam.b3 { right: 8%; transform: rotate(14deg); opacity: 0.42; }
.beam.b4 { right: 36%; transform: rotate(-8deg); width: 160px; opacity: 0.32; }

.hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(oklch(0.85 0.04 280 / 0.04) 1px, transparent 1px),
    linear-gradient(90deg, oklch(0.85 0.04 280 / 0.04) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse at 50% 60%, black 20%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at 50% 60%, black 20%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.hero-content {
  position: relative;
  z-index: 4;
  text-align: center;
  display: grid;
  gap: 18px;
  justify-items: center;
  margin-top: clamp(210px, 24vw, 360px); /* push content BELOW the orb */
  padding-bottom: 28px;
}
/* Medium headline — not the giant display size */
.hero-content h1 {
  max-width: 22ch;
  font-weight: 500;
  font-size: clamp(2.2rem, 1.4rem + 2.6vw, 3.6rem);
  letter-spacing: -0.025em;
  line-height: 1.08;
}
.hero-content h1 .accent {
  background: linear-gradient(180deg, var(--acc-bright), var(--acc));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero-content .lead {
  max-width: 56ch;
  text-align: center;
  font-size: clamp(0.95rem, 0.85rem + 0.4vw, 1.1rem);
  color: var(--text-2);
}
.hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

.hero-stats {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--hairline);
  border: 1px solid var(--hairline);
  border-radius: var(--r-3);
  margin-top: 72px;
  overflow: hidden;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.hero-stat {
  padding: 22px 22px 20px;
  background: oklch(0.1 0.025 282 / 0.55);
  text-align: left;
  position: relative;
}
.hero-stat::before {
  content: "";
  position: absolute;
  top: 14px; left: 22px;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--acc);
  box-shadow: 0 0 6px var(--acc-glow);
  opacity: 0.7;
}
.hero-stat .num { padding-top: 10px; }
.hero-stat .num {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 1.2rem + 1.5vw, 2.6rem);
  font-weight: 500;
  letter-spacing: -0.03em;
  color: var(--text-1);
  line-height: 1;
}
.hero-stat .num .suffix { color: var(--acc-bright); }
.hero-stat .label {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-top: 12px;
}

/* ====== ORB — Cinema 4D style ====== */
.orb-wrap {
  position: absolute;
  top: clamp(100px, 13vh, 160px);
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  width: clamp(220px, 24vw, 380px);
  aspect-ratio: 1;
  pointer-events: none;
}
.orb-wrap svg { overflow: visible; }

/* Outer atmospheric haze */
.orb-atmosphere {
  position: absolute; inset: -30%;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%,
      oklch(0.65 0.28 var(--acc-h) / 0.45) 0%,
      oklch(0.55 0.3 var(--acc-h) / 0.25) 22%,
      transparent 55%);
  filter: blur(40px);
  z-index: 0;
}

/* Iridescent ring (specular halo) */
.orb-halo {
  position: absolute; inset: -4%;
  border-radius: 50%;
  background: conic-gradient(from 220deg,
    oklch(0.85 0.3 var(--acc-h)) 0deg,
    oklch(0.65 0.32 320) 60deg,
    oklch(0.5 0.28 280) 130deg,
    oklch(0.4 0.22 260) 200deg,
    oklch(0.6 0.3 var(--acc-h)) 270deg,
    oklch(0.85 0.32 var(--acc-h)) 320deg,
    oklch(0.85 0.3 var(--acc-h)) 360deg);
  filter: blur(1px);
  -webkit-mask: radial-gradient(closest-side, transparent 92%, black 93%, black 100%);
          mask: radial-gradient(closest-side, transparent 92%, black 93%, black 100%);
  opacity: 0.9;
  z-index: 2;
  animation: orbHaloRotate 22s linear infinite;
}
@keyframes orbHaloRotate { to { transform: rotate(360deg); } }

/* Floating particles */
.orb-particles {
  position: absolute; inset: -10%;
  pointer-events: none;
  z-index: 3;
}
.orb-particles span {
  position: absolute;
  width: 2px; height: 2px;
  border-radius: 50%;
  background: oklch(0.92 0.18 var(--acc-h));
  box-shadow: 0 0 6px oklch(0.85 0.3 var(--acc-h));
  opacity: 0;
  animation: orbParticle 6s linear infinite;
}
@keyframes orbParticle {
  0% { opacity: 0; transform: translate(0,0) scale(0.5); }
  20% { opacity: 1; }
  80% { opacity: 1; }
  100% { opacity: 0; transform: translate(var(--px, 60px), var(--py, -80px)) scale(1.4); }
}

/* Float / breathe animation — subtle Y-only motion, X stays centered */
@keyframes orbBreathe {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%      { transform: translateX(-50%) translateY(-10px); }
}
.orb-wrap { animation: orbBreathe 9s ease-in-out infinite; }

/* Slow rotation ring lines */
.orb-rings {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 152%; aspect-ratio: 1;
  pointer-events: none;
  opacity: 0.5;
  z-index: 4;
}
.orb-ring {
  position: absolute; inset: 0;
  border-radius: 50%;
  border: 1px solid oklch(0.85 0.1 var(--acc-h) / 0.18);
  animation: ringRotate 40s linear infinite;
}
.orb-ring.r2 { inset: 7%; border-style: dashed; animation-duration: 70s; animation-direction: reverse; opacity: 0.55; }
.orb-ring.r3 { inset: 14%; border-color: oklch(0.85 0.1 var(--acc-h) / 0.1); animation-duration: 110s; }
.orb-ring.r4 {
  inset: -8%;
  border-color: oklch(0.95 0.18 var(--acc-h) / 0.15);
  border-width: 1px;
  border-style: dotted;
  animation-duration: 160s;
}
@keyframes ringRotate { to { transform: rotate(360deg); } }

/* ====== ORB — sophisticated layer animations ====== */
.orb-core-pulse { animation: orbCorePulse 4.2s ease-in-out infinite; transform-origin: center; }
@keyframes orbCorePulse {
  0%, 100% { opacity: 0.85; }
  50% { opacity: 1; }
}

.orb-wire { animation: orbWireRotate 80s linear infinite; transform-origin: center; transform-box: fill-box; }
@keyframes orbWireRotate { to { transform: rotate(360deg); } }

.orb-equator { animation: orbEquatorSpin 18s linear infinite; transform-origin: center; transform-box: fill-box; }
@keyframes orbEquatorSpin { to { transform: rotate(360deg); } }

.orb-scan { animation: orbScan 5.6s cubic-bezier(0.45, 0, 0.55, 1) infinite; transform-origin: center; transform-box: fill-box; opacity: 0.85; }
@keyframes orbScan {
  0%, 100% { transform: translateY(-44px); opacity: 0; }
  40%, 60% { opacity: 0.65; }
  50% { transform: translateY(44px); opacity: 0; }
}

.orb-tag {
  opacity: 0;
  animation: orbTagFade 7s ease-in-out infinite;
}
@keyframes orbTagFade {
  0%, 100% { opacity: 0; }
  8%, 70%  { opacity: 1; }
}

.orb-surface-data circle { animation: orbDataBlink 3.5s ease-in-out infinite; transform-origin: center; transform-box: fill-box; }
.orb-surface-data circle:nth-child(2n) { animation-delay: 0.6s; }
.orb-surface-data circle:nth-child(3n) { animation-delay: 1.2s; }
@keyframes orbDataBlink {
  0%, 100% { opacity: 0.25; transform: scale(0.8); }
  50%      { opacity: 1;    transform: scale(1.3); }
}

.orb-poles { animation: orbPoleBreath 5s ease-in-out infinite; transform-box: fill-box; transform-origin: center; }
@keyframes orbPoleBreath {
  0%, 100% { opacity: 0.55; transform: scaleY(1); }
  50%      { opacity: 0.85; transform: scaleY(1.08); }
}

/* ====== ORB — WebGL canvas (minimalist fluid sphere) ====== */
.orb-webgl-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  pointer-events: none;
  z-index: 2;
  filter: drop-shadow(0 0 80px oklch(0.7 0.3 var(--acc-h) / 0.45));
}

/* CSS-only fallback orb — used when WebGL fails (iOS Safari memory pressure, etc.) */
.orb-css-fallback {
  position: absolute;
  top: 50%; left: 50%;
  width: 70%;
  aspect-ratio: 1;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  background:
    radial-gradient(circle at 32% 28%,
      oklch(0.94 0.20 290) 0%,
      oklch(0.72 0.27 290) 18%,
      oklch(0.42 0.24 290) 42%,
      oklch(0.20 0.14 290) 70%,
      oklch(0.10 0.06 290) 100%),
    conic-gradient(from 220deg at 50% 50%,
      oklch(0.65 0.28 320),
      oklch(0.78 0.28 290),
      oklch(0.7 0.25 220),
      oklch(0.65 0.28 320));
  background-blend-mode: screen, normal;
  box-shadow:
    inset -20px -30px 60px oklch(0 0 0 / 0.5),
    inset 18px 24px 60px oklch(0.95 0.22 290 / 0.35),
    0 0 80px oklch(0.7 0.3 290 / 0.45);
  z-index: 2;
  pointer-events: none;
  animation: orbCssBreathe 6s ease-in-out infinite;
}
@keyframes orbCssBreathe {
  0%, 100% { transform: translate(-50%, -50%) scale(1); }
  50%      { transform: translate(-50%, -50%) scale(1.03); }
}
.orb-css-fallback::after {
  content: "";
  position: absolute; inset: 0;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 22%, rgba(255,255,255,0.55), transparent 35%);
  mix-blend-mode: screen;
}

/* iOS Safari — disable expensive filters and reduce concurrent animations */
@supports (-webkit-touch-callout: none) {
  .orb-webgl-canvas { filter: none; }
  .orb-css-fallback { box-shadow: 0 0 60px oklch(0.7 0.3 290 / 0.3); animation: none; }
  /* Backdrop-filter is the biggest GPU/memory hog on iOS — kill it everywhere */
  .header-inner, .glass, .mega-inner, .nexus-tabs, .price-card, .nexus-main,
  .nexus-feature, .orbital-panel, .orbital-satellite, .mega-card,
  .fselect-trigger, .fselect-menu-inner, .demo-tabs, .demo-canvas,
  .px-toggle, .configurator, .configurator-summary-inner,
  .walk-screen, .nav-mega-trigger, .btn {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
  /* Reduce blur values — Safari runs Gaussian blur on CPU above certain size */
  .hero-glow { filter: blur(80px) !important; }
  .mega-inner::after, .orbital-panel::before, .configurator::before,
  .orbital-bg circle { filter: blur(40px) !important; }
  /* Disable noise overlay — heavy SVG turbulence */
  body::before { display: none !important; }
  /* Cut decorative motion that consumes GPU during scroll */
  .stars, .beam { display: none !important; }
  .orb-wrap { animation: none !important; }
  /* Limit per-element transforms — iOS can OOM with many composite layers */
  .reveal { transition-duration: 400ms !important; }
}

/* Reduced motion fallback — also helps iOS Low Power mode */
@media (prefers-reduced-motion: reduce) {
  .orb-webgl-canvas, .orb-wrap, .stars, .beam, .marquee, .brand-marquee-track,
  .orb-core-pulse, .orb-equator, .orb-scan, .orb-wire, .orb-poles,
  .orb-surface-data circle, .orb-tag, .configurator-dot,
  .brand-marquee-eyebrow-dot, .mega-pulse span,
  .orbital-core-pulse { animation: none !important; }
}

/* ====== HEADER — Mega menu ====== */
.nav-item-mega {
  position: relative;
  display: inline-flex;
}
.nav-mega-trigger {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.nav-caret {
  transition: transform var(--dur-mid) var(--ease-out);
  opacity: 0.6;
}
.nav-mega-trigger.is-open .nav-caret { transform: rotate(180deg); opacity: 1; }

.mega-menu {
  position: absolute;
  top: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%) translateY(-12px);
  width: min(1180px, calc(100vw - 64px));
  pointer-events: none;
  opacity: 0;
  transition: opacity 320ms var(--ease-out),
              transform 420ms var(--ease-spring);
  z-index: 99;
}
.mega-menu.is-open {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}

.mega-inner {
  position: relative;
  padding: 28px;
  border-radius: 26px;
  background: oklch(0.09 0.025 282 / 0.88);
  border: 1px solid oklch(0.92 0.04 280 / 0.16);
  backdrop-filter: blur(36px) saturate(180%);
  -webkit-backdrop-filter: blur(36px) saturate(180%);
  box-shadow:
    0 50px 120px -40px rgba(0,0,0,0.85),
    0 20px 60px -25px rgba(0,0,0,0.6),
    inset 0 1px 0 rgba(255,255,255,0.08);
  isolation: isolate;
  overflow: hidden;
}
/* Iridescent edge — subtle premium ring */
.mega-inner::before {
  content: "";
  position: absolute; inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg,
    rgba(255,255,255,0.22) 0%,
    transparent 28%,
    transparent 70%,
    oklch(0.78 0.22 var(--acc-h) / 0.35) 100%);
  -webkit-mask: linear-gradient(black, black) content-box, linear-gradient(black, black);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
  z-index: 1;
}
/* Background atmosphere blob */
.mega-inner::after {
  content: "";
  position: absolute;
  top: -120px; right: -60px;
  width: 380px; height: 380px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--acc-glow), transparent 70%);
  filter: blur(60px);
  z-index: -1;
}

/* Header — title + status */
.mega-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 24px;
  padding: 0 4px 20px;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--hairline);
}
.mega-head-left { display: grid; gap: 4px; }
.mega-eyebrow {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: oklch(0.85 0.12 var(--acc-h));
}
.mega-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: -0.025em;
  color: var(--text-1);
  margin: 0;
}
.mega-head-right {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--hairline);
  background: oklch(0.16 0.03 282 / 0.6);
}
.mega-pulse {
  position: relative;
  width: 8px; height: 8px;
  display: inline-grid; place-items: center;
}
.mega-pulse span {
  position: absolute; inset: 0;
  border-radius: 50%;
  background: oklch(0.7 0.22 145);
  box-shadow: 0 0 10px oklch(0.7 0.3 145 / 0.7);
  animation: megaPulseDot 2s ease-in-out infinite;
}
@keyframes megaPulseDot {
  0%, 100% { transform: scale(1);   opacity: 1; }
  50%      { transform: scale(1.4); opacity: 0.6; }
}
.mega-status-text {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  color: oklch(0.85 0.04 280);
}

/* Card grid */
.mega-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
@media (max-width: 1000px) { .mega-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .mega-grid { grid-template-columns: 1fr; } }

/* Premium card */
.mega-card {
  position: relative;
  display: flex; flex-direction: column;
  border-radius: 18px;
  border: 1px solid oklch(0.92 0.04 280 / 0.12);
  background: linear-gradient(180deg,
    oklch(0.14 0.045 var(--card-h, var(--acc-h)) / 0.6),
    oklch(0.08 0.022 282 / 0.85));
  color: var(--text-1);
  cursor: pointer;
  isolation: isolate;
  overflow: hidden;
  text-decoration: none;
  transition: border-color 320ms var(--ease-out),
              box-shadow 320ms var(--ease-out);
  opacity: 0;
  transform: translate3d(0, 16px, 0);
  will-change: transform, opacity;
}
.mega-menu.is-open .mega-card {
  animation: megaCardIn 540ms var(--ease-out) var(--mega-delay, 80ms) forwards;
}
@keyframes megaCardIn {
  from { opacity: 0; transform: translate3d(0, 16px, 0); }
  to   { opacity: 1; transform: translate3d(0, 0, 0); }
}

.mega-card-accent {
  position: absolute;
  top: 0; left: 8%; right: 8%;
  height: 1px;
  background: linear-gradient(90deg,
    transparent,
    oklch(0.86 0.28 var(--card-h, var(--acc-h))) 50%,
    transparent);
  opacity: 0.5;
  transition: opacity 320ms var(--ease-out), top 320ms var(--ease-out);
}
.mega-card:hover .mega-card-accent { opacity: 1; box-shadow: 0 0 10px oklch(0.86 0.32 var(--card-h, var(--acc-h)) / 0.7); }

.mega-card:hover {
  border-color: oklch(0.85 0.22 var(--card-h, var(--acc-h)) / 0.45);
  box-shadow:
    0 20px 50px -20px oklch(0.5 0.28 var(--card-h, var(--acc-h)) / 0.55),
    inset 0 1px 0 rgba(255,255,255,0.06);
}

/* Card preview area (top half) */
.mega-card-preview {
  position: relative;
  height: 92px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px 12px;
  isolation: isolate;
  overflow: hidden;
}
.mega-card-preview-blob {
  position: absolute;
  bottom: -50px; right: -30px;
  width: 160px; height: 160px;
  border-radius: 50%;
  background: radial-gradient(circle,
    oklch(0.7 0.28 var(--card-h, var(--acc-h)) / 0.55),
    transparent 65%);
  filter: blur(28px);
  z-index: -1;
  transition: transform 480ms var(--ease-spring);
}
.mega-card:hover .mega-card-preview-blob { transform: scale(1.2) translate(-10px, -10px); }

.mega-card-icon {
  width: 46px; height: 46px;
  display: grid; place-items: center;
  border-radius: 12px;
  color: white;
  background: linear-gradient(135deg,
    oklch(0.78 0.27 var(--card-h, var(--acc-h))),
    oklch(0.42 0.22 var(--card-h, var(--acc-h))));
  box-shadow:
    0 0 24px oklch(0.72 0.3 var(--card-h, var(--acc-h)) / 0.55),
    inset 0 1px 0 rgba(255,255,255,0.32),
    inset 0 -6px 14px rgba(0,0,0,0.25);
  position: relative;
  isolation: isolate;
}
.mega-card-icon::before {
  content: "";
  position: absolute; inset: 1px;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(255,255,255,0.28), transparent 45%);
  pointer-events: none;
}
.mega-card-icon svg { width: 22px; height: 22px; }
.mega-card-index {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.22em;
  color: oklch(0.85 0.04 280 / 0.6);
}

/* Card body (bottom area) */
.mega-card-body {
  padding: 14px 16px 16px;
  border-top: 1px solid oklch(0.92 0.04 280 / 0.08);
  display: grid;
  gap: 8px;
  flex: 1;
}
.mega-card-name {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: -0.025em;
  color: var(--text-1);
  line-height: 1;
}
.mega-card-tag {
  font-family: var(--font-mono);
  font-size: 0.58rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: oklch(0.85 0.14 var(--card-h, var(--acc-h)));
}
.mega-card-feats {
  list-style: none;
  padding: 0; margin: 6px 0 0;
  display: grid;
  gap: 6px;
  flex: 1;
}
.mega-card-feats li {
  display: flex; align-items: flex-start; gap: 7px;
  font-size: 0.78rem;
  line-height: 1.4;
  color: var(--text-2);
}
.mega-card-bullet {
  width: 4px; height: 4px;
  border-radius: 50%;
  background: oklch(0.85 0.2 var(--card-h, var(--acc-h)));
  box-shadow: 0 0 5px oklch(0.85 0.28 var(--card-h, var(--acc-h)) / 0.7);
  margin-top: 7px;
  flex-shrink: 0;
}
.mega-card-cta {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 8px;
  padding-top: 10px;
  border-top: 1px solid oklch(0.92 0.04 280 / 0.08);
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--text-1);
  letter-spacing: -0.005em;
  transition: gap 280ms var(--ease-spring), color 280ms var(--ease-out);
}
.mega-card:hover .mega-card-cta {
  gap: 10px;
  color: oklch(0.92 0.22 var(--card-h, var(--acc-h)));
}
.mega-card-cta svg { width: 12px; height: 12px; }

/* Footer */
.mega-foot {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 6px 0;
  margin-top: 18px;
  border-top: 1px solid var(--hairline);
}
.mega-foot-meta {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  color: oklch(0.7 0.04 280);
  text-transform: uppercase;
}
.mega-foot-dot {
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--acc-bright);
  box-shadow: 0 0 6px var(--acc-glow);
}
.mega-foot-link {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--text-1);
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.88rem;
  transition: gap 280ms var(--ease-spring), color 200ms;
}
.mega-foot-link:hover { color: var(--acc-bright); gap: 10px; }
.mega-foot-link svg { width: 14px; height: 14px; }

/* ====== DEMO TABS & CANVAS (inside orbital panel) ====== */
.demo-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 4px;
  border-radius: 14px;
  background: oklch(0.13 0.025 282 / 0.6);
  border: 1px solid var(--hairline);
}
.demo-tab {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  border-radius: 10px;
  font-family: var(--font-body);
  color: var(--text-3);
  font-size: 0.85rem;
  letter-spacing: -0.005em;
  cursor: pointer;
  background: transparent;
  border: 0;
  transition: color var(--dur-fast), background var(--dur-fast);
  flex: 1;
  justify-content: center;
}
.demo-tab:hover { color: var(--text-1); }
.demo-tab .demo-tab-num {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.18em;
  opacity: 0.6;
}
.demo-tab.is-active {
  color: white;
  background: linear-gradient(180deg,
    oklch(0.62 0.25 var(--hue, var(--acc-h))),
    oklch(0.4 0.22 var(--hue, var(--acc-h))));
  box-shadow: 0 0 16px oklch(0.6 0.3 var(--hue) / 0.5),
              inset 0 1px 0 rgba(255,255,255,0.25);
}
.demo-tab.is-active .demo-tab-num { opacity: 1; }

.demo-canvas {
  position: relative;
  border-radius: 14px;
  background: oklch(0.08 0.02 282 / 0.7);
  border: 1px solid var(--hairline);
  overflow: hidden;
  height: 200px;
  animation: cardSlideInLeft 520ms var(--ease-out);
  will-change: transform, opacity;
}
/* Cards slide in from the left — GPU-only, no filter blur (prevents flicker) */
@keyframes cardSlideInLeft {
  from { opacity: 0; transform: translate3d(-24px, 0, 0); }
  to   { opacity: 1; transform: translate3d(0, 0, 0); }
}
.demo-canvas-bar {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 12px;
  border-bottom: 1px solid var(--hairline);
  background: oklch(0.12 0.02 282 / 0.6);
}
.demo-dots {
  display: inline-flex; gap: 4px;
}
.demo-dots span {
  width: 7px; height: 7px; border-radius: 50%;
  background: oklch(0.35 0.02 282);
}
.demo-url {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.08em;
  color: var(--text-3);
}
.demo-canvas-body {
  padding: 12px;
  height: calc(100% - 32px);
  overflow: hidden;
}

.demo-explain {
  font-size: 0.85rem;
  color: var(--text-2);
  line-height: 1.5;
  display: flex; align-items: baseline; gap: 10px;
  margin: 0;
}
.demo-explain .mono {
  font-family: var(--font-mono);
  font-size: 0.58rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: oklch(0.85 0.12 var(--hue, var(--acc-h)));
  flex-shrink: 0;
  padding-top: 1px;
}

.demo-stats {
  list-style: none;
  padding: 0; margin: 0;
  display: flex; gap: 16px;
}
.demo-stats li {
  display: grid; gap: 2px;
}
.demo-stats .mono {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-3);
}
.demo-stats strong {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 0.95rem;
  letter-spacing: -0.01em;
  color: var(--text-1);
}

/* ===== Demo mock components ===== */
.dm-list {
  display: flex; flex-direction: column; gap: 6px;
  height: 100%;
}
.dm-row {
  display: grid;
  grid-template-columns: 8px 1fr auto auto;
  gap: 10px;
  align-items: center;
  padding: 7px 10px;
  border-radius: 8px;
  background: oklch(0.13 0.03 282 / 0.6);
  border: 1px solid var(--hairline);
  font-size: 0.78rem;
}
.dm-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: oklch(0.6 0.2 145);
  box-shadow: 0 0 6px oklch(0.7 0.3 145 / 0.5);
}
.dm-dot.pause { background: oklch(0.6 0.15 60); box-shadow: 0 0 6px oklch(0.7 0.25 60 / 0.5); }
.dm-dot.warn  { background: oklch(0.65 0.2 30);  box-shadow: 0 0 6px oklch(0.75 0.3 30 / 0.5); }
.dm-row-name { color: var(--text-1); overflow: hidden; text-overflow: ellipsis; }
.dm-row-num  { font-family: var(--font-mono); color: var(--text-3); font-size: 0.72rem; }
.dm-row-roas { font-family: var(--font-mono); color: oklch(0.8 0.18 var(--hue, var(--acc-h))); font-weight: 600; }
.dm-row-sku  { font-family: var(--font-mono); font-size: 0.7rem; color: oklch(0.85 0.12 var(--hue)); }

.dm-anom .dm-anom-icon { font-family: var(--font-mono); color: oklch(0.85 0.18 var(--hue)); }
.dm-anom.dm-warn { border-color: oklch(0.6 0.2 60 / 0.45); }
.dm-anom.dm-high { border-color: oklch(0.65 0.22 30 / 0.5); background: oklch(0.16 0.05 30 / 0.5); }

.dm-chart { width: 100%; height: 100%; }
.dm-chart-label {
  font-family: ui-monospace, "Geist Mono", monospace;
  font-size: 7px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.dm-bars { display: flex; flex-direction: column; gap: 10px; }
.dm-bar-row {
  display: grid;
  grid-template-columns: 64px 1fr 38px;
  gap: 10px;
  align-items: center;
  font-size: 0.75rem;
}
.dm-bar-name { color: var(--text-2); font-family: var(--font-mono); letter-spacing: 0.06em; font-size: 0.7rem; }
.dm-bar-track {
  height: 8px;
  border-radius: 4px;
  background: oklch(0.18 0.02 282 / 0.7);
  overflow: hidden;
}
.dm-bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 600ms var(--ease-out);
}
.dm-bar-pct { font-family: var(--font-mono); color: var(--text-1); font-size: 0.72rem; text-align: right; }

.dm-chat { display: flex; flex-direction: column; gap: 8px; height: 100%; }
.dm-msg { display: flex; gap: 6px; align-items: flex-start; }
.dm-msg-ai .dm-bubble {
  background: oklch(0.16 0.05 var(--hue) / 0.85);
  border: 1px solid oklch(0.85 0.2 var(--hue) / 0.3);
}
.dm-msg-user { justify-content: flex-end; }
.dm-msg-user .dm-bubble {
  background: linear-gradient(180deg, oklch(0.62 0.22 var(--hue)), oklch(0.42 0.2 var(--hue)));
  color: white;
}
.dm-bubble {
  padding: 6px 10px;
  border-radius: 12px;
  font-size: 0.75rem;
  max-width: 70%;
  line-height: 1.35;
}
.dm-avatar {
  width: 16px; height: 16px;
  border-radius: 50%;
  background: linear-gradient(135deg, oklch(0.7 0.25 var(--hue)), oklch(0.4 0.22 var(--hue)));
  flex-shrink: 0;
  margin-top: 2px;
}
.dm-chat-meta {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.15em;
  color: var(--text-3);
  margin-top: auto;
  padding-top: 6px;
  border-top: 1px solid var(--hairline);
}

.dm-flow { width: 100%; height: 100%; }

.dm-heat {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 3px;
  height: 100%;
}
.dm-heat span { border-radius: 2px; }

.dm-catalog {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}
.dm-tile {
  display: grid; gap: 4px;
  padding: 6px;
  border-radius: 8px;
  border: 1px solid var(--hairline);
  background: oklch(0.12 0.02 282 / 0.5);
}
.dm-tile-img { aspect-ratio: 1; border-radius: 4px; }
.dm-tile-sku {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 0.1em;
  color: var(--text-3);
}

.dm-pipeline {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  align-items: end;
  height: 100%;
}
.dm-stage {
  display: grid; gap: 6px;
  padding: 10px;
  border-radius: 8px;
  background: oklch(0.13 0.03 var(--hue) / 0.45);
  border: 1px solid var(--hairline);
  text-align: center;
}
.dm-stage-name {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-3);
}
.dm-stage-count {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: -0.02em;
  color: var(--text-1);
}
.dm-stage-bar {
  border-radius: 4px;
  background: linear-gradient(180deg,
    oklch(0.7 0.25 var(--hue)),
    oklch(0.35 0.18 var(--hue)));
  margin-top: auto;
}

/* Star field */
.stars {
  position: absolute; inset: 0;
  background-image:
    radial-gradient(1px 1px at 10% 20%, white, transparent),
    radial-gradient(1px 1px at 25% 80%, white, transparent),
    radial-gradient(1px 1px at 45% 30%, white, transparent),
    radial-gradient(1.5px 1.5px at 60% 65%, white, transparent),
    radial-gradient(1px 1px at 78% 25%, white, transparent),
    radial-gradient(1px 1px at 88% 70%, white, transparent),
    radial-gradient(2px 2px at 15% 55%, white, transparent),
    radial-gradient(1px 1px at 35% 90%, white, transparent),
    radial-gradient(1px 1px at 70% 45%, white, transparent),
    radial-gradient(1.5px 1.5px at 92% 15%, white, transparent);
  opacity: 0.5;
  animation: twinkle 6s ease-in-out infinite;
}
@keyframes twinkle {
  50% { opacity: 0.25; }
}

/* ====== APPS HUB ====== */
.apps-section { position: relative; }

/* ===== Nexus tabs ===== */
.nexus-tabs {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 4px;
  margin: 0 auto 32px;
  border-radius: var(--r-pill);
  background: oklch(0.13 0.025 282 / 0.6);
  border: 1px solid var(--hairline);
  backdrop-filter: blur(20px);
}
.nexus-tabs-wrap { display: flex; justify-content: center; }
.nexus-tab {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 22px;
  border-radius: var(--r-pill);
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--text-3);
  transition: color var(--dur-mid), background var(--dur-mid);
  position: relative;
}
.nexus-tab:hover { color: var(--text-1); }
.nexus-tab .nexus-tab-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: oklch(0.5 0.2 var(--card-h, var(--acc-h)));
  box-shadow: 0 0 0 0 transparent;
  transition: box-shadow var(--dur-mid);
}
.nexus-tab.active {
  color: white;
  background: linear-gradient(180deg, oklch(0.6 0.25 var(--card-h, var(--acc-h))), oklch(0.4 0.22 var(--card-h, var(--acc-h))));
  box-shadow: 0 0 24px oklch(0.6 0.3 var(--card-h, var(--acc-h)) / 0.5), inset 0 1px 0 rgba(255,255,255,0.25);
}
.nexus-tab.active .nexus-tab-dot { background: white; box-shadow: 0 0 12px white; }

/* ===== Nexus grid: big left card + 2x2 right grid (ref 2) ===== */
.nexus-grid {
  display: grid;
  grid-template-columns: 1.05fr 1.4fr;
  gap: 20px;
  min-height: 580px;
  align-items: stretch;
}
@media (max-width: 1000px) {
  .nexus-grid { grid-template-columns: 1fr; }
}

/* MAIN card (the active app — ref 2's "EVM-Based Scalability") */
.nexus-main {
  position: relative;
  padding: 40px;
  border-radius: var(--r-5);
  background: linear-gradient(180deg, oklch(0.16 0.04 var(--card-h, var(--acc-h)) / 0.55), oklch(0.1 0.025 282 / 0.7));
  border: 1px solid oklch(0.85 0.04 280 / 0.16);
  backdrop-filter: blur(30px) saturate(160%);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  isolation: isolate;
  min-height: 580px;
}
.nexus-main::before {
  /* bottom-left iridescent blob (ref 2) */
  content: "";
  position: absolute;
  bottom: -120px; left: -80px;
  width: 460px; height: 460px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%,
      oklch(0.75 0.32 var(--card-h, var(--acc-h))) 0%,
      oklch(0.55 0.3 var(--card-h, var(--acc-h))) 25%,
      oklch(0.45 0.32 calc(var(--card-h, var(--acc-h)) + 40)) 55%,
      transparent 75%);
  filter: blur(40px);
  opacity: 0.85;
  z-index: -1;
}
.nexus-main::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 30% 80%, oklch(0.9 0.3 var(--card-h, var(--acc-h)) / 0.18), transparent 60%);
  z-index: -1;
}
.nexus-main .nexus-icon {
  width: 72px; height: 72px;
  border-radius: var(--r-3);
  display: grid; place-items: center;
  background: linear-gradient(135deg, oklch(0.7 0.25 var(--card-h, var(--acc-h))), oklch(0.4 0.22 var(--card-h, var(--acc-h))));
  box-shadow: 0 0 30px oklch(0.7 0.3 var(--card-h, var(--acc-h)) / 0.6), inset 0 1px 0 rgba(255,255,255,0.35);
  margin-bottom: 28px;
}
.nexus-main .nexus-icon svg { width: 34px; height: 34px; color: white; }
.nexus-main .nexus-tagline {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: oklch(0.85 0.1 var(--card-h, var(--acc-h)));
  margin-bottom: 14px;
}
.nexus-main .nexus-title {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 1.6rem + 1.4vw, 3rem);
  font-weight: 500;
  letter-spacing: -0.03em;
  line-height: 1;
  margin-bottom: 20px;
}
.nexus-main .nexus-desc {
  font-size: 1rem;
  line-height: 1.55;
  color: var(--text-2);
  max-width: 38ch;
  margin-bottom: 32px;
}
.nexus-main .nexus-cta {
  margin-top: auto;
  display: flex; gap: 10px; flex-wrap: wrap;
}

/* RIGHT side — 2x2 feature grid */
.nexus-features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
@media (max-width: 600px) { .nexus-features { grid-template-columns: 1fr; } }

.nexus-feature {
  position: relative;
  padding: 24px;
  border-radius: var(--r-4);
  background: linear-gradient(180deg, oklch(0.14 0.03 282 / 0.5), oklch(0.1 0.025 282 / 0.7));
  border: 1px solid var(--hairline);
  backdrop-filter: blur(20px);
  display: flex; flex-direction: column;
  overflow: hidden;
  isolation: isolate;
  min-height: 270px;
}
.nexus-feature::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 100% 0%, oklch(0.7 0.25 var(--card-h, var(--acc-h)) / 0.06), transparent 50%);
  z-index: -1;
}
.nexus-feature .nf-eyebrow {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 14px;
}
.nexus-feature .nf-eyebrow svg {
  width: 14px; height: 14px;
  color: oklch(0.75 0.18 var(--card-h, var(--acc-h)));
}
.nexus-feature h4 {
  font-family: var(--font-display);
  font-size: clamp(0.95rem, 0.85rem + 0.3vw, 1.05rem);
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--text-1);
  line-height: 1.25;
  margin-bottom: 14px;
  max-width: 22ch;
}
.nexus-feature .nf-visual {
  margin-top: auto;
  height: 100px;
  border-radius: var(--r-2);
  background: oklch(0.12 0.025 282 / 0.6);
  border: 1px solid var(--hairline);
  display: grid; place-items: center;
  overflow: hidden;
  position: relative;
}

/* ===== Original AppCard (still used in app-page cross-sell) ===== */
.apps-hub {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  perspective: 1500px;
}
.apps-hub[data-layout="staggered"] .app-card:nth-child(2) { transform: translateY(40px); }
.apps-hub[data-layout="staggered"] .app-card:nth-child(4) { transform: translateY(40px); }
.apps-hub[data-layout="grid-2"] { grid-template-columns: repeat(2, 1fr); max-width: 900px; margin-inline: auto; }
@media (max-width: 1000px) {
  .apps-hub { grid-template-columns: repeat(2, 1fr); }
  .apps-hub[data-layout="staggered"] .app-card { transform: none !important; }
}
@media (max-width: 580px) { .apps-hub { grid-template-columns: 1fr; } }

.app-card {
  position: relative;
  display: flex; flex-direction: column;
  padding: 24px;
  min-height: 360px;
  border-radius: var(--r-4);
  background: var(--surf-1);
  border: 1px solid var(--hairline);
  backdrop-filter: blur(20px);
  overflow: hidden;
  cursor: pointer;
  transition: border-color var(--dur-mid) var(--ease-out);
  isolation: isolate;
}
.app-card::after {
  content: "";
  position: absolute; inset: -1px;
  border-radius: inherit;
  background: radial-gradient(400px circle at var(--mx, 50%) var(--my, 50%), oklch(0.7 0.25 var(--card-h, var(--acc-h)) / 0.2), transparent 60%);
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--dur-mid) var(--ease-out);
  z-index: 0;
}
.app-card:hover { border-color: oklch(0.85 0.04 280 / 0.28); }
.app-card:hover::after { opacity: 1; }
.app-card > * { position: relative; z-index: 1; }
.app-card .app-glow {
  position: absolute; bottom: -80px; left: -40px;
  width: 250px; height: 250px;
  border-radius: 50%;
  background: radial-gradient(circle, oklch(0.6 0.3 var(--card-h, var(--acc-h)) / 0.5), transparent 65%);
  filter: blur(40px); z-index: 0;
}
.app-card .app-icon {
  width: 56px; height: 56px;
  border-radius: var(--r-3);
  display: grid; place-items: center;
  background: linear-gradient(135deg, oklch(0.7 0.25 var(--card-h, var(--acc-h))), oklch(0.4 0.22 var(--card-h, var(--acc-h))));
  box-shadow: 0 0 24px oklch(0.7 0.3 var(--card-h, var(--acc-h)) / 0.5), inset 0 1px 0 rgba(255,255,255,0.3);
  margin-bottom: 22px;
}
.app-card .app-icon svg { width: 28px; height: 28px; color: white; }
.app-card .app-name { font-family: var(--font-display); font-size: clamp(1.5rem, 1.2rem + 0.5vw, 1.9rem); font-weight: 500; letter-spacing: -0.02em; }
.app-card .app-tagline { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-3); margin-top: 6px; }
.app-card .app-desc { font-size: 0.92rem; color: var(--text-2); margin-top: 16px; line-height: 1.55; flex: 1; }
.app-card .app-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--hairline); }
.app-card .app-cta { display: inline-flex; align-items: center; gap: 6px; font-size: 0.85rem; color: var(--text-1); }
.app-card .app-status { font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-3); display: inline-flex; align-items: center; gap: 6px; }
.app-card .app-status::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: oklch(0.7 0.2 145); box-shadow: 0 0 8px oklch(0.7 0.3 145 / 0.6); }

/* Fade transition between active apps in nexus — slide-in from left */
.nexus-grid { animation: cardSlideInLeft 560ms var(--ease-out); }

/* Stagger the main card and 4 feature cards on tab switch */
.nexus-grid .nexus-main      { animation: cardSlideInLeft 600ms var(--ease-out) 0ms backwards; }
.nexus-grid .nexus-feature   { animation: cardSlideInLeft 600ms var(--ease-out) backwards; }
.nexus-grid .nexus-feature:nth-child(1) { animation-delay: 80ms; }
.nexus-grid .nexus-feature:nth-child(2) { animation-delay: 160ms; }
.nexus-grid .nexus-feature:nth-child(3) { animation-delay: 240ms; }
.nexus-grid .nexus-feature:nth-child(4) { animation-delay: 320ms; }

/* Tab indicator pop on active change */
.nexus-tab.active .nexus-tab-dot {
  animation: tabDotPop 360ms var(--ease-spring);
}
@keyframes tabDotPop {
  0%   { transform: scale(0.5); }
  60%  { transform: scale(1.4); }
  100% { transform: scale(1); }
}

/* ====== ORBITAL NEXUS — architectural orbit UI ====== */
.nexus-section { isolation: isolate; }

.orbital {
  position: relative;
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  gap: 48px;
  align-items: center;
  min-height: 640px;
  --hue: var(--acc-h);
}
@media (max-width: 1000px) {
  .orbital { grid-template-columns: 1fr; gap: 32px; }
}

.orbital-stage {
  position: relative;
  aspect-ratio: 1;
  width: 100%;
  max-width: 720px;
  margin-inline: auto;
  isolation: isolate;
}

.orbital-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
}

/* Orbit paths */
.orbit-path { transition: stroke-opacity var(--dur-mid) var(--ease-out); }

/* ===== CORE ===== */
.orbital-core {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  z-index: 6;
  display: grid;
  place-items: center;
  gap: 10px;
  pointer-events: none;
}
.orbital-core-inner {
  position: relative;
  width: 96px; height: 96px;
  border-radius: 24px;
  background:
    radial-gradient(circle at 30% 25%, oklch(0.78 0.28 var(--card-h, var(--acc-h))) 0%, oklch(0.42 0.22 var(--card-h, var(--acc-h))) 55%, oklch(0.18 0.12 var(--card-h, var(--acc-h))) 100%);
  box-shadow:
    0 0 60px oklch(0.7 0.3 var(--card-h, var(--acc-h)) / 0.55),
    inset 0 1px 0 rgba(255,255,255,0.4),
    inset 0 -10px 24px rgba(0,0,0,0.4);
  display: grid; place-items: center;
  isolation: isolate;
  overflow: hidden;
}
.orbital-core-inner::before {
  content: "";
  position: absolute; inset: 1px;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(255,255,255,0.22), transparent 45%);
  pointer-events: none;
}
.orbital-core-pulse {
  position: absolute; inset: -8px;
  border-radius: inherit;
  background: radial-gradient(circle, oklch(0.95 0.3 var(--card-h, var(--acc-h)) / 0.45), transparent 60%);
  animation: nexusCorePulse 3.4s ease-in-out infinite;
  z-index: -1;
}
@keyframes nexusCorePulse {
  0%, 100% { transform: scale(1);   opacity: 0.7; }
  50%      { transform: scale(1.15); opacity: 1; }
}
.orbital-core-mark { color: white; display: grid; place-items: center; }
.orbital-core-mark svg { width: 36px; height: 36px; }
.orbital-core-label {
  display: grid; gap: 2px; text-align: center;
}
.orbital-core-label .mono {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: oklch(0.85 0.1 var(--card-h, var(--acc-h)));
}
.orbital-core-label strong {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.05rem;
  letter-spacing: -0.01em;
  color: var(--text-1);
}
.orbital-bus {
  font-size: 0.58rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-3);
  padding: 4px 10px;
  border: 1px solid var(--hairline-strong);
  border-radius: 999px;
  background: oklch(0.12 0.025 282 / 0.6);
  backdrop-filter: blur(12px);
}

/* ===== ARMS / SATELLITES — cardinal positions (N/E/S/W), no rotation, always axis-aligned ===== */
.orbital-stage { container-type: inline-size; }

.orbital-arm {
  position: absolute;
  pointer-events: none;
  z-index: 3;
}
.orbital-arm > * { pointer-events: auto; }

/* Fixed cardinal positions — never tilt, always horizontal labels */
.arm-1 { top: 8%;  left: 50%; transform: translate(-50%, 0);   }   /* NORTH — Marketix */
.arm-2 { top: 50%; right: 6%; transform: translate(0, -50%);   }   /* EAST  — Leila */
.arm-3 { bottom: 8%; left: 50%; transform: translate(-50%, 0); }   /* SOUTH — Ash */
.arm-4 { top: 50%; left: 6%;  transform: translate(0, -50%);   }   /* WEST  — B2B */

.orbital-satellite {
  position: relative;
  display: flex; align-items: center;
  padding: 8px 16px 8px 8px;
  border-radius: 999px;
  background: oklch(0.12 0.04 var(--hue, var(--acc-h)) / 0.88);
  border: 1px solid oklch(0.85 0.04 280 / 0.2);
  backdrop-filter: blur(20px) saturate(160%);
  cursor: pointer;
  color: var(--text-1);
  white-space: nowrap;
  transition: border-color var(--dur-mid) var(--ease-out),
              background var(--dur-mid) var(--ease-out),
              box-shadow var(--dur-mid) var(--ease-out),
              transform var(--dur-mid) var(--ease-spring);
}
.orbital-satellite:hover { box-shadow: 0 0 18px oklch(0.7 0.3 var(--hue, var(--acc-h)) / 0.5); }

/* No counter-rotation needed anymore — labels are always upright */
.sat-content {
  display: flex; align-items: center; gap: 10px;
}

/* Pulsing dot indicator (decorative orbit anchor point) */
.orbital-arm::before {
  content: "";
  position: absolute;
  top: 50%; left: 50%;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: oklch(0.95 0.2 var(--hue, var(--acc-h)));
  box-shadow: 0 0 10px oklch(0.85 0.3 var(--hue, var(--acc-h)) / 0.7);
  transform: translate(-50%, -50%);
  opacity: 0;
  transition: opacity var(--dur-mid) var(--ease-out);
  pointer-events: none;
  z-index: -1;
}
.orbital-arm.is-active::before { opacity: 1; animation: orbitDotPulse 1.6s ease-in-out infinite; }
@keyframes orbitDotPulse {
  0%, 100% { box-shadow: 0 0 10px oklch(0.85 0.3 var(--hue) / 0.7); }
  50%      { box-shadow: 0 0 20px oklch(0.95 0.4 var(--hue) / 0.95); }
}
.orbital-satellite .sat-glyph {
  width: 36px; height: 36px;
  display: grid; place-items: center;
  border-radius: 50%;
  background: linear-gradient(135deg, oklch(0.7 0.25 var(--hue, var(--acc-h))), oklch(0.4 0.22 var(--hue, var(--acc-h))));
  box-shadow: 0 0 18px oklch(0.7 0.3 var(--hue, var(--acc-h)) / 0.45),
              inset 0 1px 0 rgba(255,255,255,0.3);
  color: white;
  flex-shrink: 0;
}
.orbital-satellite .sat-glyph svg { width: 18px; height: 18px; }
.orbital-satellite .sat-label {
  display: grid; gap: 1px;
}
.orbital-satellite .sat-label .mono {
  font-family: var(--font-mono);
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  color: oklch(0.85 0.1 var(--hue, var(--acc-h)));
}
.orbital-satellite .sat-label strong {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 0.92rem;
  letter-spacing: -0.005em;
}

/* Active satellite — when its arm matches data-active */
.orbital-arm.is-active { z-index: 5; }
.orbital-arm.is-active .orbital-satellite {
  background: oklch(0.18 0.06 var(--hue) / 0.92);
  border-color: oklch(0.85 0.2 var(--hue) / 0.6);
  box-shadow:
    0 0 32px oklch(0.7 0.3 var(--hue) / 0.55),
    0 0 0 1px oklch(0.95 0.2 var(--hue) / 0.4),
    inset 0 1px 0 rgba(255,255,255,0.15);
}
.orbital-satellite:hover .sat-glyph,
.orbital-arm.is-active .sat-glyph {
  box-shadow: 0 0 28px oklch(0.85 0.3 var(--hue) / 0.65),
              inset 0 1px 0 rgba(255,255,255,0.4);
}

/* Orbit path highlight when active product changes */
.orbital .orbit-main {
  stroke: oklch(0.95 0.18 var(--card-h, var(--acc-h)) / 0.55);
  transition: stroke var(--dur-mid) var(--ease-out), filter var(--dur-mid) var(--ease-out);
  filter: drop-shadow(0 0 4px oklch(0.85 0.3 var(--card-h, var(--acc-h)) / 0.45));
}
.orbital:hover .orbit-main {
  filter: drop-shadow(0 0 10px oklch(0.85 0.3 var(--card-h, var(--acc-h)) / 0.75));
}

/* ===== DETAIL PANEL ===== */
.orbital-panel {
  position: relative;
  padding: 32px;
  border-radius: var(--r-4);
  background: linear-gradient(180deg, oklch(0.16 0.04 var(--card-h, var(--acc-h)) / 0.5), oklch(0.1 0.025 282 / 0.7));
  border: 1px solid oklch(0.85 0.04 280 / 0.14);
  backdrop-filter: blur(28px) saturate(160%);
  display: grid;
  gap: 22px;
  isolation: isolate;
  overflow: hidden;
  animation: cardSlideInLeft 560ms var(--ease-out);
}
/* Stagger inner sections so the panel reveals like a deck of cards left→right */
.orbital-panel > * { animation: cardSlideInLeft 640ms var(--ease-out) backwards; }
.orbital-panel > *:nth-child(1) { animation-delay: 0ms; }
.orbital-panel > *:nth-child(2) { animation-delay: 90ms; }
.orbital-panel > *:nth-child(3) { animation-delay: 160ms; }
.orbital-panel > *:nth-child(4) { animation-delay: 220ms; }
.orbital-panel > *:nth-child(5) { animation-delay: 280ms; }
.orbital-panel > *:nth-child(6) { animation-delay: 340ms; }
.orbital-panel > *:nth-child(7) { animation-delay: 400ms; }
.orbital-panel::before {
  content: "";
  position: absolute;
  bottom: -80px; left: -60px;
  width: 260px; height: 260px;
  border-radius: 50%;
  background: radial-gradient(circle, oklch(0.7 0.28 var(--card-h, var(--acc-h)) / 0.4), transparent 65%);
  filter: blur(40px);
  z-index: -1;
}
.orbital-panel-head {
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-3);
}
.orbital-status { color: oklch(0.75 0.2 145); }
.orbital-panel-title {
  display: flex; align-items: center; gap: 16px;
}
.orbital-panel-mark {
  width: 56px; height: 56px;
  border-radius: 14px;
  display: grid; place-items: center;
  background: linear-gradient(135deg, oklch(0.7 0.25 var(--hue, var(--acc-h))), oklch(0.4 0.22 var(--hue, var(--acc-h))));
  box-shadow: 0 0 24px oklch(0.7 0.3 var(--hue, var(--acc-h)) / 0.5),
              inset 0 1px 0 rgba(255,255,255,0.3);
  color: white; flex-shrink: 0;
}
.orbital-panel-mark svg { width: 28px; height: 28px; }
.orbital-panel-eyebrow {
  font-size: 0.66rem; letter-spacing: 0.2em;
  text-transform: uppercase;
  color: oklch(0.85 0.1 var(--card-h, var(--acc-h)));
}
.orbital-panel-name {
  font-family: var(--font-display);
  font-size: clamp(1.7rem, 1.3rem + 1vw, 2.2rem);
  font-weight: 500;
  letter-spacing: -0.025em;
  line-height: 1;
  margin-top: 4px;
  color: var(--text-1);
}
.orbital-panel-desc {
  font-size: 0.98rem;
  line-height: 1.55;
  color: var(--text-2);
  max-width: 40ch;
}
.orbital-panel-stats {
  list-style: none;
  padding: 0; margin: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--hairline);
  border: 1px solid var(--hairline);
  border-radius: var(--r-2);
  overflow: hidden;
}
.orbital-panel-stats li {
  padding: 14px 16px;
  background: oklch(0.1 0.025 282 / 0.75);
  display: grid; gap: 4px;
}
.orbital-panel-stats .mono {
  font-family: var(--font-mono);
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-3);
}
.orbital-panel-stats strong {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.1rem;
  letter-spacing: -0.01em;
  color: var(--text-1);
}
.orbital-panel-cta {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
}
.orbital-tabs {
  display: inline-flex;
  gap: 6px;
  padding: 5px;
  border-radius: 999px;
  background: oklch(0.13 0.025 282 / 0.6);
  border: 1px solid var(--hairline);
}
.orbital-tab {
  position: relative;
  width: 18px; height: 18px;
  display: grid; place-items: center;
  background: transparent; border: 0;
  cursor: pointer;
  border-radius: 50%;
  transition: background var(--dur-fast);
}
.orbital-tab .orbital-tab-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: oklch(0.5 0.15 var(--hue, var(--acc-h)));
  transition: transform var(--dur-mid) var(--ease-spring), background var(--dur-mid);
}
.orbital-tab.is-active .orbital-tab-dot {
  background: oklch(0.9 0.25 var(--hue));
  transform: scale(1.5);
  box-shadow: 0 0 10px oklch(0.85 0.3 var(--hue) / 0.7);
}
.orbital-tab:hover .orbital-tab-dot { transform: scale(1.3); }

/* ===== Legacy fallback ===== */
.tech-diagram {
  position: relative;
  height: 540px;
  border-radius: var(--r-5);
  background: linear-gradient(180deg, var(--surf-1), transparent 70%);
  border: 1px solid var(--hairline);
  overflow: hidden;
  isolation: isolate;
}

/* ===========================================================
   LARGE LAPTOP / FHD (≥1440px): scale up hero, orbital, walkthrough
   =========================================================== */
@media (min-width: 1440px) {
  :root {
    --fs-h1: clamp(4rem, 2rem + 5.6vw, 8rem);
    --fs-display: clamp(5rem, 2.5rem + 8vw, 12rem);
    --fs-h2: clamp(3rem, 2rem + 3.2vw, 5.2rem);
    --section-y: clamp(100px, 11vw, 220px);
  }
  .orbital { gap: 64px; min-height: 720px; }
  .orbital-stage { max-width: 760px; }
  .walk-grid { gap: 56px; }
  .walk-screen-frame { height: 360px; }
  .hero-content { gap: 28px; padding-bottom: 100px; }
  .hero-content .lead { max-width: 64ch; font-size: clamp(1.15rem, 0.95rem + 0.55vw, 1.5rem); }
  .hero-stats { margin-top: 88px; }
  .hero-stat { padding: 28px 28px 26px; }
}

@media (min-width: 1700px) {
  .orbital-stage { max-width: 820px; }
  .walk-screen-frame { height: 400px; }
  .nexus-main, .nexus-feature { padding: 48px; }
}

/* ===========================================================
   APP PAGE — Live Walkthrough section
   =========================================================== */
.app-walkthrough { position: relative; isolation: isolate; }
.app-walkthrough::before {
  content: "";
  position: absolute;
  top: 40px; right: -160px;
  width: 460px; height: 460px;
  border-radius: 50%;
  background: radial-gradient(circle, oklch(0.55 0.28 var(--card-h, var(--acc-h)) / 0.32), transparent 65%);
  filter: blur(80px);
  z-index: -1;
}

.walk-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 40px;
  align-items: start;
}
@media (max-width: 1000px) {
  .walk-grid { grid-template-columns: 1fr; gap: 24px; }
}

.walk-nav {
  position: sticky;
  top: 120px;
  display: flex; flex-direction: column;
  gap: 18px;
}
@media (max-width: 1000px) { .walk-nav { position: static; } }

.walk-nav-eyebrow {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-3);
}

.walk-steps {
  list-style: none;
  padding: 0; margin: 0;
  display: flex; flex-direction: column;
  gap: 6px;
  counter-reset: walkstep;
}

.walk-step {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  align-items: center;
  gap: 16px;
  width: 100%;
  padding: 16px 18px;
  border-radius: var(--r-3);
  background: oklch(0.13 0.025 282 / 0.45);
  border: 1px solid var(--hairline);
  color: var(--text-2);
  text-align: left;
  cursor: pointer;
  transition: background var(--dur-mid), border-color var(--dur-mid), transform var(--dur-mid) var(--ease-spring);
}
.walk-step:hover {
  background: oklch(0.17 0.04 var(--card-h, var(--acc-h)) / 0.55);
  border-color: oklch(0.85 0.04 280 / 0.25);
}
.walk-step.is-active {
  background: oklch(0.16 0.05 var(--card-h, var(--acc-h)) / 0.7);
  border-color: oklch(0.5 0.22 var(--card-h, var(--acc-h)) / 0.55);
  color: var(--text-1);
  box-shadow: 0 0 24px oklch(0.6 0.28 var(--card-h, var(--acc-h)) / 0.18);
}
.walk-step-num {
  display: grid; place-items: center;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: oklch(0.18 0.05 var(--card-h, var(--acc-h)) / 0.85);
  border: 1px solid oklch(0.5 0.22 var(--card-h, var(--acc-h)) / 0.35);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  color: oklch(0.85 0.18 var(--card-h, var(--acc-h)));
  flex-shrink: 0;
}
.walk-step.is-active .walk-step-num {
  background: linear-gradient(135deg,
    oklch(0.7 0.25 var(--card-h, var(--acc-h))),
    oklch(0.4 0.22 var(--card-h, var(--acc-h))));
  color: white;
  border-color: transparent;
}
.walk-step-body {
  display: grid; gap: 4px;
}
.walk-step-body strong {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.05rem;
  letter-spacing: -0.015em;
  color: var(--text-1);
}
.walk-step-desc {
  font-size: 0.82rem;
  line-height: 1.45;
  color: var(--text-3);
}
.walk-step.is-active .walk-step-desc { color: var(--text-2); }
.walk-step-arrow {
  width: 16px; height: 16px;
  display: grid; place-items: center;
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity var(--dur-mid), transform var(--dur-mid) var(--ease-spring);
  color: oklch(0.85 0.18 var(--card-h, var(--acc-h)));
}
.walk-step.is-active .walk-step-arrow { opacity: 1; transform: none; }
.walk-step-arrow svg { width: 14px; height: 14px; }

.walk-cta-row {
  margin-top: 4px;
  display: flex; gap: 10px;
}

.walk-screen {
  position: relative;
  border-radius: var(--r-4);
  background: linear-gradient(180deg, oklch(0.14 0.04 var(--card-h, var(--acc-h)) / 0.55), oklch(0.1 0.025 282 / 0.7));
  border: 1px solid var(--hairline);
  backdrop-filter: blur(24px) saturate(160%);
  overflow: hidden;
  isolation: isolate;
  animation: cardSlideInLeft 560ms var(--ease-out);
}
.walk-screen-frame > * { animation: cardSlideInLeft 620ms var(--ease-out) 80ms backwards; }
.walk-bullets li { animation: cardSlideInLeft 620ms var(--ease-out) backwards; }
.walk-bullets li:nth-child(1) { animation-delay: 160ms; }
.walk-bullets li:nth-child(2) { animation-delay: 240ms; }
.walk-bullets li:nth-child(3) { animation-delay: 320ms; }
.walk-kpis .walk-kpi { animation: cardSlideInLeft 620ms var(--ease-out) backwards; }
.walk-kpis .walk-kpi:nth-child(1) { animation-delay: 200ms; }
.walk-kpis .walk-kpi:nth-child(2) { animation-delay: 280ms; }
.walk-kpis .walk-kpi:nth-child(3) { animation-delay: 360ms; }

.walk-screen-head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--hairline);
  background: oklch(0.12 0.025 282 / 0.55);
}
.walk-screen-dots { display: inline-flex; gap: 6px; }
.walk-screen-dots span { width: 9px; height: 9px; border-radius: 50%; background: oklch(0.4 0.02 280); }
.walk-screen-url {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  color: var(--text-3);
  text-align: center;
}
.walk-screen-live {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.18em;
  color: oklch(0.75 0.2 145);
}

.walk-screen-frame {
  position: relative;
  height: 320px;
  padding: 18px;
  overflow: hidden;
}

.walk-screen-foot {
  padding: 22px;
  display: grid;
  gap: 22px;
  border-top: 1px solid var(--hairline);
  background: oklch(0.1 0.025 282 / 0.4);
}
.walk-tab-meta {
  display: grid; gap: 6px;
}
.walk-tab-meta .mono {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: oklch(0.85 0.14 var(--card-h, var(--acc-h)));
}
.walk-tab-meta p {
  font-size: 1rem;
  line-height: 1.55;
  color: var(--text-2);
  margin: 0;
  max-width: 56ch;
}

.walk-bullets {
  list-style: none;
  padding: 0; margin: 0;
  display: grid; gap: 10px;
}
.walk-bullets li {
  display: flex; gap: 10px; align-items: flex-start;
  font-size: 0.92rem;
  color: var(--text-2);
  line-height: 1.5;
}
.walk-bullets li svg {
  width: 16px; height: 16px;
  flex-shrink: 0;
  margin-top: 3px;
  color: oklch(0.85 0.2 var(--card-h, var(--acc-h)));
}

.walk-kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--hairline);
  border: 1px solid var(--hairline);
  border-radius: var(--r-2);
  overflow: hidden;
}
@media (max-width: 600px) { .walk-kpis { grid-template-columns: 1fr 1fr; } }
.walk-kpi {
  padding: 14px 16px;
  background: oklch(0.11 0.025 282 / 0.75);
  display: grid; gap: 4px;
}
.walk-kpi .mono {
  font-family: var(--font-mono);
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-3);
}
.walk-kpi strong {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.25rem;
  letter-spacing: -0.02em;
  color: var(--text-1);
}

/* Light mode for walkthrough */
[data-theme="light"] .walk-step {
  background: oklch(0.97 0.007 280 / 0.85);
  border-color: oklch(0.2 0.02 280 / 0.12);
}
[data-theme="light"] .walk-step:hover {
  background: oklch(0.94 0.02 var(--card-h, var(--acc-h)) / 0.9);
}
[data-theme="light"] .walk-step.is-active {
  background: oklch(0.92 0.04 var(--card-h, var(--acc-h)) / 0.85);
  border-color: oklch(0.5 0.22 var(--card-h, var(--acc-h)) / 0.55);
}
[data-theme="light"] .walk-step-num {
  background: oklch(0.93 0.02 var(--card-h, var(--acc-h)) / 0.85);
}
[data-theme="light"] .walk-step-body strong { color: oklch(0.15 0.02 280); }
[data-theme="light"] .walk-screen {
  background: linear-gradient(180deg, oklch(0.95 0.015 var(--card-h, var(--acc-h)) / 0.7), oklch(0.98 0.005 280 / 0.85));
  border-color: oklch(0.2 0.02 280 / 0.12);
}
[data-theme="light"] .walk-screen-head {
  background: oklch(0.96 0.008 280 / 0.8);
  border-color: oklch(0.2 0.02 280 / 0.12);
}
[data-theme="light"] .walk-screen-foot {
  background: oklch(0.96 0.008 280 / 0.5);
  border-color: oklch(0.2 0.02 280 / 0.1);
}
[data-theme="light"] .walk-kpi {
  background: oklch(0.98 0.005 280 / 0.95);
}
[data-theme="light"] .walk-kpi strong { color: oklch(0.15 0.02 280); }
[data-theme="light"] .walk-bullets li { color: oklch(0.42 0.02 280); }
[data-theme="light"] .walk-tab-meta p { color: oklch(0.42 0.02 280); }

/* Mobile walkthrough */
@media (max-width: 860px) {
  .walk-screen-frame { height: 240px; padding: 14px; }
  .walk-screen-foot { padding: 16px; gap: 16px; }
  .walk-step { padding: 12px 14px; grid-template-columns: 32px 1fr auto; gap: 12px; }
  .walk-step-num { width: 32px; height: 32px; }
  .walk-step-body strong { font-size: 0.95rem; }
  .walk-step-desc { font-size: 0.78rem; }
}

/* ===========================================================
   LIGHT MODE OVERRIDES — make every dark-only token swap cleanly
   =========================================================== */
[data-theme="light"] .mega-inner {
  background: oklch(0.99 0.005 280 / 0.96);
  border-color: oklch(0.2 0.02 280 / 0.14);
  box-shadow:
    0 50px 120px -40px rgba(0,0,0,0.18),
    0 20px 40px -20px rgba(0,0,0,0.1),
    inset 0 1px 0 rgba(255,255,255,0.9);
}
[data-theme="light"] .mega-card {
  background: linear-gradient(180deg,
    oklch(0.96 0.012 var(--card-h, var(--acc-h)) / 0.85),
    oklch(0.99 0.005 280 / 0.95));
  border-color: oklch(0.2 0.02 280 / 0.1);
}
[data-theme="light"] .mega-card:hover {
  border-color: oklch(0.55 0.22 var(--card-h, var(--acc-h)) / 0.5);
  box-shadow:
    0 22px 50px -22px oklch(0.5 0.25 var(--card-h, var(--acc-h)) / 0.35),
    inset 0 1px 0 rgba(255,255,255,0.6);
}
[data-theme="light"] .mega-card-name,
[data-theme="light"] .mega-card-cta,
[data-theme="light"] .mega-title { color: oklch(0.15 0.02 280); }
[data-theme="light"] .mega-card-feats li { color: oklch(0.42 0.02 280); }
[data-theme="light"] .mega-card-index,
[data-theme="light"] .mega-status-text,
[data-theme="light"] .mega-foot-meta { color: oklch(0.5 0.02 280); }
[data-theme="light"] .mega-head-right { background: oklch(0.97 0.007 280 / 0.85); border-color: oklch(0.2 0.02 280 / 0.12); }
[data-theme="light"] .mega-card-body { border-color: oklch(0.2 0.02 280 / 0.08); }
[data-theme="light"] .mega-card-cta { border-color: oklch(0.2 0.02 280 / 0.08); }

/* Orbital section in light mode */
[data-theme="light"] .orbital-bus {
  background: oklch(0.96 0.008 280 / 0.85);
  color: oklch(0.42 0.02 280);
}
[data-theme="light"] .orbital-core-label strong { color: oklch(0.15 0.02 280); }
[data-theme="light"] .orbital-satellite {
  background: oklch(0.97 0.008 var(--hue, var(--acc-h)) / 0.92);
  border-color: oklch(0.2 0.02 var(--hue, var(--acc-h)) / 0.18);
  color: oklch(0.18 0.02 280);
}
[data-theme="light"] .orbital-arm.is-active .orbital-satellite {
  background: oklch(0.92 0.04 var(--hue) / 0.95);
  border-color: oklch(0.5 0.22 var(--hue) / 0.6);
  box-shadow: 0 0 24px oklch(0.6 0.3 var(--hue) / 0.4),
              0 0 0 1px oklch(0.5 0.22 var(--hue) / 0.5);
}
[data-theme="light"] .orbital-bg circle,
[data-theme="light"] .orbital-bg ellipse {
  stroke-opacity: 0.85;
}
[data-theme="light"] .orbital-panel {
  background: linear-gradient(180deg, oklch(0.96 0.012 var(--card-h, var(--acc-h)) / 0.75), oklch(0.98 0.005 280 / 0.9));
  border-color: oklch(0.2 0.02 280 / 0.12);
  color: oklch(0.18 0.02 280);
}
[data-theme="light"] .orbital-panel-name { color: oklch(0.15 0.02 280); }
[data-theme="light"] .orbital-panel-desc { color: oklch(0.4 0.02 280); }
[data-theme="light"] .orbital-panel-stats { border-color: oklch(0.2 0.02 280 / 0.14); }
[data-theme="light"] .orbital-panel-stats li {
  background: oklch(0.98 0.005 280 / 0.85);
}
[data-theme="light"] .orbital-panel-stats strong { color: oklch(0.15 0.02 280); }
[data-theme="light"] .orbital-status { color: oklch(0.45 0.2 145); }

/* Demo canvas / tabs in light mode */
[data-theme="light"] .demo-tabs {
  background: oklch(0.94 0.01 280 / 0.85);
  border-color: oklch(0.2 0.02 280 / 0.12);
}
[data-theme="light"] .demo-tab { color: oklch(0.5 0.02 280); }
[data-theme="light"] .demo-tab:hover { color: oklch(0.18 0.02 280); }
[data-theme="light"] .demo-canvas {
  background: oklch(0.99 0.003 280 / 0.92);
  border-color: oklch(0.2 0.02 280 / 0.1);
}
[data-theme="light"] .demo-canvas-bar {
  background: oklch(0.96 0.008 280 / 0.8);
  border-color: oklch(0.2 0.02 280 / 0.12);
}
[data-theme="light"] .demo-dots span { background: oklch(0.78 0.01 280); }
[data-theme="light"] .demo-stats strong { color: oklch(0.15 0.02 280); }

/* Demo mock components — light variants */
[data-theme="light"] .dm-row {
  background: oklch(0.97 0.007 280 / 0.9);
  border-color: oklch(0.2 0.02 280 / 0.1);
}
[data-theme="light"] .dm-row-name { color: oklch(0.18 0.02 280); }
[data-theme="light"] .dm-row-num,
[data-theme="light"] .dm-bar-name { color: oklch(0.45 0.02 280); }
[data-theme="light"] .dm-bar-track { background: oklch(0.9 0.008 280); }
[data-theme="light"] .dm-bar-pct { color: oklch(0.18 0.02 280); }
[data-theme="light"] .dm-stage {
  background: oklch(0.96 0.02 var(--hue) / 0.7);
  border-color: oklch(0.2 0.02 280 / 0.12);
}
[data-theme="light"] .dm-stage-count { color: oklch(0.15 0.02 280); }
[data-theme="light"] .dm-stage-name { color: oklch(0.5 0.02 280); }
[data-theme="light"] .dm-chat-meta { color: oklch(0.5 0.02 280); border-color: oklch(0.2 0.02 280 / 0.12); }
[data-theme="light"] .dm-msg-ai .dm-bubble {
  background: oklch(0.94 0.02 var(--hue) / 0.85);
  border-color: oklch(0.5 0.2 var(--hue) / 0.3);
  color: oklch(0.18 0.02 280);
}
[data-theme="light"] .dm-tile {
  background: oklch(0.96 0.007 280 / 0.7);
  border-color: oklch(0.2 0.02 280 / 0.1);
}

/* Orb in light mode — much dimmer drop-shadow to avoid darkening the page */
[data-theme="light"] .orb-webgl-canvas {
  filter: drop-shadow(0 0 40px oklch(0.6 0.22 var(--acc-h) / 0.22));
  opacity: 0.92;
}

/* Hero atmosphere in light mode — let the orb breathe on light bg */
[data-theme="light"] .hero-glow { opacity: 0.18; mix-blend-mode: multiply; }
[data-theme="light"] .hero-glow.g1 { background: radial-gradient(circle, oklch(0.78 0.18 var(--acc-h)) 0%, transparent 65%); }
[data-theme="light"] .hero-glow.g2 { background: radial-gradient(circle, oklch(0.7 0.2 var(--acc-h)) 0%, transparent 65%); }
[data-theme="light"] .hero-glow.g3 { background: radial-gradient(ellipse, oklch(0.65 0.18 var(--acc-h)) 0%, transparent 70%); opacity: 0.12; }
[data-theme="light"] .beam { opacity: 0.18 !important; mix-blend-mode: multiply; }
[data-theme="light"] .stars { display: none; }
[data-theme="light"] .hero-grid {
  background-image:
    linear-gradient(oklch(0.2 0.04 280 / 0.04) 1px, transparent 1px),
    linear-gradient(90deg, oklch(0.2 0.04 280 / 0.04) 1px, transparent 1px);
}

/* Header in light mode */
[data-theme="light"] .header-inner {
  background: oklch(0.98 0.005 280 / 0.85);
  border-color: oklch(0.2 0.02 280 / 0.12);
  box-shadow: 0 14px 36px -20px rgba(0,0,0,0.25);
}
[data-theme="light"] .brand-mark { box-shadow: 0 0 14px oklch(0.5 0.25 var(--acc-h) / 0.35), inset 0 1px 0 rgba(255,255,255,0.4); }
[data-theme="light"] .nav a { color: oklch(0.4 0.02 280); }
[data-theme="light"] .nav a:hover { color: oklch(0.15 0.02 280); }
[data-theme="light"] .nav a.is-active { color: oklch(0.15 0.02 280); background: oklch(0.92 0.012 280); }
[data-theme="light"] .icon-btn {
  background: oklch(0.96 0.008 280);
  border-color: oklch(0.2 0.02 280 / 0.14);
  color: oklch(0.4 0.02 280);
}
[data-theme="light"] .icon-btn:hover { color: oklch(0.15 0.02 280); background: oklch(0.92 0.012 280); }
[data-theme="light"] .lang-switch {
  background: oklch(0.96 0.008 280);
  border-color: oklch(0.2 0.02 280 / 0.14);
}
[data-theme="light"] .lang-switch button { color: oklch(0.5 0.02 280); }

/* Tags / chips in light mode */
[data-theme="light"] .tag {
  background: oklch(0.97 0.007 280);
  border-color: oklch(0.2 0.02 280 / 0.12);
  color: oklch(0.4 0.02 280);
}
[data-theme="light"] .eyebrow { color: oklch(0.5 0.02 280); }

/* Nexus tabs (apps section) light */
[data-theme="light"] .nexus-tabs {
  background: oklch(0.96 0.008 280 / 0.85);
  border-color: oklch(0.2 0.02 280 / 0.12);
}
[data-theme="light"] .nexus-tab { color: oklch(0.5 0.02 280); }
[data-theme="light"] .nexus-tab:hover { color: oklch(0.15 0.02 280); }

/* Nexus main and feature cards in light mode */
[data-theme="light"] .nexus-main,
[data-theme="light"] .nexus-feature,
[data-theme="light"] .app-card,
[data-theme="light"] .price-card,
[data-theme="light"] .feature,
[data-theme="light"] .testi,
[data-theme="light"] .faq-item,
[data-theme="light"] .snapshot,
[data-theme="light"] .mock-bar {
  background: oklch(0.97 0.007 280 / 0.85);
  border-color: oklch(0.2 0.02 280 / 0.12);
}
[data-theme="light"] .price-card.featured {
  background: linear-gradient(180deg, oklch(0.94 0.04 var(--acc-h) / 0.85), oklch(0.97 0.012 var(--acc-h) / 0.7));
  border-color: oklch(0.5 0.22 var(--acc-h));
}
[data-theme="light"] .nexus-main .nexus-title,
[data-theme="light"] .app-card .app-name,
[data-theme="light"] .price-card .price-name,
[data-theme="light"] .price-card .price-amount .num,
[data-theme="light"] .feature h4 { color: oklch(0.15 0.02 280); }
[data-theme="light"] .nexus-feature .nf-eyebrow,
[data-theme="light"] .app-card .app-tagline,
[data-theme="light"] .app-card .app-status,
[data-theme="light"] .price-card .price-tag,
[data-theme="light"] .footer-col h6 { color: oklch(0.5 0.02 280); }

/* Footer in light mode */
[data-theme="light"] .footer { border-color: oklch(0.2 0.02 280 / 0.12); }
[data-theme="light"] .footer-cols { border-color: oklch(0.2 0.02 280 / 0.12); }
[data-theme="light"] .footer-col a { color: oklch(0.4 0.02 280); }
[data-theme="light"] .footer-col a:hover { color: oklch(0.15 0.02 280); }
[data-theme="light"] .footer-bottom { color: oklch(0.5 0.02 280); }
[data-theme="light"] .footer-bottom .socials a { background: oklch(0.96 0.008 280); border-color: oklch(0.2 0.02 280 / 0.12); }

/* Form fields in light mode */
[data-theme="light"] .field input,
[data-theme="light"] .field textarea,
[data-theme="light"] .field select,
[data-theme="light"] .newsletter {
  background: oklch(0.97 0.007 280);
  border-color: oklch(0.2 0.02 280 / 0.14);
  color: oklch(0.15 0.02 280);
}
[data-theme="light"] .field label { color: oklch(0.5 0.02 280); }

/* Body atmosphere in light mode — softer */
[data-theme="light"] body::before {
  opacity: 0.15;
  background-image:
    radial-gradient(ellipse at 50% 0%, oklch(0.85 0.05 280 / 0.55), transparent 55%),
    radial-gradient(ellipse at 50% 100%, oklch(0.82 0.04 285 / 0.45), transparent 55%);
  background-size: auto, auto;
}

/* Hero stats in light mode */
[data-theme="light"] .hero-stat {
  background: oklch(0.99 0.003 280 / 0.7);
}
[data-theme="light"] .hero-stats { backdrop-filter: blur(20px); }

/* Mega card hover bg in light mode */
[data-theme="light"] .mega-card-icon {
  box-shadow: 0 0 14px oklch(0.5 0.22 var(--card-h, var(--acc-h)) / 0.35),
              inset 0 1px 0 rgba(255,255,255,0.4);
}

/* ===========================================================
   MOBILE — hamburger, mega-menu, orbital stack
   =========================================================== */
.hamburger {
  display: none;
  width: 38px; height: 38px;
  border-radius: 50%;
  border: 1px solid var(--hairline);
  background: var(--surf-1);
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 4px;
  cursor: pointer;
}
.hamburger span {
  display: block;
  width: 16px; height: 1.5px;
  background: var(--text-1);
  transition: transform var(--dur-mid) var(--ease-out), opacity var(--dur-mid) var(--ease-out);
}
.hamburger.is-open span:nth-child(1) { transform: translateY(3px) rotate(45deg); }
.hamburger.is-open span:nth-child(2) { opacity: 0; }
.hamburger.is-open span:nth-child(3) { transform: translateY(-3px) rotate(-45deg); }

/* MOBILE BREAKPOINT */
@media (max-width: 860px) {
  .hamburger { display: inline-flex; }
  .nav.desktop-only { display: none; }
  .lang-switch.desktop-only { display: none; }

  .header { top: 8px !important; width: calc(100% - 16px); }
  .header-inner { gap: 12px; padding: 8px 10px 8px 14px; }
  .brand-name small { display: none; }

  /* Mega menu becomes a full overlay on mobile */
  .mega-menu {
    position: fixed;
    inset: auto 0 0 0;
    top: 70px;
    left: 0;
    transform: none;
    width: 100%;
    height: calc(100vh - 80px);
    overflow-y: auto;
  }
  .mega-menu.is-open { transform: none; }
  .mega-inner { padding: 16px; border-radius: 18px; }
  .mega-grid { grid-template-columns: 1fr; gap: 8px; }
  .mega-card { padding: 14px; }

  /* Orbital nexus — stack on mobile */
  .orbital { grid-template-columns: 1fr !important; gap: 20px; }
  .orbital-stage { max-width: 420px; }
  .arm-1, .arm-2, .arm-3, .arm-4 { --orbit-r: clamp(90px, 40cqi, 140px); }
  .orbital-core-inner { width: 76px; height: 76px; border-radius: 18px; }
  .orbital-core-mark svg { width: 28px; height: 28px; }

  /* Demo canvas — shorter on mobile */
  .demo-canvas { height: 170px; }
  .demo-tabs { padding: 3px; }
  .demo-tab { padding: 8px 10px; font-size: 0.8rem; gap: 6px; }
  .demo-tab .demo-tab-num { display: none; }

  /* Hero stats — 2x2 on mobile */
  .hero-stats { grid-template-columns: 1fr 1fr !important; }
  .hero-content { padding-bottom: 40px; }

  /* Pricing — already stacks at 980px */
  .container { padding-inline: 16px; }
  section { padding-block: clamp(60px, 14vw, 100px); }
}

/* Touch device — disable custom cursor and hover-only patterns */
@media (pointer: coarse) {
  .btn, .icon-btn, .nexus-tab, .orbital-satellite, .demo-tab, .mega-card,
  .price-card, .app-card, .field input, .field textarea, .field select {
    cursor: pointer;
  }
  /* Mega menu — show as click toggle, not hover */
  .nav-item-mega .mega-menu { transition: opacity 200ms; }
}

/* ===========================================================
   TWEAKS DEV PANEL — hide in production-looking pages
   =========================================================== */
.twk-panel { display: none !important; }
.twk-toggle { display: none !important; }
.tech-diagram svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.tech-node {
  position: absolute;
  padding: 14px 18px;
  border-radius: var(--r-3);
  background: var(--surf-3);
  border: 1px solid var(--hairline-strong);
  backdrop-filter: blur(20px);
  display: flex; align-items: center; gap: 10px;
  white-space: nowrap;
  z-index: 2;
}
.tech-node .nd-icon {
  width: 28px; height: 28px;
  display: grid; place-items: center;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--acc-bright), var(--acc-deep));
  color: white;
}
.tech-node .nd-icon svg { position: relative; width: 16px; height: 16px; }
.tech-node .nd-meta {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
}
.tech-node .nd-name {
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 500;
  letter-spacing: -0.01em;
}
.tech-node.core {
  background: linear-gradient(135deg, var(--acc-deep), oklch(0.2 0.06 var(--acc-h)));
  border-color: var(--acc);
  box-shadow: 0 0 60px var(--acc-glow), inset 0 1px 0 rgba(255,255,255,0.2);
}
.tech-node.core .nd-name { color: white; }
.tech-node.core .nd-meta { color: oklch(0.85 0.1 var(--acc-h)); }

/* ====== SNAPSHOTS ====== */
.snapshots {
  position: relative;
  overflow: hidden;
}
.snapshots-track {
  display: flex;
  gap: 24px;
  padding-block: 20px;
  scroll-snap-type: x mandatory;
  overflow-x: auto;
  scroll-padding-left: var(--container-pad);
  cursor: grab;
}
.snapshots-track::-webkit-scrollbar { display: none; }
.snapshot {
  flex: 0 0 clamp(280px, 32vw, 460px);
  aspect-ratio: 4 / 5;
  scroll-snap-align: start;
  border-radius: var(--r-4);
  background: var(--surf-1);
  border: 1px solid var(--hairline);
  overflow: hidden;
  position: relative;
  display: flex; flex-direction: column;
  transition: transform var(--dur-mid) var(--ease-out);
}
.snapshot:hover { border-color: oklch(0.85 0.04 280 / 0.3); }
.snapshot .snap-frame {
  flex: 1;
  position: relative;
  background: linear-gradient(135deg, oklch(0.12 0.04 var(--card-h, var(--acc-h))), oklch(0.08 0.02 280));
  overflow: hidden;
}
.snapshot .snap-meta {
  padding: 18px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--hairline);
}
.snapshot .snap-title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 500;
}
.snapshot .snap-sub {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-top: 4px;
}
.snapshot .snap-play {
  width: 38px; height: 38px;
  border-radius: 50%;
  display: grid; place-items: center;
  background: var(--surf-3);
  border: 1px solid var(--hairline-strong);
  color: var(--text-1);
  cursor: pointer;
  transition: transform .2s var(--ease-out), border-color .2s, color .2s;
}
.snapshot .snap-play:hover { transform: scale(1.08); border-color: oklch(0.85 0.1 var(--card-h, 280) / 0.5); color: #fff; }

/* Mockup UI */
.mock {
  position: absolute; inset: 0;
  padding: 14px;
  display: flex; flex-direction: column;
}
.mock-bar {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--surf-2);
  border: 1px solid var(--hairline);
  font-family: var(--font-mono);
  font-size: 0.65rem;
  color: var(--text-3);
}
.mock-bar .dots { display: inline-flex; gap: 4px; }
.mock-bar .dots span { width: 8px; height: 8px; border-radius: 50%; background: oklch(0.4 0.02 280); }
.mock-body {
  flex: 1;
  margin-top: 10px;
  border-radius: var(--r-3);
  background: linear-gradient(180deg, var(--surf-2), var(--surf-1));
  border: 1px solid var(--hairline);
  padding: 14px;
  position: relative;
  overflow: hidden;
}
.mock-line { height: 6px; border-radius: 3px; background: var(--surf-3); margin-bottom: 8px; }
.mock-line.w70 { width: 70%; } .mock-line.w50 { width: 50%; } .mock-line.w90 { width: 90%; } .mock-line.w35 { width: 35%; }

/* ====== PRICING ====== */
/* (eski .pricing-toggle stilleri kaldırıldı — PillToggle/.px-toggle kullanılıyor) */
.pricing-toggle .save-badge {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  padding: 2px 6px;
  border-radius: 999px;
  background: oklch(0.6 0.25 145);
  color: white;
  margin-left: 6px;
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  align-items: stretch;
}
@media (max-width: 980px) { .pricing-grid { grid-template-columns: 1fr; } }

.price-card {
  position: relative;
  padding: 32px;
  border-radius: var(--r-4);
  background: var(--surf-1);
  border: 1px solid var(--hairline);
  backdrop-filter: blur(20px);
  display: flex; flex-direction: column;
  isolation: isolate;
  overflow: hidden;
  cursor: pointer;
  transition: background 420ms var(--ease-out),
              border-color 420ms var(--ease-out),
              box-shadow 420ms var(--ease-out);
}
.price-card:hover { border-color: oklch(0.85 0.18 var(--acc-h) / 0.32); }
.price-card:focus-visible { outline: 2px solid var(--acc-bright); outline-offset: 4px; }

/* Pricing page hero */
.pricing-page-hero {
  position: relative;
  padding: 160px 0 60px;
  overflow: hidden;
  text-align: center;
  isolation: isolate;
}
.pricing-page-hero .container { display: grid; gap: 16px; justify-items: center; }
.pricing-page-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2.8rem, 2rem + 4vw, 5.2rem);
  letter-spacing: -0.035em;
  line-height: 1;
  margin: 8px 0 4px;
  text-align: center;
}
.price-card.featured {
  background: linear-gradient(180deg, oklch(0.22 0.08 var(--acc-h) / 0.6), oklch(0.12 0.04 var(--acc-h) / 0.4));
  border-color: var(--acc);
  box-shadow: 0 0 60px oklch(0.5 0.25 var(--acc-h) / 0.3);
}
.price-card.featured::after {
  content: "";
  position: absolute;
  bottom: -80px; left: 50%;
  transform: translateX(-50%);
  width: 300px; height: 200px;
  background: radial-gradient(ellipse, var(--acc-glow), transparent 70%);
  filter: blur(40px);
  z-index: -1;
}
.price-card .price-tag {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 8px;
  display: flex; align-items: center; justify-content: space-between;
}
.price-card .featured-badge {
  padding: 3px 10px;
  border-radius: 999px;
  background: var(--acc);
  color: white;
  font-size: 0.6rem;
  letter-spacing: 0.14em;
}
.price-card .price-name {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 1.3rem + 0.6vw, 2rem);
  font-weight: 500;
  letter-spacing: -0.025em;
}
.price-card .price-amount {
  margin: 18px 0 6px;
  display: flex; align-items: baseline; gap: 6px;
}
.price-card .price-amount .num {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 1.8rem + 1.5vw, 3.4rem);
  font-weight: 500;
  letter-spacing: -0.04em;
  line-height: 1;
}
.price-card .price-amount .per { color: var(--text-3); font-family: var(--font-mono); font-size: 0.85rem; }

/* ====== PRICING CONFIGURATOR ====== */
.configurator {
  position: relative;
  margin-top: 80px;
  padding: 40px;
  border-radius: var(--r-4);
  background: linear-gradient(180deg,
    oklch(0.14 0.04 var(--acc-h) / 0.45),
    oklch(0.09 0.022 282 / 0.85));
  border: 1px solid var(--hairline-strong);
  backdrop-filter: blur(28px) saturate(160%);
  -webkit-backdrop-filter: blur(28px) saturate(160%);
  isolation: isolate;
  overflow: hidden;
}
.configurator::before {
  content: "";
  position: absolute;
  top: -100px; right: -60px;
  width: 360px; height: 360px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--acc-glow), transparent 70%);
  filter: blur(60px);
  z-index: -1;
}

.configurator-head { margin-bottom: 36px; }
.configurator-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 5px 12px;
  border-radius: 999px;
  background: oklch(0.18 0.06 var(--acc-h) / 0.6);
  border: 1px solid oklch(0.55 0.22 var(--acc-h) / 0.4);
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  color: oklch(0.92 0.16 var(--acc-h));
  margin-bottom: 14px;
}
.configurator-dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--acc-bright);
  box-shadow: 0 0 8px var(--acc-glow);
  animation: marqueeDotPulse 2s ease-in-out infinite;
}
.configurator-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.8rem, 1.2rem + 2vw, 2.8rem);
  letter-spacing: -0.03em;
  line-height: 1.05;
  color: var(--text-1);
  margin: 0 0 10px;
}
.configurator-sub {
  color: var(--text-2);
  font-size: 1rem;
  max-width: 60ch;
  margin: 0;
}

.configurator-body {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 32px;
  align-items: start;
}
@media (max-width: 1000px) { .configurator-body { grid-template-columns: 1fr; } }

.configurator-options {
  display: grid;
  gap: 28px;
}

.configurator-group { display: grid; gap: 12px; }
.configurator-group-label {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-3);
}

/* Base plan selector */
.configurator-base-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
@media (max-width: 720px) { .configurator-base-row { grid-template-columns: 1fr; } }
.configurator-base {
  position: relative;
  display: grid;
  gap: 4px;
  padding: 16px 18px;
  border-radius: var(--r-3);
  border: 1px solid var(--hairline);
  background: oklch(0.13 0.025 282 / 0.5);
  color: var(--text-1);
  text-align: left;
  cursor: pointer;
  transition: border-color 240ms, background 240ms, box-shadow 240ms;
}
.configurator-base:hover {
  background: oklch(0.17 0.04 var(--acc-h) / 0.55);
  border-color: oklch(0.6 0.18 var(--acc-h) / 0.4);
}
.configurator-base.is-active {
  background: oklch(0.18 0.06 var(--acc-h) / 0.75);
  border-color: oklch(0.7 0.22 var(--acc-h) / 0.6);
  box-shadow: 0 0 24px oklch(0.6 0.28 var(--acc-h) / 0.25);
}
.configurator-base.is-featured::after {
  content: "";
  position: absolute;
  top: 0; left: 14%; right: 14%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--acc-bright), transparent);
}
.configurator-base strong {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.15rem;
  letter-spacing: -0.02em;
}
.configurator-base .mono {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: oklch(0.85 0.14 var(--acc-h));
}
.configurator-base-blurb { font-size: 0.78rem; color: var(--text-3); }
.configurator-base-badge {
  position: absolute;
  top: 10px; right: 12px;
  font-size: 0.7rem;
  color: oklch(0.92 0.2 var(--acc-h));
}

/* Addon row */
.configurator-addons { display: grid; gap: 8px; }
.configurator-addon {
  display: grid;
  grid-template-columns: 28px 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 12px 16px;
  border-radius: var(--r-3);
  border: 1px solid var(--hairline);
  background: oklch(0.12 0.022 282 / 0.5);
  color: var(--text-1);
  text-align: left;
  cursor: pointer;
  transition: border-color 200ms, background 200ms;
}
.configurator-addon:hover {
  background: oklch(0.16 0.035 var(--card-h, var(--acc-h)) / 0.55);
  border-color: oklch(0.85 0.04 280 / 0.25);
}
.configurator-addon.is-on {
  background: oklch(0.17 0.05 var(--card-h, var(--acc-h)) / 0.6);
  border-color: oklch(0.6 0.2 var(--card-h, var(--acc-h)) / 0.55);
}
.configurator-addon-check {
  width: 22px; height: 22px;
  display: grid; place-items: center;
  border-radius: 6px;
  border: 1.5px solid var(--hairline-strong);
  background: transparent;
  color: white;
  transition: background 200ms, border-color 200ms;
}
.configurator-addon.is-on .configurator-addon-check {
  background: linear-gradient(135deg,
    oklch(0.7 0.27 var(--card-h, var(--acc-h))),
    oklch(0.42 0.22 var(--card-h, var(--acc-h))));
  border-color: oklch(0.7 0.27 var(--card-h, var(--acc-h)));
}
.configurator-addon-check svg { width: 14px; height: 14px; }
.configurator-addon-body { display: grid; gap: 2px; }
.configurator-addon-body strong {
  font-weight: 500;
  font-size: 0.9rem;
  letter-spacing: -0.005em;
}
.configurator-addon-desc {
  font-size: 0.78rem;
  color: var(--text-3);
}
.configurator-addon-price {
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: oklch(0.85 0.14 var(--card-h, var(--acc-h)));
  font-weight: 600;
}

/* Summary panel */
.configurator-summary {
  position: sticky;
  top: 120px;
}
@media (max-width: 1000px) { .configurator-summary { position: static; } }

.configurator-summary-inner {
  position: relative;
  padding: 28px;
  border-radius: var(--r-3);
  background: linear-gradient(180deg,
    oklch(0.16 0.05 var(--acc-h) / 0.7),
    oklch(0.09 0.022 282 / 0.92));
  border: 1px solid oklch(0.6 0.22 var(--acc-h) / 0.4);
  box-shadow: 0 30px 70px -30px rgba(0,0,0,0.7),
              inset 0 1px 0 rgba(255,255,255,0.06);
  display: grid;
  gap: 16px;
  isolation: isolate;
  overflow: hidden;
}
.configurator-summary-inner::before {
  content: "";
  position: absolute;
  bottom: -80px; right: -40px;
  width: 240px; height: 240px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--acc-glow), transparent 70%);
  filter: blur(50px);
  z-index: -1;
}
.configurator-summary-eyebrow {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-3);
}
.configurator-summary-total {
  display: flex;
  align-items: baseline;
  gap: 2px;
}
.configurator-summary-currency {
  font-family: var(--font-display);
  font-size: 1.5rem;
  color: oklch(0.92 0.18 var(--acc-h));
  margin-right: 2px;
}
.configurator-summary-amount {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2.6rem, 2rem + 2vw, 4rem);
  letter-spacing: -0.04em;
  line-height: 1;
  background: linear-gradient(180deg, var(--text-1), oklch(0.85 0.18 var(--acc-h)));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.configurator-summary-per {
  font-family: var(--font-mono);
  font-size: 0.85rem;
  color: var(--text-3);
  margin-left: 4px;
}
.configurator-summary-note {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.8rem;
  color: oklch(0.85 0.12 var(--acc-h));
}
.configurator-summary-line {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--hairline-strong), transparent);
}
.configurator-summary-list {
  list-style: none;
  padding: 0; margin: 0;
  display: grid; gap: 8px;
  max-height: 260px;
  overflow-y: auto;
}
.configurator-summary-list li {
  display: flex; justify-content: space-between;
  font-size: 0.85rem;
  color: var(--text-2);
}
.configurator-summary-list li .mono {
  color: var(--text-1);
  font-family: var(--font-mono);
  font-size: 0.8rem;
}
.configurator-summary-meta {
  display: flex; justify-content: space-between; align-items: center;
}
.configurator-summary-meta .mono {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.18em;
  color: var(--text-3);
}
.configurator-summary-cta { width: 100%; }

/* Light mode */
[data-theme="light"] .configurator {
  background: linear-gradient(180deg,
    oklch(0.95 0.018 var(--acc-h) / 0.7),
    oklch(0.99 0.005 280 / 0.92));
  border-color: oklch(0.2 0.02 280 / 0.14);
}
[data-theme="light"] .configurator-title { color: oklch(0.15 0.02 280); }
[data-theme="light"] .configurator-sub { color: oklch(0.42 0.02 280); }
[data-theme="light"] .configurator-base,
[data-theme="light"] .configurator-addon {
  background: oklch(0.97 0.008 280 / 0.85);
  border-color: oklch(0.2 0.02 280 / 0.12);
  color: oklch(0.15 0.02 280);
}
[data-theme="light"] .configurator-base.is-active,
[data-theme="light"] .configurator-addon.is-on {
  background: oklch(0.92 0.04 var(--card-h, var(--acc-h)) / 0.85);
  border-color: oklch(0.5 0.22 var(--card-h, var(--acc-h)) / 0.55);
}
[data-theme="light"] .configurator-base strong { color: oklch(0.15 0.02 280); }
[data-theme="light"] .configurator-summary-inner {
  background: linear-gradient(180deg,
    oklch(0.96 0.022 var(--acc-h) / 0.95),
    oklch(0.99 0.005 280 / 0.98));
  border-color: oklch(0.5 0.22 var(--acc-h) / 0.4);
}
[data-theme="light"] .configurator-summary-amount {
  background: linear-gradient(180deg, oklch(0.15 0.02 280), oklch(0.4 0.22 var(--acc-h)));
  -webkit-background-clip: text;
  background-clip: text;
}
.price-card .price-desc { color: var(--text-2); font-size: 0.92rem; margin-bottom: 24px; }
.price-card ul {
  list-style: none;
  padding: 0; margin: 0 0 24px;
  display: flex; flex-direction: column; gap: 12px;
  flex: 1;
}
.price-card ul li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 0.9rem; color: var(--text-2);
}
.price-card ul li svg {
  flex: 0 0 18px;
  width: 18px; height: 18px;
  margin-top: 1px;
  color: var(--acc-bright);
}

/* ====== PRICING CTA — glass pill + right-aligned orb arrow (design language) ====== */
.btn-plan {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  padding: 10px 10px 10px 22px;
  border-radius: var(--r-pill);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.9375rem;
  letter-spacing: -0.005em;
  color: var(--text-1);
  text-decoration: none;
  cursor: pointer;
  isolation: isolate;
  overflow: hidden;
  border: 1px solid transparent;
  /* glass body + luminous rim (token-driven; variants tweak the tokens) */
  background:
    linear-gradient(180deg, var(--btn-body-1), var(--btn-body-2)) padding-box,
    linear-gradient(135deg, var(--btn-rim-hi), var(--btn-rim-lo) 55%, var(--btn-rim-hi) 100%) border-box;
  backdrop-filter: blur(16px) saturate(150%);
  -webkit-backdrop-filter: blur(16px) saturate(150%);
  box-shadow: inset 0 1px 0 oklch(1 0 0 / 0.22), 0 12px 28px -16px oklch(0 0 0 / 0.7);
  /* light only — no transform (no movement on hover) */
  transition: filter var(--dur-mid) var(--ease-out), box-shadow var(--dur-mid) var(--ease-out);
}
.btn-plan:hover { filter: brightness(1.07); }
.btn-plan-label {
  flex: 1;
  text-align: left;
  letter-spacing: -0.005em;
  line-height: 1;
}
/* orb arrow — mini sphere, accent rim, glow blooms on hover */
.btn-plan-arrow {
  position: relative;
  width: 38px; height: 38px;
  display: grid; place-items: center;
  border-radius: 50%;
  background:
    radial-gradient(120% 120% at 50% 24%,
      oklch(0.50 0.06 var(--btn-h) / 0.60),
      oklch(0.16 0.05 var(--btn-h) / 0.80) 72%);
  color: #fff;
  flex-shrink: 0;
  box-shadow:
    inset 0 1px 0 oklch(1 0 0 / 0.30),
    inset 0 0 0 1px oklch(0.80 0.12 var(--btn-h) / 0.40),
    0 4px 12px -6px oklch(0 0 0 / 0.6);
  transition: box-shadow var(--dur-mid) var(--ease-out), filter var(--dur-mid) var(--ease-out);
}
.btn-plan-arrow svg { width: 16px; height: 16px; }
.btn-plan:hover .btn-plan-arrow {
  filter: brightness(1.12);
  box-shadow:
    inset 0 1px 0 oklch(1 0 0 / 0.40),
    inset 0 0 0 1px oklch(0.88 0.14 var(--btn-h) / 0.60),
    0 0 16px -2px var(--btn-glow);
}

/* Ghost variant — Starter / Enterprise (lighter glass) */
.btn-plan--ghost {
  --btn-body-1: oklch(0.30 0.03 var(--btn-h) / 0.30);
  --btn-body-2: oklch(0.18 0.03 var(--btn-h) / 0.45);
}

/* Primary variant — featured plan: dark-glass + metallic label */
.btn-plan--primary {
  --btn-body-1: oklch(0.32 0.07 var(--btn-h) / 0.70);
  --btn-body-2: oklch(0.15 0.06 var(--btn-h) / 0.85);
  --btn-rim-hi: oklch(0.88 0.16 var(--btn-h));
}
.btn-plan--primary .btn-plan-label {
  color: oklch(0.98 0.006 var(--btn-h));   /* near-white label */
  text-shadow: 0 1px 1.5px oklch(0 0 0 / 0.55);
}
.btn-plan--primary .btn-plan-arrow {
  background:
    radial-gradient(120% 120% at 50% 24%, oklch(0.96 0.02 var(--btn-h) / 0.95), oklch(0.62 0.12 var(--btn-h) / 0.85) 75%);
  color: oklch(0.20 0.05 var(--btn-h));
}
.btn-plan--primary:hover { filter: brightness(1.08); }

/* Light mode */
[data-theme="light"] .btn-plan--ghost {
  background: oklch(0.97 0.007 280 / 0.85);
  border-color: oklch(0.2 0.02 280 / 0.14);
  color: oklch(0.15 0.02 280);
}
[data-theme="light"] .btn-plan--ghost:hover {
  background: oklch(0.94 0.012 280 / 0.95);
  border-color: oklch(0.2 0.02 280 / 0.3);
}
[data-theme="light"] .btn-plan--ghost .btn-plan-arrow {
  background: oklch(0.92 0.012 280);
  border-color: oklch(0.2 0.02 280 / 0.14);
  color: oklch(0.15 0.02 280);
}
[data-theme="light"] .btn-plan--ghost:hover .btn-plan-arrow {
  background: oklch(0.18 0.04 var(--acc-h));
  border-color: oklch(0.18 0.04 var(--acc-h));
  color: white;
}

/* ====== FAQ ====== */
.faq-list { display: flex; flex-direction: column; gap: 8px; }
.faq-item {
  border: 1px solid var(--hairline);
  border-radius: var(--r-3);
  background: var(--surf-1);
  backdrop-filter: blur(20px);
  overflow: hidden;
}
.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 22px 26px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 20px;
  font-family: var(--font-display);
  font-size: clamp(1rem, 0.95rem + 0.3vw, 1.2rem);
  font-weight: 500;
  color: var(--text-1);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary .plus {
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1px solid var(--hairline-strong);
  display: grid; place-items: center;
  transition: transform var(--dur-mid) var(--ease-out), background var(--dur-mid) var(--ease-out);
  color: var(--text-2);
  flex-shrink: 0;
}
.faq-item[open] summary .plus {
  transform: rotate(45deg);
  background: var(--acc);
  color: white;
  border-color: var(--acc);
}
.faq-item .faq-body {
  padding: 0 26px 22px;
  color: var(--text-2);
  font-size: 0.95rem;
  line-height: 1.6;
  max-width: 76ch;
}

/* ====== CONTACT / NEWSLETTER ====== */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
}
@media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; gap: 40px; } }

.form { display: flex; flex-direction: column; gap: 14px; }
.field { display: grid; gap: 6px; }
.field label {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
}
.field input,
.field textarea,
.field select {
  font: inherit;
  color: var(--text-1);
  background: var(--surf-1);
  border: 1px solid var(--hairline);
  border-radius: var(--r-3);
  padding: 14px 16px;
  outline: none;
  transition: border-color var(--dur-fast), background var(--dur-fast);
  cursor: pointer;
}
.field input::placeholder, .field textarea::placeholder { color: var(--text-4); }
.field input:focus, .field textarea:focus, .field select:focus {
  border-color: var(--acc);
  background: var(--surf-2);
  box-shadow: 0 0 0 4px oklch(0.6 0.25 var(--acc-h) / 0.15);
}

/* ====== FUTURISTIC SELECT — custom dropdown for forms ====== */
.fselect {
  position: relative;
  font-family: var(--font-body);
  z-index: 1;
}
.fselect.is-open { z-index: 60; }

.fselect-trigger {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 12px 14px;
  border-radius: var(--r-3);
  border: 1px solid var(--hairline);
  background: oklch(0.13 0.03 282 / 0.6);
  backdrop-filter: blur(20px);
  color: var(--text-1);
  cursor: pointer;
  text-align: left;
  position: relative;
  isolation: isolate;
  overflow: hidden;
  transition: border-color var(--dur-mid) var(--ease-out),
              background var(--dur-mid) var(--ease-out),
              box-shadow var(--dur-mid) var(--ease-out);
}
.fselect-trigger::before {
  content: "";
  position: absolute;
  top: 0; left: 14%; right: 14%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--acc-bright), transparent);
  opacity: 0;
  transition: opacity 400ms var(--ease-out);
  pointer-events: none;
}
.fselect.is-open .fselect-trigger,
.fselect-trigger:hover {
  background: oklch(0.18 0.05 var(--card-h, var(--acc-h)) / 0.7);
  border-color: oklch(0.7 0.22 var(--card-h, var(--acc-h)) / 0.5);
  box-shadow: 0 0 24px oklch(0.6 0.28 var(--card-h, var(--acc-h)) / 0.22);
}
.fselect.is-open .fselect-trigger::before { opacity: 1; }

.fselect-icon {
  width: 36px; height: 36px;
  display: grid; place-items: center;
  border-radius: 10px;
  color: white;
  background: linear-gradient(135deg,
    oklch(0.72 0.27 var(--card-h, var(--acc-h))),
    oklch(0.4 0.22 var(--card-h, var(--acc-h))));
  box-shadow: 0 0 14px oklch(0.7 0.3 var(--card-h, var(--acc-h)) / 0.4),
              inset 0 1px 0 rgba(255,255,255,0.28);
  flex-shrink: 0;
}
.fselect-icon svg { width: 18px; height: 18px; }
.fselect-current { display: grid; gap: 2px; flex: 1; min-width: 0; }
.fselect-label {
  font-size: 0.95rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--text-1);
  line-height: 1.1;
}
.fselect-hint {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  color: oklch(0.85 0.1 var(--card-h, var(--acc-h)));
  text-transform: uppercase;
}
.fselect-caret {
  width: 28px; height: 28px;
  display: grid; place-items: center;
  border-radius: 50%;
  background: oklch(0.18 0.04 282 / 0.6);
  border: 1px solid var(--hairline);
  color: var(--text-2);
  transition: transform var(--dur-mid) var(--ease-spring),
              background var(--dur-mid),
              border-color var(--dur-mid);
}
.fselect-caret svg { width: 12px; height: 12px; }
.fselect.is-open .fselect-caret {
  transform: rotate(180deg);
  background: oklch(0.25 0.06 var(--card-h, var(--acc-h)) / 0.85);
  border-color: oklch(0.7 0.25 var(--card-h, var(--acc-h)) / 0.6);
  color: oklch(0.95 0.2 var(--card-h, var(--acc-h)));
}

.fselect-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0; right: 0;
  z-index: 100;
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
  transition: opacity 220ms var(--ease-out),
              transform 280ms var(--ease-spring);
}
.fselect.is-open .fselect-menu {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.fselect-menu-inner {
  position: relative;
  padding: 6px;
  border-radius: var(--r-3);
  background: oklch(0.09 0.025 282 / 0.92);
  border: 1px solid oklch(0.92 0.04 280 / 0.16);
  backdrop-filter: blur(30px) saturate(180%);
  -webkit-backdrop-filter: blur(30px) saturate(180%);
  box-shadow:
    0 30px 80px -30px rgba(0,0,0,0.85),
    inset 0 1px 0 rgba(255,255,255,0.06);
  isolation: isolate;
  overflow: hidden;
}
.fselect-menu-inner::before {
  content: "";
  position: absolute;
  top: -60px; right: -40px;
  width: 200px; height: 200px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--acc-glow), transparent 70%);
  filter: blur(40px);
  z-index: -1;
}

.fselect-option {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--text-1);
  cursor: pointer;
  text-align: left;
  position: relative;
  transition: background var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out);
  opacity: 0;
  transform: translateX(-8px);
  animation: fselectOptionIn 320ms var(--ease-out) var(--opt-delay, 0ms) forwards;
}
@keyframes fselectOptionIn { to { opacity: 1; transform: none; } }
.fselect-option:hover {
  background: oklch(0.16 0.05 var(--card-h, var(--acc-h)) / 0.55);
  border-color: oklch(0.85 0.04 280 / 0.1);
}
.fselect-option.is-active {
  background: oklch(0.18 0.06 var(--card-h, var(--acc-h)) / 0.7);
  border-color: oklch(0.7 0.22 var(--card-h, var(--acc-h)) / 0.4);
}
.fselect-option-icon {
  width: 30px; height: 30px;
  display: grid; place-items: center;
  border-radius: 8px;
  color: white;
  background: linear-gradient(135deg,
    oklch(0.72 0.25 var(--card-h, var(--acc-h))),
    oklch(0.4 0.22 var(--card-h, var(--acc-h))));
  box-shadow: 0 0 10px oklch(0.7 0.3 var(--card-h, var(--acc-h)) / 0.35),
              inset 0 1px 0 rgba(255,255,255,0.24);
  flex-shrink: 0;
}
.fselect-option-icon svg { width: 14px; height: 14px; }
.fselect-option-body { display: grid; gap: 2px; flex: 1; min-width: 0; }
.fselect-option-label {
  font-size: 0.9rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  line-height: 1.1;
  color: var(--text-1);
}
.fselect-option-hint {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  color: var(--text-3);
  text-transform: uppercase;
}
.fselect-option-check {
  width: 22px; height: 22px;
  display: grid; place-items: center;
  border-radius: 50%;
  background: oklch(0.6 0.28 var(--card-h, var(--acc-h)));
  color: white;
  box-shadow: 0 0 8px oklch(0.6 0.3 var(--card-h, var(--acc-h)) / 0.55);
}
.fselect-option-check svg { width: 12px; height: 12px; }

/* Light mode */
[data-theme="light"] .fselect-trigger {
  background: oklch(0.97 0.007 280 / 0.9);
  border-color: oklch(0.2 0.02 280 / 0.14);
  color: oklch(0.15 0.02 280);
}
[data-theme="light"] .fselect.is-open .fselect-trigger,
[data-theme="light"] .fselect-trigger:hover {
  background: oklch(0.94 0.018 var(--card-h, var(--acc-h)) / 0.95);
  border-color: oklch(0.5 0.22 var(--card-h, var(--acc-h)) / 0.5);
}
[data-theme="light"] .fselect-label { color: oklch(0.15 0.02 280); }
[data-theme="light"] .fselect-caret {
  background: oklch(0.94 0.012 280);
  border-color: oklch(0.2 0.02 280 / 0.14);
  color: oklch(0.4 0.02 280);
}
[data-theme="light"] .fselect-menu-inner {
  background: oklch(0.99 0.005 280 / 0.98);
  border-color: oklch(0.2 0.02 280 / 0.14);
  box-shadow: 0 30px 80px -30px rgba(0,0,0,0.2),
              inset 0 1px 0 rgba(255,255,255,0.9);
}
[data-theme="light"] .fselect-option:hover {
  background: oklch(0.94 0.018 var(--card-h, var(--acc-h)) / 0.85);
}
[data-theme="light"] .fselect-option.is-active {
  background: oklch(0.92 0.04 var(--card-h, var(--acc-h)) / 0.92);
  border-color: oklch(0.5 0.22 var(--card-h, var(--acc-h)) / 0.4);
}
[data-theme="light"] .fselect-option-label { color: oklch(0.15 0.02 280); }
[data-theme="light"] .fselect-option-hint { color: oklch(0.5 0.02 280); }

.newsletter {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  padding: 8px;
  background: var(--surf-1);
  border: 1px solid var(--hairline);
  border-radius: var(--r-pill);
  max-width: 480px;
}
.newsletter input {
  background: transparent;
  border: 0;
  padding: 10px 16px;
  color: var(--text-1);
  outline: none;
  cursor: pointer;
}

/* ====== BRAND MARQUEE — 3D perspective scrolling partners ====== */
.brand-marquee {
  position: relative;
  padding: 80px 0 60px;
  margin-top: 40px;
  border-top: 1px solid var(--hairline);
  isolation: isolate;
  overflow: hidden;
}
.brand-marquee::before {
  content: "";
  position: absolute;
  top: -1px; left: 50%;
  transform: translateX(-50%);
  width: 40%; height: 1px;
  background: linear-gradient(90deg, transparent, var(--acc), transparent);
  filter: blur(0.5px);
}

.brand-marquee-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 40px;
  margin-bottom: 44px;
  flex-wrap: wrap;
}
.brand-marquee-head-left { display: grid; gap: 16px; }

/* Eyebrow with pulsing dot — clearly visible */
.brand-marquee-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 14px;
  border-radius: 999px;
  background: oklch(0.16 0.05 var(--acc-h) / 0.6);
  border: 1px solid oklch(0.55 0.22 var(--acc-h) / 0.4);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: oklch(0.92 0.16 var(--acc-h));
  width: fit-content;
  box-shadow: 0 0 18px oklch(0.6 0.28 var(--acc-h) / 0.18);
}
.brand-marquee-eyebrow-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--acc-bright);
  box-shadow: 0 0 10px var(--acc-glow);
  animation: marqueeDotPulse 2s ease-in-out infinite;
}
@keyframes marqueeDotPulse {
  0%, 100% { transform: scale(1);   box-shadow: 0 0 10px var(--acc-glow); }
  50%      { transform: scale(1.3); box-shadow: 0 0 16px var(--acc-glow); }
}

/* Big readable title */
.brand-marquee-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2rem, 1.4rem + 2.2vw, 3.4rem);
  letter-spacing: -0.03em;
  line-height: 1.05;
  color: var(--text-1);
  margin: 0;
}
.brand-marquee-title-accent {
  background: linear-gradient(180deg, var(--acc-bright), var(--acc));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* Stat row on the right */
.brand-marquee-stats {
  display: grid;
  grid-template-columns: repeat(3, auto);
  gap: 1px;
  background: var(--hairline);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-3);
  overflow: hidden;
  backdrop-filter: blur(20px);
  box-shadow: 0 12px 40px -20px rgba(0,0,0,0.5);
}
.brand-marquee-stat {
  padding: 14px 22px;
  background: oklch(0.11 0.025 282 / 0.85);
  display: grid;
  gap: 4px;
  min-width: 110px;
  text-align: center;
}
.brand-marquee-stat strong {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--text-1);
}
.brand-marquee-stat .mono {
  font-family: var(--font-mono);
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: oklch(0.85 0.1 var(--acc-h));
}

/* Light mode */
[data-theme="light"] .brand-marquee-eyebrow {
  background: oklch(0.96 0.025 var(--acc-h) / 0.9);
  border-color: oklch(0.55 0.22 var(--acc-h) / 0.4);
  color: oklch(0.32 0.22 var(--acc-h));
}
[data-theme="light"] .brand-marquee-title { color: oklch(0.15 0.02 280); }
[data-theme="light"] .brand-marquee-stats {
  background: oklch(0.2 0.02 280 / 0.12);
  border-color: oklch(0.2 0.02 280 / 0.18);
}
[data-theme="light"] .brand-marquee-stat {
  background: oklch(0.98 0.005 280 / 0.95);
}
[data-theme="light"] .brand-marquee-stat strong { color: oklch(0.15 0.02 280); }
[data-theme="light"] .brand-marquee-stat .mono { color: oklch(0.4 0.22 var(--acc-h)); }

/* Mobile */
@media (max-width: 720px) {
  .brand-marquee-head { gap: 24px; }
  .brand-marquee-stats { grid-template-columns: 1fr 1fr 1fr; width: 100%; }
  .brand-marquee-stat { min-width: 0; padding: 12px 10px; }
  .brand-marquee-stat strong { font-size: 1.2rem; }
}

.brand-marquee-stage {
  position: relative;
  height: 260px;
  width: 100%;
  perspective: 1200px;
  perspective-origin: 50% 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.brand-marquee-stage::before,
.brand-marquee-stage::after {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  width: 22%;
  pointer-events: none;
  z-index: 3;
}
.brand-marquee-stage::before {
  left: 0;
  background: linear-gradient(90deg, var(--bg-0) 0%, transparent 100%);
}
.brand-marquee-stage::after {
  right: 0;
  background: linear-gradient(270deg, var(--bg-0) 0%, transparent 100%);
}
/* vertical fade */
.brand-marquee-stage > .brand-marquee-rotator::before,
.brand-marquee-stage > .brand-marquee-rotator::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  height: 40%;
  pointer-events: none;
  z-index: 3;
}
.brand-marquee-stage > .brand-marquee-rotator::before {
  top: 0;
  background: linear-gradient(180deg, var(--bg-0) 0%, transparent 100%);
}
.brand-marquee-stage > .brand-marquee-rotator::after {
  bottom: 0;
  background: linear-gradient(0deg, var(--bg-0) 0%, transparent 100%);
}

.brand-marquee-rotator {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  transform: rotateX(8deg) rotateY(-28deg);
  transform-style: preserve-3d;
  transform-origin: 50% 50%;
}

.brand-marquee-track {
  display: flex;
  align-items: center;
  white-space: nowrap;
  will-change: transform;
  /* Never-stalling scroll: pure CSS, duration sized by JS (--bm-duration). */
  animation: bm-scroll var(--bm-duration, 420s) linear infinite;
}
@keyframes bm-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-33.3333%); } /* one of the 3 rendered copies */
}

.brand-marquee-item {
  display: inline-block;
  font-family: var(--font-display);
  font-size: clamp(56px, 5.5vw, 96px);
  font-weight: 600;
  letter-spacing: -0.03em;
  color: var(--text-1);
  padding-right: clamp(48px, 4vw, 72px);
  filter: blur(var(--bm-blur, 0px));
  opacity: var(--bm-opacity, 1);
  user-select: none;
}

/* Light mode */
[data-theme="light"] .brand-marquee-stage::before {
  background: linear-gradient(90deg, var(--bg-0) 0%, transparent 100%);
}
[data-theme="light"] .brand-marquee-stage::after {
  background: linear-gradient(270deg, var(--bg-0) 0%, transparent 100%);
}
[data-theme="light"] .brand-marquee-stage > .brand-marquee-rotator::before {
  background: linear-gradient(180deg, var(--bg-0) 0%, transparent 100%);
}
[data-theme="light"] .brand-marquee-stage > .brand-marquee-rotator::after {
  background: linear-gradient(0deg, var(--bg-0) 0%, transparent 100%);
}

/* Mobile — flatten rotation a touch */
@media (max-width: 860px) {
  .brand-marquee { padding: 56px 0 40px; }
  .brand-marquee-stage { height: 180px; }
  .brand-marquee-rotator { transform: rotateX(4deg) rotateY(-18deg); }
  .brand-marquee-item { font-size: clamp(40px, 9vw, 64px); padding-right: 36px; }
}

/* ====== FOOTER ====== */
.footer {
  position: relative;
  padding: 100px 0 40px;
  border-top: 1px solid var(--hairline);
  margin-top: 100px;
  isolation: isolate;
}
.footer::before {
  content: "";
  position: absolute;
  top: -1px; left: 50%;
  transform: translateX(-50%);
  width: 60%; height: 1px;
  background: linear-gradient(90deg, transparent, var(--acc-bright), transparent);
  filter: blur(0.5px);
}
.footer-glow {
  position: absolute;
  bottom: -200px; left: 50%;
  transform: translateX(-50%);
  width: 900px; height: 400px;
  background: radial-gradient(ellipse, var(--acc-glow), transparent 70%);
  filter: blur(80px);
  z-index: -1;
  opacity: 0.5;
}
.footer-display {
  font-family: var(--font-display);
  font-size: clamp(4rem, 8vw + 1rem, 12rem);
  letter-spacing: -0.05em;
  line-height: 0.9;
  font-weight: 500;
  background: linear-gradient(180deg, var(--text-1), var(--text-3) 70%, transparent);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin-bottom: 60px;
  text-align: center;
}
.footer-cols {
  display: grid;
  grid-template-columns: 1.5fr repeat(4, 1fr);
  gap: 40px;
  padding-bottom: 60px;
  border-bottom: 1px solid var(--hairline);
}
@media (max-width: 900px) {
  .footer-cols { grid-template-columns: 1fr 1fr; }
}
.footer-col h6 {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 18px;
  font-weight: 400;
}
.footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.footer-col a { color: var(--text-2); font-size: 0.9rem; transition: color var(--dur-fast); }
.footer-col a:hover { color: var(--text-1); }

.footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 30px;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--text-3);
}
.footer-bottom .socials { display: flex; gap: 12px; }
.footer-bottom .socials a { width: 32px; height: 32px; border-radius: 50%; display: grid; place-items: center; background: var(--surf-1); border: 1px solid var(--hairline); }

/* ============================================
   AUTH — login / signup flow (mock)
   ============================================ */
/* Auth routes: paint the page shell black the same frame .auth enters the DOM.
   Without this, light theme's near-white --bg-0 body shows for one frame while
   the home page unmounts → visible white flash before the black login screen. */
html:has(.auth), html:has(.auth) body { background: #000; }

.auth { position: relative; min-height: 100vh; width: 100%; display: grid; place-items: center; background: #000; color: #fff; overflow: hidden; }
.auth-bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.auth-dots { display: none; }   /* IlluminatedHero bg has no dot matrix */

/* Illuminated spotlight — a capsule of light pushed up so it glows from the top
   (recreation of IlluminatedHero: warm-white key light + cool under-glow on black). */
/* Two capsule light layers (= .shadow-bgt / .shadow-bgb), exact IlluminatedHero keyframes */
.auth-glow {
  position: absolute; left: 50%; top: 0;
  width: min(44em, 96vw); height: 100%;
  border-radius: 100em;
  opacity: 0.85;
  mix-blend-mode: screen;
  filter: blur(6px);
  background: radial-gradient(closest-side, rgba(255,250,246,0.85), rgba(223,229,238,0.38) 48%, transparent 75%);
  box-shadow: 0 0 240px 70px rgba(255,250,246,0.34);
}
.auth-glow--t { transform: translate(-50%, -70%) scale(1.2); animation: onloadbgt 1.1s ease-in-out forwards; }
.auth-glow--b { transform: translate(-50%, 70%) scale(1.2); animation: onloadbgb 1.1s ease-in-out forwards; }
@keyframes onloadbgt { 0% { transform: translate(-50%, -70%) scale(1.2); opacity: 0.3; } 100% { transform: translate(-50%, -64%) scale(1.2); opacity: 0.8; } }
@keyframes onloadbgb { 0% { transform: translate(-50%, 70%) scale(1.2); opacity: 0.3; } 100% { transform: translate(-50%, 64%) scale(1.2); opacity: 0.8; } }
.auth-vignette { position: absolute; inset: 0; background: radial-gradient(ellipse 130% 88% at 50% 50%, transparent 52%, #000 92%); }

.auth-close { position: absolute; top: 22px; right: 22px; z-index: 5; width: 40px; height: 40px; display: grid; place-items: center; border-radius: 50%; color: #fff; border: 1px solid rgba(255,255,255,0.14); background: rgba(255,255,255,0.05); backdrop-filter: blur(8px); transition: background .2s, border-color .2s; }
.auth-close:hover { background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.32); }

.auth-shell { position: relative; z-index: 2; width: 100%; max-width: 1000px; padding: 44px 24px; display: grid; gap: 22px; justify-items: center; text-align: center; }
.auth-brand { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 600; font-size: 1.05rem; color: #fff; }

.auth-steps { display: flex; gap: 8px; }
.auth-stepdot { width: 26px; height: 4px; border-radius: 2px; background: rgba(255,255,255,0.15); transition: background .3s; }
.auth-stepdot.is-active { background: oklch(0.8 0.13 208); }
.auth-stepdot.done { background: oklch(0.62 0.12 212); }

.auth-step { width: 100%; max-width: 420px; margin-inline: auto; display: grid; gap: 18px; justify-items: center; animation: authStepIn 0.5s var(--ease-out) both; }
.auth-step--wide { max-width: 1000px; }
@keyframes authStepIn { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
.auth-head { display: grid; gap: 6px; justify-items: center; }
.auth-title { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.9rem, 1.4rem + 2vw, 2.5rem); letter-spacing: -0.02em; line-height: 1.05; }
.auth-sub { color: rgba(255,255,255,0.6); font-size: 0.98rem; max-width: 38ch; }

.auth-toggle { position: relative; display: inline-grid; grid-template-columns: 1fr 1fr; padding: 4px; border-radius: var(--r-pill); background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1); }
.auth-toggle button { position: relative; z-index: 1; padding: 8px 28px; border-radius: var(--r-pill); font-size: 0.85rem; font-weight: 600; color: rgba(255,255,255,0.6); transition: color .25s; }
.auth-toggle button.is-active { color: #fff; }
.auth-toggle-pill { position: absolute; top: 4px; left: 4px; width: calc(50% - 4px); height: calc(100% - 8px); border-radius: var(--r-pill); background: linear-gradient(180deg, oklch(0.32 0.07 var(--btn-h) / 0.92), oklch(0.16 0.06 var(--btn-h) / 0.95)); border: 1px solid oklch(0.70 0.12 var(--btn-h) / 0.40); box-shadow: 0 0 16px -2px var(--btn-glow), inset 0 1px 0 oklch(1 0 0 / 0.25); transition: transform .3s var(--ease-spring); z-index: 0; }
.auth-toggle-pill.right { transform: translateX(100%); }

/* Shared pill toggle — the auth-toggle pattern for pricing & other surfaces.
   Works on both themes (auth version assumes the dark overlay). */
.px-toggle { position: relative; display: inline-grid; grid-template-columns: 1fr 1fr; padding: 4px; border-radius: var(--r-pill); background: oklch(0.5 0.02 var(--btn-h) / 0.10); border: 1px solid oklch(0.6 0.03 var(--btn-h) / 0.18); }
.px-toggle button { position: relative; z-index: 1; padding: 9px 26px; border-radius: var(--r-pill); font-size: 0.85rem; font-weight: 600; color: var(--text-2); white-space: nowrap; transition: color .25s; }
.px-toggle button.is-active { color: #fff; }
.px-toggle-pill { position: absolute; top: 4px; left: 4px; width: calc(50% - 4px); height: calc(100% - 8px); border-radius: var(--r-pill); background: linear-gradient(180deg, oklch(0.32 0.07 var(--btn-h) / 0.92), oklch(0.16 0.06 var(--btn-h) / 0.95)); border: 1px solid oklch(0.70 0.12 var(--btn-h) / 0.40); box-shadow: 0 0 16px -2px var(--btn-glow), inset 0 1px 0 oklch(1 0 0 / 0.25); transition: transform .3s var(--ease-spring); z-index: 0; }
.px-toggle-pill.right { transform: translateX(100%); }
[data-theme="light"] .px-toggle { background: oklch(0.45 0.02 var(--btn-h) / 0.07); border-color: oklch(0.45 0.03 var(--btn-h) / 0.16); }
[data-theme="light"] .px-toggle button { color: var(--text-2); }
[data-theme="light"] .px-toggle button.is-active { color: #fff; }

/* Remember me + forgot — one row under the email form (login mode) */
.auth-mini-row { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-top: 12px; width: 100%; }
.auth-mini-row .auth-forgot { margin: 0; }
.auth-remember { display: inline-flex; align-items: center; gap: 8px; font-size: 0.85rem; color: rgba(255,255,255,0.65); cursor: pointer; user-select: none; }
.auth-remember input { width: 15px; height: 15px; accent-color: oklch(0.65 0.20 var(--btn-h)); cursor: pointer; }
.auth-remember:hover { color: rgba(255,255,255,0.85); }

.auth-google { width: 100%; display: inline-flex; align-items: center; justify-content: center; gap: 10px; padding: 13px 18px; border-radius: var(--r-pill); background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); color: #fff; font-weight: 500; backdrop-filter: blur(6px); transition: background .2s, border-color .2s; }
.auth-google:hover { background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.25); }
.auth-g { display: grid; place-items: center; width: 20px; height: 20px; border-radius: 50%; background: #fff; color: #1a73e8; font-weight: 800; font-size: 0.78rem; }

.auth-divider { display: flex; align-items: center; gap: 14px; width: 100%; color: rgba(255,255,255,0.4); font-size: 0.8rem; }
.auth-divider span { flex: 1; height: 1px; background: rgba(255,255,255,0.12); }

.auth-emailform { position: relative; width: 100%; }
.auth-emailform input { width: 100%; padding: 14px 46px; border-radius: var(--r-pill); background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.12); color: #fff; text-align: center; font-size: 1rem; outline: none; transition: border-color .2s, background .2s; }
.auth-emailform input::placeholder { color: rgba(255,255,255,0.4); }
.auth-emailform input:focus { border-color: oklch(0.8 0.12 208 / 0.8); background: rgba(255,255,255,0.08); }
.auth-go { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; color: rgba(255,255,255,0.55); background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.14); transition: color .2s, background .2s, border-color .2s; }
.auth-go:hover { color: #fff; background: rgba(255,255,255,0.12); border-color: oklch(0.8 0.12 208 / 0.55); }
.auth-go svg { width: 14px; height: 14px; transition: transform .2s; }
.auth-go:hover svg { transform: translateX(2px); }

.dash-open-row { display: flex; gap: 8px; flex-wrap: wrap; margin: 4px 0 14px; }

.auth-forgot { display: block; margin: 4px auto 0; font-size: 0.78rem; color: rgba(255,255,255,0.45); background: none; border: none; cursor: pointer; transition: color .2s; }
.auth-forgot:hover { color: oklch(0.85 0.1 208); text-decoration: underline; }

.auth-legal { font-size: 0.72rem; color: rgba(255,255,255,0.4); max-width: 36ch; line-height: 1.5; }
.auth-legal a { color: rgba(255,255,255,0.62); text-decoration: underline; }

.auth-otp { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.auth-otp-box { width: 46px; height: 56px; border-radius: 14px; text-align: center; font-size: 1.4rem; font-weight: 600; color: #fff; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.14); outline: none; transition: border-color .2s, background .2s; }
.auth-otp-box:focus { border-color: oklch(0.82 0.12 208); background: rgba(255,255,255,0.09); }
/* own paint layer (translateZ) — its hover repaint must not force the sibling
   .btn pills' backdrop-filter to resample (Chromium glitch: Back button "broke"
   whenever Resend was hovered). */
.auth-resend { color: rgba(255,255,255,0.55); font-size: 0.85rem; padding: 4px 10px; border-radius: 8px; transform: translateZ(0); transition: color .2s, background .2s; }
.auth-resend:hover { color: #fff; background: rgba(255,255,255,0.06); }
.auth-row { display: flex; gap: 12px; width: 100%; }
.auth-row .btn { flex: 1; transform: translateZ(0); }   /* isolate pill blur from sibling repaints */
.btn:disabled, .btn[disabled] { opacity: 0.45; cursor: not-allowed; }

.auth-form { width: 100%; display: grid; gap: 14px; text-align: left; }
.auth-field { display: grid; gap: 6px; }
.auth-field > span { font-size: 0.78rem; color: rgba(255,255,255,0.55); font-weight: 500; }
.auth-field input { width: 100%; padding: 13px 16px; border-radius: 14px; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.12); color: #fff; font-size: 0.95rem; outline: none; transition: border-color .2s, background .2s; }
.auth-field input::placeholder { color: rgba(255,255,255,0.35); }
.auth-field input:focus { border-color: oklch(0.8 0.12 208 / 0.8); background: rgba(255,255,255,0.08); }
.auth-form-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

.auth-hubs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; width: 100%; }
@media (max-width: 880px) { .auth-hubs { grid-template-columns: 1fr 1fr; } }
.auth-hub { position: relative; display: grid; gap: 12px; justify-items: center; text-align: center; padding: 34px 18px; min-height: 230px; border-radius: 20px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); color: #fff; cursor: pointer; isolation: isolate; opacity: 0; transform: translateY(16px); animation: authHubIn .5s var(--ease-out) both; transition: border-color .25s, background .25s, box-shadow .25s; }
@keyframes authHubIn { to { opacity: 1; transform: none; } }
.auth-hub:hover { border-color: oklch(0.7 0.18 var(--card-h, 209) / 0.6); background: rgba(255,255,255,0.07); }
.auth-hub.is-sel { border-color: oklch(0.78 0.2 var(--card-h, 209)); background: oklch(0.5 0.14 var(--card-h, 209) / 0.18); box-shadow: 0 0 0 1px oklch(0.78 0.2 var(--card-h, 209) / 0.5), 0 14px 34px -14px oklch(0.6 0.2 var(--card-h, 209) / 0.55); }
.auth-hub-icon { width: 62px; height: 62px; display: grid; place-items: center; border-radius: 16px; color: #fff; background: linear-gradient(135deg, oklch(0.72 0.2 var(--card-h, 209)), oklch(0.42 0.18 var(--card-h, 209))); box-shadow: 0 0 22px oklch(0.7 0.25 var(--card-h, 209) / 0.45), inset 0 1px 0 rgba(255,255,255,0.3); }
.auth-hub-icon svg { width: 30px; height: 30px; }
.auth-hub-name { font-family: var(--font-display); font-weight: 600; font-size: 1.2rem; }
.auth-hub-tag { font-family: var(--font-mono); font-size: 0.55rem; letter-spacing: 0.14em; color: rgba(255,255,255,0.5); max-width: 18ch; }
.auth-hub-price { font-family: var(--font-display); font-weight: 600; font-size: 1.5rem; margin-top: 4px; }
.auth-hub-price small { font-size: 0.62rem; color: rgba(255,255,255,0.5); font-weight: 400; }
.auth-hub-check { position: absolute; top: 10px; right: 10px; width: 22px; height: 22px; border-radius: 50%; display: grid; place-items: center; color: #fff; background: oklch(0.82 0.16 var(--card-h, 209)); opacity: 0; transform: scale(0.5); transition: opacity .2s, transform .2s var(--ease-spring); }
.auth-hub-check svg { width: 13px; height: 13px; }
.auth-hub.is-sel .auth-hub-check { opacity: 1; transform: scale(1); }

/* Add-ons step — selectable extra AI / plug-ins / features (extra pricing) */
.auth-addons { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; width: 100%; text-align: left; }
@media (max-width: 760px) { .auth-addons { grid-template-columns: 1fr; } }
.auth-addon { display: grid; grid-template-columns: 30px 1fr auto; align-items: center; gap: 14px; padding: 16px 18px; border-radius: 16px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); color: #fff; cursor: pointer; text-align: left; opacity: 0; transform: translateY(10px); animation: authHubIn 0.45s var(--ease-out) both; transition: border-color .2s, background .2s; }
.auth-addon:hover { background: rgba(255,255,255,0.07); border-color: oklch(0.7 0.12 209 / 0.5); }
.auth-addon.is-on { background: oklch(0.5 0.12 209 / 0.16); border-color: oklch(0.78 0.16 209 / 0.7); }
.auth-addon-check { width: 30px; height: 30px; border-radius: 9px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,0.2); transition: background .2s, border-color .2s; }
.auth-addon-check svg { width: 15px; height: 15px; color: rgba(255,255,255,0.55); }
.auth-addon.is-on .auth-addon-check { background: linear-gradient(145deg, oklch(0.58 0.06 292), oklch(0.3 0.09 288)); border-color: transparent; }
.auth-addon.is-on .auth-addon-check svg { color: #fff; }
.auth-addon-body { display: grid; gap: 2px; min-width: 0; }
.auth-addon-name { font-weight: 600; font-size: 0.95rem; }
.auth-addon-desc { font-size: 0.78rem; color: rgba(255,255,255,0.5); }
.auth-addon-price { font-family: var(--font-display); font-weight: 600; font-size: 1.1rem; color: oklch(0.85 0.12 208); white-space: nowrap; }
.auth-addon-price small { font-size: 0.6rem; color: rgba(255,255,255,0.45); font-weight: 400; }
.auth-total { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: 16px 22px; border-radius: 16px; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.12); }
.auth-total > span { color: rgba(255,255,255,0.6); font-size: 0.9rem; }
.auth-total strong { font-family: var(--font-display); font-weight: 600; font-size: 1.7rem; }
.auth-total strong small { font-size: 0.7rem; color: rgba(255,255,255,0.5); font-weight: 400; }

.auth-pay { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; width: 100%; align-items: start; text-align: left; }
@media (max-width: 720px) { .auth-pay { grid-template-columns: 1fr; } }
.auth-cardface { position: relative; aspect-ratio: 1.6; border-radius: 18px; padding: 22px; display: flex; flex-direction: column; justify-content: space-between; color: #fff; overflow: hidden; background: linear-gradient(150deg, oklch(0.5 0.14 var(--card-h, 209)), oklch(0.2 0.07 calc(var(--card-h, 209) + 12))); box-shadow: 0 22px 50px -22px oklch(0.4 0.14 var(--card-h, 209) / 0.6), inset 0 1px 0 rgba(255,255,255,0.18); }
.auth-cardface-row { display: flex; align-items: flex-end; justify-content: space-between; position: relative; z-index: 1; font-size: 0.82rem; }
.auth-cardface-row small { font-size: 0.55rem; letter-spacing: 0.14em; color: rgba(255,255,255,0.65); display: block; margin-bottom: 3px; }
.auth-cardface-row .r { text-align: right; }
.auth-chip { width: 40px; height: 30px; border-radius: 6px; background: linear-gradient(135deg, #f3d27a, #c9a14a); }
.auth-cardnum { font-size: 1.25rem; letter-spacing: 0.12em; position: relative; z-index: 1; }

/* Welcome — pure black; small, simple, centered "Welcome to MAE CORTEX" with blur in→out */
.auth--welcome { background: #000; }
.auth--welcome .auth-bg { display: none; }
.auth--welcome .auth-brand { display: none; }   /* only the single, centered welcome text */
/* Payment "processing" — pure black, ONLY the bouncing dots */
.auth--black { background: #000; }
.auth--black .auth-bg, .auth--black .auth-brand, .auth--black .auth-close, .auth--black .auth-steps { display: none; }
.auth--black .auth-processing { padding: 0; }
.auth-welcome { gap: 0; }
.auth-welcome-text { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.5rem, 1rem + 2.2vw, 2.6rem); letter-spacing: -0.01em; line-height: 1.1; white-space: nowrap; }
.auth-welcome-text span { display: inline-block; opacity: 0; filter: blur(12px); animation: authChar 0.85s var(--ease-out) both; color: #f4f7fb; }
@keyframes authChar { to { opacity: 1; filter: blur(0); } }
.auth-welcome.is-leaving .auth-welcome-text span { animation: authCharOut 0.7s ease-in both; }
@keyframes authCharOut { from { opacity: 1; filter: blur(0); } to { opacity: 0; filter: blur(12px); } }

/* Payment processing — bouncing dots (shown while the mock charge runs) */
.auth-processing { display: grid; gap: 22px; justify-items: center; padding: 64px 0; }
.auth-bdots { display: flex; gap: 12px; }
.auth-bdots span { width: 14px; height: 14px; border-radius: 50%; background: oklch(0.85 0.1 210); animation: authBounce 0.6s ease-in-out infinite; }
.auth-bdots span:nth-child(2) { animation-delay: 0.2s; }
.auth-bdots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes authBounce { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-18px); } }

/* ============================================
   404 — Not Found
   ============================================ */
.nf { position: relative; min-height: 100vh; display: grid; place-items: center; overflow: hidden; background: radial-gradient(circle at center, oklch(0.5 0.2 285 / 0.12), transparent 70%); }
.nf-orbs { position: absolute; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.nf-orb { position: absolute; border-radius: 50%; filter: blur(80px); }
.nf-orb--1 { top: 44%; left: 30%; width: 280px; height: 280px; background: linear-gradient(135deg, oklch(0.6 0.22 290 / 0.34), oklch(0.6 0.2 240 / 0.3)); animation: nfOrb1 6s ease-in-out infinite; }
.nf-orb--2 { right: 24%; bottom: 30%; width: 320px; height: 320px; background: linear-gradient(135deg, oklch(0.6 0.18 280 / 0.22), oklch(0.66 0.2 330 / 0.18)); animation: nfOrb2 6s ease-in-out infinite; }
@keyframes nfOrb1 { 0%, 100% { transform: translate(0, 0) rotate(0deg); } 33% { transform: translate(40px, 20px) rotate(10deg); } 66% { transform: translate(-40px, -20px) rotate(-10deg); } }
@keyframes nfOrb2 { 0%, 100% { transform: translate(0, 0); } 33% { transform: translate(-40px, -20px); } 66% { transform: translate(40px, 20px); } }
.nf-inner { position: relative; z-index: 1; display: grid; gap: 20px; justify-items: center; text-align: center; padding: 24px; }
.nf-code { font-family: var(--font-display); font-weight: 800; font-size: clamp(6rem, 4rem + 12vw, 11rem); line-height: 1; letter-spacing: -0.04em; background: linear-gradient(180deg, var(--text-1), var(--text-3)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.nf-desc { color: var(--text-2); font-size: 1.05rem; max-width: 42ch; }
.nf-actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; margin-top: 8px; }

/* Buttons (.btn / .btn-plan / .icon-btn) are now defined once — pill + orb
   design language in base.css (.btn) and below (.btn-plan, .icon-btn), all
   driven by --btn-* tokens. The old purple !important override block was
   removed so there is a single source of truth. */

/* ============================================
   USER DASHBOARD / PANEL
   ============================================ */
.auth--dash { display: block; background: var(--bg-0); }
.auth--dash .auth-bg, .auth--dash .auth-close, .auth--dash .auth-steps, .auth--dash .auth-brand { display: none; }
.auth--dash .auth-shell { max-width: none; width: 100%; padding: 0; display: block; }
.dash { display: grid; grid-template-columns: 264px 1fr; min-height: 100vh; width: 100%; text-align: left; color: var(--text-1); }
@media (max-width: 860px) { .dash { grid-template-columns: 1fr; } }
.dash-side { position: sticky; top: 0; align-self: start; height: 100vh; display: flex; flex-direction: column; gap: 18px; padding: 24px 18px; border-right: 1px solid var(--hairline); background: oklch(0.12 0.02 285 / 0.55); backdrop-filter: blur(20px); }
@media (max-width: 860px) { .dash-side { position: static; height: auto; } }
.dash-brand { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 600; color: var(--text-1); padding: 4px 6px; }
.dash-nav { display: flex; flex-direction: column; gap: 4px; flex: 1; }
@media (max-width: 860px) { .dash-nav { flex-direction: row; flex-wrap: wrap; } }
.dash-nav button { display: flex; align-items: center; gap: 12px; padding: 11px 14px; border-radius: 12px; color: var(--text-3); font-size: 0.92rem; font-weight: 500; transition: background .2s, color .2s; }
.dash-nav button svg { width: 18px; height: 18px; }
.dash-nav button:hover { color: var(--text-1); background: var(--surf-1); }
.dash-nav button.is-active { color: #fff; background: linear-gradient(145deg, oklch(0.5 0.1 292 / 0.5), oklch(0.32 0.09 288 / 0.4)); border: 1px solid oklch(0.7 0.1 290 / 0.4); }
.dash-user { display: flex; align-items: center; gap: 10px; padding: 10px; border-radius: 12px; background: var(--surf-1); border: 1px solid var(--hairline); }
.dash-avatar { width: 38px; height: 38px; border-radius: 50%; display: grid; place-items: center; font-weight: 700; color: #fff; flex-shrink: 0; background: linear-gradient(145deg, oklch(0.6 0.16 292), oklch(0.4 0.16 288)); }
.dash-user-meta { display: grid; line-height: 1.25; min-width: 0; }
.dash-user-meta strong { font-size: 0.9rem; }
.dash-user-meta span { font-size: 0.74rem; color: var(--text-3); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dash-logout { padding: 10px; border-radius: 12px; border: 1px solid var(--hairline); color: var(--text-2); font-size: 0.88rem; transition: color .2s, border-color .2s; }
.dash-logout:hover { color: var(--text-1); border-color: var(--hairline-strong); }

.dash-main { padding: clamp(20px, 4vw, 44px); display: grid; gap: 20px; align-content: start; max-width: 1120px; }
.dash-head h1 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.6rem, 1.2rem + 1.5vw, 2.2rem); }
.dash-head p { color: var(--text-3); margin-top: 4px; }
.dash-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: 16px; }
.dash-card { padding: 22px; border-radius: 18px; background: var(--surf-1); border: 1px solid var(--hairline); backdrop-filter: blur(20px); display: grid; gap: 14px; align-content: start; }
.dash-card-eyebrow { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.16em; color: var(--text-3); }
.dash-plan { grid-column: span 2; }
@media (max-width: 620px) { .dash-plan { grid-column: auto; } }
.dash-plan-row { display: flex; align-items: center; gap: 14px; }
.dash-plan-hub { width: 50px; height: 50px; border-radius: 12px; display: grid; place-items: center; color: #fff; flex-shrink: 0; background: linear-gradient(135deg, oklch(0.7 0.2 var(--card-h, 290)), oklch(0.42 0.18 var(--card-h, 290))); }
.dash-plan-hub svg { width: 24px; height: 24px; }
.dash-plan-row > div { display: grid; }
.dash-plan-row strong { font-family: var(--font-display); font-size: 1.15rem; }
.dash-plan-row > div span { font-size: 0.8rem; color: var(--text-3); }
.dash-plan-price { margin-left: auto; font-family: var(--font-display); font-weight: 600; font-size: 1.5rem; }
.dash-plan-price small { font-size: 0.7rem; color: var(--text-3); font-weight: 400; }
.dash-stat strong { font-family: var(--font-display); font-weight: 600; font-size: 1.8rem; }
.dash-stat > span:last-child { font-size: 0.78rem; color: var(--text-3); }
.dash-activity { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.dash-activity li { display: flex; align-items: center; gap: 10px; font-size: 0.9rem; color: var(--text-2); }
.dash-activity time { margin-left: auto; font-size: 0.74rem; color: var(--text-4); }
.dash-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--text-4); flex-shrink: 0; }
.dash-dot.ok { background: oklch(0.7 0.2 145); box-shadow: 0 0 8px oklch(0.7 0.3 145 / 0.5); }
.dash-form { gap: 16px; }
.dash-form-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 620px) { .dash-form-2 { grid-template-columns: 1fr; } }
.dash-form .auth-field span { color: var(--text-3); font-size: 0.78rem; }
.dash-form .auth-field input, .dash-form .auth-field select, .dash-form .auth-field textarea { background: var(--surf-2); border: 1px solid var(--hairline); color: var(--text-1); border-radius: 12px; padding: 12px 14px; width: 100%; font: inherit; outline: none; transition: border-color .2s; }
.dash-form .auth-field input:focus, .dash-form .auth-field select:focus, .dash-form .auth-field textarea:focus { border-color: oklch(0.7 0.12 290 / 0.7); }
.dash-form-actions { display: flex; align-items: center; gap: 14px; justify-content: flex-end; }
.dash-saved { color: oklch(0.7 0.2 145); font-size: 0.85rem; display: inline-flex; align-items: center; gap: 6px; margin-right: auto; }
.dash-saved svg { width: 16px; height: 16px; }
.dash-lines { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.dash-lines li { display: flex; justify-content: space-between; font-size: 0.9rem; color: var(--text-2); }
.dash-lines li b { color: var(--text-1); }
.dash-lines-total { border-top: 1px solid var(--hairline); padding-top: 10px; font-weight: 600; }
.dash-muted { color: var(--text-4); font-size: 0.8rem; }
.dash-pm { display: flex; align-items: center; gap: 12px; font-size: 1.05rem; }
.dash-pm-chip { width: 34px; height: 24px; border-radius: 5px; background: linear-gradient(135deg, #f3d27a, #c9a14a); }
.dash-table { width: 100%; border-collapse: collapse; font-size: 0.88rem; }
.dash-table th { text-align: left; font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.12em; color: var(--text-4); padding: 0 10px 10px; font-weight: 500; }
.dash-table td { padding: 12px 10px; border-top: 1px solid var(--hairline); color: var(--text-2); }
.dash-badge { padding: 3px 10px; border-radius: 999px; font-size: 0.7rem; font-weight: 600; text-transform: capitalize; }
.dash-badge.ok { background: oklch(0.6 0.18 145 / 0.18); color: oklch(0.82 0.18 145); }
.dash-badge.warn { background: oklch(0.7 0.18 70 / 0.18); color: oklch(0.84 0.16 70); }
.dash-hubs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
@media (max-width: 720px) { .dash-hubs { grid-template-columns: 1fr 1fr; } }
.dash-hub { display: grid; justify-items: center; gap: 6px; padding: 18px 10px; border-radius: 14px; background: var(--surf-2); border: 1px solid var(--hairline); color: var(--text-1); cursor: pointer; transition: border-color .2s, background .2s; }
.dash-hub strong { font-size: 0.95rem; }
.dash-hub > span:last-child { font-size: 0.78rem; color: var(--text-3); }
.dash-hub-icon { width: 42px; height: 42px; border-radius: 10px; display: grid; place-items: center; color: #fff; background: linear-gradient(135deg, oklch(0.7 0.2 var(--card-h, 290)), oklch(0.42 0.18 var(--card-h, 290))); }
.dash-hub-icon svg { width: 20px; height: 20px; }
.dash-hub.is-sel { border-color: oklch(0.78 0.2 var(--card-h, 290)); background: oklch(0.5 0.14 var(--card-h, 290) / 0.16); }
.dash-addons { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width: 620px) { .dash-addons { grid-template-columns: 1fr; } }
.dash-addon { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border-radius: 12px; background: var(--surf-2); border: 1px solid var(--hairline); color: var(--text-1); cursor: pointer; transition: border-color .2s, background .2s; }
.dash-addon.is-on { background: oklch(0.5 0.1 290 / 0.16); border-color: oklch(0.72 0.12 290 / 0.6); }
.dash-addon-name { flex: 1; font-size: 0.9rem; }
.dash-addon-price { font-family: var(--font-display); font-weight: 600; color: oklch(0.82 0.1 290); }
.dash-total { margin-right: auto; color: var(--text-3); }
.dash-total b { color: var(--text-1); font-family: var(--font-display); font-size: 1.2rem; margin-left: 6px; }

/* === Dashboard — minimalist refinement pass === */
.dash-side { background: transparent; backdrop-filter: none; border-right: 1px solid var(--hairline); padding: 30px 16px; gap: 26px; }
.dash-nav { gap: 2px; }
.dash-nav button { padding: 10px 12px; border-radius: 10px; font-weight: 500; }
.dash-nav button svg { opacity: 0.8; }
.dash-nav button:hover { background: oklch(1 0 0 / 0.045); }
.dash-nav button.is-active { background: transparent; border: 0; color: var(--text-1); position: relative; }
.dash-nav button.is-active svg { opacity: 1; color: var(--acc-bright); }
.dash-nav button.is-active::before { content: ""; position: absolute; left: -16px; top: 50%; transform: translateY(-50%); width: 3px; height: 20px; border-radius: 0 3px 3px 0; background: var(--acc-bright); }
.dash-user { background: transparent; }
.dash-logout { border-color: var(--hairline); }

.dash-main { padding: clamp(26px, 4.5vw, 60px); gap: 30px; max-width: 1080px; }
.dash-head { padding-bottom: 22px; border-bottom: 1px solid var(--hairline); }
.dash-head h1 { font-weight: 500; letter-spacing: -0.025em; }
.dash-head p { font-size: 0.92rem; }

.dash-card { background: oklch(0.17 0.02 285 / 0.32); border: 1px solid var(--hairline); backdrop-filter: none; padding: 26px; gap: 16px; border-radius: 20px; transition: border-color .25s; }
.dash-card-eyebrow { font-size: 0.6rem; letter-spacing: 0.22em; color: var(--text-4); }
.dash-stat { gap: 8px; }
.dash-stat strong { font-weight: 500; font-size: 2.1rem; letter-spacing: -0.025em; }
.dash-plan-row strong { font-weight: 500; }
.dash-plan-price { font-weight: 500; }
.dash-plan-hub { box-shadow: none; }
.dash-activity li { font-size: 0.88rem; padding: 4px 0; }
.dash-table th { padding-bottom: 14px; }
.dash-table td { padding: 14px 10px; }
.dash-badge { font-weight: 500; }
.dash-hub { background: oklch(0.17 0.018 285 / 0.3); border-radius: 16px; padding: 20px 10px; box-shadow: none; }
.dash-hub-icon { box-shadow: none; }
.dash-addon { background: oklch(0.17 0.018 285 / 0.3); }
.dash-form .auth-field input, .dash-form .auth-field select, .dash-form .auth-field textarea { background: oklch(0.14 0.015 285 / 0.5); }

/* Support — 3-col row, file attach, severity badges */
.dash-form-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; }
@media (max-width: 620px) { .dash-form-3 { grid-template-columns: 1fr; } }
.dash-file { display: flex; align-items: center; gap: 12px; cursor: pointer; }
.dash-file input { display: none; }
.dash-file-btn { display: inline-flex; align-items: center; gap: 8px; padding: 9px 14px; border-radius: 10px; border: 1px dashed var(--hairline-strong); color: var(--text-2); font-size: 0.85rem; transition: color .2s, border-color .2s; }
.dash-file-btn svg { width: 14px; height: 14px; }
.dash-file:hover .dash-file-btn { color: var(--text-1); border-color: oklch(0.7 0.1 290 / 0.6); }
.dash-file-name { font-size: 0.8rem; color: var(--text-3); }
.dash-sev { padding: 3px 10px; border-radius: 999px; font-size: 0.7rem; font-weight: 600; text-transform: capitalize; }
.dash-sev--low { background: oklch(0.6 0.12 230 / 0.18); color: oklch(0.82 0.12 230); }
.dash-sev--medium { background: oklch(0.7 0.15 80 / 0.16); color: oklch(0.85 0.14 80); }
.dash-sev--high { background: oklch(0.65 0.2 40 / 0.18); color: oklch(0.82 0.18 40); }
.dash-sev--critical { background: oklch(0.6 0.24 25 / 0.2); color: oklch(0.84 0.22 25); }

/* ====== APP DETAIL PAGE ====== */
.app-hero {
  position: relative;
  padding-top: 160px;
  padding-bottom: 100px;
  overflow: hidden;
}
.app-hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 60px;
  align-items: center;
}
@media (max-width: 900px) { .app-hero-grid { grid-template-columns: 1fr; } }

.app-hero-title { font-size: clamp(3rem, 2rem + 4vw, 6rem); font-weight: 500; letter-spacing: -0.04em; line-height: 0.95; }
.app-hero .app-icon-lg {
  width: 80px; height: 80px;
  border-radius: var(--r-4);
  display: grid; place-items: center;
  background: linear-gradient(135deg, oklch(0.7 0.25 var(--card-h, var(--acc-h))), oklch(0.4 0.22 var(--card-h, var(--acc-h))));
  box-shadow: 0 0 40px oklch(0.7 0.3 var(--card-h, var(--acc-h)) / 0.55), inset 0 1px 0 rgba(255,255,255,0.3);
  margin-bottom: 28px;
}
.app-hero .app-icon-lg svg { width: 40px; height: 40px; color: white; }

.app-hero-visual {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--r-5);
  background: linear-gradient(180deg, var(--surf-2), var(--surf-1));
  border: 1px solid var(--hairline-strong);
  overflow: hidden;
  box-shadow: 0 60px 120px -40px oklch(0.6 0.3 var(--card-h, var(--acc-h)) / 0.4);
}

.feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  /* equal-height rows: the Reveal wrappers stretch, the cards fill them */
  grid-auto-rows: 1fr;
}
.feature-grid > .reveal { display: flex; }
.feature-grid > .reveal > .feature { width: 100%; }
@media (max-width: 980px) { .feature-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 580px) { .feature-grid { grid-template-columns: 1fr; grid-auto-rows: auto; } }

.feature {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 28px;
  border-radius: var(--r-3);
  background: var(--surf-1);
  border: 1px solid var(--hairline);
  backdrop-filter: blur(20px);
}
/* bare futuristic icon — no boxed background, soft accent glow */
.feature .f-icon {
  width: 44px; height: 44px;
  display: grid; place-items: center;
  background: none;
  border: none;
  color: var(--acc-bright);
  margin-bottom: 14px;
  filter: drop-shadow(0 0 10px oklch(0.65 0.22 var(--acc-h) / 0.45));
}
.feature .f-icon svg { width: 27px; height: 27px; }
.feature h4 { font-size: 1.15rem; margin-bottom: 8px; }
.feature p { font-size: 0.9rem; }

/* Big feature row (alternating) */
.feature-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  padding-block: 60px;
}
.feature-row.reverse > .feature-row-visual { order: -1; }
@media (max-width: 900px) {
  .feature-row { grid-template-columns: 1fr; gap: 40px; padding-block: 30px; }
  .feature-row.reverse > .feature-row-visual { order: 0; }
}
.feature-row-visual {
  aspect-ratio: 4 / 3;
  border-radius: var(--r-4);
  background: linear-gradient(180deg, var(--surf-2), var(--surf-1));
  border: 1px solid var(--hairline-strong);
  overflow: hidden;
  position: relative;
}

/* Integrations grid */
.int-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1px;
  background: var(--hairline);
  border: 1px solid var(--hairline);
  border-radius: var(--r-3);
  overflow: hidden;
}
@media (max-width: 900px) { .int-grid { grid-template-columns: repeat(3, 1fr); } }
.int-cell {
  background: var(--bg-0);
  padding: 22px;
  display: grid; place-items: center;
  aspect-ratio: 1.2;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: var(--text-3);
  letter-spacing: 0.05em;
  transition: color var(--dur-fast), background var(--dur-fast);
}
.int-cell:hover { color: var(--text-1); background: var(--surf-1); }

/* Testimonials */
.testi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 900px) { .testi-grid { grid-template-columns: 1fr; } }
.testi {
  padding: 28px;
  border-radius: var(--r-3);
  background: var(--surf-1);
  border: 1px solid var(--hairline);
  display: flex; flex-direction: column; gap: 20px;
}
.testi p {
  font-family: var(--font-display);
  font-size: 1.1rem;
  letter-spacing: -0.015em;
  color: var(--text-1);
  line-height: 1.4;
}
.testi-author { display: flex; align-items: center; gap: 12px; }
.testi-avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--acc-bright), var(--acc-deep));
  display: grid; place-items: center;
  font-family: var(--font-mono);
  color: white;
  font-size: 0.8rem;
}
.testi-meta { font-size: 0.85rem; }
.testi-meta .name { color: var(--text-1); }
.testi-meta .role { color: var(--text-3); font-size: 0.78rem; font-family: var(--font-mono); }

/* Use cases */
.case-list { display: grid; gap: 1px; background: var(--hairline); border-block: 1px solid var(--hairline); }
.case {
  display: grid;
  grid-template-columns: 80px 1fr 2fr auto;
  gap: 32px;
  align-items: center;
  padding: 28px var(--container-pad);
  background: var(--bg-0);
  transition: background var(--dur-fast);
}
.case:hover { background: var(--surf-1); }
.case .case-num {
  font-family: var(--font-mono);
  font-size: 0.85rem;
  color: var(--text-3);
}
.case h5 { font-size: 1.2rem; }
.case p { font-size: 0.92rem; }
.case .case-arrow { color: var(--text-3); }
@media (max-width: 900px) {
  .case { grid-template-columns: auto 1fr; gap: 12px; padding: 20px var(--container-pad); }
  .case p { grid-column: 1 / -1; }
  .case .case-arrow { display: none; }
}

/* Spinner / loader subtle */
.shimmer {
  background: linear-gradient(90deg, transparent, oklch(0.85 0.04 280 / 0.08), transparent);
  background-size: 200% 100%;
  animation: shimmer 2.5s linear infinite;
}
@keyframes shimmer { to { background-position: -200% 0; } }

/* ===========================================================
   DOCS — three-panel documentation (glass + glow).
   Styles DocsPage in app.jsx: left nav · content · right TOC.
   Header is fixed (~68px from top) → sticky offset 88px clears it.
   =========================================================== */
.docs {
  position: relative;
  isolation: isolate;
  padding: clamp(92px, 11vh, 128px) 0 var(--sp-9);
  min-height: 100vh;
}
/* ambient accent glow, top-right — same language as .app-walkthrough::before */
.docs::before {
  content: "";
  position: absolute;
  top: -60px; right: -220px;
  width: 640px; height: 640px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--acc-glow), transparent 64%);
  filter: blur(130px);
  opacity: 0.42;
  z-index: -1;
  pointer-events: none;
}

.docs-grid {
  display: grid;
  grid-template-columns: 244px minmax(0, 1fr) 216px;
  gap: clamp(28px, 4vw, 68px);
  align-items: start;
}

/* ---------- Left sidebar ---------- */
.docs-side { position: relative; }
.doc-nav {
  position: sticky;
  top: 88px;
  max-height: calc(100vh - 112px);
  overflow-y: auto;
  overscroll-behavior: contain;
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  padding-right: 6px;
  scrollbar-width: thin;
  scrollbar-color: var(--hairline-strong) transparent;
}
.doc-nav::-webkit-scrollbar { width: 6px; }
.doc-nav::-webkit-scrollbar-thumb { background: var(--hairline-strong); border-radius: 99px; }

.doc-search {
  position: relative;
  display: flex; align-items: center; gap: var(--sp-1);
  padding: 10px 12px;
  border-radius: var(--r-3);
  background: var(--surf-1);
  border: 1px solid var(--hairline);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.doc-search:focus-within {
  border-color: var(--acc);
  box-shadow: 0 0 0 3px oklch(0.7 0.18 var(--acc-h) / 0.16);
}
.doc-search svg { width: 16px; height: 16px; color: var(--text-3); flex: none; }
.doc-search input {
  flex: 1; min-width: 0;
  background: none; border: none; outline: none;
  color: var(--text-1); font: inherit; font-size: 0.9rem;
}
.doc-search input::placeholder { color: var(--text-4); }

.doc-nav-group { display: flex; flex-direction: column; gap: 2px; }
.doc-nav-label {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 6px;
  padding-left: 12px;
}
.doc-nav-link {
  position: relative;
  text-align: left;
  padding: 7px 12px;
  border-radius: var(--r-2);
  border: 1px solid transparent;
  background: none;
  color: var(--text-2);
  font: inherit; font-size: 0.9rem;
  cursor: pointer;
  transition: color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
}
.doc-nav-link:hover { color: var(--text-1); background: var(--surf-1); }
.doc-nav-link.is-active {
  color: var(--text-1);
  background: var(--surf-2);
  border-color: var(--hairline);
}
.doc-nav-link.is-active::before {
  content: "";
  position: absolute; left: 0; top: 50%;
  transform: translateY(-50%);
  width: 3px; height: 16px; border-radius: 99px;
  background: var(--acc-bright);
  box-shadow: 0 0 10px var(--acc-glow);
}
.doc-search-results { display: flex; flex-direction: column; gap: 2px; }
.doc-nav-empty { color: var(--text-3); font-size: 0.85rem; padding: 8px 12px; }

/* ---------- Main content ---------- */
.docs-main { min-width: 0; max-width: 760px; }
.doc-crumb {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.72rem;
  color: var(--text-3);
  margin-bottom: var(--sp-3);
}
.doc-crumb a { color: var(--text-3); text-decoration: none; transition: color var(--dur-fast); }
.doc-crumb a:hover { color: var(--acc-soft); }

.doc-title {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 1.5rem + 2.4vw, 3.4rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0 0 var(--sp-2);
}
.doc-lead {
  font-size: var(--fs-lead);
  color: var(--text-2);
  line-height: 1.5;
  margin: 0 0 var(--sp-5);
  max-width: 60ch;
}
.doc-body { color: var(--text-2); }
.doc-h2 {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1.2rem + 1vw, 2rem);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--text-1);
  margin: var(--sp-6) 0 var(--sp-3);
  padding-bottom: 10px;
  border-bottom: 1px solid var(--hairline);
  scroll-margin-top: 96px;
}
.doc-h3 {
  font-size: clamp(1.15rem, 1rem + 0.6vw, 1.4rem);
  font-weight: 600;
  color: var(--text-1);
  margin: var(--sp-5) 0 var(--sp-2);
  scroll-margin-top: 96px;
}
.doc-p { font-size: var(--fs-body); line-height: 1.7; margin: 0 0 var(--sp-3); }

.doc-ul { list-style: none; padding-left: 0; margin: 0 0 var(--sp-4); display: flex; flex-direction: column; gap: 8px; }
.doc-ul li { position: relative; padding-left: 1.5em; line-height: 1.6; font-size: var(--fs-body); }
.doc-ul li::before {
  content: ""; position: absolute; left: 4px; top: 0.62em;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--acc); box-shadow: 0 0 8px var(--acc-glow);
}
.doc-steps { counter-reset: step; list-style: none; padding-left: 0; margin: 0 0 var(--sp-4); display: flex; flex-direction: column; gap: 12px; }
.doc-steps li { position: relative; padding-left: 2.6em; line-height: 1.6; font-size: var(--fs-body); min-height: 1.9em; display: flex; align-items: center; }
.doc-steps li::before {
  counter-increment: step;
  content: counter(step);
  position: absolute; left: 0; top: 0;
  width: 1.8em; height: 1.8em;
  display: grid; place-items: center;
  border-radius: 50%;
  background: var(--surf-2);
  border: 1px solid var(--hairline-strong);
  color: var(--acc-soft);
  font-family: var(--font-mono); font-size: 0.78rem;
}

.doc-code {
  position: relative;
  margin: 0 0 var(--sp-4);
  padding: 18px 18px 16px;
  border-radius: var(--r-3);
  background: oklch(0.12 0.025 282 / 0.78);
  border: 1px solid var(--hairline);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: 0.84rem; line-height: 1.6;
  color: var(--text-1);
}
.doc-code code { font-family: inherit; white-space: pre; }
.doc-code[data-lang]:not([data-lang=""])::before {
  content: attr(data-lang);
  position: absolute; top: 10px; right: 12px;
  font-size: 0.6rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--text-4);
}
.doc-code::-webkit-scrollbar { height: 8px; }
.doc-code::-webkit-scrollbar-thumb { background: var(--hairline-strong); border-radius: 99px; }

.doc-note {
  position: relative;
  margin: 0 0 var(--sp-4);
  padding: 14px 16px 14px 44px;
  border-radius: var(--r-3);
  border: 1px solid var(--hairline);
  background: var(--surf-1);
  font-size: 0.9rem; line-height: 1.6;
  color: var(--text-2);
}
.doc-note::before {
  position: absolute; left: 15px; top: 13px;
  font-family: var(--font-mono); font-size: 0.95rem; font-weight: 600;
}
.doc-note--info { border-left: 3px solid var(--acc); }
.doc-note--info::before { content: "i"; color: var(--acc-soft); }
.doc-note--tip  { border-left: 3px solid oklch(0.72 0.16 160); }
.doc-note--tip::before  { content: "\2726"; color: oklch(0.8 0.16 160); }
.doc-note--warn { border-left: 3px solid oklch(0.78 0.16 75); }
.doc-note--warn::before { content: "!"; color: oklch(0.84 0.16 75); }

.doc-pager {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3);
  margin-top: var(--sp-7);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--hairline);
}
.doc-pager-link {
  display: flex; flex-direction: column; gap: 6px;
  padding: 16px 18px;
  border-radius: var(--r-3);
  background: var(--surf-1);
  border: 1px solid var(--hairline);
  cursor: pointer;
  text-align: left;
  transition: border-color var(--dur-fast), transform var(--dur-fast), background var(--dur-fast);
}
.doc-pager-link.next { text-align: right; }
.doc-pager-link:hover { border-color: var(--acc); transform: translateY(-2px); background: var(--surf-2); }
.doc-pager-link span { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-3); }
.doc-pager-link strong { color: var(--text-1); font-weight: 600; font-size: 0.98rem; }

/* ---------- Right TOC ---------- */
.docs-toc {
  position: sticky;
  top: 88px;
  align-self: start;
  display: flex; flex-direction: column; gap: 8px;
  font-size: 0.82rem;
  max-height: calc(100vh - 112px);
  overflow-y: auto;
}
.docs-toc ul { list-style: none; display: flex; flex-direction: column; border-left: 1px solid var(--hairline); }
.docs-toc li a {
  display: block;
  padding: 5px 0 5px 14px;
  margin-left: -1px;
  border-left: 2px solid transparent;
  color: var(--text-3);
  text-decoration: none; line-height: 1.4;
  transition: color var(--dur-fast), border-color var(--dur-fast);
}
.docs-toc li.lvl-3 a { padding-left: 26px; font-size: 0.78rem; }
.docs-toc li a:hover { color: var(--text-1); }
.docs-toc li.is-active a { color: var(--acc-soft); border-left-color: var(--acc-bright); }

/* ---------- Mobile drawer toggle (desktop: hidden) ---------- */
.doc-nav-toggle {
  display: none;
  align-items: center; gap: 8px;
  margin: 0 auto var(--sp-4);
  padding: 10px 18px;
  border-radius: var(--r-pill);
  background: var(--surf-2);
  border: 1px solid var(--hairline);
  color: var(--text-1);
  font: inherit; font-size: 0.9rem; cursor: pointer;
}
.doc-nav-toggle svg { width: 16px; height: 16px; }

/* ---------- Responsive ---------- */
@media (max-width: 1180px) {
  .docs-grid { grid-template-columns: 230px minmax(0, 1fr); }
  .docs-toc { display: none; }
}
@media (max-width: 860px) {
  .docs { padding-top: clamp(78px, 10vh, 104px); }
  .doc-nav-toggle { display: inline-flex; }
  .docs-grid { grid-template-columns: 1fr; }
  .docs-side {
    position: fixed; inset: 0 auto 0 0;
    z-index: 60;
    width: min(82vw, 320px);
    padding: 84px 20px 24px;
    background: var(--surf-3);
    backdrop-filter: blur(30px) saturate(160%);
    -webkit-backdrop-filter: blur(30px) saturate(160%);
    border-right: 1px solid var(--hairline-strong);
    transform: translateX(-100%);
    transition: transform var(--dur-mid) var(--ease-out);
    overflow-y: auto;
  }
  .docs-side.is-open { transform: none; box-shadow: var(--shadow-card); }
  .doc-nav { position: static; max-height: none; }
}

/* ---------- Theme + motion tuning ---------- */
[data-theme="light"] .doc-code { background: oklch(0.96 0.006 280 / 0.92); color: var(--text-1); }
[data-theme="light"] .docs::before { opacity: 0.26; }
@media (prefers-reduced-motion: reduce) {
  .doc-pager-link:hover { transform: none; }
  .docs-side { transition: none; }
}

/* ===== Legal / policy pages (Cookies, Security, Terms, Privacy, DPA) ===== */
.legal { min-height: 60vh; }
.legal-hero { position: relative; overflow: hidden; padding: clamp(72px, 11vw, 132px) 0 clamp(30px, 5vw, 54px); border-bottom: 1px solid var(--hairline); }
.legal-hero-glow { position: absolute; inset: 0; background: radial-gradient(58% 120% at 16% -12%, oklch(0.55 0.22 var(--acc-h) / 0.22), transparent 60%); pointer-events: none; }
.legal-hero .container { position: relative; }
.legal-hero h1 { font-size: clamp(2.2rem, 5vw, 3.4rem); margin: 14px 0 16px; letter-spacing: -0.02em; }
.legal-hero .lead { font-size: 1.05rem; color: var(--text-2); max-width: 62ch; line-height: 1.62; }
.legal-updated { color: var(--text-3); font-size: 0.78rem; margin-top: 18px; }
.legal-grid { display: grid; grid-template-columns: minmax(0,1fr) 220px; gap: clamp(28px, 5vw, 64px); padding-top: clamp(34px, 5vw, 56px); padding-bottom: var(--sp-8); align-items: start; }
.legal-main { min-width: 0; max-width: 72ch; }
.legal-section { margin-bottom: 38px; scroll-margin-top: 96px; }
.legal-section h2 { font-size: 1.4rem; letter-spacing: -0.01em; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--hairline); }
.legal-section p { color: var(--text-2); line-height: 1.72; margin-bottom: 14px; font-size: 0.97rem; }
.legal-h3 { font-size: 1.05rem; margin: 18px 0 8px; }
.legal-list { display: grid; gap: 9px; margin: 4px 0 16px; padding-left: 0; list-style: none; }
.legal-list li { position: relative; padding-left: 22px; color: var(--text-2); line-height: 1.6; font-size: 0.95rem; }
.legal-list li::before { content: ""; position: absolute; left: 4px; top: 9px; width: 6px; height: 6px; border-radius: 50%; background: oklch(0.7 0.2 var(--acc-h)); }
.legal-note { border: 1px solid oklch(0.7 0.18 var(--acc-h) / 0.32); background: oklch(0.6 0.2 var(--acc-h) / 0.07); border-radius: 14px; padding: 14px 16px; font-size: 0.9rem; color: var(--text-2); line-height: 1.6; margin: 6px 0 16px; }
.legal-table-wrap { overflow-x: auto; margin: 6px 0 18px; border: 1px solid var(--hairline); border-radius: 14px; }
.legal-table { width: 100%; border-collapse: collapse; font-size: 0.85rem; min-width: 440px; }
.legal-table th { text-align: left; padding: 11px 14px; background: var(--surf-1); color: var(--text-3); font-weight: 600; font-size: 0.7rem; letter-spacing: 0.06em; text-transform: uppercase; border-bottom: 1px solid var(--hairline); }
.legal-table td { padding: 11px 14px; color: var(--text-2); border-bottom: 1px solid var(--hairline); vertical-align: top; }
.legal-table tr:last-child td { border-bottom: none; }
.legal-foot { color: var(--text-3); font-size: 0.74rem; padding-top: 20px; border-top: 1px solid var(--hairline); }
.legal-toc { position: sticky; top: 92px; align-self: start; }
.legal-toc ul { list-style: none; padding: 0; margin: 8px 0 0; display: grid; gap: 2px; border-left: 1px solid var(--hairline); }
.legal-toc li a { display: block; padding: 5px 0 5px 14px; margin-left: -1px; border-left: 2px solid transparent; color: var(--text-3); font-size: 0.83rem; line-height: 1.4; transition: color .15s, border-color .15s; }
.legal-toc li a:hover { color: var(--text-1); }
.legal-toc li.is-active a { color: oklch(0.8 0.14 var(--acc-h)); border-left-color: oklch(0.7 0.2 var(--acc-h)); }
@media (max-width: 820px) { .legal-grid { grid-template-columns: 1fr; } .legal-toc { display: none; } }

/* ===== Status page ===== */
.status-banner { display: inline-flex; align-items: center; gap: 10px; padding: 9px 16px; border-radius: var(--r-pill); font-weight: 500; font-size: 0.95rem; margin-top: 8px; border: 1px solid var(--hairline); }
.status-banner .status-dot { width: 9px; height: 9px; border-radius: 50%; }
.status-banner.is-up { background: oklch(0.65 0.16 150 / 0.12); border-color: oklch(0.65 0.16 150 / 0.4); color: oklch(0.8 0.16 150); }
.status-banner.is-up .status-dot { background: oklch(0.72 0.18 150); box-shadow: 0 0 10px oklch(0.72 0.18 150); }
.status-banner.is-down { background: oklch(0.62 0.2 25 / 0.12); border-color: oklch(0.62 0.2 25 / 0.4); color: oklch(0.74 0.2 25); }
.status-banner.is-down .status-dot { background: oklch(0.66 0.22 25); box-shadow: 0 0 10px oklch(0.66 0.22 25); }
.status-banner.is-load { color: var(--text-3); }
.status-banner.is-load .status-dot { background: var(--text-3); }
.status-row { padding: 18px 0; border-bottom: 1px solid var(--hairline); }
.status-row-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.status-hub { font-family: var(--font-display); font-size: 1.1rem; font-weight: 500; }
.status-pill { font-size: 0.72rem; font-weight: 600; padding: 3px 10px; border-radius: var(--r-pill); letter-spacing: 0.02em; }
.status-pill.is-up { background: oklch(0.65 0.16 150 / 0.14); color: oklch(0.8 0.16 150); }
.status-pill.is-down { background: oklch(0.62 0.2 25 / 0.14); color: oklch(0.76 0.2 25); }
.status-pill.is-none { background: var(--surf-2); color: var(--text-3); }
.status-bars { display: flex; gap: 4px; }
.status-bar { flex: 1; height: 34px; border-radius: 4px; background: var(--surf-2); transition: filter .15s; }
.status-bar.is-up { background: oklch(0.68 0.16 150); }
.status-bar.is-down { background: oklch(0.62 0.21 25); }
.status-bar.is-none { background: var(--surf-2); }
.status-bars .status-bar:hover { filter: brightness(1.2); }
.status-axis { display: flex; justify-content: space-between; color: var(--text-3); font-size: 0.66rem; margin-top: 6px; }
.status-legend { display: flex; gap: 18px; margin-top: 24px; color: var(--text-3); font-size: 0.78rem; align-items: center; flex-wrap: wrap; }
.status-legend span { display: inline-flex; align-items: center; gap: 7px; }
.status-legend i.status-bar { width: 22px; height: 12px; flex: none; display: inline-block; }
