/* ───────────────────────────────────────────────────────────
   SpaceJam — Landing Page
   System: deep space dark + restrained violet/pink glow
   Type:   Space Grotesk (display) · Inter (body) · JetBrains Mono (labels)
   ─────────────────────────────────────────────────────────── */

:root {
  --void:      #07060f;
  --void-2:    #0a0814;
  --nebula:    #120a1f;
  --nebula-2:  #1a0e2e;
  --card:      rgba(20, 12, 36, 0.55);
  --card-hi:   rgba(28, 16, 48, 0.7);

  --violet:    #9b4dff;
  --violet-2:  #c97bff;
  --pink:      #ff4daa;
  --teal:      #00d4c8;
  --gold:      #ffd700;

  --ink:       #f0eaff;
  --ink-2:     #cdc2e6;
  --ink-mute:  #7a6e9a;
  --ink-soft:  #5a5278;

  --line:      rgba(155, 77, 255, 0.16);
  --line-2:    rgba(155, 77, 255, 0.08);
  --hairline:  rgba(255, 255, 255, 0.06);

  --radius-sm: 10px;
  --radius:    18px;
  --radius-lg: 28px;

  --maxw:      1240px;
  --pad-x:     clamp(20px, 4vw, 56px);

  --grad-brand:    linear-gradient(92deg, #9b4dff 0%, #c97bff 35%, #ff4daa 100%);
  --grad-brand-2:  linear-gradient(135deg, #9b4dff, #ff4daa);
  --grad-cool:     linear-gradient(135deg, #9b4dff, #00d4c8);

  --shadow-glow:   0 24px 80px -20px rgba(155, 77, 255, 0.4);
  --shadow-card:   0 30px 80px -30px rgba(0, 0, 0, 0.9);
  --shadow-phone:  0 60px 120px -30px rgba(0,0,0,0.8),
                   0 20px 60px -20px rgba(155, 77, 255, 0.35);
}

/* ─── Reset / base ─── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--void);
  color: var(--ink);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }

/* ─── Ambient space backdrop ─── */
/* Layer 1 — diffuse nebula clouds (large, blurred color washes) */
body::before {
  content: '';
  position: fixed;
  inset: -10%;
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(40% 35% at 18% 22%, rgba(155, 77, 255, 0.22), transparent 65%),
    radial-gradient(35% 30% at 82% 15%, rgba(255, 77, 170, 0.16), transparent 65%),
    radial-gradient(45% 35% at 70% 78%, rgba(0, 212, 200, 0.10), transparent 65%),
    radial-gradient(30% 25% at 30% 88%, rgba(201, 123, 255, 0.14), transparent 65%),
    radial-gradient(25% 20% at 90% 50%, rgba(255, 215, 0, 0.06), transparent 70%);
  filter: blur(60px);
  opacity: 0.85;
}

/* Layer 2 — multi-density starfield (3 sizes scattered) */
.starfield {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image:
    /* tiny stars — dense field */
    radial-gradient(0.7px 0.7px at 3% 4%,   rgba(255,255,255,0.55), transparent 50%),
    radial-gradient(0.7px 0.7px at 12% 22%, rgba(255,255,255,0.55), transparent 50%),
    radial-gradient(0.7px 0.7px at 78% 18%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 33% 78%, rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.7px 0.7px at 88% 64%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 55% 42%, rgba(255,255,255,0.4),  transparent 50%),
    radial-gradient(0.7px 0.7px at 22% 56%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 65% 88%, rgba(255,255,255,0.4),  transparent 50%),
    radial-gradient(0.7px 0.7px at 8% 70%,  rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 92% 32%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 44% 64%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 18% 38%, rgba(255,255,255,0.4),  transparent 50%),
    radial-gradient(0.7px 0.7px at 72% 50%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 38% 8%,  rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.7px 0.7px at 95% 88%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 5% 5%,   rgba(255,255,255,0.4),  transparent 50%),
    radial-gradient(0.7px 0.7px at 60% 22%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 28% 92%, rgba(255,255,255,0.4),  transparent 50%),
    radial-gradient(0.7px 0.7px at 76% 70%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 2% 36%,  rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.7px 0.7px at 16% 12%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 24% 4%,  rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.7px 0.7px at 34% 46%, rgba(255,255,255,0.4),  transparent 50%),
    radial-gradient(0.7px 0.7px at 42% 26%, rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.7px 0.7px at 52% 60%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 58% 76%, rgba(255,255,255,0.4),  transparent 50%),
    radial-gradient(0.7px 0.7px at 66% 4%,  rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.7px 0.7px at 70% 28%, rgba(255,255,255,0.4),  transparent 50%),
    radial-gradient(0.7px 0.7px at 80% 44%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 86% 8%,  rgba(255,255,255,0.4),  transparent 50%),
    radial-gradient(0.7px 0.7px at 98% 56%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 6% 84%,  rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 14% 96%, rgba(255,255,255,0.4),  transparent 50%),
    radial-gradient(0.7px 0.7px at 36% 36%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 48% 84%, rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.7px 0.7px at 62% 50%, rgba(255,255,255,0.4),  transparent 50%),
    radial-gradient(0.7px 0.7px at 82% 96%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 90% 76%, rgba(255,255,255,0.4),  transparent 50%),
    radial-gradient(0.7px 0.7px at 50% 16%, rgba(255,255,255,0.45), transparent 50%),
    radial-gradient(0.7px 0.7px at 26% 68%, rgba(255,255,255,0.4),  transparent 50%),
    /* medium stars — softly glowing */
    radial-gradient(1.6px 1.6px at 47% 14%, rgba(255,255,255,0.75), transparent 55%),
    radial-gradient(1.6px 1.6px at 14% 52%, rgba(220,210,255,0.65), transparent 55%),
    radial-gradient(1.6px 1.6px at 84% 80%, rgba(255,235,220,0.65), transparent 55%),
    radial-gradient(1.6px 1.6px at 62% 36%, rgba(200,220,255,0.6),  transparent 55%),
    radial-gradient(1.6px 1.6px at 30% 30%, rgba(255,220,240,0.6),  transparent 55%),
    radial-gradient(1.6px 1.6px at 88% 18%, rgba(255,255,255,0.65), transparent 55%),
    radial-gradient(1.6px 1.6px at 10% 84%, rgba(220,200,255,0.6),  transparent 55%),
    radial-gradient(1.6px 1.6px at 56% 88%, rgba(255,235,220,0.6),  transparent 55%),
    radial-gradient(1.6px 1.6px at 74% 60%, rgba(255,220,240,0.55), transparent 55%),
    radial-gradient(1.6px 1.6px at 40% 70%, rgba(200,220,255,0.55), transparent 55%),
    /* large twinkle stars — rare, with color */
    radial-gradient(2.4px 2.4px at 25% 70%, rgba(255,255,255,0.9),  transparent 60%),
    radial-gradient(2.4px 2.4px at 70% 12%, rgba(255,235,200,0.85), transparent 60%),
    radial-gradient(2.4px 2.4px at 50% 86%, rgba(220,200,255,0.8),  transparent 60%),
    radial-gradient(2.4px 2.4px at 92% 44%, rgba(220,240,255,0.8),  transparent 60%),
    radial-gradient(2.4px 2.4px at 8% 28%,  rgba(255,220,240,0.8),  transparent 60%);
  animation: starfield-breathe 8s ease-in-out infinite;
}
@keyframes starfield-breathe {
  0%, 100% { opacity: 0.85; }
  50%      { opacity: 1; }
}
/* Layer 2b — second offset starfield, blinking on a different rhythm */
.starfield::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(0.8px 0.8px at 7% 14%,  rgba(255,255,255,0.55), transparent 50%),
    radial-gradient(0.8px 0.8px at 21% 8%,  rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.8px 0.8px at 37% 18%, rgba(255,255,255,0.55), transparent 50%),
    radial-gradient(0.8px 0.8px at 53% 28%, rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.8px 0.8px at 69% 38%, rgba(255,255,255,0.55), transparent 50%),
    radial-gradient(0.8px 0.8px at 85% 48%, rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.8px 0.8px at 11% 58%, rgba(255,255,255,0.55), transparent 50%),
    radial-gradient(0.8px 0.8px at 27% 68%, rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.8px 0.8px at 43% 78%, rgba(255,255,255,0.55), transparent 50%),
    radial-gradient(0.8px 0.8px at 59% 88%, rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.8px 0.8px at 75% 98%, rgba(255,255,255,0.55), transparent 50%),
    radial-gradient(0.8px 0.8px at 91% 6%,  rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.8px 0.8px at 5% 46%,  rgba(255,255,255,0.55), transparent 50%),
    radial-gradient(0.8px 0.8px at 19% 32%, rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.8px 0.8px at 35% 54%, rgba(255,255,255,0.55), transparent 50%),
    radial-gradient(0.8px 0.8px at 49% 42%, rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.8px 0.8px at 63% 64%, rgba(255,255,255,0.55), transparent 50%),
    radial-gradient(0.8px 0.8px at 77% 24%, rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.8px 0.8px at 93% 84%, rgba(255,255,255,0.55), transparent 50%),
    radial-gradient(0.8px 0.8px at 4% 74%,  rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.8px 0.8px at 17% 86%, rgba(255,255,255,0.55), transparent 50%),
    radial-gradient(0.8px 0.8px at 31% 96%, rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.8px 0.8px at 45% 14%, rgba(255,255,255,0.55), transparent 50%),
    radial-gradient(0.8px 0.8px at 67% 76%, rgba(255,255,255,0.5),  transparent 50%),
    radial-gradient(0.8px 0.8px at 81% 36%, rgba(255,255,255,0.55), transparent 50%),
    radial-gradient(1.4px 1.4px at 23% 24%, rgba(220,210,255,0.65), transparent 55%),
    radial-gradient(1.4px 1.4px at 67% 58%, rgba(255,235,220,0.65), transparent 55%),
    radial-gradient(1.4px 1.4px at 9% 92%,  rgba(255,255,255,0.7),  transparent 55%),
    radial-gradient(1.4px 1.4px at 79% 6%,  rgba(200,220,255,0.6),  transparent 55%);
  animation: blink-slow 5.5s ease-in-out infinite;
  opacity: 0.7;
}
.starfield::after {
  /* slow twinkle on the brighter color stars */
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(3px 3px at 25% 70%, rgba(155, 77, 255, 0.55), transparent 60%),
    radial-gradient(3px 3px at 70% 12%, rgba(255, 215, 0, 0.45),  transparent 60%),
    radial-gradient(3px 3px at 50% 86%, rgba(255, 77, 170, 0.45), transparent 60%),
    radial-gradient(3px 3px at 47% 14%, rgba(0, 212, 200, 0.4),   transparent 60%),
    radial-gradient(3px 3px at 92% 44%, rgba(155, 77, 255, 0.4),  transparent 60%),
    radial-gradient(3px 3px at 8% 28%,  rgba(255, 77, 170, 0.4),  transparent 60%),
    radial-gradient(3px 3px at 88% 78%, rgba(0, 212, 200, 0.35),  transparent 60%),
    radial-gradient(3px 3px at 14% 84%, rgba(255, 215, 0, 0.35),  transparent 60%);
  opacity: 0.6;
  animation: twinkle 6s ease-in-out infinite;
}
@keyframes twinkle {
  0%, 100% { opacity: 0.45; }
  25%      { opacity: 0.9; }
  50%      { opacity: 0.6; }
  75%      { opacity: 0.95; }
}
@keyframes blink-slow {
  0%, 100% { opacity: 0.4; }
  35%      { opacity: 0.85; }
  65%      { opacity: 0.55; }
}
@media (prefers-reduced-motion: reduce) {
  .starfield,
  .starfield::before,
  .starfield::after { animation: none; }
}

/* Layer 3 — film grain */
body::after {
  content:'';
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0.04;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

.orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  pointer-events: none;
  z-index: 0;
  opacity: 0.55;
}

/* ─── Layout primitives ─── */
.container {
  max-width: var(--maxw);
  margin: 0 auto;
  padding-inline: var(--pad-x);
  position: relative;
  z-index: 2;
}

.section { padding: clamp(80px, 11vw, 160px) 0; position: relative; }
.section--tight { padding: clamp(48px, 7vw, 96px) 0; }

.eyebrow {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.28em;
  color: var(--ink-mute);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.eyebrow::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--violet);
  box-shadow: 0 0 12px var(--violet);
}
.eyebrow--teal::before { background: var(--teal); box-shadow: 0 0 12px var(--teal); }
.eyebrow--gold::before { background: var(--gold); box-shadow: 0 0 12px var(--gold); }
.eyebrow--pink::before { background: var(--pink); box-shadow: 0 0 12px var(--pink); }

h1, h2, h3, h4 {
  font-family: 'Space Grotesk', system-ui, sans-serif;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0;
}
h2 { font-size: clamp(36px, 5vw, 60px); }
h3 { font-size: clamp(24px, 2.4vw, 32px); letter-spacing: -0.01em; line-height: 1.2; }

.lead {
  color: var(--ink-2);
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.6;
  max-width: 56ch;
}

.grad-text {
  background: var(--grad-brand);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* ─── Buttons ─── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 22px;
  border-radius: 100px;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: -0.005em;
  transition: transform .15s ease, box-shadow .25s ease, background .25s ease, border-color .2s;
  white-space: nowrap;
}
.btn svg { width: 16px; height: 16px; }
.btn--primary {
  background: var(--grad-brand-2);
  color: white;
  box-shadow: 0 12px 30px -10px rgba(255, 77, 170, 0.55),
              0 0 0 1px rgba(255,255,255,0.08) inset;
}
.btn--primary:hover { transform: translateY(-1px); box-shadow: 0 16px 40px -10px rgba(255, 77, 170, 0.7), 0 0 0 1px rgba(255,255,255,0.12) inset; }
.btn--ghost {
  background: transparent;
  color: var(--ink);
  border: 1px solid rgba(255,255,255,0.14);
}
.btn--ghost:hover { border-color: var(--violet); background: rgba(155, 77, 255, 0.06); }
.btn--teal {
  background: var(--teal);
  color: #03241f;
  font-weight: 700;
}
.btn--teal:hover { transform: translateY(-1px); box-shadow: 0 14px 30px -10px rgba(0,212,200,0.5); }
.btn--lg { padding: 18px 30px; font-size: 17px; }
.btn--xl { padding: 22px 36px; font-size: 19px; }

/* Admin button — quiet but distinct shield-style */
.btn--admin {
  background: rgba(0, 212, 200, 0.06);
  color: var(--teal);
  border: 1px solid rgba(0, 212, 200, 0.28);
  letter-spacing: 0.04em;
}
.btn--admin svg { width: 14px; height: 14px; }
.btn--admin:hover {
  background: rgba(0, 212, 200, 0.12);
  border-color: rgba(0, 212, 200, 0.5);
  box-shadow: 0 0 0 3px rgba(0, 212, 200, 0.08);
}
@media (max-width: 720px) {
  .nav__cta .btn--admin { display: none; }
}

/* ─── Glass card ─── */
.glass {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  backdrop-filter: blur(20px) saturate(120%);
  -webkit-backdrop-filter: blur(20px) saturate(120%);
}

/* ═══════════════════════════════════════════════════════════
   NAV
   ═══════════════════════════════════════════════════════════ */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(7, 6, 15, 0.7);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border-bottom: 1px solid var(--line-2);
}
.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px var(--pad-x);
  max-width: var(--maxw);
  margin: 0 auto;
  gap: 32px;
  min-height: 60px;
}
.nav__brand {
  display: inline-flex;
  align-items: center;
}
.nav__brand img {
  height: 42px;
  width: auto;
  filter: drop-shadow(0 0 22px rgba(255, 77, 170, 0.3));
}
.nav__links {
  display: flex;
  gap: 36px;
  list-style: none;
  padding: 0; margin: 0;
}
.nav__links a {
  font-size: 14px;
  color: var(--ink-2);
  transition: color .2s;
  letter-spacing: -0.005em;
}
.nav__links a:hover { color: var(--ink); }
.nav__cta { display: flex; gap: 12px; align-items: center; }
.nav__cta .btn { padding: 11px 18px; font-size: 14px; }

.nav__burger {
  display: none;
  width: 40px; height: 40px;
  border-radius: 10px;
  border: 1px solid var(--line);
  align-items: center;
  justify-content: center;
}
.nav__burger span {
  width: 16px; height: 1.5px; background: var(--ink); position: relative;
}
.nav__burger span::before,
.nav__burger span::after {
  content:''; position: absolute; left: 0; width: 100%; height: 100%; background: var(--ink);
}
.nav__burger span::before { top: -5px; }
.nav__burger span::after  { top: 5px; }

@media (max-width: 960px) {
  .nav__links { display: none; }
  .nav__cta .btn--ghost { display: none; }
  .nav__burger { display: inline-flex; }
}

/* ═══════════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════════ */
.hero {
  position: relative;
  padding: clamp(80px, 12vw, 140px) 0 clamp(60px, 8vw, 100px);
  overflow: hidden;
  isolation: isolate;
}
.hero__orb-1 {
  width: 720px; height: 720px;
  background: radial-gradient(closest-side, rgba(155, 77, 255, 0.55), transparent 70%);
  top: -180px; left: -180px;
}
.hero__orb-2 {
  width: 640px; height: 640px;
  background: radial-gradient(closest-side, rgba(255, 77, 170, 0.4), transparent 70%);
  top: 40%; right: -220px;
}
.hero__orb-3 {
  width: 420px; height: 420px;
  background: radial-gradient(closest-side, rgba(0, 212, 200, 0.18), transparent 70%);
  bottom: -120px; left: 30%;
  opacity: 0.7;
}

/* Hero brand logo — big, transparent, with presence */
.hero__logo {
  display: flex;
  justify-content: center;
  margin: 0 auto clamp(28px, 5vw, 56px);
  position: relative;
  z-index: 2;
}
.hero__logo img {
  width: clamp(280px, 42vw, 560px);
  height: auto;
  filter:
    drop-shadow(0 0 60px rgba(155, 77, 255, 0.55))
    drop-shadow(0 0 120px rgba(255, 77, 170, 0.35))
    drop-shadow(0 8px 24px rgba(0, 0, 0, 0.5));
  animation: hero-logo-float 7s ease-in-out infinite;
}
@keyframes hero-logo-float {
  0%, 100% { transform: translateY(0) scale(1); filter: drop-shadow(0 0 60px rgba(155, 77, 255, 0.55)) drop-shadow(0 0 120px rgba(255, 77, 170, 0.35)) drop-shadow(0 8px 24px rgba(0,0,0,0.5)); }
  50%      { transform: translateY(-6px) scale(1.012); filter: drop-shadow(0 0 80px rgba(155, 77, 255, 0.7)) drop-shadow(0 0 160px rgba(255, 77, 170, 0.5)) drop-shadow(0 12px 28px rgba(0,0,0,0.55)); }
}
@media (prefers-reduced-motion: reduce) {
  .hero__logo img { animation: none; }
}

.hero__pill {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 14px;
  border-radius: 100px;
  background: rgba(255, 215, 0, 0.07);
  border: 1px solid rgba(255, 215, 0, 0.18);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 28px;
}
.hero__pill .dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--teal);
  box-shadow: 0 0 12px var(--teal);
  animation: pulse 1.8s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.4; transform: scale(0.85); }
}

.hero h1 {
  font-size: clamp(44px, 7.2vw, 96px);
  line-height: 0.98;
  letter-spacing: -0.035em;
  font-weight: 600;
  margin: 0 0 28px;
  max-width: 14ch;
}
.hero h1 .grad-text {
  background: linear-gradient(95deg, #9b4dff 0%, #c97bff 40%, #ff4daa 90%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero h1 em {
  font-style: italic;
  font-weight: 400;
  font-family: 'Space Grotesk';
  color: var(--ink-2);
}

.hero__sub {
  font-size: clamp(17px, 1.4vw, 21px);
  color: var(--ink-2);
  max-width: 56ch;
  line-height: 1.55;
  margin: 0 0 40px;
}

.hero__ctas {
  display: flex;
  gap: 14px;
  margin-bottom: 56px;
  flex-wrap: wrap;
}

.hero__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: clamp(40px, 6vw, 80px);
  align-items: center;
}

@media (max-width: 1024px) {
  .hero__layout { grid-template-columns: 1fr; }
}

/* Trust meta strip */
.hero__meta {
  display: flex;
  gap: clamp(20px, 3vw, 48px);
  flex-wrap: wrap;
  padding-top: 36px;
  border-top: 1px solid var(--hairline);
}
.meta-stat__num {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.meta-stat__label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ink-mute);
  margin-top: 4px;
}

/* ─── Hero phone showcase ─── */
.phones {
  position: relative;
  width: 100%;
  height: clamp(520px, 60vw, 720px);
  perspective: 1800px;
}
.phone {
  position: absolute;
  width: 280px;
  aspect-ratio: 1122 / 1852;
  border-radius: 32px;
  background: #0a0814;
  padding: 6px;
  box-shadow: var(--shadow-phone);
  border: 1px solid rgba(255,255,255,0.07);
  transition: transform .6s cubic-bezier(.2,.8,.2,1);
}
.phone::before {
  /* soft inner ring highlight */
  content:'';
  position: absolute;
  inset: 0;
  border-radius: 32px;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(255,255,255,0.07), transparent 30%);
  z-index: 2;
}
.phone__screen {
  position: relative;
  border-radius: 26px;
  overflow: hidden;
  height: 100%;
  background: #07060f;
}
.phone__screen img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}
.phone--center {
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(0deg);
  z-index: 3;
  width: 300px;
}
.phone--left {
  left: 0%;
  top: 50%;
  transform: translate(-10%, -50%) rotate(-9deg);
  z-index: 2;
}
.phone--right {
  right: 0%;
  top: 50%;
  transform: translate(10%, -50%) rotate(9deg);
  z-index: 2;
}
@media (max-width: 720px) {
  .phones { height: 560px; }
  .phone { width: 230px; }
  .phone--center { width: 250px; }
  .phone--left  { transform: translate(-25%, -50%) rotate(-10deg); }
  .phone--right { transform: translate(25%, -50%)  rotate(10deg); }
}

/* ═══════════════════════════════════════════════════════════
   SECTION HEADERS
   ═══════════════════════════════════════════════════════════ */
.section-head {
  display: grid;
  gap: 18px;
  margin-bottom: 64px;
  max-width: 760px;
}
.section-head h2 {
  font-weight: 600;
  letter-spacing: -0.028em;
}
.section-head h2 em {
  font-style: italic; font-weight: 400; color: var(--ink-mute);
}

/* ═══════════════════════════════════════════════════════════
   SPLIT FEATURE (image + copy)
   ═══════════════════════════════════════════════════════════ */
.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 96px);
  align-items: center;
}
.split--reverse .split__visual { order: 2; }
.split + .split { margin-top: clamp(80px, 10vw, 140px); }

@media (max-width: 880px) {
  .split { grid-template-columns: 1fr; }
  .split--reverse .split__visual { order: 0; }
}

.split__copy h3 {
  font-size: clamp(30px, 3.6vw, 48px);
  font-weight: 600;
  letter-spacing: -0.025em;
  margin: 18px 0 20px;
  line-height: 1.08;
}
.split__copy p {
  color: var(--ink-2);
  font-size: 17px;
  line-height: 1.6;
  margin: 0 0 28px;
  max-width: 52ch;
}
.split__points {
  list-style: none;
  margin: 0; padding: 0;
  display: grid;
  gap: 14px;
}
.split__points li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  color: var(--ink-2);
  font-size: 15px;
}
.split__points li svg {
  flex-shrink: 0;
  width: 18px; height: 18px;
  margin-top: 2px;
  color: var(--violet-2);
}

/* Visual stage */
.stage {
  position: relative;
  isolation: isolate;
}
.stage::before {
  content:'';
  position: absolute;
  inset: -10% -5%;
  background: radial-gradient(60% 50% at 50% 50%, rgba(155,77,255,0.25), transparent 70%);
  filter: blur(40px);
  z-index: -1;
}
.stage--pink::before { background: radial-gradient(60% 50% at 50% 50%, rgba(255,77,170,0.22), transparent 70%); }
.stage--teal::before { background: radial-gradient(60% 50% at 50% 50%, rgba(0,212,200,0.18), transparent 70%); }

.phone-static {
  width: 100%;
  max-width: 340px;
  aspect-ratio: 1122 / 1852;
  border-radius: 32px;
  background: #0a0814;
  padding: 6px;
  margin: 0 auto;
  box-shadow: var(--shadow-phone);
  border: 1px solid rgba(255,255,255,0.07);
  position: relative;
}
.phone-static::before {
  content:'';
  position: absolute;
  inset: 0;
  border-radius: 32px;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(255,255,255,0.08), transparent 35%);
  z-index: 2;
}
.phone-static__screen {
  border-radius: 26px;
  overflow: hidden;
  height: 100%;
  background: #07060f;
}
.phone-static__screen img {
  width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block;
}

/* Dual phone stage */
.duo {
  position: relative;
  width: 100%;
  aspect-ratio: 5/4;
  max-width: 560px;
  margin: 0 auto;
}
.duo .phone-static {
  position: absolute;
  width: 55%;
}
.duo .phone-static:nth-child(1) {
  left: 0; top: 0;
  transform: rotate(-5deg);
  z-index: 1;
}
.duo .phone-static:nth-child(2) {
  right: 0; bottom: 0;
  transform: rotate(5deg);
  z-index: 2;
}

/* Web/desktop window mock */
.window {
  position: relative;
  border-radius: 14px;
  background: #08060f;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: var(--shadow-phone);
  overflow: hidden;
}
.window__bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 11px 14px;
  background: linear-gradient(180deg, rgba(255,255,255,0.04), transparent);
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.window__bar i {
  width: 11px; height: 11px; border-radius: 50%;
  background: rgba(255,255,255,0.12);
  display: inline-block;
}
.window__bar i:nth-child(1) { background: #ff5f57; }
.window__bar i:nth-child(2) { background: #febc2e; }
.window__bar i:nth-child(3) { background: #28c840; }
.window__bar .window__url {
  margin-left: 14px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
}
.window img {
  width: 100%;
  height: auto;
  display: block;
}

/* ═══════════════════════════════════════════════════════════
   FEATURE GRID
   ═══════════════════════════════════════════════════════════ */
.feat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
@media (max-width: 980px) { .feat-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px) { .feat-grid { grid-template-columns: 1fr; } }

.feat {
  position: relative;
  padding: 28px;
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(28,16,48,0.55), rgba(16,9,28,0.55));
  border: 1px solid var(--line-2);
  transition: border-color .25s, transform .25s;
  overflow: hidden;
  min-height: 240px;
}
.feat:hover { border-color: var(--line); transform: translateY(-2px); }
.feat::after {
  /* corner glow */
  content: '';
  position: absolute;
  width: 200px; height: 200px;
  border-radius: 50%;
  top: -80px; right: -80px;
  background: radial-gradient(closest-side, rgba(155,77,255,0.22), transparent 70%);
  pointer-events: none;
  opacity: 0;
  transition: opacity .3s;
}
.feat:hover::after { opacity: 1; }
.feat--pink::after { background: radial-gradient(closest-side, rgba(255,77,170,0.22), transparent 70%); }
.feat--teal::after { background: radial-gradient(closest-side, rgba(0,212,200,0.22), transparent 70%); }
.feat--gold::after { background: radial-gradient(closest-side, rgba(255,215,0,0.18), transparent 70%); }

.feat__icon {
  display: inline-flex;
  align-items: center; justify-content: center;
  width: 48px; height: 48px;
  border-radius: 12px;
  background: rgba(155, 77, 255, 0.12);
  border: 1px solid rgba(155, 77, 255, 0.24);
  margin-bottom: 22px;
  color: var(--violet-2);
}
.feat--pink .feat__icon { background: rgba(255,77,170,0.1); border-color: rgba(255,77,170,0.22); color: var(--pink); }
.feat--teal .feat__icon { background: rgba(0,212,200,0.1); border-color: rgba(0,212,200,0.22); color: var(--teal); }
.feat--gold .feat__icon { background: rgba(255,215,0,0.08); border-color: rgba(255,215,0,0.18); color: var(--gold); }
.feat__icon svg { width: 22px; height: 22px; }
.feat h3 {
  font-size: 22px;
  margin-bottom: 10px;
  letter-spacing: -0.015em;
}
.feat p {
  color: var(--ink-2);
  font-size: 14.5px;
  line-height: 1.55;
  margin: 0;
}
.feat__tag {
  display: inline-block;
  margin-top: 16px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--ink-mute);
  text-transform: uppercase;
  padding: 5px 9px;
  border-radius: 6px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--hairline);
}

/* ═══════════════════════════════════════════════════════════
   TOOLS STRIP (Tuner / Metro / Looper / Memos)
   ═══════════════════════════════════════════════════════════ */
.tools {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
@media (max-width: 880px) { .tools { grid-template-columns: repeat(2, 1fr); } }

.tool {
  padding: 24px 22px;
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0));
  border: 1px solid var(--hairline);
  transition: border-color .2s;
}
.tool:hover { border-color: var(--line); }
.tool__label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.tool h4 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.015em;
  margin: 6px 0 8px;
}
.tool p {
  margin: 0;
  color: var(--ink-2);
  font-size: 14px;
  line-height: 1.5;
}
.tool__icon {
  margin-bottom: 14px;
  width: 32px; height: 32px;
  color: var(--violet-2);
}

/* ═══════════════════════════════════════════════════════════
   PRICING
   ═══════════════════════════════════════════════════════════ */
.toggle {
  display: inline-flex;
  background: rgba(20, 12, 36, 0.65);
  border: 1px solid var(--line);
  padding: 4px;
  border-radius: 100px;
  font-size: 13px;
  margin: 24px 0 56px;
}
.toggle button {
  padding: 10px 18px;
  border-radius: 100px;
  color: var(--ink-mute);
  font-weight: 500;
  transition: color .2s, background .2s;
  position: relative;
}
.toggle button.active {
  color: white;
  background: var(--grad-brand-2);
  box-shadow: 0 8px 20px -10px rgba(255,77,170,0.5);
}
.toggle__save {
  display: inline-block;
  margin-left: 8px;
  font-size: 10px;
  background: rgba(0,212,200,0.15);
  color: var(--teal);
  padding: 2px 8px;
  border-radius: 100px;
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: 0.06em;
}

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

.price-card {
  padding: 36px 30px;
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, rgba(20,12,36,0.75), rgba(12,7,24,0.85));
  border: 1px solid var(--line-2);
  display: flex; flex-direction: column;
  position: relative;
  overflow: hidden;
}
.price-card--featured {
  border-color: rgba(255,215,0,0.35);
  background: linear-gradient(180deg, rgba(38,24,8,0.55), rgba(20,12,36,0.85));
  box-shadow:
    0 0 0 1px rgba(255,215,0,0.15) inset,
    0 30px 80px -20px rgba(255,215,0,0.12);
}
.price-card--featured::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, rgba(255,215,0,0.25), transparent 50%);
  z-index: -1;
}
.price-card--enterprise {
  border-color: rgba(0,212,200,0.25);
}
.price-card__badge {
  position: absolute;
  top: 18px; right: 20px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 5px 10px;
  border-radius: 100px;
  border: 1px solid var(--line);
  color: var(--ink-mute);
  background: rgba(0,0,0,0.3);
}
.price-card--featured .price-card__badge {
  border-color: rgba(255,215,0,0.4);
  color: var(--gold);
  background: rgba(255,215,0,0.06);
}
.price-card--enterprise .price-card__badge {
  border-color: rgba(0,212,200,0.4);
  color: var(--teal);
  background: rgba(0,212,200,0.06);
}
.price-card__name {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 28px;
}
.price-card__price {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 56px;
  font-weight: 600;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--ink);
  display: flex;
  align-items: baseline;
  gap: 6px;
}
.price-card__price small {
  font-size: 15px;
  font-weight: 400;
  color: var(--ink-mute);
  letter-spacing: 0;
}
.price-card__desc {
  margin: 12px 0 32px;
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.5;
}
.price-card__features {
  list-style: none;
  padding: 0; margin: 0 0 32px;
  display: grid;
  gap: 13px;
  flex-grow: 1;
}
.price-card__features li {
  display: flex;
  gap: 11px;
  font-size: 14px;
  color: var(--ink-2);
  align-items: flex-start;
}
.price-card__features li svg { flex-shrink: 0; width: 16px; height: 16px; color: var(--violet-2); margin-top: 3px; }
.price-card--featured .price-card__features li svg { color: var(--gold); }
.price-card--enterprise .price-card__features li svg { color: var(--teal); }
.price-card__features li.muted { color: var(--ink-soft); }
.price-card__features li.muted svg { color: var(--ink-soft); }
.price-card .btn { width: 100%; justify-content: center; }

.pricing-note {
  text-align: center;
  margin-top: 32px;
  font-size: 13px;
  color: var(--ink-mute);
}

/* ═══════════════════════════════════════════════════════════
   FAQ
   ═══════════════════════════════════════════════════════════ */
.faq {
  max-width: 820px;
  margin: 0 auto;
  display: grid;
  gap: 4px;
}
.faq__item {
  border-bottom: 1px solid var(--hairline);
  padding: 24px 0;
}
.faq__item summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 19px;
  font-weight: 500;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item .plus {
  width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  border: 1px solid var(--line);
  color: var(--violet-2);
  transition: transform .25s, background .25s;
  flex-shrink: 0;
}
.faq__item[open] .plus { transform: rotate(45deg); background: rgba(155,77,255,0.12); }
.faq__item p {
  margin: 16px 0 0;
  color: var(--ink-2);
  font-size: 15.5px;
  line-height: 1.65;
  max-width: 64ch;
}

/* ═══════════════════════════════════════════════════════════
   STAGE / EVENT FEATURE (full-bleed style)
   ═══════════════════════════════════════════════════════════ */
.stage-feature {
  position: relative;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, rgba(155,77,255,0.07), rgba(255,77,170,0.04));
  border: 1px solid var(--line);
  padding: clamp(40px, 5vw, 72px);
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: center;
  overflow: hidden;
  isolation: isolate;
}
.stage-feature::before {
  content:'';
  position: absolute;
  width: 600px; height: 600px;
  border-radius: 50%;
  right: -150px; top: -200px;
  background: radial-gradient(closest-side, rgba(255, 77, 170, 0.25), transparent 70%);
  filter: blur(40px);
  z-index: -1;
}
@media (max-width: 880px) {
  .stage-feature { grid-template-columns: 1fr; }
}
.stage-feature h3 {
  font-size: clamp(30px, 3.8vw, 48px);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.05;
  margin: 16px 0 20px;
}
.stage-feature p {
  color: var(--ink-2);
  font-size: 17px;
  line-height: 1.6;
  margin: 0 0 32px;
  max-width: 48ch;
}

/* ═══════════════════════════════════════════════════════════
   GLOBAL REACH
   ═══════════════════════════════════════════════════════════ */
.globe-section {
  text-align: center;
  position: relative;
}
.globe {
  position: relative;
  width: min(720px, 90vw);
  aspect-ratio: 2/1;
  margin: 48px auto 56px;
}
.globe svg {
  width: 100%;
  height: 100%;
}
.globe__stats {
  display: flex;
  justify-content: center;
  gap: clamp(20px, 4vw, 64px);
  flex-wrap: wrap;
  padding: 28px 0;
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
}
.globe__stat .n {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 600;
  letter-spacing: -0.02em;
  background: var(--grad-brand);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.globe__stat .l {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--ink-mute);
  text-transform: uppercase;
}

.testimonials {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 72px;
}
@media (max-width: 880px) { .testimonials { grid-template-columns: 1fr; } }
.tcard {
  padding: 28px;
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(20,12,36,0.55), rgba(12,7,24,0.55));
  border: 1px solid var(--line-2);
  text-align: left;
}
.tcard__quote {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 17px;
  line-height: 1.55;
  color: var(--ink);
  letter-spacing: -0.01em;
  margin-bottom: 24px;
}
.tcard__quote::before {
  content: '“';
  font-size: 48px;
  line-height: 0.5;
  color: var(--violet-2);
  display: block;
  margin-bottom: 12px;
  font-family: 'Space Grotesk';
}
.tcard__who {
  display: flex;
  align-items: center;
  gap: 12px;
}
.tcard__avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--grad-brand-2);
  font-family: 'Space Grotesk';
  font-weight: 600;
  font-size: 14px;
  color: white;
  display: flex; align-items: center; justify-content: center;
  letter-spacing: 0;
}
.tcard__name {
  font-size: 14px;
  font-weight: 500;
}
.tcard__role {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
}

/* ═══════════════════════════════════════════════════════════
   FINAL CTA
   ═══════════════════════════════════════════════════════════ */
.final-cta {
  position: relative;
  text-align: center;
  padding: clamp(80px, 12vw, 160px) var(--pad-x);
  overflow: hidden;
  isolation: isolate;
}
.final-cta__orb-1 {
  width: 800px; height: 800px;
  background: radial-gradient(closest-side, rgba(155, 77, 255, 0.4), transparent 70%);
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  opacity: 0.7;
}
.final-cta__orb-2 {
  width: 600px; height: 600px;
  background: radial-gradient(closest-side, rgba(255, 77, 170, 0.3), transparent 70%);
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
}
.final-cta h2 {
  font-size: clamp(48px, 8vw, 110px);
  letter-spacing: -0.035em;
  line-height: 0.98;
  margin: 0 auto 24px;
  max-width: 14ch;
}
.final-cta p {
  font-size: clamp(17px, 1.4vw, 21px);
  color: var(--ink-2);
  max-width: 56ch;
  margin: 0 auto 48px;
  line-height: 1.5;
}
.final-cta__platforms {
  margin-top: 32px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--ink-mute);
  text-transform: uppercase;
  display: flex;
  justify-content: center;
  gap: 28px;
  flex-wrap: wrap;
}
.final-cta__platforms span { position: relative; }
.final-cta__platforms span + span::before {
  content: '·';
  position: absolute;
  left: -16px;
  color: var(--ink-soft);
}

/* ═══════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════ */
footer {
  padding: 72px 0 32px;
  border-top: 1px solid var(--hairline);
  position: relative;
  z-index: 2;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 56px;
}
@media (max-width: 720px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
.footer__brand img { height: 24px; margin-bottom: 18px; }
.footer__brand p {
  color: var(--ink-mute);
  font-size: 14px;
  line-height: 1.55;
  margin: 0;
  max-width: 32ch;
}
.footer__col h5 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--ink-mute);
  text-transform: uppercase;
  margin: 0 0 18px;
  font-weight: 500;
}
.footer__col ul {
  list-style: none;
  padding: 0; margin: 0;
  display: grid;
  gap: 12px;
}
.footer__col a {
  color: var(--ink-2);
  font-size: 14px;
  transition: color .2s;
}
.footer__col a:hover { color: var(--violet-2); }

.footer__bottom {
  padding-top: 24px;
  border-top: 1px solid var(--hairline);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  font-size: 12px;
  color: var(--ink-mute);
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: 0.04em;
}

/* ─── Animation reveal ─── */
[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .8s cubic-bezier(.2,.8,.2,1), transform .8s cubic-bezier(.2,.8,.2,1);
}
[data-reveal].in {
  opacity: 1; transform: translateY(0);
}

/* ─── Mobile menu overlay ─── */
.mobile-menu {
  position: fixed;
  inset: 0;
  background: rgba(7,6,15,0.96);
  backdrop-filter: blur(20px);
  z-index: 100;
  display: none;
  padding: 80px var(--pad-x) 40px;
  flex-direction: column;
  gap: 6px;
}
.mobile-menu.open { display: flex; }
.mobile-menu a {
  font-family: 'Space Grotesk';
  font-size: 32px;
  letter-spacing: -0.02em;
  padding: 14px 0;
  border-bottom: 1px solid var(--hairline);
  color: var(--ink);
}
.mobile-menu__close {
  position: absolute;
  top: 18px; right: var(--pad-x);
  width: 40px; height: 40px;
  border-radius: 50%;
  border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  color: var(--ink);
}
.mobile-menu .btn { margin-top: 24px; align-self: flex-start; }
