/* ═══ GeneOps Group — Shared Stylesheet ═══ */

:root {
  --bg: #060a0e;
  --bg-slide: #080d12;
  --surface: #0e151c;
  --surface-raised: #121c25;
  --border: #1a2733;
  --border-dim: #131d27;
  --accent: #34d399;
  --accent-dim: rgba(52, 211, 153, 0.10);
  --accent-glow: rgba(52, 211, 153, 0.20);
  --text: #e8edf2;
  --text-mid: #94a8b8;
  --text-dim: #586d7e;
  --amber: #fbbf24;
  --amber-dim: rgba(251, 191, 36, 0.12);
  --rose: #fb7185;
  --rose-dim: rgba(251, 113, 133, 0.10);
  --blue: #60a5fa;
  --blue-dim: rgba(96, 165, 250, 0.10);
  --purple: #a78bfa;
  --purple-dim: rgba(167, 139, 250, 0.10);
  --cyan: #22d3ee;
  --cyan-dim: rgba(34, 211, 238, 0.10);
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'DM Sans', -apple-system, sans-serif;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

a { color: inherit; }

/* ─── PITCH DECK: Scroll-snap mode ─── */
html.pitch { scroll-behavior: smooth; scroll-snap-type: y mandatory; }

/* ─── LANDING PAGE: Normal scroll ─── */
html.landing { scroll-behavior: smooth; }

/* ─── SLIDE BASE ─── */
.slide {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 80px 80px;
  position: relative;
  overflow: hidden;
}
html.pitch .slide { scroll-snap-align: start; }

.slide-inner { max-width: 1200px; width: 100%; margin: 0 auto; }

.slide-number {
  font-family: 'Space Mono', monospace;
  font-size: 11px; letter-spacing: 3px;
  color: var(--text-dim); text-transform: uppercase;
  margin-bottom: 40px; opacity: 0.6;
}

/* ─── TYPOGRAPHY ─── */
h1 { font-size: 64px; font-weight: 300; letter-spacing: -2px; line-height: 1.08; }
h1 strong { font-weight: 500; color: var(--accent); }
h2 { font-size: 42px; font-weight: 300; letter-spacing: -1.2px; line-height: 1.2; }
h2 strong { font-weight: 500; }
h2 em { font-style: normal; color: var(--accent); }

.subtitle {
  font-size: 20px; font-weight: 300; line-height: 1.7;
  color: var(--text-mid); max-width: 680px; margin-top: 24px;
}

.label { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--accent); }
.label-dim { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--text-dim); }

.ref {
  color: var(--accent); cursor: pointer; font-size: 0.7em; vertical-align: super;
  font-family: 'Space Mono', monospace; text-decoration: none;
  transition: opacity 0.2s; font-weight: 700;
}
.ref:hover { opacity: 0.7; }

/* ─── COVER ─── */
.cover { background: radial-gradient(ellipse 80% 60% at 50% 40%, rgba(52, 211, 153, 0.04) 0%, transparent 70%); }
.cover-logo {
  font-family: 'Space Mono', monospace; font-size: 15px; font-weight: 700;
  letter-spacing: 4px; color: var(--accent); text-transform: uppercase;
  margin-bottom: 56px; opacity: 0; animation: fadeIn 1s ease 0.2s forwards;
}
.cover h1 { font-size: 68px; max-width: 960px; opacity: 0; animation: fadeUp 1s ease 0.4s forwards; }
.cover .subtitle { max-width: 720px; opacity: 0; animation: fadeUp 1s ease 0.6s forwards; }
.cover-meta {
  margin-top: 64px; display: flex; gap: 48px;
  opacity: 0; animation: fadeUp 1s ease 0.8s forwards;
}
.cover-meta-item { display: flex; flex-direction: column; gap: 6px; }
.cover-meta-item .label-dim { margin-bottom: 2px; }
.cover-meta-item span { font-size: 14px; color: var(--text-mid); }
.cover-confidential {
  position: absolute; bottom: 40px; left: 80px;
  font-family: 'Space Mono', monospace; font-size: 10px;
  letter-spacing: 2px; color: var(--text-dim); opacity: 0.4; text-transform: uppercase;
}

/* ─── MOMENT ─── */
.moment-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; margin-top: 48px; }
.moment-curve { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 40px; position: relative; overflow: hidden; }
.moment-curve::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--accent), transparent); opacity: 0.3; }
.curve-title { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--accent); margin-bottom: 20px; }
.curve-visual { height: 160px; position: relative; margin: 20px 0; }
.curve-svg { width: 100%; height: 100%; }
.curve-stat { display: flex; justify-content: space-between; align-items: baseline; margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--border-dim); }
.curve-stat .from { font-size: 13px; color: var(--text-dim); }
.curve-stat .to { font-size: 28px; font-weight: 500; color: var(--accent); letter-spacing: -1px; }

/* ─── PROBLEM ─── */
.problem-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; margin-top: 56px; }
.problem-stat { background: var(--surface); border: 1px solid var(--border-dim); border-radius: 14px; padding: 36px 32px; position: relative; }
.problem-stat::before { content: ''; position: absolute; top: 0; left: 24px; right: 24px; height: 1px; background: linear-gradient(90deg, transparent, var(--rose), transparent); opacity: 0.2; }
.problem-stat .num { font-size: 44px; font-weight: 300; letter-spacing: -2px; color: var(--rose); margin-bottom: 12px; }
.problem-stat .desc { font-size: 15px; line-height: 1.6; color: var(--text-mid); }
.problem-quote { margin-top: 48px; padding: 32px 40px; border-left: 2px solid var(--rose); background: var(--rose-dim); border-radius: 0 12px 12px 0; }
.problem-quote p { font-size: 18px; font-weight: 300; line-height: 1.6; color: var(--text); font-style: italic; }

/* ─── DEMAND / TAILWINDS ─── */
.tailwind-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; margin-top: 56px; }
.tailwind-card { background: var(--surface); border: 1px solid var(--border-dim); border-radius: 14px; padding: 36px 28px; position: relative; overflow: hidden; }
.tailwind-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--accent), transparent); opacity: 0.2; }
.tw-value { font-size: 40px; font-weight: 300; letter-spacing: -1.5px; color: var(--accent); margin-bottom: 4px; }
.tw-metric { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--text-dim); margin-bottom: 16px; }
.tw-desc { font-size: 14px; line-height: 1.6; color: var(--text-mid); }
.tailwind-narrative {
  margin-top: 40px; padding: 28px 36px; background: var(--accent-dim);
  border: 1px solid rgba(52,211,153,0.15); border-radius: 14px;
  font-size: 16px; line-height: 1.7; color: var(--text-mid);
}
.tailwind-narrative strong { color: var(--accent); font-weight: 500; }

/* ─── INSIGHT ─── */
.insight-block { margin-top: 48px; display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
.insight-card { background: var(--surface); border: 1px solid var(--border-dim); border-radius: 14px; padding: 40px; }
.insight-card.highlight { border-color: var(--accent); box-shadow: 0 0 60px rgba(52, 211, 153, 0.06); }
.insight-card .card-label { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 16px; }
.insight-card .card-label.neg { color: var(--rose); }
.insight-card .card-label.pos { color: var(--accent); }
.insight-card h3 { font-size: 18px; font-weight: 500; margin-bottom: 12px; }
.insight-card p { font-size: 15px; line-height: 1.7; color: var(--text-mid); }
.insight-arrow { display: flex; align-items: center; justify-content: center; margin-top: 40px; gap: 24px; }
.insight-arrow .line { flex: 1; height: 1px; background: linear-gradient(90deg, var(--border), var(--accent)); }
.insight-arrow .arrow-text { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 2px; color: var(--accent); text-transform: uppercase; white-space: nowrap; }
.insight-arrow .line-r { flex: 1; height: 1px; background: linear-gradient(90deg, var(--accent), var(--border)); }
.moat-argument { margin-top: 56px; }
.moat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 32px; }
.moat-card { background: var(--surface); border: 1px solid var(--border-dim); border-radius: 14px; padding: 32px 28px; }
.moat-card h4 { font-size: 15px; font-weight: 500; margin-bottom: 10px; color: var(--text); }
.moat-card p { font-size: 14px; line-height: 1.6; color: var(--text-mid); }
.moat-card .moat-label { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--accent); margin-bottom: 14px; }

/* ─── SOLUTION ─── */
.solution-hero { margin-top: 48px; display: grid; grid-template-columns: 2fr 1fr; gap: 64px; align-items: start; }
.solution-pipeline { display: flex; flex-direction: column; margin-top: 40px; }
.pipeline-step { display: flex; align-items: stretch; gap: 24px; min-height: 80px; }
.pipeline-track { display: flex; flex-direction: column; align-items: center; width: 32px; flex-shrink: 0; }
.pipeline-dot { width: 12px; height: 12px; border-radius: 50%; background: var(--accent); border: 2px solid var(--bg-slide); box-shadow: 0 0 12px var(--accent-glow); flex-shrink: 0; margin-top: 4px; }
.pipeline-line { width: 1px; flex: 1; background: linear-gradient(180deg, var(--accent), var(--border)); min-height: 40px; }
.pipeline-content { padding-bottom: 32px; }
.pipeline-content h4 { font-family: 'Space Mono', monospace; font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--accent); margin-bottom: 6px; }
.pipeline-content p { font-size: 14px; line-height: 1.6; color: var(--text-mid); }
.solution-numbers { display: flex; flex-direction: column; gap: 24px; }
.sol-num { background: var(--surface); border: 1px solid var(--border-dim); border-radius: 12px; padding: 24px 28px; text-align: center; }
.sol-num .value { font-size: 36px; font-weight: 300; letter-spacing: -1.5px; color: var(--accent); }
.sol-num .unit { font-size: 12px; color: var(--text-dim); margin-top: 4px; font-family: 'Space Mono', monospace; letter-spacing: 1px; text-transform: uppercase; }

/* ─── PRODUCT ─── */
.product-categories { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 48px; }
.cat-card { background: var(--surface); border: 1px solid var(--border-dim); border-radius: 12px; padding: 28px 24px; transition: border-color 0.3s; }
.cat-card:hover { border-color: var(--accent); }
.cat-card .cat-name { font-size: 15px; font-weight: 500; margin-bottom: 8px; }
.cat-card .cat-stats { font-family: 'Space Mono', monospace; font-size: 11px; color: var(--text-dim); }
.product-examples { margin-top: 40px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.example-card { border-radius: 12px; padding: 28px 24px; }
.example-card.critical { background: var(--rose-dim); border: 1px solid rgba(251,113,133,0.2); }
.example-card.supplement { background: var(--blue-dim); border: 1px solid rgba(96,165,250,0.2); }
.example-card.lifestyle { background: var(--purple-dim); border: 1px solid rgba(167,139,250,0.2); }
.example-type { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 12px; }
.example-card.critical .example-type { color: var(--rose); }
.example-card.supplement .example-type { color: var(--blue); }
.example-card.lifestyle .example-type { color: var(--purple); }
.example-card h4 { font-size: 14px; font-weight: 500; margin-bottom: 8px; line-height: 1.4; }
.example-card p { font-size: 13px; line-height: 1.5; color: var(--text-mid); }
.example-gene { margin-top: 12px; font-family: 'Space Mono', monospace; font-size: 11px; color: var(--text-dim); }

/* ─── CONVERSATION UI ─── */
.product-dual { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; margin-top: 48px; align-items: start; }
.product-mode-label { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--border-dim); }
.product-mode-label.push { color: var(--accent); }
.product-mode-label.pull { color: var(--blue); }
.action-feed { background: var(--surface); border: 1px solid var(--border-dim); border-radius: 16px; padding: 32px; }
.action-item { padding: 16px 0; border-bottom: 1px solid var(--border-dim); }
.action-item:last-child { border-bottom: none; }
.action-item-header { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.action-badge { font-family: 'Space Mono', monospace; font-size: 9px; letter-spacing: 1px; text-transform: uppercase; padding: 3px 8px; border-radius: 4px; white-space: nowrap; }
.action-badge.critical { background: var(--rose-dim); color: var(--rose); }
.action-badge.supplement { background: var(--blue-dim); color: var(--blue); }
.action-badge.nutrition { background: var(--accent-dim); color: var(--accent); }
.action-badge.lifestyle { background: var(--purple-dim); color: var(--purple); }
.action-badge.monitoring { background: rgba(251,191,36,0.1); color: #fbbf24; }
.action-item h4 { font-size: 14px; font-weight: 500; line-height: 1.4; }
.action-item p { font-size: 13px; line-height: 1.5; color: var(--text-mid); margin-top: 4px; }
.action-item .action-gene { font-family: 'Space Mono', monospace; font-size: 11px; color: var(--text-dim); margin-top: 6px; }
.action-feed-footer { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--border-dim); font-family: 'Space Mono', monospace; font-size: 11px; color: var(--text-dim); text-align: center; }
.action-feed-footer span { color: var(--accent); }
.convo-window { background: var(--surface); border: 1px solid var(--border-dim); border-radius: 16px; padding: 32px; }
.convo-msg { margin-bottom: 24px; }
.convo-msg:last-child { margin-bottom: 0; }
.convo-label { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 8px; }
.convo-label.user { color: var(--text-dim); }
.convo-label.ai { color: var(--blue); }
.convo-text { font-size: 14px; line-height: 1.75; color: var(--text); }
.convo-text .cite { font-family: 'Space Mono', monospace; font-size: 10px; color: var(--accent); background: var(--accent-dim); padding: 2px 6px; border-radius: 4px; white-space: nowrap; }
.convo-text .gene-ref { font-family: 'Space Mono', monospace; font-size: 11px; color: var(--blue); }
.convo-text em { color: var(--text); font-style: italic; }
.convo-divider { height: 1px; background: var(--border-dim); margin: 0 0 24px 0; }
.convo-followups { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 16px; }
.convo-chip { font-family: 'Space Mono', monospace; font-size: 10px; color: var(--text-mid); background: var(--bg); border: 1px solid var(--border-dim); padding: 7px 12px; border-radius: 100px; letter-spacing: 0.3px; }
.product-categories-compact { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 40px; }
.cat-chip { font-family: 'Space Mono', monospace; font-size: 11px; color: var(--text-mid); background: var(--surface); border: 1px solid var(--border-dim); padding: 10px 16px; border-radius: 8px; letter-spacing: 0.3px; }
.cat-chip .cat-chip-count { color: var(--accent); margin-left: 6px; }

/* ─── VERTICALS GRID ─── */
.verticals-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 40px; }
.vertical-card { background: var(--surface); border: 1px solid var(--border-dim); border-radius: 12px; padding: 20px; transition: border-color 0.3s; }
.vertical-card:hover { border-color: var(--accent); }
.vertical-card .v-name { font-size: 15px; font-weight: 500; margin-bottom: 4px; }
.vertical-card .v-desc { font-size: 12px; color: var(--text-mid); line-height: 1.5; margin-bottom: 10px; }
.vertical-card .v-url { font-family: 'Space Mono', monospace; font-size: 10px; color: var(--accent); letter-spacing: 0.3px; opacity: 0.7; }
.vertical-card.own { border-color: rgba(52,211,153,0.2); }
.vertical-card .v-badge { font-family: 'Space Mono', monospace; font-size: 9px; letter-spacing: 1px; text-transform: uppercase; padding: 3px 7px; border-radius: 4px; display: inline-block; margin-bottom: 10px; }
.vertical-card .v-badge.partner { background: var(--blue-dim); color: var(--blue); }
.vertical-card .v-badge.showcase { background: var(--accent-dim); color: var(--accent); }
.verticals-count { margin-top: 24px; text-align: center; font-family: 'Space Mono', monospace; font-size: 12px; color: var(--text-dim); }
.verticals-count span { color: var(--accent); font-weight: 700; font-size: 14px; }

/* ─── PARTNERS ─── */
.partners-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 24px; margin-top: 48px; }
.partner-card { background: var(--surface); border: 1px solid var(--border-dim); border-radius: 14px; padding: 40px 24px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; min-height: 160px; transition: border-color 0.3s; }
.partner-card:hover { border-color: var(--accent); }
.partner-logo-placeholder { width: 80px; height: 80px; border-radius: 12px; background: var(--bg); border: 1px dashed var(--border); display: flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.partner-logo-placeholder span { font-family: 'Space Mono', monospace; font-size: 10px; color: var(--text-dim); letter-spacing: 1px; }
.partner-name { font-size: 14px; font-weight: 500; margin-bottom: 4px; }
.partner-type { font-family: 'Space Mono', monospace; font-size: 10px; color: var(--text-dim); letter-spacing: 1px; text-transform: uppercase; }
.partners-note { margin-top: 32px; text-align: center; font-size: 14px; color: var(--text-dim); font-style: italic; }

/* ─── ARCHITECTURE ─── */
.arch-layers { margin-top: 48px; display: flex; flex-direction: column; }
.arch-layer { display: grid; grid-template-columns: 200px 1fr; gap: 40px; padding: 32px 0; border-bottom: 1px solid var(--border-dim); align-items: start; }
.arch-layer:last-child { border-bottom: none; }
.arch-layer-num { font-family: 'Space Mono', monospace; font-size: 32px; font-weight: 700; color: var(--border); }
.arch-layer-name { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--accent); margin-top: 8px; }
.arch-layer-desc h3 { font-size: 20px; font-weight: 400; margin-bottom: 10px; }
.arch-layer-desc p { font-size: 15px; line-height: 1.7; color: var(--text-mid); max-width: 700px; }
.arch-badge { display: inline-block; margin-top: 14px; padding: 5px 14px; border-radius: 20px; font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; }
.arch-badge.deterministic { background: var(--accent-dim); color: var(--accent); border: 1px solid rgba(52,211,153,0.2); }
.arch-badge.optional { background: var(--amber-dim); color: var(--amber); border: 1px solid rgba(251,191,36,0.2); }
.arch-badge.live { background: var(--blue-dim); color: var(--blue); border: 1px solid rgba(96,165,250,0.2); }

/* ─── MCP VISUAL ─── */
.mcp-compact { margin-top: 40px; display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.mcp-visual { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 28px; font-family: 'Space Mono', monospace; font-size: 12px; line-height: 2.1; color: var(--text-dim); position: relative; overflow: hidden; }
.mcp-visual::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--accent), transparent); opacity: 0.3; }
.mcp-visual .comment { opacity: 0.5; }
.mcp-visual .keyword { color: var(--accent); }
.mcp-visual .string { color: var(--amber); }
.mcp-visual .fn { color: var(--blue); }
.mcp-compact-points { display: flex; flex-direction: column; gap: 20px; justify-content: center; }
.mcp-point { display: flex; gap: 16px; align-items: start; }
.mcp-point .bullet { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); margin-top: 7px; flex-shrink: 0; }
.mcp-point p { font-size: 15px; line-height: 1.6; color: var(--text-mid); }
.mcp-point strong { color: var(--text); font-weight: 500; }
.mcp-differentiator { margin-top: 40px; padding: 28px 36px; border-left: 2px solid var(--accent); background: var(--accent-dim); border-radius: 0 12px 12px 0; }
.mcp-differentiator p { font-size: 17px; font-weight: 300; line-height: 1.6; color: var(--text); }
.mcp-differentiator p em { font-style: normal; color: var(--accent); font-weight: 500; }

/* ─── DEPLOYMENT ─── */
.platform-arch { margin-top: 56px; }
.arch-side { padding: 40px 36px; }
.arch-side.geneops { background: var(--surface); border: 1px solid var(--border); border-radius: 20px; overflow: hidden; }
.arch-core { border-radius: 12px; padding: 20px 24px; text-align: center; margin-bottom: 28px; }
.arch-side.geneops .arch-core { background: linear-gradient(135deg, var(--accent-dim), rgba(52,211,153,0.03)); border: 1px solid var(--accent); box-shadow: 0 0 40px rgba(52,211,153,0.06); }
.arch-core h4 { font-family: 'Space Mono', monospace; font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase; }
.arch-side.geneops .arch-core h4 { color: var(--accent); }
.arch-core p { font-size: 11px; color: var(--text-dim); margin-top: 4px; line-height: 1.4; }
.arch-connector { display: flex; justify-content: center; margin-bottom: 20px; }
.arch-connector .vline { width: 1px; height: 20px; }
.arch-side.geneops .arch-connector .vline { background: linear-gradient(180deg, var(--accent), var(--border)); }
.arch-row-label { font-family: 'Space Mono', monospace; font-size: 9px; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 10px; }
.arch-side.geneops .arch-row-label.b2c { color: var(--amber); }
.arch-side.geneops .arch-row-label.b2b { color: var(--blue); }
.arch-nodes { display: grid; gap: 8px; margin-bottom: 20px; }
.arch-nodes.five { grid-template-columns: repeat(5, 1fr); }
.arch-nodes.four { grid-template-columns: repeat(4, 1fr); }
.arch-nodes.three { grid-template-columns: repeat(3, 1fr); }
.arch-node { border-radius: 8px; padding: 10px 8px; text-align: center; font-size: 10px; line-height: 1.3; }
.arch-side.geneops .arch-node { background: rgba(52,211,153,0.04); border: 1px solid var(--border-dim); color: var(--text-mid); transition: border-color 0.3s; }
.arch-side.geneops .arch-node:hover { border-color: var(--accent); }
.arch-node strong { display: block; font-weight: 500; margin-bottom: 2px; font-size: 11px; }

/* ─── BUSINESS MODEL ─── */
.biz-model-top { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; margin-top: 48px; }
.market-col-title { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--accent); margin-bottom: 20px; padding-bottom: 12px; border-bottom: 1px solid var(--border-dim); }
.market-item { padding: 20px 0; border-bottom: 1px solid var(--border-dim); }
.market-item:last-child { border-bottom: none; }
.market-item-header { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 6px; }
.market-item h4 { font-size: 15px; font-weight: 500; }
.market-item .market-val { font-size: 18px; font-weight: 300; color: var(--accent); letter-spacing: -0.5px; }
.market-item p { font-size: 13px; line-height: 1.5; color: var(--text-mid); }
.biz-pricing { margin-top: 48px; }
.biz-pricing-title { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--accent); margin-bottom: 20px; padding-bottom: 12px; border-bottom: 1px solid var(--border-dim); }
.biz-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px; }
.biz-card { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 32px 28px; position: relative; overflow: hidden; }
.biz-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; }
.biz-card.free::before { background: linear-gradient(90deg, transparent, var(--text-dim), transparent); opacity: 0.2; }
.biz-card.sub::before { background: linear-gradient(90deg, transparent, var(--accent), transparent); opacity: 0.4; }
.biz-card.lifetime::before { background: linear-gradient(90deg, transparent, var(--amber), transparent); opacity: 0.3; }
.biz-card.sub { border-color: var(--accent); box-shadow: 0 0 60px rgba(52,211,153,0.06); }
.biz-tier-label { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 12px; }
.biz-card.free .biz-tier-label { color: var(--text-dim); }
.biz-card.sub .biz-tier-label { color: var(--accent); }
.biz-card.lifetime .biz-tier-label { color: var(--amber); }
.biz-price { font-size: 40px; font-weight: 300; letter-spacing: -2px; margin-bottom: 2px; }
.biz-card.free .biz-price { color: var(--text-mid); }
.biz-card.sub .biz-price { color: var(--accent); }
.biz-card.lifetime .biz-price { color: var(--amber); }
.biz-price-label { font-size: 12px; color: var(--text-dim); margin-bottom: 20px; }
.biz-features { display: flex; flex-direction: column; gap: 8px; }
.biz-feature { font-size: 12px; line-height: 1.5; color: var(--text-mid); padding-left: 16px; position: relative; }
.biz-feature::before { content: '\2192'; position: absolute; left: 0; color: var(--text-dim); font-size: 10px; }
.biz-b2b-row { margin-top: 20px; padding: 24px 28px; background: var(--surface); border: 1px solid var(--border); border-radius: 14px; display: grid; grid-template-columns: auto 1fr; gap: 28px; align-items: center; }
.biz-b2b-label { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--blue); }
.biz-b2b-desc { font-size: 13px; line-height: 1.5; color: var(--text-mid); }
.rev-flywheel { margin-top: 32px; padding: 24px 28px; text-align: center; background: var(--surface); border: 1px solid var(--border); border-radius: 14px; position: relative; }
.rev-flywheel::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--accent), transparent); opacity: 0.3; }
.rev-flywheel p { font-size: 14px; line-height: 1.7; color: var(--text-mid); }
.rev-flywheel strong { color: var(--accent); font-weight: 500; }

/* ─── TEAM ─── */
.team-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; margin-top: 48px; }
.team-card { background: var(--surface); border: 1px solid var(--border-dim); border-radius: 16px; padding: 40px; position: relative; overflow: hidden; }
.team-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--accent), transparent); opacity: 0.3; }
.team-role { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--accent); margin-bottom: 16px; }
.team-name { font-size: 24px; font-weight: 500; margin-bottom: 16px; }
.team-points { display: flex; flex-direction: column; gap: 10px; }
.team-point { font-size: 14px; line-height: 1.6; color: var(--text-mid); padding-left: 16px; position: relative; }
.team-point::before { content: ''; position: absolute; left: 0; top: 9px; width: 6px; height: 6px; border-radius: 50%; background: var(--border); }
.team-point strong { color: var(--text); font-weight: 500; }
.team-thesis { margin-top: 40px; padding: 28px 36px; border-left: 2px solid var(--accent); background: var(--accent-dim); border-radius: 0 12px 12px 0; }
.team-thesis p { font-size: 16px; font-weight: 300; line-height: 1.7; color: var(--text); }
.team-thesis strong { color: var(--accent); font-weight: 500; }

/* ─── TRACTION ─── */
.traction-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; margin-top: 48px; }
.traction-col h3 { font-family: 'Space Mono', monospace; font-size: 12px; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 24px; padding-bottom: 16px; border-bottom: 1px solid var(--border-dim); }
.traction-col.live h3 { color: var(--accent); }
.traction-col.next h3 { color: var(--text-dim); }
.traction-items { display: flex; flex-direction: column; gap: 16px; }
.traction-item { display: flex; gap: 14px; align-items: start; }
.traction-dot { width: 8px; height: 8px; border-radius: 50%; margin-top: 6px; flex-shrink: 0; }
.traction-col.live .traction-dot { background: var(--accent); box-shadow: 0 0 8px var(--accent-glow); }
.traction-col.next .traction-dot { background: var(--border); border: 1px solid var(--text-dim); }
.traction-item p { font-size: 15px; line-height: 1.5; color: var(--text-mid); }
.traction-item strong { color: var(--text); font-weight: 500; }

/* ─── ASK ─── */
.ask-amount { font-size: 72px; font-weight: 300; letter-spacing: -3px; color: var(--accent); margin-bottom: 8px; }
.ask-purpose { font-size: 16px; color: var(--text-dim); margin-bottom: 48px; max-width: 800px; }
.ask-allocation { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.ask-item { background: var(--surface); border: 1px solid var(--border-dim); border-radius: 12px; padding: 28px 24px; text-align: center; }
.ask-item .pct { font-size: 32px; font-weight: 300; color: var(--accent); letter-spacing: -1px; margin-bottom: 8px; }
.ask-item .alloc-label { font-size: 13px; color: var(--text-mid); line-height: 1.4; }

/* ─── CLOSE ─── */
.close-slide { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(52,211,153,0.04) 0%, transparent 70%); }
.close-logo { font-family: 'Space Mono', monospace; font-size: 15px; font-weight: 700; letter-spacing: 4px; color: var(--accent); text-transform: uppercase; margin-bottom: 40px; }
.close-tagline { font-size: 20px; color: var(--text-mid); margin-top: 32px; font-weight: 300; max-width: 600px; }
.close-contact { margin-top: 56px; display: flex; gap: 32px; }
.close-contact a { font-family: 'Space Mono', monospace; font-size: 13px; letter-spacing: 1px; color: var(--text-dim); text-decoration: none; transition: color 0.3s; }
.close-contact a:hover { color: var(--accent); }

/* ─── SOURCES ─── */
.sources-list { margin-top: 40px; display: flex; flex-direction: column; gap: 12px; }
.source-item { display: flex; gap: 16px; align-items: baseline; padding: 12px 0; border-bottom: 1px solid var(--border-dim); }
.source-item:last-child { border-bottom: none; }
.source-num { font-family: 'Space Mono', monospace; font-size: 12px; color: var(--accent); flex-shrink: 0; min-width: 24px; font-weight: 700; }
.source-text { font-size: 13px; line-height: 1.5; color: var(--text-mid); }
.source-text a { color: var(--text-dim); text-decoration: none; word-break: break-all; transition: color 0.2s; }
.source-text a:hover { color: var(--accent); }

/* ─── STICKY HEADER ─── */
.sticky-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 40px; height: 52px;
  background: rgba(6, 10, 14, 0.85);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border-dim);
  transition: opacity 0.4s ease, transform 0.4s ease;
}
/* In pitch mode, header starts hidden and reveals on scroll */
html.pitch .sticky-header { opacity: 0; transform: translateY(-100%); }
html.pitch .sticky-header.visible { opacity: 1; transform: translateY(0); }
/* In landing mode, header is always visible */
html.landing .sticky-header { opacity: 1; transform: translateY(0); }

.sticky-left { display: flex; align-items: center; gap: 20px; }
.sticky-logo { font-family: 'Space Mono', monospace; font-size: 12px; font-weight: 700; letter-spacing: 3px; color: var(--accent); text-transform: uppercase; text-decoration: none; }
.sticky-divider { width: 1px; height: 16px; background: var(--border); }
.sticky-context { font-size: 13px; color: var(--text-dim); transition: color 0.3s; }
.sticky-actions { display: flex; align-items: center; gap: 6px; }
.sticky-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 14px; border-radius: 6px;
  font-family: 'DM Sans', sans-serif; font-size: 12px;
  color: var(--text-dim); background: transparent;
  border: 1px solid transparent;
  cursor: pointer; transition: all 0.2s; text-decoration: none;
}
.sticky-btn:hover { color: var(--text-mid); background: var(--surface); border-color: var(--border-dim); }
.sticky-btn svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; }
.sticky-btn.primary { color: var(--accent); border-color: rgba(52,211,153,0.2); background: var(--accent-dim); }
.sticky-btn.primary:hover { background: rgba(52,211,153,0.15); border-color: rgba(52,211,153,0.3); }

/* ─── LABELED NAV ─── */
.nav-labeled {
  position: fixed; right: 28px; top: 50%; transform: translateY(-50%);
  display: flex; flex-direction: column; gap: 2px; z-index: 100;
}
.nav-item {
  display: flex; align-items: center; gap: 10px;
  justify-content: flex-end;
  padding: 5px 0; cursor: pointer; border: none; background: none;
  text-decoration: none;
}
.nav-label {
  font-family: 'Space Mono', monospace; font-size: 9px;
  letter-spacing: 1px; text-transform: uppercase;
  color: var(--text-dim); opacity: 0.3; white-space: nowrap;
  transition: all 0.3s ease;
}
.nav-item:hover .nav-label { opacity: 0.7; }
.nav-item.active .nav-label { color: var(--accent); opacity: 1; }
.nav-pip {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--border); flex-shrink: 0;
  transition: all 0.3s ease;
}
.nav-item:hover .nav-pip { background: var(--text-dim); transform: scale(1.2); }
.nav-item.active .nav-pip { background: var(--accent); box-shadow: 0 0 8px var(--accent-glow); transform: scale(1.5); }

/* ─── LANDING PAGE SECTIONS ─── */
.section {
  padding: 120px 80px;
  position: relative;
}
.section-inner { max-width: 1200px; width: 100%; margin: 0 auto; }
.section-label { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--accent); margin-bottom: 20px; }
.section-dark { background: var(--bg-slide); }

.stat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; margin-top: 48px; }
.stat-box { background: var(--surface); border: 1px solid var(--border-dim); border-radius: 14px; padding: 36px 28px; text-align: center; position: relative; overflow: hidden; }
.stat-box::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--accent), transparent); opacity: 0.2; }
.stat-box .stat-value { font-size: 44px; font-weight: 300; letter-spacing: -2px; color: var(--accent); margin-bottom: 8px; }
.stat-box .stat-label { font-size: 13px; color: var(--text-mid); line-height: 1.4; }

.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 48px; }
.feature-card { background: var(--surface); border: 1px solid var(--border-dim); border-radius: 14px; padding: 36px 28px; position: relative; overflow: hidden; }
.feature-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--accent), transparent); opacity: 0.15; }
.feature-card .feature-num { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--accent); margin-bottom: 16px; }
.feature-card h3 { font-size: 17px; font-weight: 500; margin-bottom: 10px; }
.feature-card p { font-size: 14px; line-height: 1.6; color: var(--text-mid); }

.cta-section { text-align: center; padding: 120px 80px; background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(52,211,153,0.04) 0%, transparent 70%); }
.cta-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 32px; border-radius: 8px;
  font-family: 'DM Sans', sans-serif; font-size: 16px; font-weight: 500;
  color: var(--bg); background: var(--accent);
  border: none; cursor: pointer; text-decoration: none;
  transition: all 0.2s;
}
.cta-btn:hover { background: #4ade80; }
.cta-btn-outline {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 32px; border-radius: 8px;
  font-family: 'DM Sans', sans-serif; font-size: 16px; font-weight: 500;
  color: var(--accent); background: transparent;
  border: 1px solid rgba(52,211,153,0.3);
  cursor: pointer; text-decoration: none;
  transition: all 0.2s;
}
.cta-btn-outline:hover { background: var(--accent-dim); border-color: rgba(52,211,153,0.5); }

/* ─── ANIMATIONS ─── */
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes fadeUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }
.reveal { opacity: 0; transform: translateY(20px); transition: opacity 0.8s ease, transform 0.8s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }

/* ─── RESPONSIVE ─── */
@media (max-width: 1024px) {
  .slide, .section { padding: 60px 40px; }
  h1 { font-size: 44px; } h2 { font-size: 32px; }
  .cover h1 { font-size: 48px; }
  .moment-grid, .insight-block, .mcp-compact, .traction-grid, .biz-model-top, .team-grid { grid-template-columns: 1fr; }
  .biz-grid { grid-template-columns: 1fr; }
  .problem-stats, .tailwind-grid, .moat-grid, .feature-grid { grid-template-columns: 1fr; }
  .product-categories { grid-template-columns: 1fr 1fr; }
  .product-examples { grid-template-columns: 1fr; }
  .product-dual { grid-template-columns: 1fr; }
  .partners-grid { grid-template-columns: repeat(3, 1fr); }
  .verticals-grid { grid-template-columns: repeat(2, 1fr); }
  .convo-window { padding: 24px; }
  .action-feed { padding: 24px; }
  .ask-allocation { grid-template-columns: 1fr 1fr; }
  .stat-grid { grid-template-columns: 1fr 1fr; }
  .arch-nodes.five { grid-template-columns: repeat(3, 1fr); }
  .arch-nodes.four { grid-template-columns: repeat(2, 1fr); }
  .nav-labeled { display: none; }
  .sticky-header { padding: 0 20px; }
  .cta-section { padding: 80px 40px; }
}

@media (max-width: 640px) {
  .slide, .section { padding: 40px 20px; }
  h1 { font-size: 32px; } h2 { font-size: 26px; }
  .cover h1 { font-size: 36px; }
  .stat-grid { grid-template-columns: 1fr; }
  .cover-meta { flex-direction: column; gap: 16px; }
  .close-contact { flex-direction: column; gap: 16px; }
  .solution-hero { grid-template-columns: 1fr; }
  .verticals-grid { grid-template-columns: 1fr; }
  .partners-grid { grid-template-columns: 1fr 1fr; }
  .ask-allocation { grid-template-columns: 1fr; }
}
