/* ─────────────────────────────────────────────────────────────────
   99 Social — site styles
   Three named directions (sunny / citrus / sky), light + dark,
   density modifier, font-pair switch. All themed via CSS vars
   so React tweak panel can flip everything live.
   ───────────────────────────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-size: 16px;
  line-height: 1.55;
  font-feature-settings: "ss01", "cv01";
}
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
img { display: block; max-width: 100%; }
h1, h2, h3, h4 { margin: 0; font-family: var(--font-display); line-height: 1.05; letter-spacing: -0.02em; font-weight: 600; }
p { margin: 0; }

/* ───────── theme vars (defaults = Sunny / light) ───────── */
:root {
  /* Direction-defined */
  --primary: oklch(0.72 0.17 42);
  --primary-ink: #fff;
  --primary-soft: oklch(0.94 0.06 50);
  --accent: oklch(0.78 0.16 80);
  --bg: oklch(0.985 0.012 75);
  --bg-2: oklch(0.95 0.024 70);
  --bg-3: oklch(0.94 0.025 70);
  --ink: oklch(0.2 0.022 50);
  --ink-2: oklch(0.42 0.022 50);
  --ink-3: oklch(0.62 0.018 50);
  --line: oklch(0.88 0.018 70);
  --card: #ffffff;
  --shadow-card: 0 1px 0 rgba(0,0,0,.02), 0 12px 30px -18px rgba(60,30,5,.18);
  --shadow-pop: 0 30px 60px -22px rgba(60,30,5,.28);
  --radius-sm: 8px;
  --radius: 14px;
  --radius-lg: 22px;
  --radius-xl: 32px;
  --font-display: "Geist", ui-sans-serif, system-ui, sans-serif;
  --font-body: "Geist", ui-sans-serif, system-ui, sans-serif;
  --font-mono: "Geist Mono", ui-monospace, monospace;
  --display-weight: 600;
  --display-italic: normal;
  --display-tracking: -0.025em;

  /* Density */
  --gap: 24px;
  --gap-lg: 56px;
  --pad-section: 96px;
  --pad-card: 28px;
  --hero-pad: 88px;
  --container: 1200px;
}

/* ───────── directions ───────── */
body[data-dir="sunny"] {
  --primary: oklch(0.7 0.18 38);
  --primary-ink: #fff;
  --primary-soft: oklch(0.94 0.06 50);
  --accent: oklch(0.85 0.14 95);
  --bg: oklch(0.985 0.012 75);
  --bg-2: oklch(0.945 0.028 65);
  --bg-3: oklch(0.915 0.04 55);
  --ink: oklch(0.21 0.022 50);
  --ink-2: oklch(0.44 0.022 50);
  --ink-3: oklch(0.62 0.018 50);
  --line: oklch(0.88 0.018 70);
  --card: #ffffff;
  --font-display: "Geist", ui-sans-serif, system-ui, sans-serif;
  --font-body: "Geist", ui-sans-serif, system-ui, sans-serif;
  --font-mono: "Geist Mono", ui-monospace, monospace;
  --display-weight: 600;
  --display-italic: normal;
  --display-tracking: -0.025em;
}
body[data-dir="citrus"] {
  --primary: oklch(0.78 0.19 135);
  --primary-ink: oklch(0.2 0.05 140);
  --primary-soft: oklch(0.93 0.08 130);
  --accent: oklch(0.6 0.18 28);
  --bg: oklch(0.985 0.008 100);
  --bg-2: oklch(0.945 0.022 95);
  --bg-3: oklch(0.92 0.035 110);
  --ink: oklch(0.18 0.04 135);
  --ink-2: oklch(0.4 0.03 135);
  --ink-3: oklch(0.58 0.02 130);
  --line: oklch(0.86 0.02 120);
  --card: #ffffff;
  --font-display: "Instrument Serif", "Times New Roman", serif;
  --font-body: "Plus Jakarta Sans", ui-sans-serif, system-ui, sans-serif;
  --font-mono: "Geist Mono", ui-monospace, monospace;
  --display-weight: 400;
  --display-italic: normal;
  --display-tracking: -0.01em;
}
body[data-dir="sky"] {
  --primary: oklch(0.65 0.16 255);
  --primary-ink: #fff;
  --primary-soft: oklch(0.94 0.05 255);
  --accent: oklch(0.72 0.16 310);
  --bg: oklch(0.985 0.008 250);
  --bg-2: oklch(0.945 0.022 258);
  --bg-3: oklch(0.92 0.032 262);
  --ink: oklch(0.18 0.035 255);
  --ink-2: oklch(0.4 0.03 255);
  --ink-3: oklch(0.58 0.025 255);
  --line: oklch(0.88 0.018 255);
  --card: #ffffff;
  --font-display: "Bricolage Grotesque", ui-sans-serif, system-ui, sans-serif;
  --font-body: "Manrope", ui-sans-serif, system-ui, sans-serif;
  --font-mono: "Geist Mono", ui-monospace, monospace;
  --display-weight: 600;
  --display-italic: normal;
  --display-tracking: -0.03em;
}

/* ───────── dark mode (per direction) ───────── */
body[data-theme="dark"] {
  --card: oklch(0.22 0.018 70);
  --shadow-card: 0 1px 0 rgba(255,255,255,.04), 0 18px 30px -18px rgba(0,0,0,.45);
  --shadow-pop: 0 30px 60px -22px rgba(0,0,0,.55);
}
body[data-dir="sunny"][data-theme="dark"] {
  --bg: oklch(0.18 0.02 50);
  --bg-2: oklch(0.22 0.022 55);
  --bg-3: oklch(0.27 0.03 60);
  --ink: oklch(0.97 0.012 75);
  --ink-2: oklch(0.78 0.018 70);
  --ink-3: oklch(0.6 0.018 70);
  --line: oklch(0.32 0.025 60);
  --card: oklch(0.22 0.022 55);
}
body[data-dir="citrus"][data-theme="dark"] {
  --bg: oklch(0.18 0.025 140);
  --bg-2: oklch(0.22 0.03 138);
  --bg-3: oklch(0.27 0.035 135);
  --ink: oklch(0.96 0.012 110);
  --ink-2: oklch(0.78 0.018 120);
  --ink-3: oklch(0.6 0.02 130);
  --line: oklch(0.32 0.03 130);
  --card: oklch(0.22 0.03 138);
}
body[data-dir="sky"][data-theme="dark"] {
  --bg: oklch(0.16 0.025 255);
  --bg-2: oklch(0.2 0.03 258);
  --bg-3: oklch(0.25 0.035 260);
  --ink: oklch(0.97 0.012 255);
  --ink-2: oklch(0.78 0.018 255);
  --ink-3: oklch(0.6 0.02 255);
  --line: oklch(0.32 0.03 258);
  --card: oklch(0.2 0.03 258);
}

/* ───────── density ───────── */
body[data-density="tight"] {
  --gap: 18px;
  --gap-lg: 40px;
  --pad-section: 64px;
  --pad-card: 20px;
  --hero-pad: 56px;
}
body[data-density="airy"] {
  --gap: 28px;
  --gap-lg: 72px;
  --pad-section: 128px;
  --pad-card: 36px;
  --hero-pad: 120px;
}

/* ───────── primitives ───────── */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 32px;
}
.section { padding: var(--pad-section) 0; }
.section--tight { padding: calc(var(--pad-section) * 0.6) 0; }
.section--bg2 { background: var(--bg-2); }
.section--bg3 { background: var(--bg-3); }
.section--invert { background: var(--ink); color: var(--bg); }
.section--invert h1, .section--invert h2, .section--invert h3 { color: var(--bg); }

/* ── Accent band tone ────────────────────────────────────────────────────
   Switches the bg-3 "accent" section (e.g. "What you get") between a few
   alternative tones without disturbing other bg-3 usages. Driven by
   body[data-accent]. */
body[data-accent="sage"]  .section--bg3 { background: oklch(0.915 0.02 135); }
body[data-accent="mist"]  .section--bg3 { background: oklch(0.925 0.018 245); }
body[data-accent="peach"] .section--bg3 { background: oklch(0.93 0.045 38); }
body[data-accent="stone"] .section--bg3 { background: oklch(0.91 0.008 75); }
body[data-accent="ink"]   .section--bg3 {
  background: oklch(0.22 0.022 50);
  color: oklch(0.97 0.012 75);
}
body[data-accent="ink"] .section--bg3 h1,
body[data-accent="ink"] .section--bg3 h2,
body[data-accent="ink"] .section--bg3 h3 { color: oklch(0.98 0.012 75); }
body[data-accent="ink"] .section--bg3 p { color: rgba(255,255,255,0.72); }
body[data-accent="ink"] .section--bg3 .kicker {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.82);
}

.kicker {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ink-2);
  padding: 6px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--card);
}
.kicker .dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--primary);
  box-shadow: 0 0 0 4px color-mix(in oklch, var(--primary) 25%, transparent);
}
.kicker--invert {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.7);
}

h1, .h1 {
  font-size: clamp(40px, 6vw, 84px);
  font-weight: var(--display-weight);
  letter-spacing: var(--display-tracking);
  line-height: 0.98;
}
h2, .h2 {
  font-size: clamp(32px, 4.2vw, 56px);
  font-weight: var(--display-weight);
  letter-spacing: var(--display-tracking);
  line-height: 1.02;
}
h3, .h3 {
  font-size: clamp(22px, 2vw, 30px);
  font-weight: var(--display-weight);
  letter-spacing: -0.015em;
}

body[data-dir="citrus"] h1 em,
body[data-dir="citrus"] h2 em,
body[data-dir="citrus"] .display-em {
  font-style: italic;
  font-family: "Instrument Serif", serif;
}
body[data-dir="sunny"] h1 em,
body[data-dir="sunny"] h2 em,
body[data-dir="sunny"] .display-em {
  font-style: italic;
  font-family: "Instrument Serif", serif;
  font-weight: 400;
  letter-spacing: -0.01em;
}
body[data-dir="sky"] h1 em,
body[data-dir="sky"] h2 em,
body[data-dir="sky"] .display-em {
  font-family: "Bricolage Grotesque", sans-serif;
  font-style: italic;
  font-weight: 500;
}

.eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

/* ───────── buttons ───────── */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  height: 48px; padding: 0 22px;
  border-radius: 999px;
  font-weight: 500;
  border: 1px solid transparent;
  transition: transform .12s ease, background .15s ease, box-shadow .15s ease;
  white-space: nowrap;
  font-size: 15px;
}
.btn--primary {
  background: var(--primary); color: var(--primary-ink);
  box-shadow: 0 6px 18px -8px color-mix(in oklch, var(--primary) 80%, transparent);
}
.btn--primary:hover { transform: translateY(-1px); box-shadow: 0 10px 22px -8px color-mix(in oklch, var(--primary) 80%, transparent); }
.btn--ghost {
  background: transparent; color: var(--ink);
  border-color: var(--line);
}
.btn--ghost:hover { background: var(--bg-2); }
.btn--invert {
  background: var(--bg); color: var(--ink);
}
.btn--invert:hover { transform: translateY(-1px); }
.btn--lg { height: 56px; padding: 0 28px; font-size: 16px; }
.btn--sm { height: 36px; padding: 0 14px; font-size: 13px; }

.arrow {
  display: inline-block;
  transition: transform .15s ease;
}
.btn:hover .arrow { transform: translateX(2px); }

/* ───────── cards ───────── */
.card {
  background: var(--card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  padding: var(--pad-card);
  box-shadow: var(--shadow-card);
}

/* ───────── nav ───────── */
.nav-wrap {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in oklch, var(--bg) 80%, transparent);
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  border-bottom: 1px solid color-mix(in oklch, var(--line) 50%, transparent);
}
.nav {
  height: 72px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
}
.nav-logo {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-display); font-weight: 600;
  letter-spacing: -0.02em;
  font-size: 19px;
}
.nav-mark {
  min-width: 44px;
  height: 30px;
  padding: 0 9px;
  border-radius: 9px;
  background: var(--primary);
  color: var(--primary-ink);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.06em;
  position: relative;
  overflow: hidden;
  gap: 0;
}
.nav-mark-dollar {
  font-size: 10px;
  margin-right: 1px;
  margin-top: -6px;
  letter-spacing: 0;
  opacity: 0.85;
}

/* SVG brand mark used in the nav + footer logo (separate from the inline
   $99 pill above, which is reused inside example/IG avatar cards). */
.brand-mark {
  display: block;
  flex-shrink: 0;
  height: 36px;
  width: auto;
}
.brand-mark-tag {
  fill: var(--primary);
}
.brand-mark-hole {
  fill: var(--bg);
}
.brand-mark-d,
.brand-mark-99 {
  fill: var(--primary-ink);
  font-family: "Bricolage Grotesque", "Geist", ui-sans-serif, system-ui, sans-serif;
  font-weight: 800;
}
.brand-mark-d {
  font-size: 32px;
}
.brand-mark-99 {
  font-size: 56px;
  letter-spacing: -3px;
}
.brand-mark-spark {
  fill: var(--accent);
}
.nav-links {
  display: flex; gap: 4px; align-items: center;
}
.nav-link {
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 14.5px;
  color: var(--ink-2);
  transition: background .15s, color .15s;
}
.nav-link:hover, .nav-link[data-active="1"] {
  background: var(--bg-2);
  color: var(--ink);
}
.nav-cta { display: flex; align-items: center; gap: 10px; }

/* ───────── nav dropdown ───────── */
.nav-drop {
  position: relative;
}
.nav-link--drop {
  background: transparent;
  border: 0;
  font: inherit;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.nav-link--drop:hover,
.nav-link--drop[data-active="1"] {
  background: var(--bg-2);
  color: var(--ink);
}
.nav-link--drop svg {
  transition: transform .15s ease;
  opacity: 0.55;
}
.nav-drop:hover .nav-link--drop svg,
.nav-link--drop[aria-expanded="true"] svg {
  transform: rotate(180deg);
  opacity: 1;
}
.nav-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 240px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 8px;
  box-shadow:
    0 1px 0 rgba(0,0,0,0.02),
    0 18px 40px -16px rgba(20, 20, 30, 0.18),
    0 6px 12px -6px rgba(20, 20, 30, 0.10);
  display: flex;
  flex-direction: column;
  gap: 2px;
  opacity: 0;
  transform: translateY(-4px);
  pointer-events: none;
  transition: opacity .12s ease, transform .14s ease;
  z-index: 60;
}
.nav-menu[data-open="1"] {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.nav-menu::before {
  /* invisible hover bridge so cursor can cross gap without closing */
  content: "";
  position: absolute;
  top: -10px; left: 0; right: 0; height: 10px;
}
.nav-menu-item {
  appearance: none;
  background: transparent;
  border: 0;
  font: inherit;
  cursor: pointer;
  color: var(--ink);
  font-size: 14px;
  padding: 10px 12px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  text-align: left;
  transition: background .12s, color .12s;
}
.nav-menu-item:hover {
  background: var(--bg-2);
}
.nav-menu-item svg {
  opacity: 0;
  transform: translateX(-4px);
  transition: opacity .14s, transform .14s;
  color: var(--primary);
}
.nav-menu-item:hover svg {
  opacity: 1;
  transform: translateX(0);
}

/* ───────── hero ───────── */
.hero {
  padding: var(--hero-pad) 0 calc(var(--hero-pad) * 0.8);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.hero > .container { position: relative; z-index: 1; }

/* hero background — subtle warm radial blobs + dot grid */
.hero-bg {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}
.hero-bg-blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.55;
}
.hero-bg-blob--a {
  width: 620px; height: 620px;
  top: -180px; left: -160px;
  background: radial-gradient(circle, color-mix(in oklch, var(--primary) 55%, transparent), transparent 70%);
}
.hero-bg-blob--b {
  width: 720px; height: 720px;
  top: -120px; right: -260px;
  background: radial-gradient(circle, color-mix(in oklch, var(--accent) 55%, transparent), transparent 70%);
  opacity: 0.5;
}
.hero-bg-blob--c {
  width: 540px; height: 540px;
  bottom: -260px; left: 35%;
  background: radial-gradient(circle, color-mix(in oklch, var(--primary) 30%, transparent), transparent 70%);
  opacity: 0.35;
}
.hero-bg-grid {
  position: absolute; inset: 0;
  background-image:
    radial-gradient(color-mix(in oklch, var(--ink) 14%, transparent) 1px, transparent 1px);
  background-size: 28px 28px;
  background-position: 0 0;
  -webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 35%, #000 30%, transparent 75%);
          mask-image: radial-gradient(ellipse 80% 70% at 50% 35%, #000 30%, transparent 75%);
  opacity: 0.5;
}
body[data-theme="dark"] .hero-bg-blob { opacity: 0.35; }
body[data-theme="dark"] .hero-bg-grid {
  background-image: radial-gradient(rgba(255,255,255,0.12) 1px, transparent 1px);
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: 64px;
  align-items: center;
}
.hero-eyebrow { margin-bottom: 20px; }
.hero h1 {
  margin-bottom: 18px;
  max-width: 640px;
  font-size: clamp(36px, 4.6vw, 64px);
  line-height: 1.02;
}
.hero-lede {
  font-size: clamp(16px, 1.2vw, 18px);
  color: var(--ink-2);
  max-width: 520px;
  margin-bottom: 22px;
}

/* feedbird-style bullets above the CTAs */
.hero-bullets {
  list-style: none;
  margin: 0 0 26px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-width: 520px;
}
.hero-bullets li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 15.5px;
  color: var(--ink-2);
  line-height: 1.4;
}
.hero-bullets li strong { color: var(--ink); font-weight: 600; }
.hero-bullets-check {
  flex-shrink: 0;
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--primary);
  color: var(--primary-ink);
  display: inline-grid;
  place-items: center;
  box-shadow: 0 0 0 4px color-mix(in oklch, var(--primary) 18%, transparent);
}
.hero-bullets-check svg { stroke-width: 2.6; }

.hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; }

/* trust line under the CTAs */
.hero-trust {
  margin-top: 14px;
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  font-size: 13px;
  color: var(--ink-3);
}
.hero-trust strong { color: var(--ink-2); font-weight: 600; }
.hero-trust-sep {
  width: 1px; height: 14px; background: var(--line);
}

/* supported channels strip */
.hero-channels {
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px solid var(--line);
  max-width: 520px;
}
.hero-channels-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 12px;
}
.hero-channels-row { display: flex; gap: 8px; flex-wrap: wrap; }
.hero-channel {
  width: 30px; height: 30px;
  border-radius: 50%;
  display: inline-grid; place-items: center;
  color: #fff;
  box-shadow: 0 2px 6px -2px rgba(0,0,0,0.18);
  transition: transform .15s ease;
}
.hero-channel:hover { transform: translateY(-2px); }
.hero-channel svg { stroke-width: 2; }

@media (max-width: 880px) {
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero h1 { font-size: clamp(34px, 8vw, 52px); }
}

/* Hero carousel — phone-mockup style content reel */
.reel {
  position: relative;
  height: 560px;
  display: grid;
  place-items: center;
}
.reel-stage {
  position: relative;
  width: 320px;
  height: 100%;
}
.reel-card {
  position: absolute;
  inset: 0;
  background: var(--card);
  border-radius: 28px;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-pop);
  overflow: hidden;
  transform-origin: center;
  will-change: transform, opacity;
  transition: transform .7s cubic-bezier(.22,1,.36,1), opacity .5s ease;
}
.reel-card[data-state="back"] {
  transform: translate(40px, -20px) rotate(4deg) scale(0.92);
  opacity: 0.5;
}
.reel-card[data-state="back2"] {
  transform: translate(-46px, -34px) rotate(-6deg) scale(0.86);
  opacity: 0.32;
}
.reel-card[data-state="front"] {
  transform: translate(0, 0) rotate(0) scale(1);
  opacity: 1;
  z-index: 5;
}
.reel-card[data-state="out"] {
  transform: translate(0, 100px) rotate(2deg) scale(0.94);
  opacity: 0;
  z-index: 0;
}

.reel-head {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 14px 10px;
}
.reel-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  display: grid; place-items: center;
  color: var(--primary-ink);
  font-weight: 600;
  font-size: 14px;
  font-family: var(--font-display);
}
.reel-meta { display: flex; flex-direction: column; }
.reel-meta b { font-size: 13.5px; font-weight: 600; }
.reel-meta span { font-size: 11.5px; color: var(--ink-3); }
.reel-platform {
  margin-left: auto;
  width: 26px; height: 26px;
  border-radius: 8px;
  background: var(--bg-2);
  display: grid; place-items: center;
  color: var(--ink-2);
}
.reel-img {
  height: 320px;
  margin: 0 14px;
  border-radius: 18px;
  position: relative;
  overflow: hidden;
}
.reel-img.placeholder {
  background:
    linear-gradient(135deg, color-mix(in oklch, var(--primary) 60%, transparent) 0%, color-mix(in oklch, var(--accent) 70%, transparent) 100%),
    var(--bg-3);
}
.reel-img--photo {
  background: var(--bg-3);
}
.reel-img--photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.reel-actions--image {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 14px 14px;
  color: var(--ink-2);
}
.reel-img.placeholder::before {
  content: "";
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(45deg, rgba(255,255,255,0.07) 0 8px, transparent 8px 16px);
}
.reel-img-label {
  position: absolute; bottom: 12px; left: 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.85);
  background: rgba(0,0,0,0.35);
  padding: 4px 8px;
  border-radius: 6px;
  backdrop-filter: blur(6px);
}
.reel-cap {
  padding: 12px 16px 14px;
  font-size: 13.5px;
  color: var(--ink);
  line-height: 1.45;
}
.reel-cap b { font-weight: 600; }
.reel-cap .hashtag { color: var(--primary); font-weight: 500; }
.reel-cap--image {
  padding: 10px 14px 14px;
  font-size: 12.5px;
  line-height: 1.45;
  color: var(--ink-2);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.reel-cap--image b {
  color: var(--ink);
  margin-right: 6px;
}
.reel-actions {
  display: flex; align-items: center; gap: 18px;
  padding: 10px 16px 14px;
  color: var(--ink-2);
  font-size: 12.5px;
}
.reel-actions span { display: inline-flex; align-items: center; gap: 5px; }

.reel-tag {
  position: absolute;
  z-index: 6;
  background: var(--card);
  color: var(--ink);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 6px 12px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  box-shadow: var(--shadow-card);
  display: inline-flex; align-items: center; gap: 8px;
  white-space: nowrap;
}
.reel-tag .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--primary); }
.reel-tag--tl { top: 24px; left: -34px; transform: rotate(-4deg); }
.reel-tag--br { bottom: 64px; right: -54px; transform: rotate(3deg); }

/* hero layout variants */
body[data-hero-layout="split"] .hero-grid { grid-template-columns: minmax(0,1.05fr) minmax(0,0.95fr); }
body[data-hero-layout="centered"] .hero-grid { grid-template-columns: 1fr; text-align: center; }
body[data-hero-layout="centered"] .hero h1,
body[data-hero-layout="centered"] .hero-lede { margin-left: auto; margin-right: auto; }
body[data-hero-layout="centered"] .hero-ctas,
body[data-hero-layout="centered"] .hero-foot { justify-content: center; }
body[data-hero-layout="centered"] .reel { display: none; }
body[data-hero-layout="centered"] .centered-reel { display: grid; margin-top: 56px; }
.centered-reel { display: none; }

body[data-hero-layout="stacked"] .hero-grid { grid-template-columns: 1fr; }
body[data-hero-layout="stacked"] .reel { margin: 0 auto; }

/* ───────── press strip ───────── */
.press {
  padding: 36px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.press-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}
.press-label {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  flex-shrink: 0;
}
.press-logos {
  display: flex; align-items: center; gap: 38px;
  flex-wrap: wrap;
  flex: 1;
  justify-content: center;
}
.press-logo {
  color: var(--ink-2);
  opacity: 0.75;
  transition: opacity .2s;
  font-size: 18px;
  letter-spacing: -0.01em;
}
.press-logo:hover { opacity: 1; }

/* ───────── value props ───────── */
.value-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: var(--gap);
}
@media (max-width: 900px) {
  .value-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .value-grid { grid-template-columns: 1fr; }
}
.value-card {
  display: flex; flex-direction: column; gap: 14px;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--pad-card);
  position: relative;
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease;
}
.value-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-card); }
.value-card-num {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--ink-3);
}
.value-card h3 { line-height: 1.1; }
.value-card p { color: var(--ink-2); font-size: 15px; line-height: 1.55; }
.value-card-icon {
  width: 44px; height: 44px;
  display: grid; place-items: center;
  border-radius: 12px;
  background: var(--primary-soft);
  color: var(--primary);
}
body[data-theme="dark"] .value-card-icon {
  background: color-mix(in oklch, var(--primary) 18%, transparent);
}

/* ───────── how it works ───────── */
.how-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap);
  margin-top: 56px;
}
@media (max-width: 800px) { .how-grid { grid-template-columns: 1fr; } }
.how-step {
  position: relative;
}
.how-step-num {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: 64px;
  line-height: 0.9;
  letter-spacing: -0.04em;
  color: var(--primary);
}
body[data-dir="citrus"] .how-step-num { font-style: italic; }
.how-step h3 { margin: 16px 0 8px; }
.how-step p { color: var(--ink-2); font-size: 15.5px; }
.how-step-visual {
  margin-top: 22px;
  height: 220px;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 18px;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}
.how-step-note {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px dashed var(--line);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.02em;
  color: var(--ink-3);
}

/* ───────── post browser ───────── */
.browser {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
  gap: 56px;
  align-items: center;
}
@media (max-width: 900px) { .browser { grid-template-columns: 1fr; } }

.browser-stage {
  position: relative;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: 32px;
  height: 540px;
  overflow: hidden;
}
.browser-rail {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 0 32px;
  transition: transform .55s cubic-bezier(.22,1,.36,1);
}
.browser-post {
  flex-shrink: 0;
  width: 280px;
  height: 460px;
  background: var(--card);
  border-radius: 22px;
  border: 1px solid var(--line);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .35s, opacity .35s;
}
.browser-post[data-active="0"] {
  transform: scale(0.94);
  opacity: 0.55;
}
.browser-img {
  flex: 1;
  position: relative;
  background:
    linear-gradient(135deg, color-mix(in oklch, var(--primary) 55%, transparent), color-mix(in oklch, var(--accent) 55%, transparent)),
    var(--bg-3);
  background-blend-mode: multiply;
}
.browser-img.alt {
  background:
    linear-gradient(135deg, color-mix(in oklch, var(--accent) 75%, transparent), color-mix(in oklch, var(--primary) 35%, transparent));
}
.browser-img.alt2 {
  background:
    linear-gradient(135deg, var(--ink) 0%, color-mix(in oklch, var(--primary) 70%, transparent) 100%);
}
.browser-img.alt3 {
  background:
    radial-gradient(80% 80% at 30% 20%, color-mix(in oklch, var(--accent) 80%, transparent), transparent 60%),
    linear-gradient(180deg, var(--primary), color-mix(in oklch, var(--ink) 30%, var(--primary)));
}
.browser-img::after {
  content: "";
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(45deg, rgba(255,255,255,0.06) 0 10px, transparent 10px 20px);
}
.browser-img-text {
  position: absolute; left: 18px; right: 18px; bottom: 18px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: #fff;
  text-shadow: 0 2px 12px rgba(0,0,0,0.3);
}
.browser-img-text em {
  font-family: "Instrument Serif", serif;
  font-style: italic;
  font-weight: 400;
}
.browser-cap {
  padding: 14px 16px 18px;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--ink-2);
  border-top: 1px solid var(--line);
}
.browser-cap b { color: var(--ink); font-weight: 600; }
.browser-cap .hashtag { color: var(--primary); }

.browser-nav {
  position: absolute; bottom: 22px; left: 0; right: 0;
  display: flex; align-items: center; justify-content: center;
  gap: 16px;
}
.browser-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  border: 0;
  background: var(--ink-3);
  opacity: 0.4;
  padding: 0;
  cursor: pointer;
  transition: width .2s, opacity .2s, background .2s;
}
.browser-dot[data-on="1"] {
  width: 24px;
  opacity: 1;
  background: var(--primary);
  border-radius: 4px;
}
.browser-arrow {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--card);
  border: 1px solid var(--line);
  display: grid; place-items: center;
  color: var(--ink);
  transition: transform .15s, background .15s;
}
.browser-arrow:hover { background: var(--bg); transform: scale(1.05); }
.browser-arrow:active { transform: scale(0.96); }

.browser-pills { display: flex; gap: 8px; margin-top: 24px; flex-wrap: wrap; }
.browser-pill {
  padding: 7px 14px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--card);
  color: var(--ink-2);
  font-size: 13px;
  transition: all .15s;
}
.browser-pill[data-on="1"] {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}

/* ───────── pricing ───────── */
.pricing-toggle-wrap { display: flex; justify-content: center; margin-bottom: 48px; }
.pricing-toggle {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 4px;
  display: flex;
  position: relative;
}
.pricing-toggle button {
  position: relative;
  padding: 10px 22px;
  border: 0;
  background: transparent;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-2);
  z-index: 1;
  transition: color .2s;
}
.pricing-toggle button[data-on="1"] { color: var(--primary-ink); }
.pricing-toggle-thumb {
  position: absolute;
  top: 4px; bottom: 4px;
  background: var(--primary);
  border-radius: 999px;
  transition: left .25s cubic-bezier(.22,1,.36,1), width .25s;
  z-index: 0;
}
.pricing-save {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  padding: 3px 7px;
  margin-left: 6px;
  border-radius: 6px;
  background: var(--accent);
  color: var(--ink);
}

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

.plan {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: 32px;
  display: flex; flex-direction: column; gap: 18px;
  position: relative;
}
.plan--featured {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
  box-shadow: var(--shadow-pop);
}
.plan--featured h3, .plan--featured .plan-price { color: var(--bg); }
.plan--featured .plan-price-mo { color: rgba(255,255,255,0.6); }
.plan--featured .plan-feat-li { color: rgba(255,255,255,0.85); }
.plan--featured .plan-feat-li svg { color: var(--primary); }

.plan-badge {
  position: absolute; top: -14px; left: 32px;
  background: var(--primary);
  color: var(--primary-ink);
  padding: 5px 12px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.plan-name { font-family: var(--font-display); font-weight: 600; font-size: 20px; letter-spacing: -0.015em; }
.plan-tagline { color: var(--ink-2); font-size: 14px; min-height: 36px; }
.plan--featured .plan-tagline { color: rgba(255,255,255,0.7); }
.plan-price {
  font-family: var(--font-display);
  font-size: 56px;
  font-weight: var(--display-weight);
  letter-spacing: -0.04em;
  line-height: 1;
  display: flex; align-items: baseline; gap: 4px;
}
.plan-price-dollar { font-size: 28px; margin-bottom: 4px; }
.plan-price-mo { font-size: 14px; color: var(--ink-3); font-family: var(--font-body); font-weight: 400; letter-spacing: 0; margin-left: 4px; }
.plan-feat { display: flex; flex-direction: column; gap: 12px; padding: 6px 0; }
.plan-feat-li {
  display: flex; gap: 12px; align-items: flex-start;
  font-size: 14.5px;
  color: var(--ink);
}
.plan-feat-li svg { flex-shrink: 0; color: var(--primary); margin-top: 3px; }
.plan-cta { margin-top: auto; }

/* ───────── compare table ───────── */
.compare {
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: var(--card);
}
.compare-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  border-bottom: 1px solid var(--line);
}
.compare-row:last-child { border-bottom: 0; }
.compare-cell {
  padding: 18px 22px;
  font-size: 14.5px;
  display: flex; align-items: center; gap: 10px;
}
.compare-row--head .compare-cell {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 16px;
}
.compare-cell--feature { color: var(--ink-2); }
.compare-cell--us {
  background: color-mix(in oklch, var(--primary) 8%, transparent);
  border-left: 1px solid var(--line);
  border-right: 1px solid var(--line);
}
.compare-row--head .compare-cell--us {
  background: var(--primary);
  color: var(--primary-ink);
}
.check { color: var(--primary); }
.cross { color: var(--ink-3); opacity: 0.7; }

/* ───────── testimonials ───────── */
.testi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap);
}
@media (max-width: 900px) { .testi-grid { grid-template-columns: 1fr; } }
.testi-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 28px;
  display: flex; flex-direction: column; gap: 18px;
  position: relative;
}
.testi-card .stars {
  display: flex; gap: 2px; color: var(--primary);
}
.testi-quote { font-size: 16.5px; line-height: 1.55; color: var(--ink); }
.testi-foot { display: flex; align-items: center; gap: 12px; margin-top: auto; padding-top: 8px; }
.testi-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 600;
  color: #fff;
  font-size: 15px;
}
.testi-name { font-weight: 600; font-size: 14.5px; }
.testi-biz { font-size: 13px; color: var(--ink-3); font-family: var(--font-mono); }

/* ───────── faq ───────── */
.faq-list {
  display: flex; flex-direction: column;
  border-top: 1px solid var(--line);
}
.faq-item {
  border-bottom: 1px solid var(--line);
  padding: 22px 4px;
}
.faq-q {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 24px;
  width: 100%;
  background: transparent; border: 0;
  padding: 0;
  text-align: left;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 19px;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.faq-toggle {
  width: 32px; height: 32px;
  border-radius: 50%;
  border: 1px solid var(--line);
  display: grid; place-items: center;
  flex-shrink: 0;
  font-size: 16px;
  color: var(--ink-2);
  transition: transform .2s;
}
.faq-item[data-open="1"] .faq-toggle { transform: rotate(45deg); background: var(--primary); color: var(--primary-ink); border-color: var(--primary); }
.faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height .35s ease, padding .25s ease;
  color: var(--ink-2);
  font-size: 15.5px;
  line-height: 1.6;
  padding-top: 0;
  padding-right: 56px;
}
.faq-item[data-open="1"] .faq-a {
  max-height: 320px;
  padding-top: 14px;
}

/* ───────── footer / final cta ───────── */
.final-cta {
  background: var(--ink);
  color: var(--bg);
  padding: var(--pad-section) 0;
  position: relative;
  overflow: hidden;
}
.final-cta::before {
  content: "";
  position: absolute;
  width: 600px; height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in oklch, var(--primary) 50%, transparent), transparent 60%);
  right: -200px; top: -200px;
}
.final-cta-inner { position: relative; text-align: center; max-width: 720px; margin: 0 auto; }
.final-cta h2 { color: var(--bg); margin-bottom: 20px; }
.final-cta p { color: rgba(255,255,255,0.7); font-size: 18px; margin-bottom: 36px; }
.final-cta .btn--primary { background: var(--bg); color: var(--ink); }

.footer {
  background: var(--bg-2);
  padding: 64px 0 32px;
  border-top: 1px solid var(--line);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 56px;
}
@media (max-width: 800px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
.footer-brand h3 { font-size: 22px; margin-bottom: 12px; }
.footer-brand p { color: var(--ink-2); font-size: 14px; max-width: 280px; }
.footer-col-h {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 14px;
}
.footer-col-list { display: flex; flex-direction: column; gap: 10px; }
.footer-col-list a { color: var(--ink-2); font-size: 14px; }
.footer-col-list a:hover { color: var(--ink); }
.footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 24px; border-top: 1px solid var(--line);
  color: var(--ink-3); font-size: 13px;
  flex-wrap: wrap; gap: 16px;
}
.footer-social {
  display: flex; gap: 8px;
}
.footer-social a {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%;
  border: 1px solid var(--line);
  color: var(--ink-2);
  transition: color .15s, border-color .15s, background .15s;
}
.footer-social a:hover {
  color: var(--ink);
  border-color: var(--ink-2);
  background: var(--bg);
}

/* ───────── video examples reel ───────── */
.video-head { max-width: 720px; }
.video-reel-wrap {
  position: relative;
  /* Bleed the reel out toward the viewport edges so cards peek off-screen. */
  margin: 0 calc(50% - 50vw);
  padding: 0 max(24px, calc(50vw - 600px));
}
.video-reel {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scroll-padding-left: max(24px, calc(50vw - 600px));
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 8px;
}
.video-reel::-webkit-scrollbar { display: none; }
.video-reel .video-card {
  flex: 0 0 auto;
  width: 240px;
  scroll-snap-align: start;
}
@media (max-width: 700px) {
  .video-reel .video-card { width: 64vw; max-width: 280px; }
}
.video-reel-end {
  flex: 0 0 1px;
  /* Match the side gutter so the last card can fully snap into view. */
  margin-right: max(24px, calc(50vw - 600px));
}
.video-reel-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--bg);
  color: var(--ink);
  border: 1px solid var(--line);
  border-radius: 50%;
  cursor: pointer;
  z-index: 2;
  box-shadow: 0 6px 24px -10px rgba(0,0,0,.25);
  transition: opacity .2s, transform .2s, background .15s;
}
.video-reel-arrow:hover { background: var(--bg-2); }
.video-reel-arrow[data-hidden="1"] {
  opacity: 0; pointer-events: none;
}
.video-reel-arrow--left  { left: max(8px, calc(50vw - 620px)); }
.video-reel-arrow--right { right: max(8px, calc(50vw - 620px)); }
.video-reel-arrow--left svg { transform: rotate(180deg); }
@media (max-width: 700px) {
  .video-reel-arrow { display: none; }
}
.video-card {
  position: relative;
  aspect-ratio: 9 / 16;
  border-radius: 18px;
  overflow: hidden;
  background: var(--ink);
  border: 1px solid var(--line);
  box-shadow: 0 1px 2px rgba(0,0,0,.04), 0 12px 30px -16px rgba(0,0,0,.18);
}
.video-card iframe {
  width: 100%; height: 100%;
  border: 0; display: block;
}
.video-facade {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  padding: 0; margin: 0; border: 0;
  background: linear-gradient(135deg, #2a2a30 0%, #14141a 100%);
  cursor: pointer;
  display: block;
  overflow: hidden;
}
.video-facade img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transform: scale(1.02);
  transition: transform .4s ease, filter .2s ease;
  filter: brightness(.92);
}
.video-facade:hover img { transform: scale(1.06); filter: brightness(1); }
.video-facade::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(0,0,0,.45) 100%);
  pointer-events: none;
}
.video-facade-play {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 56px; height: 56px;
  border-radius: 50%;
  background: rgba(255,255,255,.96);
  color: #111;
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  transition: transform .15s ease, background .15s ease;
  z-index: 1;
}
.video-facade-play svg { margin-left: 3px; }
.video-facade:hover .video-facade-play {
  transform: translate(-50%, -50%) scale(1.06);
  background: #fff;
}
.video-facade-index {
  position: absolute;
  top: 12px; left: 12px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: .04em;
  color: rgba(255,255,255,.85);
  background: rgba(0,0,0,.45);
  padding: 4px 8px;
  border-radius: 999px;
  backdrop-filter: blur(6px);
  z-index: 2;
}
.video-reel-hint {
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 24px;
  color: var(--ink-3);
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.video-reel-hint-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--primary, var(--ink-2));
}

/* ───────── sticky cta ───────── */
.sticky-cta {
  position: fixed;
  bottom: 24px; left: 50%;
  transform: translate(-50%, 32px);
  background: var(--ink);
  color: var(--bg);
  border-radius: 999px;
  padding: 8px 8px 8px 22px;
  display: flex; align-items: center; gap: 18px;
  box-shadow: var(--shadow-pop);
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s, transform .3s;
  z-index: 60;
  max-width: calc(100vw - 32px);
}
.sticky-cta[data-show="1"] {
  opacity: 1;
  transform: translate(-50%, 0);
  pointer-events: auto;
}
.sticky-cta-text {
  font-size: 14.5px;
  white-space: nowrap;
}
.sticky-cta-text b { font-weight: 600; }
.sticky-cta .btn {
  height: 40px; padding: 0 18px; font-size: 14px;
  background: var(--primary); color: var(--primary-ink);
}
.sticky-cta-close {
  background: rgba(255,255,255,0.1);
  border: 0; color: var(--bg);
  width: 28px; height: 28px; border-radius: 50%;
  display: grid; place-items: center;
  margin-left: -8px;
}
@media (max-width: 560px) {
  .sticky-cta-text { font-size: 13px; white-space: normal; }
}

/* ───────── modal ───────── */
.modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(20, 12, 4, 0.5);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 100;
  display: grid; place-items: center;
  padding: 32px;
  animation: fade .2s ease;
}
@keyframes fade { from { opacity: 0; } to { opacity: 1; } }
.modal {
  background: var(--card);
  border-radius: var(--radius-xl);
  max-width: 480px;
  width: 100%;
  max-height: calc(100vh - 64px);
  overflow-y: auto;
  padding: 36px;
  position: relative;
  box-shadow: var(--shadow-pop);
  animation: pop .25s cubic-bezier(.22,1,.36,1);
}
@keyframes pop {
  from { opacity: 0; transform: translateY(20px) scale(0.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.modal-x {
  position: absolute; top: 14px; right: 14px;
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 0;
  background: var(--bg-2);
  color: var(--ink);
  display: grid; place-items: center;
  font-size: 18px;
}
.modal h2 { font-size: 32px; margin-bottom: 10px; line-height: 1.1; }
.modal-sub { color: var(--ink-2); margin-bottom: 28px; }
.modal-step {
  display: flex; flex-direction: column; gap: 16px;
}
.modal-label {
  font-family: var(--font-mono); font-size: 11.5px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3);
}
.modal-input, .modal-select {
  height: 50px;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 0 18px;
  background: var(--bg);
  color: var(--ink);
  font: inherit;
  font-size: 16px;
  width: 100%;
}
.modal-input:focus, .modal-select:focus { outline: 2px solid var(--primary); outline-offset: -1px; border-color: transparent; }
.modal-platforms {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 8px;
}
.modal-platform {
  border: 1px solid var(--line);
  background: var(--bg);
  border-radius: 12px;
  padding: 14px 8px;
  text-align: center;
  font-size: 13px;
  cursor: pointer;
  display: flex; flex-direction: column; gap: 6px; align-items: center;
  transition: all .15s;
}
.modal-platform[data-on="1"] {
  border-color: var(--primary);
  background: color-mix(in oklch, var(--primary) 10%, var(--bg));
}
.modal-platform svg { color: var(--ink-2); }
.modal-platform[data-on="1"] svg { color: var(--primary); }
.modal-step-counter {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.08em;
  color: var(--ink-3);
  margin-bottom: 8px;
}
.modal-footer {
  display: flex; gap: 10px; margin-top: 28px;
}
.modal-success {
  text-align: center;
  padding: 12px 0;
}
.modal-success-icon {
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--primary);
  color: var(--primary-ink);
  display: grid; place-items: center;
  margin: 0 auto 20px;
}

/* ───────── service detail blocks ───────── */
.svc-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  margin-bottom: var(--pad-section);
}
.svc-block:last-child { margin-bottom: 0; }
.svc-block:nth-child(even) > .svc-vis { order: -1; }
@media (max-width: 880px) {
  .svc-block { grid-template-columns: 1fr; gap: 32px; }
  .svc-block:nth-child(even) > .svc-vis { order: 0; }
}
.svc-block h2 { margin-bottom: 16px; }
.svc-block p { color: var(--ink-2); font-size: 17px; margin-bottom: 24px; }
.svc-block ul { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.svc-block ul li { display: flex; gap: 12px; align-items: flex-start; font-size: 15.5px; }
.svc-block ul li svg { color: var(--primary); flex-shrink: 0; margin-top: 3px; }
.svc-vis {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: 36px;
  aspect-ratio: 4/3;
  display: flex; align-items: center; justify-content: center;
  position: relative;
  overflow: hidden;
}

/* ───────── about ───────── */
.about-hero {
  text-align: center;
  padding: 96px 0 64px;
  max-width: 720px;
  margin: 0 auto;
}
.about-hero h1 { margin-bottom: 24px; }
.about-hero p { color: var(--ink-2); font-size: 19px; line-height: 1.6; }
.stat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gap);
}
@media (max-width: 900px) { .stat-grid { grid-template-columns: 1fr 1fr; } }
.stat-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 28px;
}
.stat-num {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: 48px;
  letter-spacing: -0.03em;
  color: var(--primary);
  line-height: 1;
  margin-bottom: 10px;
}
body[data-dir="citrus"] .stat-num { font-style: italic; }
.stat-label { color: var(--ink-2); font-size: 14.5px; }

/* ───────── contact ───────── */
.contact-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 64px;
}
@media (max-width: 800px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-info { display: flex; flex-direction: column; gap: 24px; }
.contact-info-card {
  display: flex; gap: 18px;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
}
.contact-info-card svg { color: var(--primary); }
.contact-info-card h4 { font-family: var(--font-display); font-weight: 600; font-size: 16px; margin-bottom: 4px; letter-spacing: -0.01em; }
.contact-info-card p { color: var(--ink-2); font-size: 14.5px; }
.contact-form {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: 36px;
  display: flex; flex-direction: column; gap: 16px;
}
.contact-form label { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); }
.contact-form textarea {
  min-height: 120px;
  resize: vertical;
  padding: 14px 18px;
  font: inherit;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: var(--bg);
  color: var(--ink);
}
.contact-form textarea:focus { outline: 2px solid var(--primary); outline-offset: -1px; border-color: transparent; }

/* ───────── page transitions ───────── */
.page {
  animation: pageIn .35s ease;
}
@keyframes pageIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ───────── small util ───────── */
.muted { color: var(--ink-2); }
.center { text-align: center; }
.section-head { max-width: 720px; margin: 0 auto 56px; text-align: center; }
.section-head .kicker { margin-bottom: 22px; }
.section-head h2 { margin-bottom: 16px; }
.section-head p { color: var(--ink-2); font-size: 18px; }

.flow-row { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }

/* ───────── content shimmer (calendar in how-step / svc-vis) ───────── */
.mini-cal {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  margin-top: auto;
}
.mini-cal-day {
  aspect-ratio: 1;
  background: var(--bg-2);
  border-radius: 5px;
  position: relative;
}
.mini-cal-day[data-on="1"] {
  background: var(--primary);
}
.mini-cal-day[data-on="1"]::after {
  content: "";
  position: absolute;
  inset: 4px;
  border-radius: 3px;
  background: rgba(255,255,255,0.4);
}

/* Legacy .chat-line rules removed — the .chat-list / .chat-line grid layout
   defined further down is the source of truth. */

/* ───────── Nav: tighten on smaller screens ───────── */
@media (max-width: 1024px) {
  .nav-link--signin { display: none; }
}
@media (max-width: 880px) {
  .nav-links { display: none; }
}

/* ───────── btn ghost on inverted bg ───────── */
.btn--ghost-invert {
  background: transparent;
  color: var(--bg);
  border: 1px solid rgba(255,255,255,0.25);
}
.btn--ghost-invert:hover { background: rgba(255,255,255,0.08); transform: translateY(-1px); }

/* ───────── final CTA buttons row ───────── */
.final-cta-buttons {
  display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
}

/* ───────── Sales video section ───────── */
.video-section { }
.video-head {
  max-width: 820px; margin: 0 auto 48px; text-align: center;
}
.video-head .kicker { margin-bottom: 22px; }
.video-head h2 { margin-bottom: 16px; }
.video-head p { color: var(--ink-2); font-size: 18px; }

.video-frame {
  max-width: 960px;
  margin: 0 auto;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-pop);
  border: 1px solid var(--line);
  background: var(--card);
}

.video-stage {
  aspect-ratio: 16 / 9;
  position: relative;
  background: #0b0b0d;
  color: #fff;
  overflow: hidden;
  cursor: pointer;
}

.video-poster {
  position: absolute; inset: 0;
  display: flex;
  cursor: pointer;
}
.video-poster-overlay { flex: 1; min-width: 0; }
.video-poster::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(60% 60% at 80% 30%, color-mix(in oklch, var(--accent) 70%, transparent), transparent 70%),
    radial-gradient(50% 60% at 20% 70%, color-mix(in oklch, var(--primary) 50%, transparent), transparent 70%),
    linear-gradient(135deg, #0b0b0d, #16161a 70%, color-mix(in oklch, var(--primary) 20%, #1a1a20) 100%);
}
.video-poster::after {
  content: "";
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(45deg, rgba(255,255,255,0.025) 0 14px, transparent 14px 28px);
}
.video-poster-overlay {
  position: relative;
  padding: clamp(28px, 5%, 56px);
  width: 100%;
  display: flex; flex-direction: column;
  justify-content: space-between;
}
.video-poster-eyebrow {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.video-poster-title {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: clamp(36px, 5.6vw, 64px);
  letter-spacing: var(--display-tracking);
  line-height: 1;
  margin: 18px 0 28px;
}
.video-poster-title em {
  color: var(--primary);
  font-style: normal;
  font-family: var(--font-display);
}
body[data-dir="citrus"] .video-poster-title em {
  font-family: "Instrument Serif", serif;
  font-style: italic;
}
.video-poster-bullets {
  display: flex; flex-direction: column; gap: 10px;
  font-size: clamp(14px, 1.5vw, 17px);
  max-width: 540px;
  color: rgba(255,255,255,0.9);
}
.video-poster-bullets > div {
  display: flex; gap: 12px; align-items: flex-start;
}
.video-poster-bullets .vpb-dot {
  width: 22px; height: 22px;
  border-radius: 6px;
  background: var(--primary);
  flex-shrink: 0;
  margin-top: 2px;
}
.video-poster-bullets .vpb-text {
  flex: 1; min-width: 0;
  line-height: 1.45;
}
.video-poster-foot {
  margin-top: auto; padding-top: 28px;
  display: flex; align-items: center; justify-content: space-between;
}
.video-poster-host {
  display: flex; gap: 12px; align-items: center;
}
.video-poster-avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 600; font-size: 14px;
  color: #fff;
}

.video-play {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 88px; height: 88px;
  border-radius: 50%;
  border: 0;
  background: rgba(255,255,255,0.92);
  color: #0b0b0d;
  display: grid; place-items: center;
  padding-left: 6px;
  cursor: pointer;
  box-shadow: 0 12px 36px rgba(0,0,0,0.4);
  transition: transform .15s ease, background .15s ease;
}
.video-stage:hover .video-play {
  transform: translate(-50%, -50%) scale(1.06);
  background: #fff;
}
.video-duration {
  position: absolute;
  right: 18px; bottom: 18px;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(6px);
  color: rgba(255,255,255,0.9);
  font-family: var(--font-mono);
  font-size: 11.5px;
  padding: 5px 9px;
  border-radius: 6px;
  display: flex; align-items: center; gap: 6px;
}
.video-playing {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 16px;
  background: #0b0b0d;
  color: rgba(255,255,255,0.7);
}
.video-playing-label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.video-foot {
  margin-top: 24px;
  display: flex; gap: 14px; justify-content: center; align-items: center;
}
.video-transcript {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--ink-2);  font-size: 14px;
  padding: 6px 10px;
  border-radius: 8px;
  transition: background .15s, color .15s;
}
.video-transcript:hover { background: var(--bg-2); color: var(--ink); }
.video-foot-sep { color: var(--ink-3); }

/* ───────── Pricing tabs ───────── */
.pricing-tabs-wrap {
  display: flex; justify-content: center;
  margin-bottom: 24px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.pricing-tabs-wrap::-webkit-scrollbar { display: none; }
.pricing-tabs {
  display: inline-flex;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 6px;
  gap: 4px;
}
.pricing-tab {
  display: inline-flex;
  align-items: center; gap: 8px;
  padding: 10px 18px;
  background: transparent;
  border: 0;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-2);
  white-space: nowrap;
  transition: background .15s, color .15s;
  cursor: pointer;
}
.pricing-tab:hover { color: var(--ink); }
.pricing-tab[data-on="1"] {
  background: var(--primary);
  color: var(--primary-ink);
  box-shadow: 0 4px 12px -6px color-mix(in oklch, var(--primary) 80%, transparent);
}

/* ───────── Pricing card (tiers + sidebar) ───────── */
.price-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: 36px;
  box-shadow: var(--shadow-card);
}
.price-card-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 40px;
  align-items: stretch;
}
@media (max-width: 880px) {
  .price-card { padding: 22px; }
  .price-card-grid { grid-template-columns: 1fr; gap: 28px; }
}

.price-tiers {
  display: flex; flex-direction: column; gap: 14px;
}
.price-tier {
  display: grid;
  grid-template-columns: 26px 1fr auto;
  align-items: center;
  gap: 18px;
  background: transparent;
  border: 1.5px solid var(--line);
  border-radius: 16px;
  padding: 20px 22px;
  text-align: left;
  cursor: pointer;
  transition: border-color .15s ease, background .15s ease, transform .15s ease;
  font: inherit;
  color: inherit;
  width: 100%;
}
.price-tier:hover {
  border-color: color-mix(in oklch, var(--primary) 40%, var(--line));
}
.price-tier[data-on="1"] {
  border-color: var(--ink);
  background: color-mix(in oklch, var(--primary) 5%, transparent);
}
.price-tier-radio {
  width: 22px; height: 22px;
  border-radius: 50%;
  border: 1.5px solid var(--line);
  display: grid; place-items: center;
  color: #fff;
  flex-shrink: 0;
}
.price-tier[data-on="1"] .price-tier-radio {
  background: var(--ink);
  border-color: var(--ink);
}
.price-tier-body {
  display: flex; flex-direction: column; gap: 4px;
  min-width: 0;
}
.price-tier-head {
  display: flex; align-items: center; gap: 10px;
}
.price-tier-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  letter-spacing: -0.015em;
}
.price-tier-pop {
  background: var(--ink);
  color: var(--bg);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 7px;
  border-radius: 999px;
}
.price-tier-sub {
  color: var(--ink-2);
  font-size: 14px;
}
.price-tier-amount {
  font-family: var(--font-display);
  letter-spacing: -0.02em;
  white-space: nowrap;
  display: flex; align-items: baseline; gap: 2px;
}
.price-tier-amount b {
  font-weight: var(--display-weight);
  font-size: 26px;
}
.price-tier-amount span {
  color: var(--ink-3);
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 14px;
}
.price-fine {
  font-size: 12.5px;
  color: var(--ink-3);
  line-height: 1.55;
  padding: 8px 4px 0;
}
.price-fine a { color: var(--primary); text-decoration: underline; text-underline-offset: 2px; }

.price-aside {
  background: var(--bg-2);
  border-radius: 18px;
  padding: 28px;
  display: flex; flex-direction: column;
  border: 1px solid var(--line);
}
.price-aside-head {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  letter-spacing: -0.015em;
  margin-bottom: 18px;
}
.price-aside-list {
  display: flex; flex-direction: column; gap: 13px;
  margin-bottom: 22px;
}
.price-aside-li {
  display: flex; gap: 12px; align-items: center;
  font-size: 14.5px;
}
.price-aside-check {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--bg);
  display: grid; place-items: center;
  flex-shrink: 0;
}
.price-aside-cta {
  width: 100%; justify-content: center;
  margin-top: auto;
}
.price-aside-fine {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--ink-3);
  margin-top: 12px;
}

/* ───────── Modal: book a demo ───────── */
.modal--demo { max-width: 560px; }
.demo-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  margin-top: 8px;
}
@media (max-width: 520px) {
  .demo-grid { grid-template-columns: 1fr; }
}
.demo-dates {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px;
  max-height: 280px;
  overflow-y: auto;
  padding-right: 2px;
}
.demo-date {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 1px;
  padding: 10px 4px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--bg);
  font: inherit; color: inherit;
  cursor: pointer;
  transition: border-color .12s, background .12s;
}
.demo-date span { font-family: var(--font-mono); font-size: 10.5px; color: var(--ink-3); letter-spacing: 0.04em; text-transform: uppercase; }
.demo-date b { font-family: var(--font-display); font-size: 16px; font-weight: 600; }
.demo-date:hover { border-color: color-mix(in oklch, var(--primary) 40%, var(--line)); }
.demo-date[data-on="1"] {
  background: var(--ink); border-color: var(--ink); color: var(--bg);
}
.demo-date[data-on="1"] span { color: rgba(255,255,255,0.7); }

.demo-times {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  max-height: 260px;
  overflow-y: auto;
}
.demo-time {
  padding: 12px 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--bg);
  font: inherit; color: inherit;
  font-size: 13.5px;
  cursor: pointer;
  text-align: center;
  transition: border-color .12s, background .12s;
}
.demo-time:hover:not([disabled]) { border-color: color-mix(in oklch, var(--primary) 40%, var(--line)); }
.demo-time[data-on="1"] {
  background: var(--ink); color: var(--bg); border-color: var(--ink);
}
.demo-time[disabled] { opacity: 0.4; cursor: not-allowed; }

.modal-alt {
  text-align: center;
  margin-top: 18px;
  font-size: 13.5px;
  color: var(--ink-2);
}
.modal-alt a { color: var(--primary); font-weight: 500; }
.modal-alt a:hover { text-decoration: underline; }

/* ───────── Sticky CTA: tighten on phone ───────── */
@media (max-width: 560px) {
  .sticky-cta { padding: 6px 6px 6px 16px; gap: 10px; }
  .sticky-cta-text { font-size: 12.5px; max-width: 180px; }
}


/* ───────── Trust strip (editorial proof block) ───────── */
.trust-strip {
  position: relative;
  padding: clamp(72px, 9vw, 120px) 0 clamp(56px, 7vw, 96px);
  background: var(--ink);
  color: var(--bg);
  overflow: hidden;
  isolation: isolate;
}
.trust-strip--compact {
  padding: clamp(40px, 4.5vw, 64px) 0 clamp(36px, 4vw, 56px);
}

/* Hero headline inside the trust strip */
.trust-strip-hero {
  text-align: center;
  margin-bottom: clamp(36px, 4vw, 56px);
  display: flex; flex-direction: column; align-items: center;
  gap: 18px;
}
.trust-strip-hero-eyebrow {
  display: inline-flex; align-items: center; gap: 14px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.trust-strip-hero-title {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  letter-spacing: var(--display-tracking);
  line-height: 1.02;
  font-size: clamp(40px, 5.4vw, 76px);
  color: var(--bg);
  margin: 0;
  max-width: 18ch;
  text-wrap: balance;
}
.trust-strip-hero-title em {
  font-style: normal;
  font-family: var(--font-display);
  color: var(--primary);
}
body[data-dir="citrus"] .trust-strip-hero-title em {
  font-family: "Instrument Serif", serif;
  font-style: italic;
  font-weight: 400;
}
.trust-strip-hero-sub {
  font-size: clamp(15px, 1.2vw, 18px);
  color: rgba(255,255,255,0.65);
  max-width: 540px;
  margin: 0;
}

.trust-strip-stats--mini {
  max-width: 920px;
  margin: 0 auto;
}
.trust-strip-stats--mini .trust-strip-stat {
  padding: clamp(10px, 1.2vw, 16px) clamp(14px, 1.8vw, 24px);
  text-align: center;
  align-items: center;
}
.trust-strip-stats--mini .trust-strip-stat-num {
  font-size: clamp(24px, 2.4vw, 32px) !important;
  line-height: 1;
}
.trust-strip-stats--mini .trust-strip-stat-suffix {
  font-size: 0.55em;
  opacity: 0.8;
}
.trust-strip-stats--mini .trust-strip-stat-label {
  font-size: 12px !important;
  margin-top: 6px !important;
  color: rgba(255,255,255,0.55);
  letter-spacing: 0.01em;
}
.trust-strip--compact .trust-strip-corner { top: 16px; bottom: 16px; left: 16px; right: 16px; width: 16px; height: 16px; }
.trust-strip--compact .trust-strip-corner--tl { top: 16px; left: 16px; bottom: auto; right: auto; }
.trust-strip--compact .trust-strip-corner--tr { top: 16px; right: 16px; bottom: auto; left: auto; }
.trust-strip--compact .trust-strip-corner--bl { bottom: 16px; left: 16px; top: auto; right: auto; }
.trust-strip--compact .trust-strip-corner--br { bottom: 16px; right: 16px; top: auto; left: auto; }
.trust-strip--compact .trust-strip-rule { margin-bottom: clamp(24px, 3vw, 36px); }
.trust-strip--compact .trust-strip-stats { gap: 0; }
.trust-strip--compact .trust-strip-stat { padding: clamp(12px, 1.6vw, 20px) clamp(14px, 1.8vw, 24px); }
.trust-strip--compact .trust-strip-stat-num {
  font-size: clamp(40px, 5.5vw, 64px);
  line-height: 1;
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
}
.trust-strip--compact .trust-strip-stat-num em {
  font-style: normal;
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  letter-spacing: -0.04em;
}
body[data-dir="citrus"] .trust-strip--compact .trust-strip-stat-num em {
  font-family: "Instrument Serif", serif;
  font-style: italic;
  font-weight: 400;
  color: var(--primary);
}
.trust-strip-stat-suffix {
  font-family: var(--font-display);
  font-size: 0.42em;
  font-weight: 500;
  letter-spacing: 0;
  color: rgba(255,255,255,0.6);
  text-transform: lowercase;
}
.trust-strip--compact .trust-strip-stat-label {
  font-size: 13.5px;
  margin-top: 8px;
}
.trust-strip--compact .trust-strip-stat-foot {
  font-size: 10.5px;
  color: rgba(255,255,255,0.42);
  letter-spacing: 0.03em;
  text-transform: none;
}

/* ───────── Process step 1 chat (refactor for robustness) ───────── */
.chat-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  height: 100%;
}
.chat-line {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
}
.chat-line .chat-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-3);
  background: var(--bg-2);
  border-radius: 999px;
  padding: 6px 0;
  text-align: center;
  font-weight: 600;
  line-height: 1;
  align-self: start;
  margin-top: 2px;
}
.chat-line .chat-msg {
  background: var(--bg-2);
  padding: 8px 12px;
  border-radius: 12px 12px 12px 4px;
  color: var(--ink);
  font-size: 12.5px;
  line-height: 1.4;
  min-width: 0;
  word-wrap: break-word;
}
.chat-line.you .chat-tag {
  color: var(--primary);
  background: color-mix(in oklch, var(--primary) 14%, var(--bg-2));
}
.chat-line.you .chat-msg {
  background: color-mix(in oklch, var(--primary) 14%, var(--bg-2));
  border-radius: 12px 12px 4px 12px;
}

/* ───────── Real client images in examples grid ───────── */
.ex-card-image--photo {
  background: var(--bg-2);
  overflow: hidden;
}
.ex-card-image--photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.trust-strip::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%, color-mix(in oklch, var(--primary) 22%, transparent) 0%, transparent 70%),
    radial-gradient(ellipse 60% 50% at 100% 100%, color-mix(in oklch, var(--accent) 18%, transparent) 0%, transparent 60%);
  opacity: 0.85;
  pointer-events: none;
  z-index: -1;
}
.trust-strip::after {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 100% 70% at 50% 50%, #000 30%, transparent 80%);
  pointer-events: none;
  z-index: -1;
}
.trust-strip-corner {
  position: absolute;
  width: 22px; height: 22px;
  border: 1px solid rgba(255,255,255,0.18);
  pointer-events: none;
}
.trust-strip-corner--tl { top: 24px; left: 24px; border-right: 0; border-bottom: 0; }
.trust-strip-corner--tr { top: 24px; right: 24px; border-left: 0; border-bottom: 0; }
.trust-strip-corner--bl { bottom: 24px; left: 24px; border-right: 0; border-top: 0; }
.trust-strip-corner--br { bottom: 24px; right: 24px; border-left: 0; border-top: 0; }

.trust-strip-rule {
  display: flex; align-items: center; gap: 16px;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  margin-bottom: clamp(40px, 5vw, 64px);
}
.trust-strip-rule-line {
  flex: 0 1 80px;
  height: 1px;
  background: rgba(255,255,255,0.18);
}
.trust-strip-stars {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--primary);
}
.trust-strip-stars > span:last-child { color: rgba(255,255,255,0.55); }

.trust-strip-pull {
  display: grid;
  grid-template-columns: auto auto 1fr;
  align-items: end;
  gap: clamp(16px, 2vw, 32px);
  max-width: 1080px;
  margin: 0 auto clamp(56px, 7vw, 88px);
  padding: 0 8px;
}
.trust-strip-pull-lead {
  font-family: var(--font-mono);
  font-size: clamp(13px, 1.1vw, 16px);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  padding-bottom: clamp(20px, 2.5vw, 36px);
  white-space: nowrap;
}
.trust-strip-pull-big {
  display: inline-flex; align-items: flex-start;
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  line-height: 0.85;
  letter-spacing: -0.055em;
  font-size: clamp(120px, 18vw, 240px);
  color: var(--bg);
  position: relative;
}
.trust-strip-pull-big em {
  font-style: normal;
  font-family: var(--font-display);
}
body[data-dir="citrus"] .trust-strip-pull-big em {
  font-family: "Instrument Serif", serif;
  font-style: italic;
  color: var(--primary);
}
.trust-strip-pull-plus {
  font-size: 0.5em;
  font-family: var(--font-display);
  margin-left: 0.04em;
  color: var(--primary);
  align-self: flex-start;
  margin-top: 0.12em;
}
.trust-strip-pull-tail {
  max-width: 360px;
  font-size: clamp(14px, 1.1vw, 17px);
  line-height: 1.45;
  color: rgba(255,255,255,0.75);
  padding-bottom: clamp(16px, 2vw, 28px);
}
@media (max-width: 880px) {
  .trust-strip-pull {
    grid-template-columns: 1fr;
    text-align: center;
    justify-items: center;
  }
  .trust-strip-pull-lead { padding: 0; }
  .trust-strip-pull-tail { padding: 0; }
}

.trust-strip-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid rgba(255,255,255,0.12);
  border-bottom: 1px solid rgba(255,255,255,0.12);
  max-width: 1200px;
  margin: 0 auto;
}
.trust-strip-stat {
  padding: clamp(24px, 3vw, 36px) clamp(16px, 2vw, 28px);
  border-left: 1px solid rgba(255,255,255,0.12);
  display: flex; flex-direction: column; gap: 6px;
}
.trust-strip-stat:first-child { border-left: 0; }
.trust-strip-stat-num {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: clamp(32px, 3.4vw, 44px);
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--bg);
}
body[data-dir="citrus"] .trust-strip-stat-num {
  font-family: "Instrument Serif", serif;
  font-style: italic;
  color: var(--primary);
  font-weight: 400;
}
.trust-strip-stat-label {
  font-size: 14.5px;
  font-weight: 500;
  color: rgba(255,255,255,0.92);
  margin-top: 4px;
}
.trust-strip-stat-foot {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.05em;
  color: rgba(255,255,255,0.5);
  text-transform: uppercase;
}
@media (max-width: 880px) {
  .trust-strip-stats { grid-template-columns: 1fr 1fr; }
  .trust-strip-stat:nth-child(3) { border-left: 0; }
  .trust-strip-stat:nth-child(3), .trust-strip-stat:nth-child(4) {
    border-top: 1px solid rgba(255,255,255,0.12);
  }
}

.trust-strip-ticker {
  margin-top: clamp(40px, 5vw, 56px);
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}
.trust-strip-ticker-track {
  display: flex; align-items: center;
  gap: 32px;
  width: max-content;
  animation: trust-ticker 48s linear infinite;
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}
.trust-strip-ticker-item {
  display: inline-flex; align-items: center; gap: 8px;
  white-space: nowrap;
}
.trust-strip-ticker-item span { color: var(--primary); font-size: 14px; }
@keyframes trust-ticker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .trust-strip-ticker-track { animation: none; }
}

/* ───────── Value card CTA link ───────── */
.value-card-cta {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--primary);
  transition: gap .15s ease;
  align-self: flex-start;
}
.value-card-cta:hover { gap: 10px; }

/* ───────── Pricing tier add-on tag ───────── */
.price-tier-addon {
  display: block;
  font-style: normal;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.04em;
  color: var(--ink-3);
  margin-top: 3px;
  text-align: right;
  font-weight: 400;
}

/* ───────── Examples grid (Instagram style) ───────── */
.ex-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 32px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: 8px;
  justify-content: center;
  flex-wrap: wrap;
}
.ex-tabs::-webkit-scrollbar { display: none; }
.ex-tab {
  padding: 9px 16px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--card);
  color: var(--ink-2);
  font-size: 14px;
  font-weight: 500;
  white-space: nowrap;
  transition: background .15s, color .15s, border-color .15s;
  cursor: pointer;
}
.ex-tab:hover { color: var(--ink); }
.ex-tab[data-on="1"] {
  background: color-mix(in oklch, var(--primary) 14%, transparent);
  border-color: color-mix(in oklch, var(--primary) 50%, var(--line));
  color: var(--primary);
}
body[data-theme="dark"] .ex-tab[data-on="1"] { color: #fff; background: var(--primary); border-color: var(--primary); }

.ex-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 18px;
}
@media (max-width: 880px) { .ex-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .ex-grid { grid-template-columns: 1fr; } }

.ex-card {
  background: var(--card);
  border-radius: var(--radius);
  border: 1px solid var(--line);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  display: flex; flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease;
}
.ex-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-pop);
}
.ex-card-head {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 12px;
}
.ex-card-avatar { display: flex; align-items: center; }
.ex-card-handle {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.ex-card-more {
  margin-left: auto;
  color: var(--ink-3);
  font-size: 18px;
  letter-spacing: -0.05em;
}
.ex-card-image {
  aspect-ratio: 1;
  position: relative;
  overflow: hidden;
  display: flex; align-items: flex-end;
  padding: 18px;
}
.ex-card-image::after {
  content: "";
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(45deg, rgba(255,255,255,0.04) 0 12px, transparent 12px 24px);
  pointer-events: none;
}
.ex-card-overlay {
  position: relative;
  z-index: 2;
  display: flex; flex-direction: column; gap: 4px;
  width: 100%;
}
.ex-card-kicker {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.85;
}
.ex-card-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(20px, 2vw, 26px);
  letter-spacing: -0.025em;
  line-height: 1;
}
.ex-card-title em {
  font-family: "Instrument Serif", serif;
  font-style: italic;
  font-weight: 400;
  display: inline-block;
  margin-left: 2px;
}
.ex-card-foot {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 12px;
  color: var(--ink);
}
.ex-card-icons { display: flex; gap: 14px; }

/* image variants — gradient + color palette per industry */
.ex-soft-beige  { background: linear-gradient(135deg, oklch(0.92 0.04 60), oklch(0.84 0.06 50)); color: oklch(0.2 0.04 50); }
.ex-soft-green  { background: linear-gradient(135deg, oklch(0.88 0.08 145), oklch(0.74 0.1 150)); color: oklch(0.2 0.06 145); }
.ex-bright-pink { background: linear-gradient(135deg, #ff5781 0%, #ff3370 100%); color: #fff; }
.ex-yellow-sport { background: linear-gradient(180deg, #4FA3D9 0%, #2D5F9F 60%, #1a3a6c 100%); color: #fff; }
.ex-yellow-product { background: linear-gradient(180deg, #f7d100 0%, #e6a800 100%); color: oklch(0.18 0.04 70); }
.ex-dark-photo { background: linear-gradient(180deg, oklch(0.28 0.02 50) 0%, oklch(0.14 0.02 50) 100%); color: #fff; }
.ex-purple-bold { background: linear-gradient(135deg, #f3eefb 0%, #e1d4f7 100%); color: #4c2b8a; }
.ex-purple-bold .ex-card-title { color: #4c2b8a; }
.ex-moody-warm { background: linear-gradient(180deg, oklch(0.32 0.05 40) 0%, oklch(0.18 0.04 30) 100%); color: oklch(0.86 0.08 70); }
.ex-moody-warm .ex-card-title em { color: oklch(0.86 0.08 70); }
.ex-construction { background: linear-gradient(135deg, oklch(0.72 0.16 240) 0%, oklch(0.5 0.16 250) 100%); color: #fff; }

/* ───────── Add-ons section ───────── */
.addon-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap);
}
@media (max-width: 900px) { .addon-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .addon-grid { grid-template-columns: 1fr; } }

.addon-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 28px;
  display: flex; flex-direction: column; gap: 16px;
}
.addon-card-head {
  display: flex; flex-direction: column; gap: 8px;
}
.addon-card-head h3 {
  font-size: 22px;
  letter-spacing: -0.02em;
  margin-bottom: 0;
}
.addon-card-from {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--ink-2);
}
.addon-card-from b {
  font-family: var(--font-display);
  font-size: 22px;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.addon-card-body { color: var(--ink-2); font-size: 14.5px; }
.addon-card-tiers {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex; flex-direction: column; gap: 8px;
}
.addon-card-tiers li {
  display: flex; align-items: center; gap: 10px;
  font-size: 14px;
  color: var(--ink);
}
.addon-card-tiers li svg { color: var(--primary); flex-shrink: 0; }

/* ───────── Channels grid ───────── */
.channel-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gap);
}
@media (max-width: 880px) { .channel-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .channel-grid { grid-template-columns: 1fr; } }

.channel-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 22px;
  display: flex; align-items: center; gap: 16px;
  transition: transform .15s ease, box-shadow .15s ease;
}
.channel-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-card); }
.channel-card-icon {
  width: 48px; height: 48px;
  border-radius: 12px;
  background: var(--primary-soft);
  color: var(--primary);
  display: grid; place-items: center;
  flex-shrink: 0;
}
body[data-theme="dark"] .channel-card-icon {
  background: color-mix(in oklch, var(--primary) 18%, transparent);
}
.channel-card-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 16.5px;
  letter-spacing: -0.015em;
}


/* ───────── YouTube iframe + transcript body ───────── */
.video-yt-target,
.video-stage iframe {
  position: absolute; inset: 0;
  width: 100% !important;
  height: 100% !important;
  border: 0;
  border-radius: 16px;
  display: block;
}
.video-stage[data-playing="1"] { cursor: default; }
.video-stage[data-playing="1"] .video-play,
.video-stage[data-playing="1"] .video-poster,
.video-stage[data-playing="1"] .video-duration { display: none; }

.video-transcript {
  background: none;
  border: 0;
  cursor: pointer;
  font: inherit;
}
.video-transcript-body {
  max-width: 820px;
  margin: 28px auto 0;
  padding: 28px 32px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 16px;
  font-size: 15px;
  line-height: 1.65;
  color: var(--ink-2);
  text-align: left;
}
.video-transcript-body p { margin: 0 0 14px; }
.video-transcript-body p:last-child { margin-bottom: 0; }

/* ───────── Pricing: flat (single-tier) plan ───────── */
.price-flat {
  display: flex; flex-direction: column;
  padding: 28px 28px 24px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: color-mix(in oklch, var(--primary) 4%, var(--bg));
  position: relative;
  overflow: hidden;
}
.price-flat::before {
  content: "";
  position: absolute;
  top: -80px; right: -80px;
  width: 280px; height: 280px;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in oklch, var(--primary) 25%, transparent), transparent 65%);
  pointer-events: none;
}
.price-flat-head { position: relative; }
.price-flat-title {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: clamp(28px, 3vw, 38px);
  letter-spacing: -0.025em;
  line-height: 1.05;
  margin-top: 14px;
  color: var(--ink);
}
.price-flat-sub {
  margin-top: 8px;
  color: var(--ink-2);
  font-size: 15.5px;
  line-height: 1.5;
  max-width: 440px;
}
.price-flat-amount {
  display: flex; align-items: baseline; gap: 4px;
  margin: 22px 0 8px;
  font-family: var(--font-display);
  letter-spacing: -0.03em;
  position: relative;
}
.price-flat-amount b {
  font-weight: var(--display-weight);
  font-size: clamp(56px, 7vw, 84px);
  line-height: 0.9;
  color: var(--ink);
}
body[data-dir="citrus"] .price-flat-amount b {
  font-family: "Instrument Serif", serif;
  font-style: italic;
  color: var(--primary);
  font-weight: 400;
}
.price-flat-amount span {
  color: var(--ink-3);
  font-family: var(--font-body);
  font-size: 18px;
}
.price-flat-fine {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.04em;
  color: var(--ink-3);
  text-transform: uppercase;
  position: relative;
}

/* ───────── Example cards: clickable affordance ───────── */
.ex-card--click {
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 180ms ease;
}
.ex-card--click:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(20, 12, 4, 0.12);
}
.ex-card--click:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 3px;
}

/* ───────── Instagram-style post modal ───────── */
.ig-backdrop {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, 0.78);
  z-index: 80;
  display: grid; place-items: center;
  padding: 32px;
  animation: fade 180ms ease;
}
.ig-close {
  position: fixed; top: 14px; right: 18px;
  width: 36px; height: 36px;
  border-radius: 999px;
  border: 0;
  background: rgba(255,255,255,0.12);
  color: #fff;
  display: grid; place-items: center;
  cursor: pointer;
  z-index: 82;
}
.ig-close:hover { background: rgba(255,255,255,0.22); }

.ig-modal {
  background: #fff;
  color: #000;
  border-radius: 12px;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 420px;
  width: min(1100px, 100%);
  max-height: min(86vh, 720px);
  box-shadow: 0 30px 80px rgba(0,0,0,0.45);
  animation: modalIn 220ms cubic-bezier(.2,.7,.3,1);
  font-family: var(--font-sans);
}

.ig-img {
  background: #000;
  display: grid;
  place-items: center;
  min-height: 0;
  position: relative;
}
.ig-img img {
  display: block;
  width: 100%;
  height: 100%;
  max-height: min(86vh, 720px);
  object-fit: contain;
  background: #000;
}
.ig-img-placeholder {
  width: 100%;
  aspect-ratio: 1;
  display: grid;
  place-items: end start;
  padding: 24px;
}

.ig-side {
  display: flex;
  flex-direction: column;
  min-width: 0;
  border-left: 1px solid #efefef;
  background: #fff;
}
.ig-head {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px;
  border-bottom: 1px solid #efefef;
  flex-shrink: 0;
}
.ig-avatar {
  width: 34px; height: 34px;
  border-radius: 999px;
  background: linear-gradient(135deg, #f58529 0%, #dd2a7b 50%, #515bd4 100%);
  color: #fff;
  display: grid; place-items: center;
  font-weight: 700; font-size: 11px;
  letter-spacing: 0.02em;
  flex-shrink: 0;
  border: 2px solid #fff;
  box-shadow: 0 0 0 2px transparent;
}
.ig-avatar--sm { width: 30px; height: 30px; font-size: 10px; }
.ig-avatar--alt {
  background: linear-gradient(135deg, #6b7280, #1f2937);
}
.ig-head-meta { flex: 1; min-width: 0; }
.ig-handle {
  font-weight: 600;
  font-size: 14px;
  color: #000;
  letter-spacing: -0.005em;
}
.ig-sub {
  font-size: 12px;
  color: #737373;
  margin-top: 1px;
}
.ig-head-more {
  background: none; border: 0;
  font-size: 22px; color: #000;
  cursor: pointer;
  padding: 0 6px;
  line-height: 1;
}

.ig-stream {
  flex: 1;
  overflow-y: auto;
  padding: 14px 16px 8px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 0;
}
.ig-row {
  display: grid;
  grid-template-columns: 30px 1fr auto;
  gap: 12px;
  align-items: start;
}
.ig-row-body {
  font-size: 14px;
  line-height: 1.45;
  color: #000;
  min-width: 0;
}
.ig-row-handle {
  font-weight: 600;
  color: #000;
}
.ig-row-text {
  color: #000;
  white-space: pre-wrap;
  word-wrap: break-word;
}
.ig-row-time, .ig-row-meta {
  margin-top: 6px;
  font-size: 12px;
  color: #737373;
  display: flex;
  gap: 12px;
}
.ig-row-meta span:nth-child(2),
.ig-row-meta span:nth-child(3) {
  font-weight: 600;
}
.ig-row-heart {
  background: none; border: 0;
  color: #737373;
  cursor: pointer;
  align-self: start;
  padding-top: 4px;
}

.ig-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px 4px;
  border-top: 1px solid #efefef;
  flex-shrink: 0;
}
.ig-actions-left {
  display: flex;
  gap: 4px;
}
.ig-act {
  background: none; border: 0;
  color: #000;
  cursor: pointer;
  padding: 8px;
  display: grid; place-items: center;
  border-radius: 8px;
}
.ig-act:hover { color: #737373; }
.ig-act--liked { color: #ed4956; }
.ig-act--liked:hover { color: #ed4956; opacity: 0.85; }
.ig-act--saved { color: #000; }

.ig-likes {
  padding: 0 16px;
  font-size: 14px;
  font-weight: 600;
  color: #000;
}
.ig-likes b { font-weight: 600; }
.ig-comments-count {
  padding: 4px 16px 0;
  font-size: 14px;
  color: #737373;
  cursor: pointer;
}
.ig-posted {
  padding: 6px 16px 10px;
  font-size: 10px;
  letter-spacing: 0.03em;
  color: #737373;
}
.ig-input {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-top: 1px solid #efefef;
  flex-shrink: 0;
}
.ig-input > span { font-size: 18px; }
.ig-input > input {
  flex: 1;
  border: 0; outline: 0;
  background: transparent;
  font-size: 14px;
  color: #000;
  font-family: inherit;
}
.ig-input > button {
  border: 0; background: none;
  color: #0095f6;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  opacity: 0.4;
}

/* Mobile/narrow: stack image over comments */
@media (max-width: 900px) {
  .ig-backdrop { padding: 0; }
  .ig-close { top: 10px; right: 10px; }
  .ig-modal {
    grid-template-columns: 1fr;
    grid-template-rows: auto minmax(0, 1fr);
    width: 100%;
    height: 100vh;
    max-height: 100vh;
    border-radius: 0;
  }
  .ig-img img { max-height: 56vh; }
  .ig-side { border-left: 0; border-top: 1px solid #efefef; }
}

/* ───────── Grid gallery: full-feed brand showcases ───────── */
.grid-gallery .section-head { margin-bottom: 72px; }
.gallery-list {
  display: flex;
  flex-direction: column;
  gap: 96px;
}
.gallery-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr);
  gap: 80px;
  align-items: center;
}
.gallery-row--rev {
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
}
.gallery-row--rev .gallery-text { order: 2; }
.gallery-row--rev .gallery-frame { order: 1; }

.gallery-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  max-width: 460px;
}
.gallery-num-row {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 28px;
  width: 100%;
}
.gallery-num {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 42px;
  letter-spacing: -0.04em;
  color: var(--primary);
  line-height: 1;
}
.gallery-rule {
  flex: 1;
  height: 1px;
  background: var(--line);
  max-width: 80px;
}
.gallery-industry {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.gallery-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(34px, 3.2vw, 46px);
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--ink);
  margin: 0 0 22px;
}
.gallery-title em {
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-weight: 400;
  color: var(--primary);
}
.gallery-body {
  font-size: 17px;
  line-height: 1.55;
  color: var(--ink-2);
  margin: 0 0 36px;
  text-wrap: pretty;
}
.gallery-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px 28px;
  width: 100%;
  margin: 0 0 36px;
  padding: 24px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.gallery-meta-item { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.gallery-meta-item dt {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin: 0;
}
.gallery-meta-item dd {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 14.5px;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 0;
}
.gallery-cta { align-self: flex-start; }

/* Instagram profile frame */
.gallery-frame {
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow:
    0 1px 0 rgba(20,12,4,0.04),
    0 30px 60px -20px rgba(20,12,4,0.18),
    0 14px 26px -16px rgba(20,12,4,0.14);
  width: 100%;
  max-width: 560px;
  margin: 0 auto;
}
.gallery-frame-bar {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 10px 14px;
  background: color-mix(in oklch, var(--ink) 4%, var(--card));
  border-bottom: 1px solid var(--line);
}
.gallery-frame-dots { display: flex; gap: 6px; }
.gallery-frame-dots span {
  width: 10px; height: 10px;
  border-radius: 999px;
  background: color-mix(in oklch, var(--ink) 16%, transparent);
}
.gallery-frame-dots span:nth-child(1) { background: oklch(0.7 0.16 30); }
.gallery-frame-dots span:nth-child(2) { background: oklch(0.85 0.14 90); }
.gallery-frame-dots span:nth-child(3) { background: oklch(0.78 0.16 145); }
.gallery-frame-url {
  flex: 1;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--ink-3);
  letter-spacing: 0.01em;
  background: color-mix(in oklch, var(--ink) 5%, transparent);
  padding: 4px 12px;
  border-radius: 6px;
  max-width: 320px;
  margin: 0 auto;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.gallery-frame-profile {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px;
  padding: 18px 22px;
  background: #fff;
}
.gallery-frame-avatar {
  width: 56px; height: 56px;
  border-radius: 999px;
  background: linear-gradient(135deg, #f58529 0%, #dd2a7b 50%, #515bd4 100%);
  color: #fff;
  display: grid; place-items: center;
  font-weight: 700; font-size: 16px;
  border: 2px solid #fff;
  box-shadow: 0 0 0 2px color-mix(in oklch, var(--primary) 60%, transparent);
}
.gallery-frame-id { min-width: 0; }
.gallery-frame-handle {
  font-weight: 600;
  font-size: 14px;
  color: #111;
  letter-spacing: -0.005em;
}
.gallery-frame-bio {
  font-size: 12.5px;
  color: #555;
  margin-top: 2px;
}
.gallery-frame-stats {
  display: flex;
  gap: 18px;
  text-align: center;
}
.gallery-frame-stats > div { display: flex; flex-direction: column; gap: 2px; }
.gallery-frame-stats b {
  font-weight: 700;
  font-size: 14px;
  color: #111;
  font-variant-numeric: tabular-nums;
}
.gallery-frame-stats span {
  font-size: 11px;
  color: #888;
}

.gallery-frame-grid {
  background: #000;
  aspect-ratio: 1 / 1;
  position: relative;
  overflow: hidden;
}
.gallery-frame-grid img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Stack on narrower screens */
@media (max-width: 900px) {
  .gallery-list { gap: 64px; }
  .gallery-row,
  .gallery-row--rev {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .gallery-row--rev .gallery-text { order: 2; }
  .gallery-row--rev .gallery-frame { order: 1; }
  .gallery-text { max-width: none; }
  .gallery-meta { grid-template-columns: 1fr 1fr; }
  .gallery-frame-stats { gap: 14px; }
  .gallery-frame-stats span { font-size: 10px; }
}
@media (max-width: 520px) {
  .gallery-meta { grid-template-columns: 1fr; gap: 16px; }
  .gallery-frame-profile { grid-template-columns: auto 1fr; row-gap: 12px; }
  .gallery-frame-stats { grid-column: 1 / -1; justify-content: flex-start; }
  .gallery-num { font-size: 36px; }
}


/* ── Read-only IG modal (no like/comment/share/save) ────────────────────── */
.ig-side--readonly {
  /* Caption only — no actions, no input. Center the caption vertically when short. */
}
.ig-stream--caption-only {
  padding: 18px 18px 14px;
  flex: 1;
  overflow-y: auto;
}
.ig-stream--caption-only .ig-row--caption {
  display: block; /* no avatar column in read-only caption */
}
.ig-stream--caption-only .ig-row-body {
  font-size: 14px;
  line-height: 1.55;
  color: #262626;
}
.ig-stream--caption-only .ig-row-handle {
  margin-right: 6px;
}
.ig-foot-note {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 18px;
  border-top: 1px solid #efefef;
  font-size: 12px;
  color: #8e8e8e;
  letter-spacing: 0.02em;
  flex-shrink: 0;
}
.ig-foot-note svg { color: #8e8e8e; }
.ig-side--readonly .ig-head .ig-avatar {
  background: transparent;
  border: 0;
  width: auto; height: auto;
  box-shadow: none;
  padding: 0;
}

/* ───────── Guarantee section ────────────────────────────────────────────
   Feedbird-inspired risk-reversal box. Sits between Pricing and FAQ on
   the home page; replaces the legacy guarantee block on the Pricing page. */
.guarantee { padding: var(--pad-section) 0; }
.guarantee-card {
  position: relative;
  background: color-mix(in oklch, var(--primary) 8%, var(--bg));
  border: 1px solid color-mix(in oklch, var(--primary) 18%, var(--line));
  border-radius: var(--radius-xl);
  padding: clamp(36px, 5%, 72px);
  overflow: hidden;
  isolation: isolate;
}
.guarantee-card::before {
  content: "";
  position: absolute; inset: 0;
  background-image: radial-gradient(color-mix(in oklch, var(--primary) 35%, transparent) 1px, transparent 1px);
  background-size: 22px 22px;
  -webkit-mask-image: radial-gradient(ellipse 55% 75% at 100% 50%, #000 0%, transparent 75%);
          mask-image: radial-gradient(ellipse 55% 75% at 100% 50%, #000 0%, transparent 75%);
  opacity: 0.35;
  pointer-events: none;
  z-index: 0;
}
.guarantee-grid {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap: 56px;
  align-items: center;
}
@media (max-width: 900px) {
  .guarantee-grid { grid-template-columns: 1fr; gap: 32px; }
}
.guarantee-content .kicker { margin-bottom: 22px; }
.guarantee-content h2 {
  font-size: clamp(34px, 4vw, 52px);
  margin-bottom: 18px;
  max-width: 560px;
}
.guarantee-content h2 .display-underline {
  background: linear-gradient(
    transparent 0,
    transparent 62%,
    color-mix(in oklch, var(--primary) 35%, transparent) 62%,
    color-mix(in oklch, var(--primary) 35%, transparent) 92%,
    transparent 92%
  );
  padding: 0 1px;
}
.guarantee-lede {
  color: var(--ink-2);
  font-size: 16.5px;
  line-height: 1.55;
  max-width: 540px;
  margin-bottom: 28px;
}
.guarantee-lede strong { color: var(--ink); font-weight: 600; }
.guarantee-bullets {
  list-style: none;
  margin: 0 0 32px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
  max-width: 560px;
}
.guarantee-bullets li {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  font-size: 15.5px;
  color: var(--ink-2);
  line-height: 1.5;
}
.guarantee-bullets li strong { color: var(--ink); font-weight: 600; }
.guarantee-bullets-check {
  flex-shrink: 0;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--bg);
  display: inline-grid; place-items: center;
  margin-top: 1px;
}
.guarantee-ctas {
  display: flex;
  gap: 22px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 18px;
}
.guarantee-link {
  font-size: 14.5px;
  font-weight: 500;
  color: var(--ink);
  border-bottom: 1px solid var(--ink-3);
  padding-bottom: 2px;
  transition: border-color .15s;
}
.guarantee-link:hover { border-color: var(--ink); }
.guarantee-fine {
  font-size: 13px;
  color: var(--ink-3);
  max-width: 560px;
  line-height: 1.55;
}
.guarantee-fine a {
  color: var(--ink-2);
  border-bottom: 1px solid var(--line);
}
.guarantee-fine a:hover { color: var(--ink); border-color: var(--ink-3); }

/* Medallion */
.guarantee-medallion {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  max-width: 420px;
  margin: 0 auto;
}
.guarantee-disc {
  position: absolute; inset: 8%;
  border-radius: 50%;
  background: var(--card);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 30px 60px -28px color-mix(in oklch, var(--primary) 55%, transparent),
    0 12px 24px -16px rgba(20,15,5,0.18);
  display: grid; place-items: center;
}
.guarantee-disc::before,
.guarantee-disc::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.guarantee-disc::before {
  inset: 14px;
  border: 1.5px dashed color-mix(in oklch, var(--primary) 45%, var(--line));
}
.guarantee-disc::after {
  inset: 30px;
  border: 1.5px dotted color-mix(in oklch, var(--primary) 30%, var(--line));
  opacity: 0.7;
}
.guarantee-disc-inner {
  text-align: center;
  position: relative;
  z-index: 1;
  padding: 18px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.guarantee-disc-seal {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: color-mix(in oklch, var(--primary) 14%, var(--card));
  border: 1.5px solid color-mix(in oklch, var(--primary) 35%, var(--line));
  display: inline-grid; place-items: center;
  color: var(--primary);
  margin-bottom: 12px;
}
.guarantee-disc-label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--primary);
  margin-bottom: 2px;
}
.guarantee-disc-num {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: clamp(80px, 12vw, 132px);
  letter-spacing: -0.06em;
  line-height: 0.9;
  color: var(--ink);
}
body[data-dir="citrus"] .guarantee-disc-num { font-style: italic; }
.guarantee-disc-rule {
  width: 80px;
  height: 1px;
  background: var(--line);
  margin: 12px 0;
}
.guarantee-disc-sub {
  font-size: 13px;
  color: var(--ink-2);
  font-weight: 500;
  letter-spacing: -0.01em;
}

/* Floating chips */
.guarantee-chip {
  position: absolute;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 8px 14px 8px 12px;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
  display: inline-flex; align-items: center; gap: 8px;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 14px 26px -14px rgba(20,15,5,0.22);
  z-index: 2;
  white-space: nowrap;
}
.guarantee-chip-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.guarantee-chip--refund {
  top: 6%;
  right: -4%;
  background: color-mix(in oklch, oklch(0.86 0.13 145) 35%, var(--card));
  transform: rotate(3deg);
}
.guarantee-chip--refund .guarantee-chip-dot {
  background: oklch(0.52 0.16 145);
}
.guarantee-chip--hassle {
  bottom: 16%;
  left: -8%;
  background: color-mix(in oklch, var(--accent) 35%, var(--card));
  transform: rotate(-4deg);
}
.guarantee-chip--hassle .guarantee-chip-dot {
  background: color-mix(in oklch, var(--accent) 80%, var(--ink));
}

/* Bottom trust strip inside card */
.guarantee-strip {
  position: relative; z-index: 1;
  margin-top: 44px;
  padding-top: 26px;
  border-top: 1px solid color-mix(in oklch, var(--primary) 18%, var(--line));
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 22px;
  flex-wrap: wrap;
  font-size: 14px;
  color: var(--ink-2);
}
.guarantee-strip-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.guarantee-strip-item svg { color: var(--primary); flex-shrink: 0; }
.guarantee-strip-item strong { color: var(--ink); font-weight: 600; }
.guarantee-strip-sep {
  width: 3px; height: 3px;
  border-radius: 50%;
  background: var(--ink-3);
  opacity: 0.5;
}
@media (max-width: 760px) {
  .guarantee-strip { gap: 14px; font-size: 13px; }
  .guarantee-strip-sep { display: none; }
}

/* Dark-mode adjustments */
body[data-theme="dark"] .guarantee-card {
  background: color-mix(in oklch, var(--primary) 14%, var(--bg-2));
  border-color: color-mix(in oklch, var(--primary) 25%, var(--line));
}
body[data-theme="dark"] .guarantee-disc {
  background: var(--card);
  box-shadow:
    0 30px 60px -28px rgba(0,0,0,0.6),
    0 12px 24px -16px rgba(0,0,0,0.4);
}
body[data-theme="dark"] .guarantee-bullets-check {
  background: var(--card);
  color: var(--primary);
  border: 1px solid var(--line);
}

/* ───────── Policy page ──────────────────────────────────────────────────
   Long-form legal pages: Terms, Privacy, Refund. Three sections on one
   route, sticky TOC, comfortable reading width. */
.policy-wrap { max-width: 880px; }
.policy-tldr {
  background: color-mix(in oklch, var(--primary) 8%, var(--bg));
  border: 1px solid color-mix(in oklch, var(--primary) 20%, var(--line));
  border-radius: var(--radius-lg);
  padding: 26px 30px;
  display: flex;
  gap: 22px;
  align-items: flex-start;
  margin-bottom: 36px;
}
@media (max-width: 600px) {
  .policy-tldr { flex-direction: column; gap: 14px; padding: 22px; }
}
.policy-tldr-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--primary);
  background: var(--card);
  border: 1px solid color-mix(in oklch, var(--primary) 30%, var(--line));
  padding: 6px 10px;
  border-radius: 7px;
  flex-shrink: 0;
  text-transform: uppercase;
}
.policy-tldr p {
  font-size: 15.5px;
  line-height: 1.65;
  color: var(--ink);
}
.policy-tldr strong { font-weight: 600; }

.policy-toc {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 56px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--card);
  width: fit-content;
}
.policy-toc button {
  appearance: none;
  background: transparent;
  border: 0;
  padding: 8px 16px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-2);
  cursor: pointer;
  transition: background .15s, color .15s;
}
.policy-toc button:hover { background: var(--bg-2); color: var(--ink); }
.policy-toc button[data-on="1"] {
  background: var(--ink);
  color: var(--bg);
}

.policy-prose {
  font-size: 15.5px;
  line-height: 1.7;
  color: var(--ink-2);
  margin-bottom: 96px;
  scroll-margin-top: 120px;
}
.policy-prose:last-child { margin-bottom: 0; }
.policy-prose h2 {
  font-size: clamp(30px, 3.4vw, 42px);
  color: var(--ink);
  margin-bottom: 14px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
  letter-spacing: -0.02em;
}
.policy-prose h2 + p { margin-top: 24px; }
.policy-prose h3 {
  font-size: 18px;
  color: var(--ink);
  margin: 44px 0 12px;
  letter-spacing: -0.01em;
  font-weight: 600;
}
.policy-prose h4 {
  font-size: 15px;
  color: var(--ink);
  margin: 22px 0 6px;
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -0.005em;
}
.policy-prose p {
  margin: 0 0 16px;
}
.policy-prose strong { color: var(--ink); font-weight: 600; }
.policy-prose ul {
  padding-left: 22px;
  margin: 0 0 16px;
  list-style: disc;
}
.policy-prose ul li { margin-bottom: 6px; }
.policy-prose a {
  color: var(--primary);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  word-break: break-word;
}
.policy-prose a:hover { color: var(--ink); }
.policy-prose .policy-callout {
  background: var(--card);
  border: 1px solid var(--line);
  border-left: 3px solid var(--primary);
  border-radius: 12px;
  padding: 18px 22px;
  margin: 22px 0;
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink);
}
.policy-prose .policy-callout strong { font-weight: 600; }

.policy-foot {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: space-between;
  padding: 24px 0 0;
  border-top: 1px solid var(--line);
  margin-top: 24px;
  flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--ink-3);
  text-transform: uppercase;
}


/* ─────────────────────────────────────────────────────────────────
   Schedule a Call page + Call Confirmed page
   ───────────────────────────────────────────────────────────── */

/* Centre the hero h1/lede properly — site-wide .hero h1 has a
   max-width:640 that left-aligns inside a textAlign:center wrapper. */
.sch-hero h1,
.confirm-hero h1,
.pricing-hero h1,
.centered-hero h1 {
  margin-left: auto;
  margin-right: auto;
  max-width: 860px;
}
.sch-hero .hero-lede,
.confirm-hero .hero-lede,
.pricing-hero .hero-lede,
.centered-hero .hero-lede {
  max-width: 640px;
}

/* Compact hero so the Calendly embed lands closer to the fold */
.sch-hero--compact {
  padding-top: clamp(48px, 7vh, 88px);
  padding-bottom: 0;
}
.sch-hero--compact h1 { font-size: clamp(34px, 4.6vw, 56px); }
.sch-cal-section { padding-top: 28px; }

/* Trust row sitting under the hero on /schedule-a-call */
.sch-trust {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0;
  padding: 18px 22px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 18px;
  max-width: 940px;
  margin: 0 auto;
}
.sch-trust-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 18px;
  flex: 1 1 180px;
  min-width: 160px;
}
.sch-trust-item > div { display: flex; flex-direction: column; gap: 2px; }
.sch-trust-item b { font-size: 14px; font-weight: 600; letter-spacing: -0.005em; color: var(--ink); }
.sch-trust-item span:not(.sch-trust-icon) { font-size: 12.5px; color: var(--ink-3); }
.sch-trust-icon {
  display: grid; place-items: center;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: color-mix(in oklch, var(--primary) 14%, transparent);
  color: var(--primary);
  flex-shrink: 0;
}
.sch-trust-sep {
  width: 1px; align-self: stretch;
  background: var(--line);
  margin: 8px 0;
}
@media (max-width: 760px) {
  .sch-trust-sep { display: none; }
  .sch-trust-item { flex: 1 1 45%; }
}

/* Layout: Calendly column + agenda sidebar */
.sch-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(280px, 1fr);
  gap: 32px;
  align-items: start;
}
@media (max-width: 980px) {
  .sch-grid { grid-template-columns: 1fr; }
}
.sch-cal {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 22px;
  overflow: hidden;
  box-shadow: 0 1px 0 rgba(0,0,0,0.02);
}
.sch-cal-head {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--ink-3);
  background: var(--bg-2);
}
.sch-cal-head span { color: var(--ink); }
.calendly-inline-widget { display: block; }

.sch-aside { padding: 4px; display: flex; flex-direction: column; gap: 18px; }
.sch-aside-section { padding: 4px 2px; }
.sch-agenda { list-style: none; padding: 0; margin: 14px 0 0; display: flex; flex-direction: column; gap: 14px; }
.sch-agenda li {
  display: grid; grid-template-columns: 36px 1fr; gap: 12px;
  align-items: start;
}
.sch-agenda--tight { gap: 10px; }
.sch-agenda--tight li { grid-template-columns: 30px 1fr; align-items: center; }
.sch-agenda--tight .sch-agenda-icon { width: 28px; height: 28px; border-radius: 8px; }
.sch-agenda--tight b { font-size: 14px; }
.sch-agenda-icon {
  display: grid; place-items: center;
  width: 36px; height: 36px;
  border-radius: 10px;
  background: color-mix(in oklch, var(--primary) 12%, transparent);
  color: var(--primary);
}
.sch-agenda b { font-size: 14.5px; font-weight: 600; letter-spacing: -0.01em; color: var(--ink); }
.sch-agenda p { margin: 4px 0 0; font-size: 13.5px; color: var(--ink-2); line-height: 1.5; }

.sch-aside-quote {
  margin-top: 4px;
  padding: 18px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 16px;
}
.sch-aside-quote p {
  font-size: 14.5px; line-height: 1.55; color: var(--ink); margin: 0 0 14px;
  font-family: 'Instrument Serif', serif;
  font-style: italic;
}
.sch-aside-quote-foot {
  display: flex; align-items: center; gap: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
}

.sch-aside-cta {
  margin-top: 18px;
  padding: 16px;
  border: 1px dashed var(--line);
  border-radius: 14px;
}

/* ─── Show-up bonus callout ──────────────────────────────────── */
.bonus-callout {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 22px;
  align-items: center;
  text-align: left;
  padding: 22px 28px 22px 24px;
  border-radius: 22px;
  background: linear-gradient(135deg,
    color-mix(in oklch, var(--primary) 16%, var(--bg)) 0%,
    color-mix(in oklch, var(--accent) 16%, var(--bg)) 100%);
  border: 1px solid color-mix(in oklch, var(--primary) 35%, transparent);
  overflow: hidden;
  isolation: isolate;
}
.bonus-callout::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 0% 0%, color-mix(in oklch, var(--primary) 24%, transparent), transparent 38%),
    radial-gradient(circle at 100% 100%, color-mix(in oklch, var(--accent) 24%, transparent), transparent 38%);
  z-index: -1;
  pointer-events: none;
}
.bonus-callout-ribbon {
  width: 56px; height: 56px;
  border-radius: 16px;
  background: var(--primary);
  display: grid; place-items: center;
  color: #fff;
  flex-shrink: 0;
  box-shadow: 0 6px 18px -8px color-mix(in oklch, var(--primary) 70%, transparent);
}
.bonus-callout-body { min-width: 0; }
.bonus-callout-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin-bottom: 6px;
}
.bonus-callout-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--primary);
  display: inline-block;
}
.bonus-callout-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -0.018em;
  line-height: 1.15;
  color: var(--ink);
}
.bonus-callout-title em {
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-weight: 500;
  color: var(--primary);
  letter-spacing: -0.005em;
}
.bonus-callout-text {
  margin: 8px 0 0;
  font-size: 14px;
  line-height: 1.5;
  color: var(--ink-2);
  max-width: 540px;
}
.bonus-callout-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  background: var(--ink);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
  flex-shrink: 0;
}
.bonus-callout-chip span {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--primary);
  box-shadow: 0 0 0 4px color-mix(in oklch, var(--primary) 25%, transparent);
}
@media (max-width: 760px) {
  .bonus-callout { grid-template-columns: auto 1fr; padding: 18px 18px; gap: 16px; }
  .bonus-callout-chip { grid-column: 1 / -1; justify-self: start; }
  .bonus-callout-title { font-size: 19px; }
}

/* Compact vertical variant for the sidebar on /schedule-a-call */
.bonus-callout--compact {
  grid-template-columns: 44px 1fr;
  gap: 14px;
  padding: 18px 18px;
  border-radius: 18px;
}
.bonus-callout--compact .bonus-callout-ribbon {
  width: 44px; height: 44px;
  border-radius: 12px;
}
.bonus-callout--compact .bonus-callout-title { font-size: 18px; line-height: 1.18; }
.bonus-callout--compact .bonus-callout-text { font-size: 13px; margin-top: 6px; max-width: none; }
.bonus-callout--compact .bonus-callout-eyebrow { font-size: 10.5px; }

/* ─── Call Confirmed page ─────────────────────────────────────── */

.confirm-hero { padding-top: var(--pad-section); }
.confirm-check {
  display: grid; place-items: center;
  width: 72px; height: 72px;
  border-radius: 50%;
  background: var(--ink);
  margin: 0 auto;
  box-shadow: 0 10px 30px -10px color-mix(in oklch, var(--ink) 70%, transparent);
}
.confirm-note {
  margin: 26px auto 0;
  max-width: 620px;
  padding: 16px 20px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 14px;
  text-align: left;
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink);
}
.confirm-note strong { font-weight: 700; }
.confirm-note mark {
  background: color-mix(in oklch, var(--primary) 35%, transparent);
  color: var(--ink);
  padding: 1px 4px;
  border-radius: 4px;
}
.confirm-note-sub { margin-top: 6px; color: var(--ink-2); font-size: 13.5px; }

.confirm-steps {
  max-width: 760px;
  margin: 0 auto;
  display: flex; flex-direction: column;
  gap: 28px;
}
.confirm-step {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 18px;
  align-items: start;
}
.confirm-step-bullet {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: var(--ink);
  display: grid; place-items: center;
  margin-top: 2px;
}
.confirm-step b {
  display: block;
  font-size: 16px; font-weight: 700;
  color: var(--ink);
  margin-bottom: 4px;
}
.confirm-step p { margin: 0; font-size: 14.5px; line-height: 1.55; color: var(--ink-2); }

/* Mocked Google Calendar invite card */
.confirm-calmock {
  margin-top: 18px;
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 18px;
  align-items: start;
  padding: 16px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 14px;
  max-width: 580px;
}
.confirm-calmock-icon {
  width: 76px; height: 80px;
  border-radius: 10px;
  background: #fff;
  border: 1px solid var(--line);
  overflow: hidden;
  position: relative;
}
.confirm-calmock-icon-top { height: 18px; background: #4285f4; }
.confirm-calmock-icon-body { padding: 10px 8px; display: flex; flex-direction: column; gap: 6px; }
.confirm-calmock-icon-body span {
  display: block;
  height: 8px;
  background: color-mix(in oklch, var(--ink) 12%, transparent);
  border-radius: 2px;
}
.confirm-calmock-icon-body span:nth-child(1) { width: 70%; }
.confirm-calmock-icon-body span:nth-child(2) { width: 50%; }
.confirm-calmock-icon-body span:nth-child(3) { width: 60%; }
.confirm-calmock-title { font-weight: 700; font-size: 14.5px; color: var(--ink); }
.confirm-calmock-link {
  color: #1a73e8; font-size: 12.5px; margin-top: 2px;
  text-decoration: underline; text-underline-offset: 2px;
}
.confirm-calmock-meta {
  margin-top: 10px;
  display: flex; flex-direction: column; gap: 4px;
  font-size: 12.5px; color: var(--ink-2);
}
.confirm-calmock-meta > div { display: flex; gap: 10px; align-items: center; }
.confirm-calmock-meta span { color: var(--ink-3); width: 44px; }
.confirm-calmock-meta b { font-weight: 500; color: var(--ink-2); }
.confirm-calmock-redact {
  display: inline-block;
  height: 12px;
  background: color-mix(in oklch, var(--ink) 14%, transparent);
  border-radius: 3px;
}
.confirm-calmock-actions {
  margin-top: 12px;
  display: flex; align-items: center; gap: 8px;
  flex-wrap: wrap;
}
.confirm-calmock-arrow { color: #ef4444; font-size: 18px; font-weight: 700; }
.confirm-calmock-btn {
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 4px;
  padding: 6px 14px;
  font-size: 13px;
  color: var(--ink);
  cursor: pointer;
}
.confirm-calmock-btn--yes { font-weight: 600; box-shadow: 0 0 0 2px color-mix(in oklch, #1a73e8 25%, transparent); }
.confirm-calmock-caret { margin-left: 4px; opacity: 0.6; }
.confirm-calmock-more { font-size: 12.5px; color: var(--ink-3); margin-left: 4px; }
@media (max-width: 560px) {
  .confirm-calmock { grid-template-columns: 1fr; }
}

/* Reschedule/cancel helper card */
.confirm-helper {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 22px 26px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 18px;
  max-width: 960px;
  margin: 0 auto;
}
.confirm-helper-actions { display: flex; gap: 10px; flex-wrap: wrap; }
@media (max-width: 720px) {
  .confirm-helper { grid-template-columns: 1fr; }
}

/* Dark mode tweaks for the mocked calendar invite */
body[data-theme="dark"] .confirm-calmock-icon { background: #1c1c1c; }
body[data-theme="dark"] .confirm-calmock-btn { background: #1c1c1c; color: var(--ink); }
body[data-theme="dark"] .confirm-calmock-link { color: #8ab4f8; }


/* ───────── Careers ───────── */
.careers-roles {
  display: flex;
  flex-direction: column;
  gap: 14px;
  max-width: 980px;
  margin: 0 auto;
}
.careers-role {
  display: grid;
  grid-template-columns: auto auto 1fr auto;
  gap: 28px;
  align-items: center;
  padding: 26px 28px;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 18px;
  text-decoration: none;
  color: inherit;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.careers-role:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-card);
  border-color: color-mix(in oklch, var(--primary) 35%, var(--line));
}
.careers-role-num {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--ink-3);
  min-width: 28px;
}
.careers-role-icon {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: color-mix(in oklch, var(--primary) 10%, transparent);
  color: var(--primary);
  flex-shrink: 0;
}
body[data-theme="dark"] .careers-role-icon {
  background: color-mix(in oklch, var(--primary) 18%, transparent);
}
.careers-role-body { min-width: 0; }
.careers-role-tag {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--primary);
  padding: 3px 8px;
  background: color-mix(in oklch, var(--primary) 12%, transparent);
  border-radius: 4px;
  margin-bottom: 8px;
}
.careers-role h3 {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin: 0;
}
.careers-role-sub {
  font-size: 13.5px;
  color: var(--ink-3);
  margin-top: 4px;
  font-family: var(--font-mono);
  letter-spacing: 0.02em;
}
.careers-role p {
  margin: 12px 0 0;
  color: var(--ink-2);
  font-size: 15px;
  line-height: 1.55;
}
.careers-role-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--primary);
  white-space: nowrap;
  transition: gap .2s ease;
}
.careers-role:hover .careers-role-cta { gap: 10px; }

@media (max-width: 760px) {
  .careers-role {
    grid-template-columns: auto 1fr;
    gap: 16px 20px;
    padding: 22px;
  }
  .careers-role-num { grid-column: 1 / 3; margin-bottom: -8px; }
  .careers-role-cta { grid-column: 1 / 3; justify-self: start; margin-top: 4px; }
}

.careers-general {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 32px;
  align-items: center;
  padding: 36px 40px;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 22px;
  margin: 56px auto 0;
  max-width: 980px;
}
.careers-general-text .kicker { margin-bottom: 14px; }
.careers-general-text h3 {
  font-family: var(--font-display);
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin: 0 0 10px;
}
.careers-general-text p {
  margin: 0;
  color: var(--ink-2);
  font-size: 15.5px;
  line-height: 1.55;
  max-width: 540px;
}
@media (max-width: 760px) {
  .careers-general {
    grid-template-columns: 1fr;
    padding: 28px;
    gap: 20px;
  }
}


/* ───────── Reseller page ───────── */
.reseller-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  max-width: 1100px;
  margin: 0 auto;
}
@media (max-width: 940px) {
  .reseller-split { grid-template-columns: 1fr; gap: 40px; }
}
.reseller-split-text h2 { margin-bottom: 18px; }
.reseller-split-text p { color: var(--ink-2); font-size: 17px; line-height: 1.6; margin-bottom: 20px; }
.reseller-bullets {
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.reseller-bullets li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  font-size: 15.5px;
  line-height: 1.5;
  color: var(--ink);
}

/* Mock white-label dashboard */
.reseller-visual { display: flex; justify-content: center; }
.reseller-dash {
  width: 100%;
  max-width: 460px;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: var(--shadow-card);
}
.reseller-dash-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: var(--bg-2);
  border-bottom: 1px solid var(--line);
}
.reseller-dash-dots {
  display: flex; gap: 5px;
}
.reseller-dash-dots span {
  width: 10px; height: 10px; border-radius: 50%;
  background: color-mix(in oklch, var(--ink) 18%, transparent);
}
.reseller-dash-url {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--ink-3);
  letter-spacing: 0.02em;
  flex: 1;
  text-align: center;
}
.reseller-dash-url b { color: var(--primary); font-weight: 600; }
.reseller-dash-head {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px;
  border-bottom: 1px solid var(--line);
}
.reseller-dash-logo {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  color: #fff;
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: -0.01em;
}
.reseller-dash-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 15px;
  letter-spacing: -0.01em;
}
.reseller-dash-sub {
  font-size: 12px;
  color: var(--ink-3);
  font-family: var(--font-mono);
  margin-top: 2px;
}
.reseller-dash-pill {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 5px 9px;
  border-radius: 50px;
  background: color-mix(in oklch, var(--primary) 12%, transparent);
  color: var(--primary);
}
.reseller-dash-pill .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--primary);
}
.reseller-dash-rows { padding: 6px 8px; }
.reseller-dash-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 10px;
  border-radius: 10px;
}
.reseller-dash-row + .reseller-dash-row { border-top: 1px solid var(--line); }
.reseller-dash-row-avatar {
  width: 32px; height: 32px;
  border-radius: 8px;
  background: var(--bg-3);
  display: grid; place-items: center;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-2);
  letter-spacing: 0.04em;
}
.reseller-dash-row-meta { flex: 1; min-width: 0; }
.reseller-dash-row-meta b {
  display: block;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--ink);
}
.reseller-dash-row-meta span {
  display: block;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-3);
  letter-spacing: 0.02em;
  margin-top: 2px;
}
.reseller-dash-row-status {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-2);
  letter-spacing: 0.02em;
}
.reseller-dash-foot {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 18px;
  border-top: 1px solid var(--line);
  background: var(--bg-2);
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.04em;
  color: var(--ink-3);
  text-transform: uppercase;
}

/* Two-up quality + white label cards */
.reseller-twoup {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gap);
  max-width: 1100px;
  margin: 0 auto;
}
@media (max-width: 880px) {
  .reseller-twoup { grid-template-columns: 1fr; }
}
.reseller-twoup-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 36px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.reseller-twoup-card h3 {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin: 0;
}
.reseller-twoup-card > p {
  color: var(--ink-2);
  font-size: 15.5px;
  line-height: 1.6;
  margin: 0;
}
.reseller-checks {
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.reseller-checks li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 14.5px;
  color: var(--ink);
  line-height: 1.5;
}
.reseller-checks li svg { margin-top: 4px; flex-shrink: 0; }

/* Process two-column blocks */
.reseller-process {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gap);
  margin-top: 56px;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 880px) {
  .reseller-process { grid-template-columns: 1fr; }
}
.reseller-process-card {
  padding: 32px;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 18px;
}
.reseller-process-card .kicker { margin-bottom: 18px; }
.reseller-process-card h3 {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin: 0 0 12px;
}
.reseller-process-card p {
  color: var(--ink-2);
  font-size: 15.5px;
  line-height: 1.6;
  margin: 0;
}

/* Audience grid */
.reseller-audience {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  max-width: 980px;
  margin: 0 auto;
}
@media (max-width: 760px) {
  .reseller-audience { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 460px) {
  .reseller-audience { grid-template-columns: 1fr; }
}
.reseller-audience-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px 24px;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 14px;
  transition: transform .2s ease, box-shadow .2s ease;
}
.reseller-audience-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-card);
}
.reseller-audience-icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: color-mix(in oklch, var(--primary) 10%, transparent);
  color: var(--primary);
  display: grid; place-items: center;
  flex-shrink: 0;
}
body[data-theme="dark"] .reseller-audience-icon {
  background: color-mix(in oklch, var(--primary) 18%, transparent);
}
.reseller-audience-label {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 16px;
  letter-spacing: -0.01em;
  color: var(--ink);
}


/* ───────── Reseller — invisibility section ───────── */
.reseller-invis-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gap);
  max-width: 1100px;
  margin: 0 auto;
}
@media (max-width: 760px) {
  .reseller-invis-grid { grid-template-columns: 1fr; }
}
.reseller-invis-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 28px 30px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: transform .2s ease, box-shadow .2s ease;
}
.reseller-invis-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-card);
}
.reseller-invis-card h3 {
  font-family: var(--font-display);
  font-size: 21px;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin: 0;
}
.reseller-invis-card p {
  color: var(--ink-2);
  font-size: 15px;
  line-height: 1.6;
  margin: 0;
}
.reseller-invis-card em { font-style: italic; }

.reseller-invis-list {
  list-style: none;
  padding: 28px 32px;
  margin: 40px auto 0;
  max-width: 1100px;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 18px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px 32px;
}
@media (max-width: 760px) {
  .reseller-invis-list { grid-template-columns: 1fr; }
}
.reseller-invis-list li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  font-size: 15px;
  color: var(--ink);
  line-height: 1.55;
}
.reseller-invis-list li strong { font-weight: 600; }
.reseller-invis-list li em { font-style: italic; }


/* ═══════════════════════════════════════════════════════════════════════
   /social-media-management — hero with embedded Calendly + reviews scroll
   ═══════════════════════════════════════════════════════════════════════ */

.smm-hero { padding-bottom: 36px; }

.smm-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
  gap: 56px;
  align-items: start;
  position: relative;
  z-index: 1;
}
.smm-hero-left { padding-top: 8px; }
.smm-hero-left h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(38px, 4.6vw, 64px);
  letter-spacing: -0.025em;
  line-height: 1.04;
  margin: 18px 0 28px;
}

.smm-hero-bullets {
  list-style: none;
  padding: 0;
  margin: 0 0 32px;
  display: flex; flex-direction: column; gap: 14px;
}
.smm-hero-bullets li {
  display: flex; align-items: center; gap: 14px;
  font-size: 17px; color: var(--ink-2);
  line-height: 1.4;
}
.smm-hero-bullets li strong { color: var(--ink); font-weight: 600; }
.smm-hero-check {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--primary);
  display: grid; place-items: center; flex: 0 0 22px;
  box-shadow: 0 1px 3px color-mix(in oklch, var(--primary) 30%, transparent);
}

/* Calendly window — browser-chrome framed */
.smm-hero-right { width: 100%; }
.smm-cal-window {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  box-shadow:
    0 1px 0 rgba(0,0,0,0.02),
    0 14px 40px -18px rgba(15,12,9,0.18),
    0 30px 80px -40px rgba(15,12,9,0.22);
}
.smm-cal-chrome {
  display: grid;
  grid-template-columns: 80px 1fr 80px;
  align-items: center;
  height: 44px;
  padding: 0 14px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, var(--bg-2), var(--bg));
}
.smm-cal-dots { display: inline-flex; gap: 7px; }
.smm-cal-dots i {
  width: 11px; height: 11px; border-radius: 50%;
  background: color-mix(in oklch, var(--ink-3) 35%, transparent);
}
.smm-cal-dots i:nth-child(1) { background: oklch(0.72 0.16 30); }
.smm-cal-dots i:nth-child(2) { background: oklch(0.82 0.14 90); }
.smm-cal-dots i:nth-child(3) { background: oklch(0.72 0.14 145); }
.smm-cal-title {
  justify-self: center;
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--ink-2);
  font-weight: 500;
}
.smm-cal-secure { width: 14px; height: 14px; justify-self: end;
  border-radius: 3px;
  background: color-mix(in oklch, var(--ink-3) 22%, transparent);
}
.smm-cal-body { background: var(--bg); }
.smm-cal-body .calendly-inline-widget {
  width: 100%;
  min-width: 0;
  background: var(--bg);
}

/* ── Reviews scroller ── */
.smm-reviews {
  margin-top: 56px;
  padding-top: 32px;
  border-top: 1px solid var(--line);
}
.smm-reviews-head {
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 18px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--ink-3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.smm-reviews-eyebrow { display: inline-flex; align-items: center; gap: 10px; }
.smm-reviews-eyebrow b { color: var(--ink); font-weight: 600; }
.smm-reviews-stars {
  display: inline-flex; gap: 2px;
  color: oklch(0.74 0.16 85);
}
.smm-reviews-rule { flex: 1; height: 1px; background: var(--line); }
.smm-reviews-meta { color: var(--ink-3); }

.smm-reviews-track-wrap {
  position: relative;
  overflow: hidden;
  margin: 0 calc(-1 * var(--container-pad, 24px));
}
.smm-reviews-fade {
  position: absolute; top: 0; bottom: 0; width: 64px;
  z-index: 2; pointer-events: none;
}
.smm-reviews-fade--l { left: 0;  background: linear-gradient(90deg,  var(--bg), transparent); }
.smm-reviews-fade--r { right: 0; background: linear-gradient(270deg, var(--bg), transparent); }

.smm-reviews-track {
  display: flex;
  gap: 18px;
  width: max-content;
  padding: 6px 24px;
  animation: smm-marquee 56s linear infinite;
}
.smm-reviews-track:hover { animation-play-state: paused; }
@keyframes smm-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(calc(-100% / 3)); }
}

.smm-review-card {
  flex: 0 0 340px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 20px 20px 18px;
  display: flex; flex-direction: column; gap: 12px;
  box-shadow: 0 1px 0 rgba(0,0,0,0.02);
}
.smm-review-stars {
  display: inline-flex; gap: 2px;
  color: oklch(0.74 0.16 85);
}
.smm-review-quote {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.smm-review-foot {
  display: flex; align-items: center; gap: 10px;
  margin-top: auto;
  padding-top: 10px;
  border-top: 1px dashed var(--line);
}
.smm-review-name {
  font-weight: 600;
  font-size: 13.5px;
  color: var(--ink);
}
.smm-review-biz {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px;
  color: var(--ink-3);
  margin-top: 2px;
}
.smm-review-verified {
  display: inline-grid; place-items: center;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: oklch(0.62 0.16 145);
}

/* Responsive: stack hero, smaller review cards */
@media (max-width: 980px) {
  .smm-hero-grid { grid-template-columns: 1fr; gap: 36px; }
  .smm-hero-left { order: 1; }
  .smm-hero-right { order: 2; }
  .smm-cal-body .calendly-inline-widget { height: 640px !important; }
}
@media (max-width: 640px) {
  .smm-review-card { flex-basis: 280px; }
  .smm-reviews-meta { display: none; }
}

/* Dark-theme tweaks */
body[data-theme="dark"] .smm-cal-window { box-shadow: 0 14px 40px -18px rgba(0,0,0,0.55); }
body[data-theme="dark"] .smm-reviews-fade--l { background: linear-gradient(90deg,  var(--bg), transparent); }
body[data-theme="dark"] .smm-reviews-fade--r { background: linear-gradient(270deg, var(--bg), transparent); }


/* Section-end CTA row — used at the end of "What you get" and "The math" */
.section-cta-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  margin-top: 48px;
  padding-top: 40px;
  border-top: 1px solid var(--line);
}
.section-cta-row .btn { min-width: 260px; justify-content: center; }
.section-cta-foot {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ink-3);
}


/* Calendly injects a 3-dot loading spinner inside .calendly-spinner that
   remains visible behind/around the iframe even after it finishes loading.
   Hide it inside our framed SMM hero so it doesn't peek out next to the
   iframe edges. */
.smm-cal-body .calendly-spinner,
.smm-cal-body .calendly-inline-widget > .calendly-spinner {
  display: none !important;
}


/* ═════════════════════════════════════════════════════════════════
   Instagram Growth page (/instagram-growth)
   ═════════════════════════════════════════════════════════════════ */

.ig-hero { padding-bottom: 56px; }
.ig-hero-grid { align-items: center; }
.ig-hero-bullets { gap: 10px; }
.ig-hero-bullets li { font-size: 16px; }
.ig-channel-label {
  font-size: 13px; color: var(--ink-2);
  font-weight: 500;
  margin-left: 2px;
}

/* ── Hero phone mock + floating callouts ─────────────────────────── */
.ig-mock {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 32px 16px 40px;
  min-height: 620px;
}
.ig-mock-phone {
  position: relative;
  width: 320px;
  max-width: 100%;
  background: #0f1014;
  border-radius: 42px;
  padding: 14px 12px 18px;
  box-shadow:
    0 30px 60px -20px rgba(20, 14, 8, 0.35),
    0 12px 30px -12px rgba(20, 14, 8, 0.22),
    inset 0 0 0 1.5px rgba(255,255,255,0.06);
  z-index: 1;
}
.ig-mock-notch {
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
  width: 86px;
  height: 18px;
  background: #0a0a0d;
  border-radius: 12px;
  z-index: 3;
}
.ig-mock-screen {
  background: #ffffff;
  border-radius: 30px;
  overflow: hidden;
  position: relative;
  aspect-ratio: 9 / 16;
  width: 100%;
}
.ig-mock-img {
  width: 100%;
  height: 100%;
  /* New source image is already portrait — no horizontal crop needed. */
  object-fit: cover;
  object-position: center top;
  display: block;
}

/* Floating callouts */
.ig-callout {
  position: absolute;
  background: #fff;
  border-radius: 14px;
  box-shadow:
    0 14px 32px -10px rgba(17,17,17,0.18),
    0 4px 12px -4px rgba(17,17,17,0.10);
  padding: 12px 14px;
  z-index: 2;
  border: 1px solid rgba(0,0,0,0.04);
}
.ig-callout-label {
  font-size: 11px;
  color: #6b7280;
  font-weight: 500;
  margin-bottom: 4px;
}
.ig-callout-row {
  display: flex; align-items: baseline; gap: 8px;
}
.ig-callout-num {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 18px;
  color: #111;
  letter-spacing: -0.01em;
}
.ig-callout-delta {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 11.5px;
  font-weight: 600;
  color: #10b981;
}
.ig-callout-arrow {
  display: inline-grid; place-items: center;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: #10b981;
  color: #fff;
  font-size: 10px;
  line-height: 1;
}
.ig-callout--left {
  top: 36%;
  left: 0;
  transform: translateX(-12%);
}
.ig-callout--right {
  bottom: 14%;
  right: 0;
  transform: translateX(12%);
}
.ig-callout--pill {
  display: inline-flex; align-items: center; gap: 6px;
  background: linear-gradient(135deg, #FF3366, #FF5E62);
  color: #fff;
  padding: 8px 12px;
  border-radius: 999px;
  top: 14%;
  right: -4%;
  border: none;
  box-shadow:
    0 14px 26px -10px rgba(255, 51, 102, 0.5),
    0 4px 10px -4px rgba(255, 51, 102, 0.35);
  font-size: 13px;
  font-weight: 600;
}
.ig-callout--pill b {
  font-weight: 700;
  font-family: var(--font-display);
}
.ig-callout-pill-icon {
  display: inline-grid; place-items: center;
  width: 16px; height: 16px;
  opacity: 0.95;
}

/* ── How it works grid ───────────────────────────────────────────── */
.ig-feature-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-top: 48px;
}
.ig-feature {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 26px 24px;
  display: flex; flex-direction: column;
  gap: 10px;
}
.ig-feature-icon {
  width: 42px; height: 42px;
  border-radius: 12px;
  background: color-mix(in oklch, var(--primary) 14%, transparent);
  color: var(--primary);
  display: grid; place-items: center;
  margin-bottom: 6px;
}
.ig-feature-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.ig-feature-body {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-2);
}

/* ── Next-level 3-card section ───────────────────────────────────── */
.ig-next-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-top: 48px;
  margin-bottom: 32px;
}
.ig-next-card {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 28px 26px;
  position: relative;
  display: flex; flex-direction: column;
}
.ig-next-num {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.08em;
  color: var(--ink-3);
  margin-bottom: 18px;
}
.ig-next-kicker {
  display: inline-block;
  align-self: flex-start;
  padding: 3px 8px;
  background: color-mix(in oklch, var(--primary) 14%, transparent);
  color: var(--primary);
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: 4px;
  margin-bottom: 14px;
}
.ig-next-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin-bottom: 10px;
}
.ig-next-body {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-2);
}

/* ── Responsive ──────────────────────────────────────────────────── */
@media (max-width: 980px) {
  .ig-feature-grid,
  .ig-next-grid { grid-template-columns: 1fr 1fr; }
  .ig-callout--left { transform: translateX(0); left: 8px; }
  .ig-callout--right { transform: translateX(0); right: 8px; }
  .ig-callout--pill { right: 4%; }
}
@media (max-width: 640px) {
  .ig-feature-grid,
  .ig-next-grid { grid-template-columns: 1fr; }
  .ig-mock { min-height: 580px; }
  .ig-mock-phone { width: 280px; }
}


/* ═════════════════════════════════════════════════════════════════
   Instagram Growth — extended sections
   ═════════════════════════════════════════════════════════════════ */

/* ── Growth Manager ──────────────────────────────────────────────── */
.ig-manager-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: 60px;
  align-items: center;
}
.ig-manager-card {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 28px;
  display: flex; flex-direction: column; gap: 18px;
}
.ig-manager-portrait {
  position: relative;
  aspect-ratio: 4 / 5;
  width: 100%;
  border-radius: 18px;
  overflow: hidden;
  background: #f4ede2;
}
.ig-manager-portrait-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.ig-manager-portrait-badge {
  position: absolute;
  bottom: 14px; left: 14px;
  display: inline-flex; align-items: center; gap: 7px;
  background: rgba(17,17,17,0.82);
  color: #fff;
  padding: 6px 11px 6px 9px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.06em;
  backdrop-filter: blur(4px);
}
.ig-manager-portrait-pulse {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #4ade80;
  box-shadow: 0 0 0 0 rgba(74, 222, 128, 0.6);
  animation: ig-manager-pulse 2s ease-out infinite;
}
@keyframes ig-manager-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(74, 222, 128, 0.6); }
  70%  { box-shadow: 0 0 0 8px rgba(74, 222, 128, 0); }
  100% { box-shadow: 0 0 0 0 rgba(74, 222, 128, 0); }
}
.ig-manager-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.ig-manager-role {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.06em;
  color: var(--ink-3);
  text-transform: uppercase;
  margin-top: -10px;
}
.ig-manager-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  padding-top: 6px;
  border-top: 1px solid var(--line);
}
.ig-manager-stats > div {
  display: flex; flex-direction: column;
}
.ig-manager-stats b {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 22px;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.ig-manager-stats span {
  font-size: 11.5px;
  color: var(--ink-3);
}

.ig-manager-body { max-width: 580px; }
.ig-manager-body h2 { margin-top: 16px; }
.ig-manager-body p {
  margin-top: 16px;
  color: var(--ink-2);
}
.ig-manager-points {
  list-style: none;
  padding: 0;
  margin: 24px 0 18px;
  display: flex; flex-direction: column;
  gap: 14px;
}
.ig-manager-points li {
  display: flex; gap: 14px; align-items: flex-start;
}
.ig-manager-points-check {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--primary);
  display: grid; place-items: center;
  flex-shrink: 0;
  margin-top: 2px;
}
.ig-manager-points-title {
  font-weight: 600;
  font-size: 15px;
  color: var(--ink);
}
.ig-manager-points-body {
  font-size: 14px;
  color: var(--ink-2);
  margin-top: 2px;
}
.ig-manager-footnote {
  padding: 14px 18px;
  background: color-mix(in oklch, var(--primary) 8%, transparent);
  border-left: 3px solid var(--primary);
  border-radius: 8px;
  font-size: 14.5px;
  color: var(--ink-2);
}

/* ── Process (4 steps) ───────────────────────────────────────────── */
.ig-process-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin-top: 48px;
}
.ig-process-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 22px 22px 24px;
  display: flex; flex-direction: column;
  position: relative;
}
.ig-process-step {
  display: flex; align-items: baseline; gap: 8px;
  margin-bottom: 16px;
}
.ig-process-step-label {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.ig-process-step-num {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 32px;
  color: var(--primary);
  letter-spacing: -0.02em;
  line-height: 1;
}
.ig-process-vis {
  height: 92px;
  border-radius: 12px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  margin-bottom: 18px;
  position: relative;
  overflow: hidden;
  display: grid; place-items: center;
}
.ig-process-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 17px;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin-bottom: 8px;
}
.ig-process-body {
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink-2);
  flex: 1;
}
.ig-process-tag {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--ink-2);
}
.ig-process-foot {
  text-align: center;
  margin-top: 36px;
  font-size: 15px;
  color: var(--ink-2);
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

/* Step visualisations */
.ig-vis { position: relative; width: 100%; height: 100%; padding: 12px 14px; }
.ig-vis--target {
  display: grid; place-items: center;
}
.ig-vis-ring {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  border: 1.5px solid color-mix(in oklch, var(--primary) 35%, transparent);
  border-radius: 50%;
}
.ig-vis-ring--1 { width: 70px; height: 70px; opacity: 0.4; }
.ig-vis-ring--2 { width: 50px; height: 50px; opacity: 0.6; }
.ig-vis-ring--3 { width: 30px; height: 30px; opacity: 0.85; }
.ig-vis-dot {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--primary);
  z-index: 2;
}
.ig-vis-pin {
  position: absolute;
  top: 8px; right: 10px;
  background: var(--ink);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 3px 7px;
  border-radius: 6px;
}

.ig-vis--engage {
  display: flex; flex-direction: column; justify-content: center;
  gap: 6px;
  padding: 10px 14px;
}
.ig-vis-row {
  display: flex; align-items: center; gap: 8px;
  font-size: 11.5px;
  color: var(--ink-2);
}
.ig-vis-row span { color: var(--ink); font-weight: 500; }
.ig-vis-row em {
  font-style: normal;
  font-family: var(--font-mono);
  color: var(--ink-3);
  font-size: 10.5px;
  margin-left: auto;
}

.ig-vis--notify {
  display: flex; flex-direction: column; justify-content: center;
  gap: 6px;
  padding: 10px 12px;
}
.ig-vis-notif {
  display: flex; align-items: center; gap: 8px;
  background: var(--bg);
  border: 1px solid var(--line);
  padding: 6px 10px;
  border-radius: 10px;
  font-size: 11px;
}
.ig-vis-notif--secondary { opacity: 0.55; }
.ig-vis-notif-dot {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: linear-gradient(135deg, #F58529, #DD2A7B);
  flex-shrink: 0;
}
.ig-vis-notif-text {
  flex: 1;
  color: var(--ink);
}
.ig-vis-notif-text strong { font-weight: 600; }
.ig-vis-notif-time {
  font-family: var(--font-mono);
  color: var(--ink-3);
  font-size: 10px;
}

.ig-vis--growth {
  position: relative;
  padding: 8px 12px 4px;
}
.ig-vis--growth svg {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
}
.ig-vis-growth-num {
  position: absolute;
  top: 8px; left: 12px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 20px;
  color: var(--primary);
  letter-spacing: -0.02em;
}
.ig-vis-growth-label {
  position: absolute;
  bottom: 8px; right: 12px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  color: var(--ink-3);
}

/* ── Problem / warnings ──────────────────────────────────────────── */
.ig-kicker--warn .dot { background: #E11D48 !important; }
.ig-problem-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin-top: 48px;
}
.ig-problem-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-left: 3px solid #E11D48;
  border-radius: 14px;
  padding: 22px;
  display: flex; flex-direction: column;
}
.ig-problem-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 18px;
}
.ig-problem-tag {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #E11D48;
}
.ig-problem-num {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 32px;
  color: var(--ink-3);
  letter-spacing: -0.02em;
  line-height: 1;
}
.ig-problem-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 17px;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin-bottom: 8px;
}
.ig-problem-body {
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink-2);
}

/* ── Audience (brands / creators) ────────────────────────────────── */
.ig-audience-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  margin-top: 48px;
}
.ig-audience-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 28px;
  display: flex; flex-direction: column;
}
.ig-audience-vis {
  height: 280px;
  border-radius: 18px;
  margin-bottom: 24px;
  overflow: hidden;
  position: relative;
  background: var(--bg-2);
}
.ig-aud-vis {
  width: 100%;
  height: 100%;
  position: relative;
}
.ig-aud-vis-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* Crop to the right portion of the source image so the person + floating
     stat cards stay in frame and the on-image headline (which we already
     render in HTML) gets cropped out. */
  object-position: 78% center;
  display: block;
}
@media (max-width: 1100px) {
  .ig-audience-vis { height: 240px; }
}
@media (max-width: 720px) {
  .ig-audience-vis { height: 220px; }
  .ig-aud-vis-img { object-position: 72% center; }
}
.ig-audience-tag {
  display: inline-block;
  align-self: flex-start;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--primary);
  padding: 4px 9px;
  background: color-mix(in oklch, var(--primary) 12%, transparent);
  border-radius: 4px;
  margin-bottom: 14px;
}
.ig-audience-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 24px;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin-bottom: 18px;
  max-width: 360px;
}
.ig-audience-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex; flex-direction: column; gap: 10px;
}
.ig-audience-list li {
  display: flex; align-items: center; gap: 12px;
  font-size: 15px;
  color: var(--ink-2);
}
.ig-audience-check {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--primary);
  display: grid; place-items: center;
  flex-shrink: 0;
}

/* ── Geo card ────────────────────────────────────────────────────── */
.ig-geo-card {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 28px;
  padding: 48px;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: 48px;
  align-items: center;
}
.ig-geo-body h2 { margin-top: 16px; }
.ig-geo-body p {
  margin-top: 16px;
  color: var(--ink-2);
}
.ig-geo-pills {
  display: flex; flex-wrap: wrap;
  gap: 8px;
  margin-top: 22px;
}
.ig-geo-pills span {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 13px;
  color: var(--ink-2);
  font-weight: 500;
}
.ig-geo-vis {
  aspect-ratio: 1;
  width: 100%;
  max-width: 360px;
  margin-left: auto;
  position: relative;
}
.ig-geo-globe {
  width: 100%; height: 100%;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, color-mix(in oklch, var(--primary) 18%, var(--bg)), var(--bg));
  border: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.ig-geo-grid-h, .ig-geo-grid-v {
  position: absolute; inset: 0;
  background-repeat: repeat;
}
.ig-geo-grid-h {
  background-image: repeating-linear-gradient(
    0deg,
    transparent 0 18px,
    color-mix(in oklch, var(--primary) 20%, transparent) 18px 19px
  );
}
.ig-geo-grid-v {
  background-image: repeating-linear-gradient(
    90deg,
    transparent 0 18px,
    color-mix(in oklch, var(--primary) 20%, transparent) 18px 19px
  );
}
.ig-geo-pin {
  position: absolute;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--primary);
  box-shadow: 0 4px 14px color-mix(in oklch, var(--primary) 60%, transparent);
}
.ig-geo-pin span {
  position: absolute;
  inset: -8px;
  border: 2px solid var(--primary);
  border-radius: 50%;
  opacity: 0.4;
}
.ig-geo-pin--1 { top: 28%; left: 22%; }
.ig-geo-pin--2 { top: 18%; left: 60%; }
.ig-geo-pin--3 { top: 55%; left: 38%; }
.ig-geo-pin--4 { top: 68%; left: 70%; }

/* ── Responsive ──────────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .ig-process-grid { grid-template-columns: 1fr 1fr; }
  .ig-problem-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 980px) {
  .ig-manager-grid { grid-template-columns: 1fr; gap: 40px; }
  .ig-manager-card { max-width: 420px; margin: 0 auto; }
  .ig-audience-grid { grid-template-columns: 1fr; }
  .ig-geo-card { grid-template-columns: 1fr; padding: 32px; }
  .ig-geo-vis { margin: 0 auto; max-width: 280px; }
}
@media (max-width: 640px) {
  .ig-process-grid { grid-template-columns: 1fr; }
  .ig-problem-grid { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════════════════
   SEO Blog Articles page (/seo-blog-articles)
   ════════════════════════════════════════════════════════════════════════ */

/* ── Hero image art ──────────────────────────────────────────────────── */
.seo-hero-art {
  position: relative;
  width: 100%;
  max-width: 520px;
  margin: 0 auto;
  border-radius: 24px;
  overflow: hidden;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(255, 122, 74, 0.10), transparent 60%),
    var(--bg-2);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-card);
  aspect-ratio: 3 / 4;
  display: flex;
  align-items: center;
  justify-content: center;
}
.seo-hero-art-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ── Process step dot under the step number (echoes "Lower Dot" copy) ── */
.seo-process-card { position: relative; }
.seo-process-dot {
  display: flex;
  justify-content: center;
  margin: 10px 0 14px;
}
.seo-process-dot > span {
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--primary);
  box-shadow: 0 0 0 4px rgba(255, 122, 74, 0.15);
}

/* ── Pillars (4-tab card) ────────────────────────────────────────────── */
.seo-pillars-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--shadow-card);
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.3fr);
}
.seo-pillars-tabs {
  display: flex;
  flex-direction: column;
  background: var(--bg-2);
  border-right: 1px solid var(--line);
  padding: 14px;
  gap: 6px;
}
.seo-pillars-tab {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid transparent;
  border-radius: 14px;
  background: transparent;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  font-size: 15px;
  font-weight: 600;
  color: var(--ink-2);
  transition: background 160ms ease, color 160ms ease, border-color 160ms ease;
}
.seo-pillars-tab:hover { background: var(--bg); }
.seo-pillars-tab[data-on="1"] {
  background: var(--bg);
  border-color: var(--line);
  color: var(--ink-1);
}
.seo-pillars-tab-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  height: 30px;
  padding: 0 6px;
  border-radius: 9px;
  background: var(--bg-3, var(--bg-2));
  font-family: var(--font-mono, monospace);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--ink-3);
}
.seo-pillars-tab[data-on="1"] .seo-pillars-tab-num {
  background: var(--primary);
  color: #fff;
}
.seo-pillars-body {
  padding: 48px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  justify-content: center;
}
.seo-pillars-body-icon {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: rgba(255, 122, 74, 0.10);
  color: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
}
.seo-pillars-body-title {
  font-size: 28px;
  line-height: 1.15;
  font-weight: 700;
  color: var(--ink-1);
  letter-spacing: -0.01em;
}
.seo-pillars-body-text {
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink-2);
}

/* ── Quality / Scale narrative ───────────────────────────────────────── */
.seo-quality-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
}
.seo-quality-card {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 36px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
}
.seo-quality-num {
  position: absolute;
  top: 28px;
  right: 32px;
  font-family: var(--font-mono, monospace);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--ink-3);
}
.seo-quality-title {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 0;
  color: var(--ink-1);
}
.seo-quality-body {
  font-size: 16px;
  line-height: 1.65;
  color: var(--ink-2);
  margin: 0;
}

/* ── Industries grid ─────────────────────────────────────────────────── */
.seo-industries-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
  margin-top: 36px;
}
.seo-industry {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 18px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 14px;
  font-size: 15px;
  font-weight: 600;
  color: var(--ink-1);
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}
.seo-industry:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-card);
  border-color: var(--primary);
}
.seo-industry-icon {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: rgba(255, 122, 74, 0.10);
  color: var(--primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* ── Compare 3-column ────────────────────────────────────────────────── */
.seo-compare-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  align-items: stretch;
}
.seo-compare-col {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
}
.seo-compare-col[data-tone="us"] {
  background: linear-gradient(180deg, rgba(255, 122, 74, 0.06), rgba(255, 122, 74, 0.02));
  border-color: var(--primary);
  box-shadow: 0 18px 40px -20px rgba(255, 122, 74, 0.35);
}
.seo-compare-headline {
  font-size: 32px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--ink-1);
  font-family: var(--font-display, inherit);
}
.seo-compare-col[data-tone="us"] .seo-compare-headline {
  color: var(--primary);
}
.seo-compare-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink-2);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.seo-compare-rule {
  height: 1px;
  background: var(--line);
  margin: 6px 0;
}
.seo-compare-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.seo-compare-li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 15px;
  line-height: 1.45;
  color: var(--ink-2);
}
.seo-compare-x,
.seo-compare-check {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}
.seo-compare-x { background: #E11D48; }
.seo-compare-check { background: var(--primary); }
.seo-compare-cta {
  margin-top: auto;
  align-self: flex-start;
}

/* ── Responsive ──────────────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .seo-pillars-card { grid-template-columns: 1fr; }
  .seo-pillars-tabs {
    flex-direction: row;
    overflow-x: auto;
    border-right: none;
    border-bottom: 1px solid var(--line);
    padding: 12px;
  }
  .seo-pillars-tab { flex-shrink: 0; }
  .seo-pillars-body { padding: 32px; }
}
@media (max-width: 980px) {
  .seo-quality-grid { grid-template-columns: 1fr; }
  .seo-compare-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .seo-pillars-body { padding: 24px; }
  .seo-pillars-body-title { font-size: 22px; }
  .seo-quality-card { padding: 24px; }
  .seo-industries-grid { grid-template-columns: 1fr 1fr; }
}


/* ─────────────────────────────────────────────────────────────────────────
 * Short-Form Video page (/short-form-video)
 * ────────────────────────────────────────────────────────────────────── */

/* ── Hero stack: three offset 9:16 tiles ─────────────────────────────── */
.sfv-hero-stack {
  position: relative;
  width: 100%;
  max-width: 480px;
  margin: 0 auto;
  aspect-ratio: 1 / 0.85;
}
.sfv-hero-tile {
  position: absolute;
  width: 46%;
  aspect-ratio: 9 / 16;
  border-radius: 18px;
  overflow: hidden;
  background: #111;
  box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 22px 50px -22px rgba(0,0,0,.35);
  transform-origin: center center;
  border: 1px solid rgba(255,255,255,0.6);
}
.sfv-hero-tile img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  filter: brightness(0.95);
}
.sfv-hero-tile-play {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: rgba(255,255,255,0.95);
  pointer-events: none;
}
.sfv-hero-tile-play svg {
  background: rgba(0,0,0,0.35);
  border: 1px solid rgba(255,255,255,0.7);
  border-radius: 999px;
  padding: 12px;
  width: 44px; height: 44px;
  box-sizing: content-box;
  backdrop-filter: blur(4px);
}
.sfv-hero-tile--1 {
  left: 4%; top: 6%;
  transform: rotate(-7deg);
  z-index: 1;
}
.sfv-hero-tile--2 {
  left: 27%; top: 0;
  transform: rotate(0deg) scale(1.04);
  z-index: 3;
  border-color: rgba(255,255,255,0.85);
  box-shadow: 0 2px 4px rgba(0,0,0,.08), 0 30px 60px -22px rgba(0,0,0,.4);
}
.sfv-hero-tile--3 {
  right: 4%; top: 8%;
  transform: rotate(7deg);
  z-index: 2;
}

.sfv-hero-chip {
  position: absolute;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 8px 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
  box-shadow: 0 1px 2px rgba(0,0,0,.04), 0 8px 18px -10px rgba(0,0,0,.18);
  z-index: 5;
}
.sfv-hero-chip b { font-weight: 700; }
.sfv-hero-chip span { color: var(--ink-3); font-size: 12px; }
.sfv-hero-chip--views {
  top: -8px; right: 4%;
}
.sfv-hero-chip-dot {
  width: 8px; height: 8px;
  border-radius: 999px;
  background: #ef4444;
  box-shadow: 0 0 0 4px color-mix(in oklch, #ef4444 18%, transparent);
}
.sfv-hero-chip--time {
  bottom: -4px; left: 6%;
  background: var(--primary);
  color: #fff;
  border-color: color-mix(in oklch, var(--primary) 70%, #000);
}
.sfv-hero-chip--time span { color: rgba(255,255,255,0.9); font-size: 13px; }

/* ── Platforms strip ─────────────────────────────────────────────────── */
.sfv-platforms { padding: 56px 0 24px; }
.sfv-platforms-head {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}
.sfv-platforms-rule {
  flex: 1;
  min-width: 40px;
  height: 1px;
  background: var(--line);
}
.sfv-platforms-meta {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.sfv-platforms-row {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
}
.sfv-platform {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 14px;
  transition: transform .15s ease, border-color .15s ease;
}
.sfv-platform:hover {
  transform: translateY(-2px);
  border-color: color-mix(in oklch, var(--primary) 35%, var(--line));
}
.sfv-platform-badge {
  width: 32px; height: 32px;
  border-radius: 8px;
  display: grid; place-items: center;
  flex-shrink: 0;
}
.sfv-platform-name {
  font-weight: 500;
  font-size: 14px;
  color: var(--ink);
}
@media (max-width: 980px) {
  .sfv-platforms-row { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 560px) {
  .sfv-platforms-row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* ── Why grid: 3 cards (re-uses .ig-feature) ─────────────────────────── */
.sfv-why-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
@media (max-width: 900px) {
  .sfv-why-grid { grid-template-columns: 1fr; }
}

/* ── Process grid: 3 columns (override .ig-process-grid 4-col) ────────── */
.sfv-process-grid { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
.sfv-process-card { padding: 32px; }
.sfv-process-kicker {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--primary);
  margin-bottom: 14px;
  padding: 4px 10px;
  background: color-mix(in oklch, var(--primary) 10%, transparent);
  border-radius: 999px;
}
@media (max-width: 900px) {
  .sfv-process-grid { grid-template-columns: 1fr !important; }
}

/* ── Format/Type cards ───────────────────────────────────────────────── */
.sfv-types-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-top: 48px;
}
.sfv-type-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.sfv-type-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in oklch, var(--primary) 40%, var(--line));
  box-shadow: 0 1px 3px rgba(0,0,0,.04), 0 20px 40px -22px rgba(0,0,0,.18);
}
.sfv-type-thumb {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}
.sfv-type-thumb-fade {
  position: absolute; inset: 0;
  background:
    radial-gradient(120% 100% at 0% 0%, rgba(255,255,255,0.25), transparent 60%),
    radial-gradient(80% 100% at 100% 100%, rgba(0,0,0,0.25), transparent 60%);
}
.sfv-type-thumb-icon {
  position: absolute;
  left: 18px; bottom: 18px;
  width: 38px; height: 38px;
  border-radius: 10px;
  display: grid; place-items: center;
  background: rgba(0,0,0,0.35);
  border: 1px solid rgba(255,255,255,0.4);
  backdrop-filter: blur(6px);
}
.sfv-type-thumb-aspect {
  position: absolute;
  right: 14px; top: 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: rgba(255,255,255,0.9);
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(0,0,0,0.32);
  border: 1px solid rgba(255,255,255,0.3);
  letter-spacing: 0.04em;
}
.sfv-type-body { padding: 22px 24px 26px; }
.sfv-type-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  color: var(--ink);
  margin-bottom: 8px;
}
.sfv-type-text {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-2);
}
@media (max-width: 980px) {
  .sfv-types-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 600px) {
  .sfv-types-grid { grid-template-columns: 1fr; }
}

/* ── Benefits grid (4 cards, re-uses .ig-feature) ────────────────────── */
.sfv-benefits-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
@media (max-width: 1100px) {
  .sfv-benefits-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px) {
  .sfv-benefits-grid { grid-template-columns: 1fr; }
}

/* ── Workflow: 2-column with icon-left treatment ─────────────────────── */
.sfv-workflow-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  margin-top: 48px;
}
.sfv-workflow-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 28px;
  display: flex;
  gap: 18px;
  align-items: flex-start;
}
.sfv-workflow-icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: color-mix(in oklch, var(--primary) 12%, transparent);
  color: var(--primary);
  display: grid; place-items: center;
  flex-shrink: 0;
}
.sfv-workflow-body { min-width: 0; }
.sfv-workflow-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 17px;
  margin-bottom: 6px;
  color: var(--ink);
}
.sfv-workflow-text {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-2);
}
@media (max-width: 820px) {
  .sfv-workflow-grid { grid-template-columns: 1fr; }
}

/* ── Q&A: 3 narrative cards ──────────────────────────────────────────── */
.sfv-qa-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
  margin-top: 48px;
}
.sfv-qa-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 36px 32px;
  position: relative;
  display: flex;
  flex-direction: column;
}
.sfv-qa-num {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 36px;
  line-height: 1;
  color: color-mix(in oklch, var(--primary) 35%, var(--line));
  margin-bottom: 14px;
}
.sfv-qa-kicker {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--primary);
  margin-bottom: 10px;
}
.sfv-qa-q {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  line-height: 1.2;
  margin: 0 0 16px;
  color: var(--ink);
}
.sfv-qa-a {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink-2);
  margin: 0 0 12px;
}
.sfv-qa-cta {
  margin-top: auto;
  align-self: flex-start;
  background: none;
  border: 0;
  padding: 8px 0 0;
  color: var(--primary);
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.sfv-qa-cta:hover { text-decoration: underline; text-underline-offset: 3px; }
@media (max-width: 980px) {
  .sfv-qa-grid { grid-template-columns: 1fr; }
}

/* ── Before/After comparison ─────────────────────────────────────────── */
.sfv-ba-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 24px;
  align-items: stretch;
  margin-top: 48px;
}
.sfv-ba-col {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 32px;
}
.sfv-ba-col--before {
  background: color-mix(in oklch, var(--ink) 4%, var(--bg));
}
.sfv-ba-col--after {
  background: color-mix(in oklch, var(--primary) 8%, var(--bg));
  border-color: color-mix(in oklch, var(--primary) 30%, var(--line));
}
.sfv-ba-col-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px dashed var(--line);
}
.sfv-ba-col--after .sfv-ba-col-tag {
  color: var(--primary);
  border-bottom-color: color-mix(in oklch, var(--primary) 30%, var(--line));
}
.sfv-ba-col ul {
  list-style: none;
  padding: 0; margin: 0;
  display: flex; flex-direction: column;
  gap: 14px;
}
.sfv-ba-col li {
  display: flex; gap: 12px; align-items: flex-start;
  font-size: 15px; line-height: 1.5;
  color: var(--ink-2);
}
.sfv-ba-col--after li { color: var(--ink); font-weight: 500; }
.sfv-ba-x, .sfv-ba-check {
  width: 22px; height: 22px;
  border-radius: 999px;
  display: grid; place-items: center;
  flex-shrink: 0; margin-top: 1px;
}
.sfv-ba-x { background: var(--ink-3); }
.sfv-ba-check { background: var(--primary); }

.sfv-ba-rule {
  align-self: center;
  width: 44px; height: 44px;
  border-radius: 999px;
  background: var(--ink);
  color: var(--bg);
  display: grid; place-items: center;
}
@media (max-width: 900px) {
  .sfv-ba-grid { grid-template-columns: 1fr; }
  .sfv-ba-rule { transform: rotate(90deg); justify-self: center; }
}

/* ── Activation: 3 step cards + 2 features + analytics ───────────────── */
.sfv-activation-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-top: 32px;
}
.sfv-activation-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 28px;
  position: relative;
  overflow: hidden;
}
.sfv-activation-vis {
  aspect-ratio: 16 / 8;
  border-radius: 12px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  margin-bottom: 22px;
  position: relative;
  overflow: hidden;
}
.sfv-activation-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--ink-3);
  margin-bottom: 8px;
}
.sfv-activation-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  margin-bottom: 8px;
  color: var(--ink);
}
.sfv-activation-body {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-2);
}
@media (max-width: 900px) {
  .sfv-activation-grid { grid-template-columns: 1fr; }
}

.sfv-step-vis {
  position: absolute; inset: 0;
  padding: 16px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 8px;
}
.sfv-step-vis--plan { padding: 18px; }
.sfv-step-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 12.5px;
  color: var(--ink-2);
  align-self: flex-start;
}
.sfv-step-pill--on {
  background: color-mix(in oklch, var(--primary) 14%, var(--bg));
  border-color: color-mix(in oklch, var(--primary) 40%, var(--line));
  color: var(--ink);
  font-weight: 500;
}
.sfv-step-pill-dot {
  width: 8px; height: 8px;
  border-radius: 999px;
  background: var(--ink-3);
}
.sfv-step-pill--on .sfv-step-pill-dot { background: var(--primary); }

.sfv-step-vis--form { padding: 18px; gap: 10px; }
.sfv-step-field {
  height: 10px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 0;
  position: relative;
  overflow: hidden;
}
.sfv-step-field span {
  display: block;
  height: 100%;
  width: 90%;
  background: var(--ink-3);
  opacity: 0.6;
  border-radius: 999px;
}
.sfv-step-field--done {
  width: 22px; height: 22px;
  border-radius: 999px;
  background: var(--primary);
  border-color: transparent;
  display: grid; place-items: center;
  align-self: flex-start;
}

.sfv-step-vis--deliver {
  flex-direction: row;
  padding: 14px;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
.sfv-step-tile {
  width: 36px;
  aspect-ratio: 9/16;
  border-radius: 8px;
  background: linear-gradient(160deg, color-mix(in oklch, var(--primary) 30%, var(--bg)) 0%, color-mix(in oklch, var(--primary) 70%, #000) 100%);
  box-shadow: 0 8px 18px -8px rgba(0,0,0,.25);
}
.sfv-step-tile--2 {
  width: 44px;
  transform: translateY(-4px);
  background: linear-gradient(160deg, #0EA5E9, #7C3AED);
}
.sfv-step-tile--3 {
  background: linear-gradient(160deg, #111827, #1F2937);
}
.sfv-step-badge {
  position: absolute;
  right: 12px; bottom: 12px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  background: var(--primary);
  color: #fff;
  font-size: 11.5px;
  font-weight: 600;
  border-radius: 999px;
}

.sfv-activation-two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  margin-top: 28px;
}
.sfv-activation-feature {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 36px;
}
.sfv-activation-feature h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  line-height: 1.2;
  margin: 14px 0 12px;
  color: var(--ink);
}
.sfv-activation-feature p {
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink-2);
  margin: 0 0 18px;
}
.sfv-activation-bullets {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 10px;
}
.sfv-activation-bullets li {
  display: flex; gap: 10px; align-items: center;
  font-size: 14.5px;
  color: var(--ink);
}
.sfv-activation-check {
  width: 20px; height: 20px;
  border-radius: 999px;
  background: var(--primary);
  display: grid; place-items: center;
  flex-shrink: 0;
}
.sfv-activation-feature--analytics { position: relative; overflow: hidden; }
.sfv-analytics-vis {
  margin-top: 20px;
  padding: 18px;
  border-radius: 14px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  position: relative;
}
.sfv-analytics-vis svg { width: 100%; height: 60px; display: block; }
.sfv-analytics-tag {
  margin-top: 10px;
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
}
.sfv-analytics-tag b {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 22px;
  color: var(--primary);
}
.sfv-analytics-tag span {
  font-size: 13px;
  color: var(--ink-3);
}
@media (max-width: 900px) {
  .sfv-activation-two { grid-template-columns: 1fr; }
  .sfv-activation-feature { padding: 28px; }
}

/* ── Hero stack responsive ───────────────────────────────────────────── */
@media (max-width: 760px) {
  .sfv-hero-stack { max-width: 380px; }
}
