/* ═══════════════════════════════════════════════════════════════
   PADEL PIPELINE — DESIGN SYSTEM
   Emil-informed: restraint, precision, detail obsession
   Editorial typography: Instrument Serif + Geist
   ═══════════════════════════════════════════════════════════════ */

/* ─── Reset ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body { line-height: 1.5; }
img, svg { display: block; max-width: 100%; }
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }
a { color: inherit; text-decoration: none; }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: 2px; }

/* ─── Tokens ─── */
:root {
  /* Colour — dark first, one accent leads */
  --bg: #0a0a0c;
  --bg-elev: #0f0f12;
  --bg-light: #f6f4ef;
  --bg-light-elev: #ffffff;

  --fg: #f2f0eb;
  --fg-dim: #a8a7a3;
  --fg-mute: #6b6a67;
  --fg-dark: #17171a;
  --fg-dark-dim: #52525a;
  --fg-dark-mute: #8a8a92;

  --border: #1c1c21;
  --border-strong: #2a2a30;
  --border-light: #e3e0d8;
  --border-light-strong: #c9c5ba;

  /* Accents — demoted. Used as signals, not decoration */
  --accent: #5841ea;           /* primary — indigo */
  --accent-soft: #8471ff;      /* indigo for dark bg */
  --accent-teal: #46c9c1;      /* vertical-specific */
  --accent-pink: #f480d3;      /* vertical-specific */

  /* Typography */
  --ff-display: 'Bricolage Grotesque', 'Inter Tight', -apple-system, BlinkMacSystemFont, sans-serif;
  --ff-body: 'Geist', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --ff-mono: 'JetBrains Mono', 'SF Mono', Menlo, ui-monospace, monospace;

  /* Motion — Emil curves */
  --ease-out: cubic-bezier(0.23, 1, 0.32, 1);
  --ease-in-out: cubic-bezier(0.77, 0, 0.175, 1);
  --ease-drawer: cubic-bezier(0.32, 0.72, 0, 1);

  /* Layout */
  --max-w: 1180px;
  --max-w-prose: 680px;
  --pad-x: clamp(1.25rem, 4vw, 2.5rem);
  --sec-y: clamp(5rem, 10vw, 9rem);
}

/* ─── Base ─── */
body {
  font-family: var(--ff-body);
  font-weight: 400;
  font-size: 16px;
  color: var(--fg);
  background: var(--bg);
  letter-spacing: -0.005em;
}
body.light {
  color: var(--fg-dark);
  background: var(--bg-light);
}
body.modal-open { overflow: hidden; }

::selection { background: var(--accent); color: var(--fg); }

/* ─── Typography primitives ─── */
.serif { font-family: var(--ff-display); font-weight: 700; letter-spacing: -0.03em; }
.mono { font-family: var(--ff-mono); }
.italic { font-style: italic; }

.eyebrow {
  font-family: var(--ff-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-mute);
}
.light .eyebrow { color: var(--fg-dark-mute); }

/* ─── New mark system: ICON + LABEL (icons replace /NN/ numbers) ─── */
.mark {
  display: inline-flex; align-items: center;
  font-family: var(--ff-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-mute);
}
.light .mark { color: var(--fg-dark-mute); }
.mark-icon {
  width: 14px; height: 14px;
  margin-right: 0.625rem;
  color: var(--accent-soft);
  flex-shrink: 0;
}
.light .mark-icon { color: var(--accent); }
.mark-icon svg { width: 100%; height: 100%; display: block; }
.mark-label { color: var(--fg); }
.light .mark-label { color: var(--fg-dark); }
/* Offering section has light bg but doesn't use .light class — needs explicit override */
.offering-section .mark-label { color: var(--fg-dark-mute); }
.mark-sub {
  color: var(--fg-mute);
  margin-left: 0.625rem;
  position: relative;
}
.light .mark-sub { color: var(--fg-dark-mute); }
.mark-sub::before {
  content: '·';
  margin-right: 0.625rem;
  color: var(--fg-mute);
  opacity: 0.5;
}
.light .mark-sub::before { color: var(--fg-dark-mute); }

/* Legacy number variant kept for backward compat — unused in final */
.mark-num {
  color: var(--accent-soft);
  margin-right: 0.625rem;
  font-weight: 600;
}
.light .mark-num { color: var(--accent); }
.mark-sep {
  color: var(--fg-mute);
  margin: 0 0.625rem;
  opacity: 0.5;
}
.light .mark-sep { color: var(--fg-dark-mute); }

/* Inline variant — no number, just a slash-prefixed label */
.mark-inline {
  display: inline-flex; align-items: center;
  font-family: var(--ff-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-mute);
}
.light .mark-inline { color: var(--fg-dark-mute); }
.mark-inline::before {
  content: '/';
  color: var(--accent-soft);
  margin-right: 0.5rem;
  font-weight: 600;
}
.light .mark-inline::before { color: var(--accent); }

/* Gradient text utility — use sparingly */
.grad-accent {
  background: linear-gradient(90deg, var(--accent-soft) 0%, var(--accent-pink) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  /* Italic skew can clip the right edge — add right padding to compensate at line wraps */
  padding-right: 0.15em;
  /* Treat as atomic unit so the italic phrase wraps together, not mid-word */
  display: inline-block;
  vertical-align: baseline;
}
/* On light backgrounds, use the fuller-contrast indigo */
.light .grad-accent,
.offering-section .grad-accent {
  background: linear-gradient(90deg, var(--accent) 0%, var(--accent-pink) 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

h1, h2, h3, h4 { font-family: var(--ff-display); font-weight: 700; letter-spacing: -0.03em; line-height: 1; }
p { line-height: 1.6; color: var(--fg-dim); }
.light p { color: var(--fg-dark-dim); }

/* ═══════════════════════════════════════════════════════════════
   NAVIGATION
   ═══════════════════════════════════════════════════════════════ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  padding: 1rem var(--pad-x);
  background: rgba(10, 10, 12, 0.6);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid transparent;
  transition: border-color 200ms var(--ease-out), background 200ms var(--ease-out);
}
.nav.scrolled { border-bottom-color: var(--border); background: rgba(10, 10, 12, 0.85); }
.nav-inner {
  max-width: var(--max-w); margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
}
.nav-logo { display: flex; align-items: center; gap: 0.625rem; }
.nav-logo svg { width: 24px; height: 24px; }
.nav-logo-text {
  font-family: var(--ff-display); font-size: 1.125rem; letter-spacing: -0.01em;
  color: var(--fg);
}
.nav-links { display: flex; align-items: center; gap: 2rem; }
.nav-link {
  font-size: 0.875rem; color: var(--fg-dim);
  transition: color 150ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .nav-link:hover { color: var(--fg); }
}
.nav-cta {
  font-size: 0.875rem; color: var(--fg);
  padding: 0.5rem 1rem; border-radius: 100px;
  border: 1px solid var(--border-strong);
  transition: border-color 150ms var(--ease-out), background 150ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .nav-cta:hover { border-color: var(--fg-dim); background: rgba(255,255,255,0.03); }
}
.nav-cta:active { transform: scale(0.97); }
.nav-mobile-toggle { display: none; padding: 0.5rem; color: var(--fg); }
.nav-mobile-toggle svg { width: 20px; height: 20px; }

@media (max-width: 760px) {
  .nav-links { display: none; }
  .nav-mobile-toggle { display: flex; }
  .nav-links.open {
    display: flex; flex-direction: column;
    position: absolute; top: 100%; left: 0; right: 0;
    padding: 1.5rem var(--pad-x) 2rem;
    background: var(--bg);
    border-bottom: 1px solid var(--border);
    gap: 1.25rem; align-items: flex-start;
  }
}

/* ═══════════════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════════════ */
.hero {
  min-height: 100vh;
  display: flex;
  padding: 6rem var(--pad-x) var(--sec-y);
  position: relative;
  overflow: hidden;
}
.hero-inner {
  max-width: var(--max-w); margin: 0 auto; width: 100%;
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  grid-template-rows: 1fr auto;
  column-gap: clamp(2rem, 4vw, 4rem);
  row-gap: 0;
  align-items: center;
}
/* Left column: label + H1 + sub + buttons as a single cohesive block, vertically centred */
.hero-copy {
  grid-column: 1;
  grid-row: 1;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  min-width: 0;
}
.hero-copy > .hero-label { margin-bottom: 0.5rem; }
.hero-notifications {
  grid-column: 2;
  grid-row: 1;
  align-self: center;
}
/* Proof strip spans both columns as a bottom anchor */
.hero > .hero-inner > .hero-proof {
  grid-column: 1 / -1;
  grid-row: 2;
  align-self: end;
  margin-top: clamp(3rem, 6vh, 5rem);
}
.hero-label {
  display: inline-flex; align-items: center;
  font-family: var(--ff-mono);
  font-size: 0.75rem; color: var(--fg-dim);
  width: fit-content;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  animation: fade-up 600ms var(--ease-out) both;
}
.hero-label .mark-icon {
  color: var(--accent-soft);
}

.hero h1 {
  font-size: clamp(2.5rem, 6vw, 5rem);
  line-height: 0.98;
  letter-spacing: -0.035em;
  max-width: 13ch;
  animation: fade-up 700ms var(--ease-out) both;
  animation-delay: 80ms;
}
.hero h1 em {
  font-style: italic; color: var(--fg-dim);
  font-weight: 400;
}

.hero-sub {
  font-size: 1.0625rem;
  max-width: 48ch;
  color: var(--fg-dim);
  animation: fade-up 700ms var(--ease-out) both;
  animation-delay: 160ms;
}

.hero-actions {
  display: flex; gap: 0.75rem; flex-wrap: wrap;
  animation: fade-up 700ms var(--ease-out) both;
  animation-delay: 240ms;
}

/* Hero background — padel court geometry, abstract */
.hero-bg {
  position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(ellipse 60% 50% at 60% 20%, rgba(88, 65, 234, 0.15), transparent 70%),
    radial-gradient(ellipse 40% 30% at 15% 85%, rgba(70, 201, 193, 0.06), transparent 70%);
  transition: transform 50ms linear;
  will-change: transform;
}

/* ───────────────────────────────────────────────
   Hero notification stack — representative engagements
   ─────────────────────────────────────────────── */
.hero-notifications {
  position: relative;
  animation: fade-up 900ms var(--ease-out) both;
  animation-delay: 340ms;
}
.hero-notif-stack {
  position: relative;
  min-height: 300px;
}
.hero-notif-card {
  position: absolute;
  top: 0; left: 0; right: 0;
  padding: 1.25rem 1.375rem;
  background: #14121c;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  box-shadow: 0 16px 40px -12px rgba(0, 0, 0, 0.6), 0 2px 6px rgba(0, 0, 0, 0.3);
  transition: transform 560ms var(--ease-out), opacity 560ms var(--ease-out);
  will-change: transform, opacity;
}
/* Stack positions — card at each slot gets progressively pushed down and faded */
.hero-notif-card[data-slot="0"] {
  transform: translateY(0) scale(1);
  opacity: 1;
  z-index: 4;
}
.hero-notif-card[data-slot="1"] {
  transform: translateY(92px) scale(0.97);
  opacity: 0.78;
  z-index: 3;
}
.hero-notif-card[data-slot="2"] {
  transform: translateY(178px) scale(0.94);
  opacity: 0.5;
  z-index: 2;
}
.hero-notif-card[data-slot="3"] {
  transform: translateY(246px) scale(0.91);
  opacity: 0;
  z-index: 1;
  pointer-events: none;
}
/* Entering card starts above, invisible */
.hero-notif-card[data-state="entering"] {
  transform: translateY(-30px) scale(1.02);
  opacity: 0;
}
/* Card header — vertical tag + time-frame */
.hero-notif-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.375rem;
}
.hero-notif-vertical {
  font-family: var(--ff-mono);
  font-size: 0.625rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
}
.hero-notif-vertical::before {
  content: '';
  width: 6px; height: 6px; border-radius: 50%;
  background: currentColor;
}
.hero-notif-frame {
  font-family: var(--ff-mono);
  font-size: 0.625rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--fg-mute);
}
.hero-notif-body {
  font-size: 0.9375rem;
  line-height: 1.45;
  color: var(--fg);
  font-weight: 500;
}
.hero-notif-metric {
  font-family: var(--ff-display);
  font-weight: 700;
  letter-spacing: -0.01em;
}

/* Vertical colour coding */
.hero-notif-card[data-vertical="clubs"] .hero-notif-vertical { color: var(--accent-soft); }
.hero-notif-card[data-vertical="brands"] .hero-notif-vertical { color: var(--accent-pink); }
.hero-notif-card[data-vertical="events"] .hero-notif-vertical { color: var(--accent-teal); }
.hero-notif-card[data-vertical="tech"] .hero-notif-vertical { color: #c9a6ff; }

/* Hero proof strip — verticals visible from the hero */
.hero-proof {
  display: flex; align-items: center;
  gap: clamp(0.75rem, 1.8vw, 1.25rem);
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
  font-family: var(--ff-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-mute);
  flex-wrap: wrap;
  animation: fade-up 700ms var(--ease-out) both;
  animation-delay: 320ms;
}
.hero-proof-label {
  color: var(--fg-dim);
}
.hero-proof-item {
  color: var(--fg-dim);
  position: relative;
}
.hero-proof-item::before {
  content: '/';
  margin-right: 0.5rem;
  font-weight: 600;
}
.hero-proof-item:nth-child(2)::before { color: var(--accent-soft); }
.hero-proof-item:nth-child(3)::before { color: var(--accent-teal); }
.hero-proof-item:nth-child(4)::before { color: var(--accent-pink); }
.hero-proof-item:nth-child(5)::before { color: var(--fg-dim); }

@media (max-width: 560px) {
  .hero-proof { font-size: 0.625rem; gap: 0.5rem; }
}

/* Hero 2-column responsive — stacks on tablet/mobile */
@media (max-width: 960px) {
  .hero-inner {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto;
    row-gap: 3rem;
  }
  .hero-copy,
  .hero-notifications,
  .hero > .hero-inner > .hero-proof {
    grid-column: 1;
    grid-row: auto;
  }
  .hero-notifications {
    max-width: 420px;
  }
}
@media (max-width: 560px) {
  .hero-notif-stack { min-height: 230px; }
  .hero-notif-body { font-size: 0.875rem; }
}

/* ═══════════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════════ */
.btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-size: 0.9375rem; font-weight: 500;
  padding: 0.75rem 1.125rem; border-radius: 100px;
  transition: background 150ms var(--ease-out), transform 100ms var(--ease-out), border-color 150ms var(--ease-out);
}
.btn:active { transform: scale(0.97); }
.btn svg { width: 14px; height: 14px; transition: transform 200ms var(--ease-out); }
@media (hover: hover) and (pointer: fine) {
  .btn:hover svg { transform: translateX(2px); }
}

.btn-primary {
  background: var(--fg);
  color: var(--bg);
  border: 1px solid var(--fg);
}
@media (hover: hover) and (pointer: fine) {
  .btn-primary:hover { background: #ffffff; }
}

.btn-ghost {
  background: transparent;
  color: var(--fg);
  border: 1px solid var(--border-strong);
}
@media (hover: hover) and (pointer: fine) {
  .btn-ghost:hover { border-color: var(--fg-dim); background: rgba(255,255,255,0.03); }
}

.light .btn-primary { background: var(--fg-dark); color: var(--bg-light); border-color: var(--fg-dark); }
.light .btn-ghost { color: var(--fg-dark); border-color: var(--border-light-strong); }
@media (hover: hover) and (pointer: fine) {
  .light .btn-ghost:hover { border-color: var(--fg-dark-dim); background: rgba(0,0,0,0.03); }
}

/* ═══════════════════════════════════════════════════════════════
   SECTIONS — shared
   ═══════════════════════════════════════════════════════════════ */
.section {
  padding: var(--sec-y) var(--pad-x);
  position: relative;
}
.section.light { background: var(--bg-light); color: var(--fg-dark); }
.section-inner { max-width: var(--max-w); margin: 0 auto; }

.section-header { margin-bottom: clamp(3rem, 6vw, 5rem); max-width: 42rem; }
.section-header .eyebrow { margin-bottom: 1rem; }
.section-header h2 {
  font-size: clamp(2rem, 4.5vw, 3.25rem);
  line-height: 1.02;
  letter-spacing: -0.025em;
  margin-bottom: 1.25rem;
}
.section-header h2 em { font-style: italic; color: var(--fg-dim); font-weight: 400; }
.light .section-header h2 em { color: var(--fg-dark-mute); }
.section-header p {
  font-size: 1rem;
  max-width: 50ch;
}

/* Reveal on scroll */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity 700ms var(--ease-out), transform 700ms var(--ease-out); }
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal[data-stagger="1"] { transition-delay: 40ms; }
.reveal[data-stagger="2"] { transition-delay: 80ms; }
.reveal[data-stagger="3"] { transition-delay: 120ms; }
.reveal[data-stagger="4"] { transition-delay: 160ms; }

/* ═══════════════════════════════════════════════════════════════
   PILLARS — Build / Brand / Scale
   ═══════════════════════════════════════════════════════════════ */
.pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: 4px;
  overflow: hidden;
}
.light .pillars {
  background: var(--border-light);
  border-color: var(--border-light);
}
.pillar {
  background: var(--bg);
  padding: clamp(2rem, 3.5vw, 3rem);
  display: flex; flex-direction: column;
  min-height: 24rem;
  position: relative;
  overflow: hidden;
}
.light .pillar { background: var(--bg-light); }
/* Coloured top border per pillar */
.pillar::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: currentColor;
}
/* Subtle accent-toned background glow */
.pillar::after {
  content: ''; position: absolute; top: 0; right: 0;
  width: 70%; height: 60%;
  background: radial-gradient(ellipse at top right, currentColor, transparent 70%);
  opacity: 0.05;
  pointer-events: none;
}
.light .pillar::after { opacity: 0.04; }
.pillar:nth-child(1) { color: var(--accent); }
.pillar:nth-child(2) { color: var(--accent-teal); }
.pillar:nth-child(3) { color: var(--accent-pink); }
.light .pillar:nth-child(1) { color: var(--accent); }
.light .pillar:nth-child(2) { color: #2db8af; }   /* slightly darker teal for legibility on light */
.light .pillar:nth-child(3) { color: #d9519a; }   /* slightly darker pink for legibility on light */

.pillar-num {
  font-family: var(--ff-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  margin-bottom: 1.5rem;
  text-transform: uppercase;
  display: inline-flex; align-items: center;
  color: var(--fg-mute);
  position: relative; z-index: 1;
}
.light .pillar-num { color: var(--fg-dark-mute); }
.pillar-num .pillar-icon {
  width: 16px; height: 16px;
  margin-right: 0.625rem;
  color: currentColor;
  flex-shrink: 0;
}
.pillar-num .pillar-icon svg { width: 100%; height: 100%; display: block; }
.pillar-num .pillar-label {
  color: var(--fg);
}
.light .pillar-num .pillar-label { color: var(--fg-dark); }
/* Icon takes the accent colour */
.pillar:nth-child(1) .pillar-num .pillar-icon { color: var(--accent); }
.pillar:nth-child(2) .pillar-num .pillar-icon { color: var(--accent-teal); }
.light .pillar:nth-child(2) .pillar-num .pillar-icon { color: #2db8af; }
.pillar:nth-child(3) .pillar-num .pillar-icon { color: var(--accent-pink); }
.light .pillar:nth-child(3) .pillar-num .pillar-icon { color: #d9519a; }

.pillar h3 {
  font-size: clamp(1.5rem, 2.2vw, 2rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin-bottom: 1rem;
  color: var(--fg);
  position: relative; z-index: 1;
}
.light .pillar h3 { color: var(--fg-dark); }
.pillar h3 em { font-style: italic; color: var(--fg-dim); font-weight: 400; }
.light .pillar h3 em { color: var(--fg-dark-dim); }

.pillar p {
  font-size: 0.9375rem;
  margin-bottom: 2rem;
  flex-grow: 1;
  color: var(--fg-dim);
  position: relative; z-index: 1;
}
.light .pillar p { color: var(--fg-dark-dim); }

.pillar-list {
  list-style: none;
  display: flex; flex-direction: column;
  gap: 0.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
  position: relative; z-index: 1;
}
.light .pillar-list { border-top-color: var(--border-light); }
.pillar-list li {
  font-size: 0.8125rem;
  color: var(--fg-dim);
  display: flex; align-items: center; gap: 0.5rem;
}
.light .pillar-list li { color: var(--fg-dark-dim); }
.pillar-list li::before {
  content: ''; width: 4px; height: 4px; border-radius: 50%;
  background: currentColor;
  opacity: 0.6;
}

@media (max-width: 860px) {
  .pillars { grid-template-columns: 1fr; }
  .pillar { min-height: 0; }
}

/* ═══════════════════════════════════════════════════════════════
   VERTICALS / ECOSYSTEM
   ═══════════════════════════════════════════════════════════════ */
.verticals {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--border-light);
  border: 1px solid var(--border-light);
  border-radius: 4px;
  overflow: hidden;
}
.vertical {
  background: var(--bg-light);
  padding: clamp(1.75rem, 3vw, 2.5rem);
  position: relative;
  transition: background 200ms var(--ease-out);
}
.vertical::before {
  content: ''; position: absolute; top: 0; bottom: 0; left: 0;
  width: 2px; background: currentColor;
}
.vertical:nth-child(1) { color: var(--accent); }
.vertical:nth-child(2) { color: var(--accent-teal); }
.vertical:nth-child(3) { color: var(--accent-pink); }
.vertical:nth-child(4) { color: var(--fg-dark); }
@media (hover: hover) and (pointer: fine) {
  .vertical:hover { background: var(--bg-light-elev); }
}
.vertical-tag {
  font-family: var(--ff-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: currentColor;
  margin-bottom: 1rem;
  display: inline-flex; align-items: center;
}
.vertical-tag::before {
  content: '/';
  margin-right: 0.5rem;
  font-weight: 600;
  color: currentColor;
}
.vertical-tag .dot { display: none; }

.vertical h3 {
  font-size: clamp(1.5rem, 2.2vw, 1.875rem);
  letter-spacing: -0.02em;
  margin-bottom: 0.875rem;
  color: var(--fg-dark);
}
.vertical p {
  font-size: 0.9375rem;
  color: var(--fg-dark-dim);
  margin-bottom: 1.5rem;
}
.vertical-chips {
  display: flex; flex-wrap: wrap; gap: 0.375rem;
}
.vertical-chip {
  font-size: 0.75rem;
  padding: 0.25rem 0.625rem;
  background: rgba(0,0,0,0.035);
  border: 1px solid var(--border-light);
  border-radius: 100px;
  color: var(--fg-dark-dim);
}

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

/* ═══════════════════════════════════════════════════════════════
   TEAM
   ═══════════════════════════════════════════════════════════════ */
.team {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.5rem, 3vw, 2.5rem);
}
.team-card {
  display: flex; flex-direction: column;
  gap: 1.25rem;
}
.team-photo {
  aspect-ratio: 4/5;
  border-radius: 4px;
  background: var(--bg-elev);
  overflow: hidden;
  position: relative;
}
.light .team-photo { background: #ece9e1; }
.team-photo img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(0.15); transition: filter 400ms var(--ease-out), transform 600ms var(--ease-out); }
@media (hover: hover) and (pointer: fine) {
  .team-card:hover .team-photo img { filter: grayscale(0); transform: scale(1.02); }
}
.team-photo-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display); font-size: 4rem; font-style: italic;
  color: var(--fg-mute);
  background: linear-gradient(135deg, var(--bg-elev), var(--bg));
  letter-spacing: -0.05em;
}
.light .team-photo-placeholder {
  color: var(--fg-dark-mute);
  background: linear-gradient(135deg, #ece9e1, #e0ddd4);
}

.team-name {
  font-family: var(--ff-display);
  font-size: 1.5rem;
  letter-spacing: -0.015em;
  margin-bottom: 0.25rem;
}
.light .team-name { color: var(--fg-dark); }
.team-role {
  font-size: 0.8125rem;
  color: var(--fg-mute);
  margin-bottom: 0.75rem;
  font-family: var(--ff-mono);
  letter-spacing: 0.02em;
}
.light .team-role { color: var(--fg-dark-mute); }
.team-bio {
  font-size: 0.875rem;
  color: var(--fg-dim);
  line-height: 1.6;
}
.light .team-bio { color: var(--fg-dark-dim); }
.team-linkedin {
  display: inline-flex; align-items: center; gap: 0.375rem;
  font-size: 0.8125rem; color: var(--fg-mute);
  margin-top: 0.75rem;
  transition: color 150ms var(--ease-out);
}
.light .team-linkedin { color: var(--fg-dark-mute); }
@media (hover: hover) and (pointer: fine) {
  .team-linkedin:hover { color: var(--fg); }
  .light .team-linkedin:hover { color: var(--fg-dark); }
}
.team-linkedin svg { width: 12px; height: 12px; }

@media (max-width: 860px) { .team { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .team { grid-template-columns: 1fr; } }

/* ─── Advisor strip — deliberately quieter than team ─── */
.advisors {
  margin-top: clamp(3rem, 5vw, 4.5rem);
  padding-top: clamp(2rem, 4vw, 3rem);
  border-top: 1px solid var(--border);
}
.light .advisors { border-top-color: var(--border-light); }
.advisors-label {
  font-family: var(--ff-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-mute);
  margin-bottom: 1.5rem;
}
.advisors > .advisor + .advisor { margin-top: 0; }
.advisors {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media (min-width: 760px) {
  .advisors {
    grid-template-columns: repeat(2, 1fr);
    column-gap: clamp(2rem, 4vw, 3rem);
  }
  .advisors-label { grid-column: 1 / -1; }
}
.light .advisors-label { color: var(--fg-dark-mute); }
.advisor {
  display: flex; align-items: center; gap: 1.5rem;
  padding: 1.5rem 1.75rem;
  background: rgba(0, 0, 0, 0.025);
  border: 1px solid var(--border-light);
  border-radius: 8px;
}
.advisor-photo {
  width: 104px; height: 104px; border-radius: 50%;
  background: var(--bg-elev);
  overflow: hidden;
  flex-shrink: 0;
}
.light .advisor-photo { background: #ece9e1; }
.advisor-photo img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(0.3); transition: filter 400ms var(--ease-out); }
@media (hover: hover) and (pointer: fine) {
  .advisor:hover .advisor-photo img { filter: grayscale(0); }
}
.advisor-photo-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display); font-style: italic;
  color: var(--fg-mute);
  font-size: 1.5rem;
}
.light .advisor-photo-placeholder { color: var(--fg-dark-mute); }
.advisor-info { flex-grow: 1; min-width: 0; }
.advisor-name {
  font-family: var(--ff-display);
  font-size: 1.375rem;
  font-weight: 600;
  letter-spacing: -0.015em;
  margin-bottom: 0.25rem;
  line-height: 1.15;
}
.light .advisor-name { color: var(--fg-dark); }
.advisor-role {
  font-family: var(--ff-mono);
  font-size: 0.75rem;
  color: var(--fg-mute);
  letter-spacing: 0.02em;
  margin-bottom: 0.375rem;
}
.light .advisor-role { color: var(--fg-dark-mute); }

/* ═══════════════════════════════════════════════════════════════
   LOGO STRIP — clients / partners
   ═══════════════════════════════════════════════════════════════ */
.logo-strip {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 2rem 3rem;
  align-items: center;
  opacity: 0.7;
}
.logo-strip img {
  height: 24px; width: auto;
  max-width: 100%;
  object-fit: contain;
  filter: grayscale(1) brightness(2) contrast(0.8);
  opacity: 0.6;
  transition: opacity 200ms var(--ease-out);
}
.light .logo-strip img { filter: grayscale(1) brightness(0.3); }
@media (hover: hover) and (pointer: fine) {
  .logo-strip img:hover { opacity: 1; }
}
@media (max-width: 900px) { .logo-strip { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 560px) { .logo-strip { grid-template-columns: repeat(3, 1fr); gap: 1.5rem; } }

/* ═══════════════════════════════════════════════════════════════
   BLOG TEASER (homepage section)
   ═══════════════════════════════════════════════════════════════ */
.blog-teaser {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: 4px;
  overflow: hidden;
}
.blog-teaser-card {
  background: var(--bg);
  padding: clamp(1.5rem, 2.5vw, 2rem);
  display: flex; flex-direction: column;
  min-height: 16rem;
  text-decoration: none;
  transition: background 200ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .blog-teaser-card:hover { background: var(--bg-elev); }
}
.blog-teaser-meta {
  font-family: var(--ff-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-mute);
  margin-bottom: 1.25rem;
  display: inline-flex; align-items: center;
}
.blog-teaser-meta::before {
  content: '/';
  color: var(--accent-soft);
  margin-right: 0.5rem;
  font-weight: 600;
}
.light .blog-teaser-meta::before { color: var(--accent); }
.blog-teaser-title {
  font-family: var(--ff-display);
  font-size: 1.375rem;
  line-height: 1.15;
  letter-spacing: -0.015em;
  color: var(--fg);
  margin-bottom: 0.75rem;
  flex-grow: 1;
}
.blog-teaser-excerpt {
  font-size: 0.8125rem;
  color: var(--fg-dim);
  line-height: 1.55;
  margin-bottom: 1.25rem;
}
.blog-teaser-arrow {
  font-size: 0.8125rem; color: var(--fg-dim);
  display: flex; align-items: center; gap: 0.375rem;
  transition: color 200ms var(--ease-out), gap 200ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .blog-teaser-card:hover .blog-teaser-arrow { color: var(--fg); gap: 0.625rem; }
}

@media (max-width: 860px) { .blog-teaser { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════════════
   CTA
   ═══════════════════════════════════════════════════════════════ */
.cta {
  text-align: center;
  padding: clamp(4rem, 8vw, 6rem) var(--pad-x);
  background: var(--bg);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.cta-inner { max-width: 40rem; margin: 0 auto; }
.cta h2 {
  font-size: clamp(2.25rem, 5vw, 3.75rem);
  line-height: 1;
  letter-spacing: -0.03em;
  margin-bottom: 1.25rem;
}
.cta h2 em { font-style: italic; color: var(--fg-dim); font-weight: 400; }
.cta p { font-size: 1rem; margin-bottom: 2rem; max-width: 36rem; margin-left: auto; margin-right: auto; }

/* ═══════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════ */
.footer {
  padding: 4rem var(--pad-x) 2rem;
  background: var(--bg);
}
.footer-inner { max-width: var(--max-w); margin: 0 auto; }
.footer-top {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 3rem;
  margin-bottom: 3rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid var(--border);
}
.footer-brand svg { width: 28px; height: 28px; margin-bottom: 1rem; }
.footer-brand-name {
  font-family: var(--ff-display);
  font-size: 1.125rem;
  margin-bottom: 0.5rem;
}
.footer-brand-desc {
  font-size: 0.875rem; color: var(--fg-dim);
  max-width: 24rem;
}
.footer-col h4 {
  font-family: var(--ff-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-mute);
  margin-bottom: 1rem;
  font-weight: 500;
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 0.5rem; }
.footer-col a {
  font-size: 0.875rem; color: var(--fg-dim);
  transition: color 150ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .footer-col a:hover { color: var(--fg); }
}
.footer-bottom {
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem;
  font-size: 0.75rem; color: var(--fg-mute);
}
.footer-legal { display: flex; gap: 1.5rem; }

@media (max-width: 760px) {
  .footer-top { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }
}

/* ═══════════════════════════════════════════════════════════════
   MODALS & OVERLAYS
   ═══════════════════════════════════════════════════════════════ */
.modal-backdrop {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(10, 10, 12, 0.78);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: none;
  align-items: center; justify-content: center;
  padding: 1rem;
  animation: fade-in 200ms var(--ease-out);
}
.modal-backdrop.open { display: flex; }
.modal {
  background: var(--bg-light);
  width: 100%; max-width: 56rem; height: 85vh; max-height: 44rem;
  border-radius: 6px;
  overflow: hidden;
  display: flex; flex-direction: column;
  animation: modal-in 280ms var(--ease-out);
}
@keyframes modal-in {
  from { opacity: 0; transform: translateY(12px) scale(0.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes fade-in { from { opacity: 0; } to { opacity: 1; } }
.modal-header {
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--border-light);
  display: flex; align-items: center; justify-content: space-between;
  color: var(--fg-dark);
}
.modal-title {
  font-family: var(--ff-display); font-size: 1rem;
}
.modal-close {
  padding: 0.375rem;
  color: var(--fg-dark-mute);
  transition: color 150ms var(--ease-out);
  border-radius: 4px;
}
.modal-close svg { width: 18px; height: 18px; }
@media (hover: hover) and (pointer: fine) {
  .modal-close:hover { color: var(--fg-dark); background: rgba(0,0,0,0.04); }
}
.modal-close:active { transform: scale(0.95); }
.modal-body { flex: 1; overflow: hidden; }
.modal-body iframe { width: 100%; height: 100%; border: 0; }

/* Mobile: modal fills available space for usable calendar experience */
@media (max-width: 600px) {
  .modal-backdrop { padding: 0; }
  .modal {
    width: 100%; height: 100vh; height: 100dvh;
    max-height: 100vh; max-height: 100dvh;
    max-width: 100%;
    border-radius: 0;
  }
}

/* ─── Cookie banner ─── */
.cookie-banner {
  position: fixed; bottom: 1rem; left: 1rem; right: 1rem; z-index: 90;
  max-width: 32rem;
  padding: 1.25rem;
  background: var(--bg-elev);
  border: 1px solid var(--border-strong);
  border-radius: 6px;
  box-shadow: 0 20px 50px -20px rgba(0,0,0,0.5);
  transform: translateY(calc(100% + 2rem));
  opacity: 0;
  transition: transform 400ms var(--ease-out), opacity 400ms var(--ease-out);
}
.cookie-banner.visible { transform: translateY(0); opacity: 1; }
.cookie-banner h4 {
  font-family: var(--ff-display); font-size: 1.0625rem;
  margin-bottom: 0.375rem;
  color: var(--fg);
}
.cookie-banner p {
  font-size: 0.8125rem; margin-bottom: 1rem;
  color: var(--fg-dim);
}
.cookie-banner p a { color: var(--accent-soft); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.cookie-actions { display: flex; gap: 0.5rem; }
.cookie-btn {
  font-size: 0.8125rem; padding: 0.5rem 0.875rem; border-radius: 100px;
  transition: background 150ms var(--ease-out);
}
.cookie-btn:active { transform: scale(0.97); }
.cookie-btn-accept { background: var(--fg); color: var(--bg); }
@media (hover: hover) and (pointer: fine) { .cookie-btn-accept:hover { background: #fff; } }
.cookie-btn-decline { background: transparent; color: var(--fg-dim); border: 1px solid var(--border-strong); }
@media (hover: hover) and (pointer: fine) { .cookie-btn-decline:hover { color: var(--fg); border-color: var(--fg-dim); } }

@media (max-width: 560px) {
  .cookie-banner { left: 0.75rem; right: 0.75rem; bottom: 0.75rem; padding: 1rem; }
  .cookie-actions { flex-direction: column-reverse; }
  .cookie-btn { width: 100%; }
}

/* ═══════════════════════════════════════════════════════════════
   LOGO MARK — animated SVG
   ═══════════════════════════════════════════════════════════════ */
.logo-mark path { transition: fill 300ms var(--ease-out); }

/* ═══════════════════════════════════════════════════════════════
   BLOG PAGES
   ═══════════════════════════════════════════════════════════════ */
.blog-wrap {
  max-width: var(--max-w); margin: 0 auto;
  padding: 7rem var(--pad-x) var(--sec-y);
}
.blog-hero { margin-bottom: clamp(3rem, 6vw, 5rem); }
.blog-hero .eyebrow { margin-bottom: 1rem; }
.blog-hero h1 {
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  line-height: 1;
  letter-spacing: -0.03em;
  max-width: 20ch;
  margin-bottom: 1.25rem;
}
.blog-hero h1 em { font-style: italic; color: var(--fg-dim); font-weight: 400; }
.blog-hero p { font-size: 1.0625rem; max-width: 52ch; }

.blog-list {
  display: grid;
  grid-template-columns: 1fr;
  border-top: 1px solid var(--border);
}
.blog-list-item {
  padding: clamp(2rem, 4vw, 3rem) 0;
  border-bottom: 1px solid var(--border);
  display: grid;
  grid-template-columns: 0.2fr 1fr 0.25fr;
  gap: clamp(1rem, 3vw, 3rem);
  align-items: baseline;
  text-decoration: none;
  transition: opacity 200ms var(--ease-out);
  position: relative;
}
.blog-list-item::before {
  content: ''; position: absolute; inset: 0;
  background: rgba(255,255,255,0.015);
  opacity: 0;
  transition: opacity 200ms var(--ease-out);
  pointer-events: none;
}
@media (hover: hover) and (pointer: fine) {
  .blog-list-item:hover::before { opacity: 1; }
  .blog-list-item:hover .blog-list-arrow { transform: translateX(4px); color: var(--fg); }
}

.blog-list-date {
  font-family: var(--ff-mono);
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--fg-mute);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  white-space: nowrap;
  display: inline-flex; align-items: center;
}
.blog-list-date::before {
  content: '/';
  color: var(--accent-soft);
  margin-right: 0.5rem;
  font-weight: 600;
}
.blog-list-main h2 {
  font-family: var(--ff-display);
  font-size: clamp(1.375rem, 2.5vw, 1.875rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--fg);
  margin-bottom: 0.625rem;
}
.blog-list-main p {
  font-size: 0.9375rem;
  color: var(--fg-dim);
  line-height: 1.55;
  max-width: 56ch;
}
.blog-list-arrow {
  font-family: var(--ff-mono);
  font-size: 0.75rem;
  color: var(--fg-mute);
  text-align: right;
  transition: transform 200ms var(--ease-out), color 200ms var(--ease-out);
}

@media (max-width: 720px) {
  .blog-list-item {
    grid-template-columns: 1fr;
    gap: 0.625rem;
  }
  .blog-list-arrow { display: none; }
}

/* ═══════════════════════════════════════════════════════════════
   ARTICLE (single blog post)
   ═══════════════════════════════════════════════════════════════ */
.article-wrap {
  max-width: 44rem;
  margin: clamp(3rem, 6vw, 5rem) auto;
  padding: 0 var(--pad-x);
}
.article-meta {
  font-family: var(--ff-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-dark-mute);
  margin-bottom: 1.25rem;
  display: flex; align-items: center; gap: 0.75rem;
}
.article-meta::before {
  content: '/';
  color: var(--accent);
  font-weight: 600;
}
.article-wrap h1 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.05;
  letter-spacing: -0.03em;
  margin-bottom: 1.25rem;
  color: var(--fg-dark);
}
.article-lead {
  font-size: 1.125rem;
  line-height: 1.55;
  color: var(--fg-dark-dim);
  margin-bottom: clamp(2rem, 4vw, 3rem);
  max-width: 42rem;
}
.article-body h2 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(1.375rem, 2.5vw, 1.75rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin-top: clamp(2.25rem, 5vw, 3.5rem);
  margin-bottom: 1rem;
  color: var(--fg-dark);
}
.article-body h3 {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: 1.125rem;
  letter-spacing: -0.015em;
  margin-top: 2rem;
  margin-bottom: 0.625rem;
  color: var(--fg-dark);
}
.article-body p {
  font-size: 1rem;
  line-height: 1.65;
  color: var(--fg-dark-dim);
  margin-bottom: 1.25rem;
}
.article-body p strong {
  color: var(--fg-dark);
  font-weight: 600;
}
.article-body ul,
.article-body ol {
  margin: 0 0 1.5rem;
  padding-left: 1.25rem;
}
.article-body li {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--fg-dark-dim);
  margin-bottom: 0.5rem;
}
.article-body li::marker { color: var(--accent); }
.article-body a {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.article-body a:hover { text-decoration-thickness: 2px; }
.article-body blockquote {
  border-left: 2px solid var(--accent);
  padding: 0.25rem 0 0.25rem 1.25rem;
  margin: 1.75rem 0;
  font-style: italic;
  color: var(--fg-dark);
  font-size: 1.0625rem;
  line-height: 1.55;
}
.article-body .callout {
  background: rgba(88, 65, 234, 0.04);
  border-left: 3px solid var(--accent);
  padding: 1rem 1.25rem;
  margin: 1.5rem 0;
  border-radius: 0 4px 4px 0;
}
.article-body .callout p { margin: 0; color: var(--fg-dark); font-size: 0.9375rem; }
.article-body .callout p + p { margin-top: 0.5rem; }

.article-cta {
  margin-top: clamp(3rem, 6vw, 4.5rem);
  padding: clamp(1.75rem, 3vw, 2.5rem);
  background: var(--bg-light-elev);
  border: 1px solid var(--border-light);
  border-radius: 8px;
  text-align: center;
}
.article-cta h3 {
  font-family: var(--ff-display);
  font-size: clamp(1.25rem, 2vw, 1.5rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-bottom: 0.625rem;
  color: var(--fg-dark);
}
.article-cta p {
  color: var(--fg-dark-dim);
  margin-bottom: 1.25rem;
  max-width: 34rem; margin-left: auto; margin-right: auto;
}
.article-footer-nav {
  margin-top: clamp(3rem, 5vw, 4rem);
  padding-top: 2rem;
  border-top: 1px solid var(--border-light);
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 1rem;
  font-family: var(--ff-mono);
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.article-footer-nav a { color: var(--fg-dark-mute); text-decoration: none; }
.article-footer-nav a:hover { color: var(--accent); }

/* ═══════════════════════════════════════════════════════════════
   ANIMATIONS
   ═══════════════════════════════════════════════════════════════ */
@keyframes fade-up {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ═══════════════════════════════════════════════════════════════
   ACCESSIBILITY — reduced motion
   ═══════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 150ms !important;
    scroll-behavior: auto !important;
  }
  .reveal { transform: none !important; }
  .hero h1, .hero-sub, .hero-label, .hero-actions {
    animation: fade-in 200ms ease both !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   WAYS TO WORK — sticky horizontal scroll (Apple/Stripe pattern)
   Vertical scroll translates cards horizontally while section pins
   ═══════════════════════════════════════════════════════════════ */
.offering-section {
  background: var(--bg-light);
  color: var(--fg-dark);
  position: relative;
  padding: 0;
}
/* The tall scroll container — height determines horizontal travel distance */
.offering-scroll {
  height: 280vh; /* 4 cards × ~60vw each = ~240vw travel, plus padding */
  position: relative;
}
/* Sticky viewport — sits 100vh in the scroll container */
.offering-sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex; flex-direction: column;
  overflow: hidden;
  padding-top: clamp(3rem, 6vh, 5rem);
}
.offering-header {
  max-width: var(--max-w); margin: 0 auto clamp(2rem, 4vh, 3rem);
  padding: 0 var(--pad-x);
  flex-shrink: 0;
  text-align: left;
}
.offering-header .mark { margin-bottom: 1rem; }
.offering-header h2 {
  font-size: clamp(2rem, 4.5vw, 3.25rem);
  line-height: 1.02;
  letter-spacing: -0.03em;
  margin-bottom: 1.25rem;
  color: var(--fg-dark);
}
.offering-header p {
  font-size: 1rem;
  max-width: 50ch;
  color: var(--fg-dark-dim);
}

/* Horizontal rail — translated by JS based on vertical scroll progress */
.offering-rail {
  display: flex;
  gap: clamp(1rem, 2vw, 1.5rem);
  padding: 0 var(--pad-x) 2rem;
  will-change: transform;
  flex: 1;
  align-items: stretch;
}

.tier {
  flex: 0 0 clamp(320px, 58vw, 640px);
  background: var(--bg-light-elev);
  border: 1px solid var(--border-light);
  border-radius: 8px;
  padding: clamp(1.5rem, 2.5vw, 2.25rem);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 clamp(1.5rem, 3vw, 2.5rem);
  position: relative;
  transition: border-color 200ms var(--ease-out);
}
/* Left column — vertical flex, title at top, body+CTA at bottom */
.tier > .tier-left {
  grid-column: 1;
  display: flex;
  flex-direction: column;
}
.tier > .tier-left .tier-icon { margin-bottom: 0.5rem; }
.tier > .tier-left .tier-tag { margin-bottom: 0.5rem; }
.tier > .tier-left h3 { margin-bottom: 0; }
/* This pushes everything below it (sub + cta) to the bottom of the column */
.tier > .tier-left .tier-spacer { flex: 1; min-height: 1.5rem; }
.tier > .tier-left .tier-sub { margin-bottom: 1.25rem; }
.tier > .tier-left .tier-cta { align-self: flex-start; }

/* Right column — blocks aligned to bottom too */
.tier > .tier-blocks {
  grid-column: 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 1.25rem;
}

.tier-icon {
  width: 36px; height: 36px;
  color: var(--accent);
  margin-bottom: 0.5rem;
}
.tier-icon svg { width: 100%; height: 100%; display: block; }

.tier-tag {
  font-family: var(--ff-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-dark-mute);
  margin-bottom: 0.5rem;
  display: inline-flex; align-items: center;
  width: fit-content;
}
.tier-tag::before {
  content: '/';
  color: var(--accent);
  margin-right: 0.5rem;
  font-weight: 600;
}

.tier h3 {
  font-family: var(--ff-display);
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.02;
  color: var(--fg-dark);
  margin-bottom: 0.75rem;
}
.tier-sub {
  font-size: 0.9375rem;
  color: var(--fg-dark-dim);
  line-height: 1.55;
}
.tier-blocks {
  padding-top: 0;
}
.tier-block {
  padding: 0;
  border: none;
  margin: 0;
}
.tier-block-label {
  font-family: var(--ff-mono);
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-dark-mute);
  margin-bottom: 0.5rem;
  display: inline-flex; align-items: center;
}
.tier-block-label::before {
  content: '/';
  color: var(--accent);
  margin-right: 0.375rem;
  font-weight: 600;
  opacity: 0.5;
}
.tier-block-body {
  font-size: 0.875rem;
  color: var(--fg-dark-dim);
  line-height: 1.55;
}

.tier-cta {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--fg-dark);
  font-family: var(--ff-body);
  transition: gap 200ms var(--ease-out);
  width: fit-content;
}
.tier-cta svg { width: 14px; height: 14px; transition: transform 200ms var(--ease-out); }
@media (hover: hover) and (pointer: fine) {
  .tier:hover .tier-cta { gap: 0.75rem; }
  .tier:hover .tier-cta svg { transform: translateX(3px); }
}

/* Flagship tier — The Engine (recommended) */
.tier.flagship {
  border-color: var(--accent);
}
.tier.flagship::after {
  content: 'Recommended';
  position: absolute;
  top: 1rem; right: 1rem;
  font-family: var(--ff-mono);
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  padding: 3px 10px;
  background: var(--accent);
  color: white;
  border-radius: 100px;
}

/* Pro tier — dark treatment, premium */
.tier.premium {
  background: var(--bg);
  border-color: var(--bg);
  color: var(--fg);
}
.tier.premium .tier-tag { color: var(--fg-mute); }
.tier.premium .tier-tag::before { color: var(--accent-pink); }
.tier.premium h3 { color: var(--fg); }
.tier.premium .tier-sub,
.tier.premium .tier-block-body { color: var(--fg-dim); }
.tier.premium .tier-block-label { color: var(--fg-mute); }
.tier.premium .tier-block-label::before { color: var(--accent-pink); }
.tier.premium .tier-cta { color: var(--fg); }
.tier.premium .tier-icon { color: var(--accent-pink); }
@media (hover: hover) and (pointer: fine) {
  .tier.premium:hover { border-color: var(--accent-pink); }
}

/* Commission tier marker */
.tier.commission .tier-icon { color: var(--accent-teal); }
.tier.commission .tier-tag::before { color: var(--accent-teal); }
.tier.commission .tier-block-label::before { color: var(--accent-teal); }

/* Progress indicator dots */
.offering-progress {
  position: absolute;
  bottom: clamp(1.5rem, 4vh, 2.5rem);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background: rgba(255,255,255,0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 100px;
  border: 1px solid var(--border-light);
}
.offering-progress-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--border-light-strong);
  transition: background 200ms var(--ease-out), transform 200ms var(--ease-out);
}
.offering-progress-dot.active {
  background: var(--accent);
  transform: scale(1.4);
}

/* Mobile — abandon sticky-scroll, return to stacked vertical cards */
@media (max-width: 900px) {
  .offering-scroll { height: auto; }
  .offering-sticky {
    position: static;
    height: auto;
    padding-top: var(--sec-y);
    padding-bottom: var(--sec-y);
  }
  .offering-rail {
    flex-direction: column;
    padding: 0 var(--pad-x);
    gap: 1rem;
    transform: none !important;
  }
  .tier {
    flex: 1 1 auto;
    height: auto;
    max-height: none;
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    gap: 1.25rem;
  }
  .tier > .tier-left,
  .tier > .tier-blocks {
    grid-column: 1;
  }
  .tier > .tier-left .tier-spacer { display: none; }
  .offering-progress { display: none; }
  .offering-hint { display: none; }
}

/* ═══════════════════════════════════════════════════════════════
   ADVISOR INSTAGRAM LINK
   ═══════════════════════════════════════════════════════════════ */
.advisor-links {
  display: flex; gap: 0.5rem;
  margin-top: 0.25rem;
}
.advisor-link {
  display: inline-flex; align-items: center; gap: 0.375rem;
  font-size: 0.75rem;
  font-family: var(--ff-mono);
  color: var(--fg-mute);
  transition: color 150ms var(--ease-out);
}
.light .advisor-link { color: var(--fg-dark-mute); }
.advisor-link svg { width: 12px; height: 12px; }
@media (hover: hover) and (pointer: fine) {
  .advisor-link:hover { color: var(--fg); }
  .light .advisor-link:hover { color: var(--fg-dark); }
}

/* ═══════════════════════════════════════════════════════════════
   INSIDE THE ENGINE — process + platform
   ═══════════════════════════════════════════════════════════════ */
.engine-section {
  position: relative;
  /* Note: no overflow:hidden here — would break position:sticky on section-header.
     The ::before glow is clip-path'd instead. */
}
.engine-section::before {
  content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background:
    radial-gradient(ellipse 50% 40% at 20% 20%, rgba(88, 65, 234, 0.07), transparent 70%),
    radial-gradient(ellipse 40% 30% at 85% 75%, rgba(244, 128, 211, 0.05), transparent 70%);
  clip-path: inset(0);
}
.engine-section .section-inner { position: relative; z-index: 1; }

/* ═══════════════════════════════════════════════════════════════
   STICKY SECTION HEADERS — Stripe-style choreography
   ═══════════════════════════════════════════════════════════════ */
.section.sticky-section .section-inner {
  display: grid;
  grid-template-columns: minmax(280px, 0.9fr) 1.5fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: start;
}
.section.sticky-section .section-header {
  position: sticky;
  top: calc(96px + clamp(1rem, 3vw, 2rem));
  margin-bottom: 0;
  max-width: none;
  padding-right: 1rem;
}
/* Defensive: .reveal's transform breaks position:sticky. If anyone re-adds
   .reveal to a sticky header, strip the transform but keep opacity animation. */
.section.sticky-section .section-header.reveal {
  transform: none !important;
  opacity: 1;
}
@media (max-width: 900px) {
  .section.sticky-section .section-inner {
    grid-template-columns: 1fr;
  }
  .section.sticky-section .section-header {
    position: static;
    padding-right: 0;
    margin-bottom: clamp(2.5rem, 5vw, 4rem);
  }
}

/* ═══════════════════════════════════════════════════════════════
   ENGINE — scroll-revealed process steps (vertical flow on sticky)
   ═══════════════════════════════════════════════════════════════ */
.process-flow {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  position: relative;
}
.process-flow::before {
  content: ''; position: absolute;
  left: 1.125rem; top: 1.25rem; bottom: 1.25rem;
  width: 1px;
  background: linear-gradient(
    to bottom,
    var(--accent) 0%,
    var(--accent-teal) 35%,
    var(--accent-pink) 70%,
    var(--fg-mute) 100%
  );
  opacity: 0.3;
  z-index: 0;
}
.process-flow .process-step {
  padding: 0 0 2rem 3.5rem;
  position: relative;
  z-index: 1;
  opacity: 0.3;
  transition: opacity 500ms var(--ease-out), transform 500ms var(--ease-out);
  transform: translateY(8px);
}
.process-flow .process-step.active,
.process-flow .process-step.past {
  opacity: 1;
  transform: translateY(0);
}
.process-flow .process-step:last-child { padding-bottom: 0; }

.process-flow .process-num {
  position: absolute; left: 0; top: 0;
  display: inline-flex; align-items: center; justify-content: center;
  width: 2.25rem; height: 2.25rem;
  border-radius: 50%;
  background: var(--bg);
  border: 1px solid currentColor;
  font-family: var(--ff-mono);
  font-size: 0.75rem;
  font-weight: 500;
  margin-bottom: 0;
  transition: background 300ms var(--ease-out), transform 300ms var(--ease-out);
}
.light .process-flow .process-num { background: var(--bg-light); }
.process-flow .process-step.active .process-num {
  background: currentColor;
  transform: scale(1.05);
}
.process-flow .process-step:nth-child(1) { color: var(--accent); }
.process-flow .process-step:nth-child(2) { color: var(--accent-teal); }
.process-flow .process-step:nth-child(3) { color: var(--accent-pink); }
.process-flow .process-step:nth-child(4) { color: var(--fg); }
.process-flow .process-step:nth-child(5) { color: var(--fg-dim); }

.process-flow .process-num > span {
  color: currentColor;
  transition: color 300ms var(--ease-out);
}
.process-flow .process-step.active .process-num > span { color: var(--bg); }

.process-flow .process-title {
  font-family: var(--ff-display);
  font-size: clamp(1.375rem, 2.2vw, 1.75rem);
  letter-spacing: -0.015em;
  line-height: 1.1;
  color: var(--fg);
  margin-bottom: 0.625rem;
}
.light .process-flow .process-title { color: var(--fg-dark); }
.process-flow .process-desc {
  font-size: 0.9375rem;
  color: var(--fg-dim);
  line-height: 1.6;
  max-width: 50ch;
}
.light .process-flow .process-desc { color: var(--fg-dark-dim); }

/* Original horizontal process (kept for potential future use) */
.process {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  margin-bottom: clamp(4rem, 7vw, 6rem);
  position: relative;
}
.process::before {
  content: ''; position: absolute;
  top: 1.25rem; left: 2.5rem; right: 2.5rem;
  height: 1px;
  background: linear-gradient(
    to right,
    var(--accent-soft) 0%,
    var(--accent-teal) 40%,
    var(--accent-pink) 75%,
    var(--fg-mute) 100%
  );
  opacity: 0.3;
  z-index: 0;
}
.process > .process-step {
  padding: 0 1rem;
  position: relative;
  z-index: 1;
}
.process > .process-step:first-child { padding-left: 0; }
.process > .process-step:last-child { padding-right: 0; }

.process > .process-step .process-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 2.5rem; height: 2.5rem;
  border-radius: 50%;
  background: var(--bg);
  border: 1px solid currentColor;
  font-family: var(--ff-mono);
  font-size: 0.75rem;
  font-weight: 500;
  margin-bottom: 1.25rem;
  position: relative;
}
.process > .process-step:nth-child(1) .process-num { color: var(--accent-soft); }
.process > .process-step:nth-child(2) .process-num { color: var(--accent-teal); }
.process > .process-step:nth-child(3) .process-num { color: var(--accent-pink); }
.process > .process-step:nth-child(4) .process-num { color: var(--fg); }
.process > .process-step:nth-child(5) .process-num { color: var(--fg-dim); }

@media (max-width: 860px) {
  .process { grid-template-columns: 1fr; gap: 1.5rem; }
  .process::before { display: none; }
  .process > .process-step { padding: 0; padding-left: 3.5rem; position: relative; }
  .process > .process-step .process-num { position: absolute; left: 0; top: 0; margin: 0; }
}

/* ─── Platform / dashboard mockup ─── */
.platform {
  display: grid;
  grid-template-columns: 1fr 1.35fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
  padding-top: clamp(3rem, 6vw, 5rem);
  border-top: 1px solid var(--border);
}
@media (max-width: 860px) {
  .platform { grid-template-columns: 1fr; }
}
.platform-copy .eyebrow { margin-bottom: 1rem; }
.platform-copy h3 {
  font-family: var(--ff-display);
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  line-height: 1.05;
  letter-spacing: -0.025em;
  margin-bottom: 1.25rem;
  color: var(--fg);
}
.platform-copy h3 em { font-style: italic; color: var(--fg-dim); font-weight: 400; }
.platform-copy p {
  font-size: 0.9375rem;
  color: var(--fg-dim);
  margin-bottom: 1.25rem;
  max-width: 36ch;
}
.platform-features {
  list-style: none;
  margin-top: 1.5rem;
  display: grid;
  gap: 0.75rem;
}
.platform-features li {
  display: flex; gap: 0.75rem; align-items: flex-start;
  font-size: 0.875rem;
  color: var(--fg);
}
.platform-features li strong { color: var(--fg); font-weight: 500; }
.platform-features li span { color: var(--fg-dim); font-weight: 400; }
.platform-features li::before {
  content: ''; display: block; flex-shrink: 0;
  width: 16px; height: 16px; border-radius: 50%;
  margin-top: 3px;
  background:
    radial-gradient(circle at 35% 35%, var(--accent-soft) 0%, var(--accent-soft) 30%, transparent 32%),
    var(--bg-elev);
  border: 1px solid var(--border-strong);
}

/* ═══════════════════════════════════════════════════════════════
   DASHBOARD MOCKUP — stylised abstract, not pixel-perfect copy
   Coloured outlines, brand palette, embedded on dark bg
   ═══════════════════════════════════════════════════════════════ */
.dash {
  background: var(--bg);
  border: 1px solid var(--border-strong);
  border-radius: 10px;
  overflow: hidden;
  box-shadow:
    0 30px 60px -20px rgba(0,0,0,0.6),
    0 10px 30px -10px rgba(88, 65, 234, 0.15);
  font-family: var(--ff-body);
  color: var(--fg);
}
.dash-chrome {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.625rem 0.875rem;
  background: var(--bg-elev);
  border-bottom: 1px solid var(--border);
}
.dash-dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--border-strong);
}
.dash-dot:nth-child(1) { background: rgba(255,95,87,0.7); }
.dash-dot:nth-child(2) { background: rgba(255,189,46,0.7); }
.dash-dot:nth-child(3) { background: rgba(40,200,64,0.7); }
.dash-url {
  flex: 1;
  font-family: var(--ff-mono);
  font-size: 0.6875rem;
  color: var(--fg-mute);
  text-align: center;
  letter-spacing: 0;
}

.dash-body {
  padding: clamp(1rem, 2vw, 1.5rem);
  display: flex; flex-direction: column;
  gap: clamp(0.75rem, 1.5vw, 1rem);
}

/* Top header strip */
.dash-topbar {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--border);
}
.dash-topbar-title {
  font-family: var(--ff-display);
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--fg);
}
.dash-topbar-user {
  display: flex; align-items: center; gap: 0.5rem;
  font-family: var(--ff-mono);
  font-size: 0.6875rem;
  color: var(--fg-mute);
}
.dash-topbar-avatar {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--accent);
  color: white;
  font-size: 0.5625rem; font-weight: 600;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--ff-body);
}

/* KPI row — 4 outlined cards with brand-colored borders */
.dash-kpis {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.5rem;
}
.dash-kpi {
  padding: 0.75rem 0.875rem;
  border: 1px solid;
  border-radius: 6px;
  background: transparent;
  position: relative;
}
.dash-kpi:nth-child(1) { border-color: color-mix(in srgb, var(--accent-soft) 40%, transparent); }
.dash-kpi:nth-child(2) { border-color: color-mix(in srgb, var(--accent-pink) 40%, transparent); }
.dash-kpi:nth-child(3) { border-color: color-mix(in srgb, var(--accent-teal) 40%, transparent); }
.dash-kpi:nth-child(4) { border-color: var(--border); }

.dash-kpi-label {
  font-family: var(--ff-mono);
  font-size: 0.5625rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-mute);
  margin-bottom: 0.25rem;
}
.dash-kpi-value {
  font-family: var(--ff-display);
  font-size: 1.375rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1;
}
.dash-kpi:nth-child(1) .dash-kpi-value { color: var(--accent-soft); }
.dash-kpi:nth-child(2) .dash-kpi-value { color: var(--accent-pink); }
.dash-kpi:nth-child(3) .dash-kpi-value { color: var(--accent-teal); }
.dash-kpi:nth-child(4) .dash-kpi-value { color: var(--fg); }

.dash-kpi-delta {
  font-family: var(--ff-mono);
  font-size: 0.625rem;
  color: var(--fg-mute);
  margin-top: 0.25rem;
}
.dash-kpi-delta.up { color: var(--accent-teal); }

/* Main grid: funnel + ICP sidebar */
.dash-main-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 0.5rem;
}

.dash-card {
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 0.875rem;
}
.dash-card-title {
  font-family: var(--ff-mono);
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-mute);
  margin-bottom: 0.875rem;
}

/* Funnel chart */
.dash-funnel {
  display: flex; flex-direction: column;
  gap: 0.625rem;
}
.dash-funnel-row {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 0.625rem;
  align-items: center;
}
.dash-funnel-label {
  font-family: var(--ff-mono);
  font-size: 0.625rem;
  color: var(--fg-mute);
  text-align: right;
}
.dash-funnel-bar-track {
  height: 10px;
  border-radius: 2px;
  background: var(--border);
  position: relative;
  overflow: hidden;
}
.dash-funnel-bar {
  height: 100%;
  border-radius: 2px;
}

/* ICP sidebar */
.dash-icp-section {
  margin-bottom: 0.75rem;
}
.dash-icp-section:last-child { margin-bottom: 0; }
.dash-icp-label {
  font-family: var(--ff-mono);
  font-size: 0.5625rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-mute);
  margin-bottom: 0.25rem;
}
.dash-icp-value {
  font-size: 0.75rem;
  color: var(--fg-dim);
  line-height: 1.4;
}
.dash-icp-tag {
  display: inline-block;
  padding: 2px 8px;
  background: color-mix(in srgb, var(--accent-pink) 15%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent-pink) 30%, transparent);
  color: var(--accent-pink);
  font-family: var(--ff-mono);
  font-size: 0.625rem;
  border-radius: 3px;
}

/* Mobile */
@media (max-width: 640px) {
  .dash-kpis { grid-template-columns: repeat(2, 1fr); }
  .dash-main-grid { grid-template-columns: 1fr; }
  .dash-funnel-label { font-size: 0.5625rem; }
}

/* ═══════════════════════════════════════════════════════════════
   COMPARISON — Old Way / Hard Way / Pipeline Way
   ═══════════════════════════════════════════════════════════════ */
.compare {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: 4px;
  overflow: hidden;
}
.light .compare {
  background: var(--border-light);
  border-color: var(--border-light);
}
.compare-col {
  background: var(--bg);
  padding: clamp(1.75rem, 3vw, 2.5rem);
  display: flex; flex-direction: column;
}
.light .compare-col { background: var(--bg-light); }
.compare-col.us {
  background: linear-gradient(180deg, var(--bg-elev), var(--bg));
  position: relative;
}
.light .compare-col.us {
  background: linear-gradient(180deg, var(--bg-light-elev), var(--bg-light));
}
.compare-col.us::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(to right, var(--accent), var(--accent-teal), var(--accent-pink));
}
.compare-tag {
  font-family: var(--ff-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-mute);
  margin-bottom: 1rem;
  display: inline-flex; align-items: center;
}
.compare-tag::before {
  content: '/';
  color: currentColor;
  margin-right: 0.5rem;
  font-weight: 600;
  opacity: 0.4;
}
.light .compare-tag { color: var(--fg-dark-mute); }
.compare-col.us .compare-tag {
  color: var(--accent);
  display: inline-flex; align-items: center;
  width: fit-content;
}
.light .compare-col.us .compare-tag { color: var(--accent); }
.compare-col.us .compare-tag::before {
  content: '/';
  color: var(--accent);
  margin-right: 0.5rem;
  font-weight: 600;
  opacity: 1;
}
.compare-title {
  font-family: var(--ff-display);
  font-size: 1.375rem;
  letter-spacing: -0.015em;
  color: var(--fg);
  margin-bottom: 0.5rem;
}
.light .compare-title { color: var(--fg-dark); }
.compare-sub {
  font-size: 0.8125rem;
  color: var(--fg-dim);
  margin-bottom: 1.5rem;
  font-style: italic;
  font-family: var(--ff-display);
}
.light .compare-sub { color: var(--fg-dark-dim); }
.compare-list {
  list-style: none;
  display: flex; flex-direction: column; gap: 0.625rem;
}
.compare-list li {
  display: flex; gap: 0.5rem; align-items: flex-start;
  font-size: 0.8125rem;
  color: var(--fg-dim);
  line-height: 1.5;
}
.light .compare-list li { color: var(--fg-dark-dim); }
.compare-list li::before {
  content: '—'; color: var(--fg-mute); flex-shrink: 0;
  font-family: var(--ff-display);
}
.light .compare-list li::before { color: var(--fg-dark-mute); }
.compare-col.us .compare-list li::before {
  content: '✓'; color: var(--accent-teal);
  font-size: 0.875rem; line-height: 1.4;
}
.light .compare-col.us .compare-list li::before { color: #2db8af; }

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

/* ═══════════════════════════════════════════════════════════════
   FOUNDING PARTNER RIBBON
   ═══════════════════════════════════════════════════════════════ */
.founding-note {
  display: inline-flex; align-items: center;
  font-family: var(--ff-mono);
  font-size: 0.75rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg-dim);
  margin-bottom: 1rem;
}
.founding-note::before {
  content: '/2026/';
  color: var(--accent-soft);
  margin-right: 0.75rem;
  font-weight: 600;
}
