/* ============================================================
   FORIS PRESENTATION — Dark Theme
   Intentional deviation from default Cloudflare warm palette.
   
   Dark navy background, Cloudflare orange accents, white text.
   Designed for: Neet (Clement Wong) → Foris / Crypto.com
   May 2026
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&family=DM+Mono:wght@400;500&display=swap');

/* ── VARIABLES ────────────────────────────────────────────── */
:root {
  /* Dark palette */
  --cf-bg-page:    #0d1117;
  --cf-bg-content: #1a1a2e;
  --cf-bg-card:    #16213e;
  --cf-bg-card2:   #0f3460;

  /* Text */
  --cf-text:       #f0f0f0;
  --cf-text-muted: #a0a8b8;
  --cf-text-dim:   #6b7280;

  /* Cloudflare orange accents */
  --cf-orange:     #F38020;
  --cf-orange-bright: #FF6633;
  --cf-orange-muted: rgba(243, 128, 32, 0.15);
  --cf-orange-border: rgba(243, 128, 32, 0.3);

  /* Semantic */
  --cf-blue:   #3b82f6;
  --cf-green:  #22c55e;
  --cf-purple: #a855f7;
  --cf-red:    #ef4444;
  --cf-yellow: #f59e0b;

  /* Borders */
  --cf-border: rgba(255,255,255,0.08);
  --cf-border-accent: rgba(243,128,32,0.25);
}

/* ── RESET & BASE ─────────────────────────────────────────── */
.reveal-viewport {
  background: var(--cf-bg-page);
}

.reveal {
  font-family: 'DM Sans', 'Segoe UI', sans-serif;
  font-size: 18pt;
  color: var(--cf-text);
}

.reveal .slides section {
  text-align: left;
  box-sizing: border-box;
  padding: 48px 60px;
  height: 100%;
}

/* Remove default reveal margins */
.reveal .slides {
  text-align: left;
}

/* ── TYPOGRAPHY ───────────────────────────────────────────── */
.reveal h1 {
  font-family: 'DM Sans', sans-serif;
  font-size: 42pt;
  font-weight: 700;
  color: var(--cf-text);
  line-height: 1.15;
  margin: 0 0 12px 0;
  text-transform: none;
  letter-spacing: -0.5px;
}

.reveal h2 {
  font-family: 'DM Sans', sans-serif;
  font-size: 28pt;
  font-weight: 600;
  color: var(--cf-text);
  line-height: 1.2;
  margin: 0 0 10px 0;
  text-transform: none;
  letter-spacing: -0.3px;
}

.reveal h3 {
  font-family: 'DM Sans', sans-serif;
  font-size: 18pt;
  font-weight: 600;
  color: var(--cf-orange);
  line-height: 1.3;
  margin: 0 0 8px 0;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.reveal p {
  font-size: 14pt;
  line-height: 1.65;
  color: var(--cf-text-muted);
  margin: 0 0 12px 0;
}

.reveal ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.reveal ul li {
  font-size: 14pt;
  line-height: 1.7;
  color: var(--cf-text-muted);
  padding-left: 20px;
  position: relative;
  margin-bottom: 6px;
}

.reveal ul li::before {
  content: '→';
  color: var(--cf-orange);
  position: absolute;
  left: 0;
  font-weight: 600;
}

.reveal strong {
  color: var(--cf-text);
  font-weight: 600;
}

.reveal em {
  color: var(--cf-orange);
  font-style: normal;
  font-weight: 500;
}

code, .mono {
  font-family: 'DM Mono', 'Courier New', monospace;
  font-size: 12pt;
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 4px;
  padding: 2px 6px;
  color: var(--cf-orange);
}

/* ── ORANGE ACCENT LINE ───────────────────────────────────── */
.accent-bar {
  width: 56px;
  height: 4px;
  background: linear-gradient(90deg, var(--cf-orange), var(--cf-orange-bright));
  border-radius: 2px;
  margin-bottom: 20px;
}

/* ── SLIDE LABEL / EYEBROW ────────────────────────────────── */
.slide-label {
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  font-weight: 500;
  color: var(--cf-orange);
  text-transform: uppercase;
  letter-spacing: 2.5px;
  margin-bottom: 16px;
  opacity: 0.9;
}

/* ── SUBTITLE TEXT ────────────────────────────────────────── */
.subtitle {
  font-size: 16pt;
  color: var(--cf-text-muted);
  font-style: italic;
  margin-bottom: 24px;
  line-height: 1.4;
}

/* ── QUOTE / KEY LINE ─────────────────────────────────────── */
.quote-line {
  font-size: 15pt;
  color: var(--cf-orange);
  font-style: italic;
  border-left: 3px solid var(--cf-orange);
  padding-left: 16px;
  margin: 16px 0;
  line-height: 1.5;
}

.big-quote {
  font-size: 22pt;
  font-weight: 500;
  color: var(--cf-text);
  line-height: 1.35;
  margin: 20px 0;
  text-align: center;
}

/* ── CARDS ────────────────────────────────────────────────── */
.card {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 10px;
  padding: 20px 24px;
  margin-bottom: 12px;
}

.card.accent {
  border-left: 3px solid var(--cf-orange);
  border-color: var(--cf-border-accent);
  background: var(--cf-orange-muted);
}

.card-title {
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  font-weight: 500;
  color: var(--cf-orange);
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 8px;
}

.card h4 {
  font-size: 14pt;
  font-weight: 600;
  color: var(--cf-text);
  margin: 0 0 6px 0;
}

.card p {
  font-size: 12pt;
  color: var(--cf-text-muted);
  margin: 0;
}

/* ── STAT CARDS ───────────────────────────────────────────── */
.stat-card {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 10px;
  padding: 18px 20px;
  text-align: center;
}

.stat-number {
  font-family: 'DM Mono', monospace;
  font-size: 26pt;
  font-weight: 700;
  color: var(--cf-orange);
  line-height: 1;
  margin-bottom: 6px;
}

.stat-label {
  font-size: 11pt;
  color: var(--cf-text-muted);
  line-height: 1.4;
}

/* ── NUMBERED LIST ────────────────────────────────────────── */
.numbered-list {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: item;
}

.numbered-list li {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 12px;
  padding-left: 0;
}

.numbered-list li::before {
  display: none;
}

.num-circle {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--cf-orange);
  color: white;
  font-family: 'DM Mono', monospace;
  font-size: 11pt;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
}

.num-content {
  flex: 1;
}

.num-title {
  font-size: 13pt;
  font-weight: 600;
  color: var(--cf-text);
  margin-bottom: 2px;
}

.num-desc {
  font-size: 12pt;
  color: var(--cf-text-muted);
  line-height: 1.5;
}

/* ── COLUMNS ──────────────────────────────────────────────── */
.cols-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

.cols-3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 18px;
}

.col-divider {
  border-left: 1px solid var(--cf-border);
  padding-left: 24px;
}

/* ── LAYER DIAGRAM ────────────────────────────────────────── */
.layer-stack {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 16px 0;
}

.layer-block {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 10px;
  padding: 16px 24px;
  display: flex;
  align-items: center;
  gap: 20px;
}

.layer-block.observe {
  border-color: rgba(168, 85, 247, 0.4);
  background: rgba(168, 85, 247, 0.07);
}

.layer-block.scope {
  border-color: rgba(243, 128, 32, 0.35);
  background: rgba(243, 128, 32, 0.07);
}

.layer-block.connect {
  border-color: rgba(59, 130, 246, 0.4);
  background: rgba(59, 130, 246, 0.07);
}

.layer-icon {
  font-size: 28pt;
  width: 48px;
  text-align: center;
  flex-shrink: 0;
}

.layer-info {
  flex: 1;
}

.layer-name {
  font-family: 'DM Mono', monospace;
  font-size: 10pt;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 3px;
}

.layer-block.observe .layer-name { color: var(--cf-purple); }
.layer-block.scope .layer-name { color: var(--cf-orange); }
.layer-block.connect .layer-name { color: var(--cf-blue); }

.layer-desc {
  font-size: 12pt;
  color: var(--cf-text-muted);
  line-height: 1.4;
}

/* ── FLOW DIAGRAM ─────────────────────────────────────────── */
.flow-steps {
  display: flex;
  align-items: flex-start;
  gap: 0;
  margin: 16px 0;
  overflow: hidden;
}

.flow-step {
  flex: 1;
  text-align: center;
  position: relative;
}

.flow-step:not(:last-child)::after {
  content: '→';
  position: absolute;
  right: -8px;
  top: 20px;
  color: var(--cf-orange);
  font-size: 14pt;
  font-weight: 700;
  z-index: 2;
}

.flow-bubble {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--cf-orange);
  color: white;
  font-family: 'DM Mono', monospace;
  font-size: 13pt;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 8px;
}

.flow-step.highlight .flow-bubble {
  background: var(--cf-blue);
  box-shadow: 0 0 16px rgba(59, 130, 246, 0.4);
}

.flow-step.highlight2 .flow-bubble {
  background: var(--cf-red);
  box-shadow: 0 0 16px rgba(239, 68, 68, 0.4);
}

.flow-label {
  font-size: 10pt;
  color: var(--cf-text-muted);
  line-height: 1.3;
}

.flow-tag {
  font-family: 'DM Mono', monospace;
  font-size: 8pt;
  color: var(--cf-orange);
  font-weight: 600;
  display: block;
  margin-top: 3px;
}

/* ── MECHANISM PANELS ─────────────────────────────────────── */
.mechanism-row {
  display: flex;
  gap: 16px;
  margin: 12px 0;
}

.mechanism {
  flex: 1;
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 10px;
  padding: 16px;
}

.mech-num {
  font-family: 'DM Mono', monospace;
  font-size: 22pt;
  font-weight: 700;
  color: var(--cf-orange);
  line-height: 1;
  margin-bottom: 6px;
}

.mech-title {
  font-size: 11pt;
  font-weight: 700;
  color: var(--cf-text);
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.mech-desc {
  font-size: 11pt;
  color: var(--cf-text-muted);
  line-height: 1.5;
}

/* ── COMPARISON (split screen) ────────────────────────────── */
.split-compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.compare-box {
  background: var(--cf-bg-card);
  border-radius: 10px;
  padding: 20px;
  border: 1px solid var(--cf-border);
}

.compare-box.bad {
  border-color: rgba(239, 68, 68, 0.3);
  background: rgba(239, 68, 68, 0.05);
}

.compare-box.good {
  border-color: rgba(34, 197, 94, 0.3);
  background: rgba(34, 197, 94, 0.05);
}

.compare-label {
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 12px;
}

.compare-box.bad .compare-label { color: var(--cf-red); }
.compare-box.good .compare-label { color: var(--cf-green); }

/* ── CHECKLIST ────────────────────────────────────────────── */
.checklist {
  list-style: none;
  padding: 0;
  margin: 0;
}

.checklist li {
  font-size: 13pt;
  color: var(--cf-text);
  padding-left: 28px;
  position: relative;
  margin-bottom: 10px;
  line-height: 1.5;
}

.checklist li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--cf-green);
  font-weight: 700;
  font-size: 14pt;
}

.checklist li span.sub {
  display: block;
  font-size: 11pt;
  color: var(--cf-text-muted);
  margin-top: 2px;
}

/* ── GUARDRAIL GRID ───────────────────────────────────────── */
.guardrail-group {
  margin-bottom: 14px;
}

.guardrail-group-title {
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  font-weight: 700;
  color: var(--cf-orange);
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 8px;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--cf-border-accent);
}

.guardrail-items {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.guardrail-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 12pt;
  color: var(--cf-text-muted);
}

.g-num {
  font-family: 'DM Mono', monospace;
  font-size: 10pt;
  font-weight: 700;
  color: var(--cf-orange);
  background: var(--cf-orange-muted);
  border: 1px solid var(--cf-orange-border);
  border-radius: 4px;
  width: 22px;
  height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}

.g-text strong {
  color: var(--cf-text);
}

/* ── STARTING POINT CARDS ─────────────────────────────────── */
.start-cards {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 10px;
}

.start-card {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 12px;
  padding: 18px 22px;
  display: flex;
  align-items: flex-start;
  gap: 18px;
}

.start-num {
  font-family: 'DM Mono', monospace;
  font-size: 28pt;
  font-weight: 700;
  color: var(--cf-orange);
  line-height: 1;
  flex-shrink: 0;
  width: 40px;
}

.start-body {}
.start-title {
  font-size: 14pt;
  font-weight: 700;
  color: var(--cf-text);
  margin-bottom: 4px;
}

.start-desc {
  font-size: 12pt;
  color: var(--cf-text-muted);
  line-height: 1.5;
}

.start-tag {
  display: inline-block;
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  background: var(--cf-orange);
  color: white;
  border-radius: 4px;
  padding: 2px 8px;
  margin-top: 6px;
  letter-spacing: 0.5px;
}

/* ── LANDSCAPE COLUMNS ────────────────────────────────────── */
.landscape-col {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 10px;
  padding: 18px;
}

.landscape-col.highlight {
  border-color: var(--cf-orange-border);
  background: var(--cf-orange-muted);
}

.landscape-col-title {
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 12px;
  color: var(--cf-text-muted);
}

.landscape-col.highlight .landscape-col-title {
  color: var(--cf-orange);
}

.landscape-item {
  font-size: 11pt;
  color: var(--cf-text-muted);
  margin-bottom: 8px;
  line-height: 1.4;
}

.landscape-item strong {
  display: block;
  font-size: 12pt;
  color: var(--cf-text);
  font-weight: 600;
}

/* ── TITLE SLIDE ──────────────────────────────────────────── */
.title-slide {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100%;
}

.title-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--cf-orange-muted);
  border: 1px solid var(--cf-orange-border);
  border-radius: 6px;
  padding: 6px 14px;
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  color: var(--cf-orange);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 28px;
  width: fit-content;
}

.title-main {
  font-size: 46pt;
  font-weight: 700;
  color: var(--cf-text);
  line-height: 1.1;
  margin-bottom: 24px;
  letter-spacing: -1px;
}

.title-main span {
  color: var(--cf-orange);
}

.title-meta {
  font-size: 13pt;
  color: var(--cf-text-muted);
  line-height: 1.8;
}

.title-meta strong {
  color: var(--cf-text);
  font-size: 14pt;
}

/* ── CLOSE SLIDE ──────────────────────────────────────────── */
.close-quote {
  font-size: 22pt;
  font-weight: 500;
  color: var(--cf-text);
  line-height: 1.45;
  text-align: center;
  margin: 30px 0;
}

.close-quote em {
  color: var(--cf-orange);
}

.contact-block {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 10px;
  padding: 20px 28px;
  margin-top: 20px;
}

.contact-name {
  font-size: 16pt;
  font-weight: 700;
  color: var(--cf-text);
  margin-bottom: 6px;
}

.contact-links {
  font-size: 12pt;
  color: var(--cf-text-muted);
  line-height: 1.8;
}

.contact-links a {
  color: var(--cf-orange);
  text-decoration: none;
}

/* ── BOTTOM NOTE ──────────────────────────────────────────── */
.bottom-note {
  font-size: 11pt;
  color: var(--cf-text-dim);
  font-style: italic;
  margin-top: 16px;
}

/* ── SLIDE FOOTER ─────────────────────────────────────────── */
.slide-footer {
  position: absolute;
  bottom: 18px;
  left: 60px;
  right: 60px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: 'DM Mono', monospace;
  font-size: 8pt;
  color: var(--cf-text-dim);
  border-top: 1px solid var(--cf-border);
  padding-top: 10px;
}

/* ── TAGS / BADGES ────────────────────────────────────────── */
.tag {
  display: inline-block;
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  border-radius: 4px;
  padding: 2px 8px;
  margin-right: 6px;
  font-weight: 600;
}

.tag.orange { background: var(--cf-orange); color: white; }
.tag.blue   { background: var(--cf-blue); color: white; }
.tag.green  { background: var(--cf-green); color: white; }
.tag.red    { background: var(--cf-red); color: white; }
.tag.outline {
  background: transparent;
  border: 1px solid var(--cf-orange);
  color: var(--cf-orange);
}

/* ── HIGHLIGHT BOX ────────────────────────────────────────── */
.highlight-box {
  background: var(--cf-orange-muted);
  border: 1px solid var(--cf-orange-border);
  border-radius: 8px;
  padding: 14px 20px;
  margin-top: 16px;
}

.highlight-box p {
  color: var(--cf-text);
  font-size: 13pt;
  font-weight: 500;
  margin: 0;
  line-height: 1.5;
}

/* ── REVEAL OVERRIDES ─────────────────────────────────────── */
.reveal .progress {
  background: rgba(255,255,255,0.1);
  height: 3px;
}

.reveal .progress span {
  background: var(--cf-orange);
}

.reveal .controls {
  color: var(--cf-orange);
}

.reveal .slide-number {
  background: transparent;
  color: var(--cf-text-dim);
  font-family: 'DM Mono', monospace;
  font-size: 10pt;
}

/* Speaker notes */
.reveal aside.notes {
  display: none;
}

/* ══════════════════════════════════════════════════════════════
   FORIS V4 — ARCHITECTURE-FIRST COMPONENTS
   ══════════════════════════════════════════════════════════════ */

/* ── SLIDE TITLE ─────────────────────────────────────────────── */
.slide-title {
  font-size: 22pt;
  font-weight: 700;
  color: var(--cf-text);
  margin: 0 0 20px 0;
  line-height: 1.2;
  letter-spacing: -0.3px;
}

.centerpiece-title {
  font-size: 20pt;
  text-align: center;
  margin-bottom: 16px;
}

/* ── SLIDE 1 — PERIMETER COMPARE ─────────────────────────────── */
.perimeter-compare {
  gap: 28px;
  align-items: stretch;
}

.era-box {
  background: var(--cf-bg-card);
  border-radius: 12px;
  padding: 22px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  position: relative;
  overflow: hidden;
}

.era-then {
  border: 1px solid var(--cf-border);
}

.era-now {
  border: 1px solid rgba(239, 68, 68, 0.3);
  background: rgba(239, 68, 68, 0.04);
}

.era-label {
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  color: var(--cf-text-muted);
}

.era-label-now {
  color: var(--cf-red);
}

.era-metric {
  font-family: 'DM Mono', monospace;
  font-size: 11pt;
  color: var(--cf-text-muted);
  margin-top: 6px;
}

.era-metric-now {
  color: var(--cf-red);
  font-weight: 700;
}

/* 2019 Perimeter visual */
.perimeter-visual {
  position: relative;
  width: 200px;
  height: 200px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 8px 0;
}

.perim-ring {
  position: absolute;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.perim-outer {
  width: 190px;
  height: 190px;
  border: 2px dashed rgba(243,128,32,0.4);
}

.perim-ring-label {
  position: absolute;
  top: 8px;
  font-family: 'DM Mono', monospace;
  font-size: 8pt;
  color: var(--cf-orange);
  letter-spacing: 1px;
  opacity: 0.8;
}

.perim-inner {
  width: 80px;
  height: 80px;
  background: var(--cf-bg-card2);
  border: 2px solid var(--cf-orange);
}

.perim-core {
  font-family: 'DM Mono', monospace;
  font-size: 10pt;
  color: var(--cf-orange);
  font-weight: 700;
}

.perim-entry-points {
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
}

.entry-dot {
  position: absolute;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--cf-orange);
  box-shadow: 0 0 8px rgba(243,128,32,0.5);
}

.e1 { top: 6px; left: 50%; transform: translateX(-50%); }
.e2 { bottom: 20px; left: 14px; }
.e3 { bottom: 20px; right: 14px; }

/* Today — sprawling visual */
.perimeter-visual-now {
  width: 220px;
  height: 220px;
}

.perim-core-now {
  width: 60px;
  height: 60px;
  background: var(--cf-bg-card2);
  border: 2px solid rgba(239,68,68,0.6);
  z-index: 2;
}

.entry-points-now {
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
}

.entry-spoke {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
}

.spoke-node {
  background: rgba(239,68,68,0.12);
  border: 1px solid rgba(239,68,68,0.4);
  border-radius: 6px;
  padding: 3px 7px;
  font-family: 'DM Mono', monospace;
  font-size: 8pt;
  color: var(--cf-red);
}

/* Position the 8 spokes around the perimeter */
.s1 { top: 0; left: 50%; transform: translateX(-50%); }
.s2 { top: 18px; right: 6px; }
.s3 { top: 50%; right: 0; transform: translateY(-50%); }
.s4 { bottom: 18px; right: 6px; }
.s5 { bottom: 0; left: 50%; transform: translateX(-50%); }
.s6 { bottom: 18px; left: 6px; }
.s7 { top: 50%; left: 0; transform: translateY(-50%); }
.s8 { top: 18px; left: 6px; }

/* ── SLIDE 2 — THREAT LANDSCAPE ──────────────────────────────── */
.threat-landscape {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.threat-arch-container {
  position: relative;
  display: flex;
  gap: 16px;
  flex-direction: column;
}

.arch-background {
  display: none; /* Visual implied by the threat vectors themselves */
}

.threat-vector {
  background: var(--cf-bg-card);
  border-radius: 10px;
  padding: 16px 22px;
  display: flex;
  align-items: center;
  gap: 16px;
}

.threat-availability {
  border-left: 4px solid var(--cf-red);
  background: rgba(239,68,68,0.05);
}

.threat-access {
  border-left: 4px solid var(--cf-yellow);
  background: rgba(245,158,11,0.05);
}

.threat-lateral {
  border-left: 4px solid var(--cf-purple);
  background: rgba(168,85,247,0.05);
}

.threat-badge {
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  font-weight: 700;
  letter-spacing: 1.5px;
  padding: 4px 10px;
  border-radius: 4px;
  white-space: nowrap;
  flex-shrink: 0;
  width: 170px;
  text-align: center;
}

.t-red    { background: rgba(239,68,68,0.15); color: var(--cf-red); }
.t-yellow { background: rgba(245,158,11,0.15); color: var(--cf-yellow); }
.t-purple { background: rgba(168,85,247,0.15); color: var(--cf-purple); }

.threat-desc {
  font-size: 13pt;
  color: var(--cf-text-muted);
  line-height: 1.5;
}

.threat-summary-bar {
  display: flex;
  align-items: center;
  gap: 16px;
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 10px;
  padding: 14px 22px;
  margin-top: 4px;
}

.threat-summary-item {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
}

.tsb-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}

.tsb-text {
  font-size: 12pt;
  color: var(--cf-text-muted);
  line-height: 1.3;
}

.tsb-text strong {
  color: var(--cf-text);
}

.threat-summary-sep {
  font-size: 18pt;
  font-weight: 700;
  color: var(--cf-orange);
  flex-shrink: 0;
}

/* ── SLIDE 3 & 4 — ARCHITECTURE DIAGRAM ─────────────────────── */
.arch-diagram {
  display: grid;
  grid-template-columns: 1fr 2.2fr 1fr;
  gap: 0;
  align-items: center;
  height: 490px;
  margin-top: 8px;
}

.arch-diagram-foris {
  height: 500px;
  margin-top: 4px;
}

/* Left column */
.arch-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding-right: 12px;
}

.arch-left-label {
  font-family: 'DM Mono', monospace;
  font-size: 8pt;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--cf-text-dim);
  margin-bottom: 4px;
}

.arch-actors {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}

.arch-actor {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 8px;
  padding: 8px 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.actor-icon {
  font-size: 14pt;
  width: 24px;
  text-align: center;
}

.actor-name {
  font-size: 10pt;
  color: var(--cf-text-muted);
  font-weight: 500;
}

.actor-threat {
  border-color: rgba(239,68,68,0.3);
  background: rgba(239,68,68,0.06);
}

.actor-threat .actor-name {
  color: var(--cf-red);
}

/* Arrow sections */
.arch-arrow-right {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  margin-top: 8px;
  width: 100%;
}

.arch-arrow-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  margin-top: 8px;
  width: 100%;
}

.arrow-line {
  height: 2px;
  width: 80%;
  background: linear-gradient(90deg, transparent, var(--cf-orange));
}

.arrow-head {
  color: var(--cf-orange);
  font-size: 14pt;
  margin-top: -4px;
}

.arrow-head-l {
  color: var(--cf-green);
  font-size: 14pt;
  margin-bottom: -4px;
}

.arch-arrow-left .arrow-line {
  background: linear-gradient(270deg, transparent, var(--cf-green));
}

.arrow-label {
  font-family: 'DM Mono', monospace;
  font-size: 8pt;
  color: var(--cf-text-dim);
  letter-spacing: 0.5px;
}

/* CENTER: The Edge band */
.arch-edge {
  background: linear-gradient(180deg, #0f2a50 0%, #0d1f3c 100%);
  border: 2px solid var(--cf-orange);
  border-radius: 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  height: 100%;
  overflow: hidden;
  box-shadow: 0 0 40px rgba(243,128,32,0.12), inset 0 0 30px rgba(243,128,32,0.04);
}

.arch-edge-header {
  font-family: 'DM Mono', monospace;
  font-size: 14pt;
  font-weight: 700;
  color: var(--cf-orange);
  letter-spacing: 4px;
  text-transform: uppercase;
  padding: 16px 0 4px;
  text-align: center;
}

.arch-edge-subtitle {
  font-family: 'DM Mono', monospace;
  font-size: 8pt;
  color: rgba(243,128,32,0.5);
  letter-spacing: 1.5px;
  margin-bottom: 12px;
  text-align: center;
}

.arch-zones {
  display: flex;
  flex-direction: column;
  flex: 1;
  width: 100%;
  gap: 0;
}

.arch-zone {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 10px 16px;
  border-top: 1px solid rgba(255,255,255,0.06);
  text-align: center;
  position: relative;
  transition: background 0.2s;
}

.zone-hex {
  font-size: 10pt;
  margin-bottom: 2px;
  opacity: 0.5;
}

.zone-name {
  font-family: 'DM Mono', monospace;
  font-size: 11pt;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 3px;
}

.zone-desc {
  font-size: 9pt;
  color: rgba(160,168,184,0.7);
  line-height: 1.3;
}

/* Zone colors */
.zone-connect    { }
.zone-connect .zone-name    { color: #60a5fa; }
.zone-connect .zone-hex     { color: #60a5fa; }

.zone-protect    { }
.zone-protect .zone-name    { color: var(--cf-red); }
.zone-protect .zone-hex     { color: var(--cf-red); }

.zone-authenticate { }
.zone-authenticate .zone-name { color: var(--cf-yellow); }
.zone-authenticate .zone-hex  { color: var(--cf-yellow); }

.zone-accelerate { }
.zone-accelerate .zone-name  { color: var(--cf-green); }
.zone-accelerate .zone-hex   { color: var(--cf-green); }

/* ── SLIDE 4 — GAP ZONES ─────────────────────────────────────── */
.zone-covered {
  background: rgba(34,197,94,0.05);
}

.zone-gap {
  background: rgba(245,158,11,0.08);
  border-left: 3px solid var(--cf-yellow);
}

.zone-status {
  font-family: 'DM Mono', monospace;
  font-size: 8pt;
  font-weight: 700;
  letter-spacing: 1px;
  padding: 2px 8px;
  border-radius: 4px;
  margin-top: 3px;
  margin-bottom: 3px;
}

.status-covered {
  background: rgba(34,197,94,0.1);
  color: var(--cf-green);
}

.status-gap {
  background: rgba(245,158,11,0.15);
  color: var(--cf-yellow);
}

.zone-gap-note {
  font-size: 8pt;
  color: rgba(245,158,11,0.7);
  font-style: italic;
  line-height: 1.3;
  max-width: 200px;
}

/* Right column */
.arch-right {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding-left: 12px;
}

.arch-right-label {
  font-family: 'DM Mono', monospace;
  font-size: 8pt;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--cf-text-dim);
  margin-bottom: 4px;
}

.arch-infra {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}

.infra-node {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 8px;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-left: 3px solid var(--cf-green);
}

.infra-icon {
  font-size: 14pt;
  width: 24px;
  text-align: center;
}

.infra-name {
  font-size: 10pt;
  color: var(--cf-text);
  font-weight: 500;
}

/* ── SLIDE 5 — PEER COMPARISON ───────────────────────────────── */
.peer-layout {
  height: 560px;
}

.peer-compare {
  gap: 24px;
  height: 100%;
  align-items: stretch;
}

.peer-before {
  border: 1px solid rgba(239,68,68,0.25);
  background: rgba(239,68,68,0.04);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.peer-after {
  border: 1px solid rgba(34,197,94,0.25);
  background: rgba(34,197,94,0.04);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.peer-before-label { color: var(--cf-red); }
.peer-after-label  { color: var(--cf-green); }

/* Vendor tangle */
.vendor-tangle {
  position: relative;
  height: 220px;
  flex-shrink: 0;
}

.vendor-arrows {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
}

.vendor-core {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 52px; height: 52px;
  border-radius: 50%;
  background: var(--cf-bg-card2);
  border: 2px solid rgba(239,68,68,0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  color: var(--cf-red);
  font-weight: 700;
  z-index: 2;
}

.vendor-node {
  position: absolute;
  background: rgba(239,68,68,0.1);
  border: 1px solid rgba(239,68,68,0.3);
  border-radius: 6px;
  padding: 4px 8px;
  font-family: 'DM Mono', monospace;
  font-size: 8.5pt;
  color: var(--cf-red);
  z-index: 2;
}

.vn-1 { top: 0;    left: 10%; }
.vn-2 { top: 0;    right: 10%; }
.vn-3 { top: 40%;  left: 0; }
.vn-4 { top: 40%;  right: 0; }
.vn-5 { bottom: 0; left: 10%; }
.vn-6 { bottom: 0; right: 10%; }

/* Clean architecture */
.clean-arch {
  position: relative;
  height: 100px;
  display: flex;
  align-items: center;
  gap: 0;
  flex-shrink: 0;
}

.clean-world,
.clean-infra {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 8px;
  padding: 10px 14px;
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  color: var(--cf-text-muted);
  z-index: 2;
}

.clean-edge-band {
  flex: 1;
  height: 60px;
  background: linear-gradient(90deg, #0f2a50, #0d1f3c);
  border: 2px solid var(--cf-green);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 20px rgba(34,197,94,0.1);
}

.clean-edge-label {
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  font-weight: 700;
  color: var(--cf-green);
  letter-spacing: 2px;
}

.clean-arrows {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  pointer-events: none;
}

/* Peer metrics */
.peer-meta-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.peer-meta-item {
  font-size: 11pt;
  padding-left: 18px;
  position: relative;
  color: var(--cf-text-muted);
  line-height: 1.4;
}

.bad-item::before {
  content: '✕';
  position: absolute;
  left: 0;
  color: var(--cf-red);
  font-weight: 700;
}

.good-item::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--cf-green);
  font-weight: 700;
}

.peer-headline-metric {
  background: rgba(34,197,94,0.08);
  border: 1px solid rgba(34,197,94,0.25);
  border-radius: 8px;
  padding: 10px 14px;
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-top: 6px;
}

.peer-metric-num {
  font-family: 'DM Mono', monospace;
  font-size: 26pt;
  font-weight: 700;
  color: var(--cf-green);
  line-height: 1;
}

.peer-metric-label {
  font-size: 11pt;
  color: var(--cf-text-muted);
  line-height: 1.4;
}

/* ── SLIDE 6 — MANAGEMENT COMPARE ────────────────────────────── */
.management-compare {
  gap: 28px;
  align-items: start;
  margin-top: 4px;
  height: 510px;
}

.mgmt-col {
  display: flex;
  flex-direction: column;
  gap: 12px;
  height: 100%;
}

.mgmt-col-label {
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--cf-text-dim);
  margin-bottom: 4px;
}

.mgmt-col-label-after {
  color: var(--cf-green);
}

/* Fragmented list */
.fragmented-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.frag-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-left: 3px solid rgba(239,68,68,0.4);
  border-radius: 8px;
  padding: 10px 14px;
}

.frag-icon {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11pt;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px;
}

.frag-red { color: var(--cf-red); }

.frag-text strong {
  display: block;
  font-size: 12pt;
  color: var(--cf-text);
  font-weight: 600;
  margin-bottom: 2px;
}

.frag-text span {
  font-size: 10.5pt;
  color: var(--cf-text-muted);
  line-height: 1.4;
}

/* Unified architecture */
.unified-block {
  display: flex;
  flex-direction: column;
  gap: 14px;
  flex: 1;
}

.unified-banner {
  background: linear-gradient(135deg, #0f2a50, #0d1f3c);
  border: 2px solid var(--cf-green);
  border-radius: 10px;
  padding: 18px;
  text-align: center;
  box-shadow: 0 0 24px rgba(34,197,94,0.08);
}

.unified-banner-text {
  font-family: 'DM Mono', monospace;
  font-size: 14pt;
  font-weight: 700;
  color: var(--cf-green);
  letter-spacing: 3px;
}

.unified-properties {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.unified-prop {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-left: 3px solid rgba(34,197,94,0.4);
  border-radius: 8px;
  padding: 10px 14px;
}

.up-icon {
  color: var(--cf-green);
  font-weight: 700;
  font-size: 13pt;
  flex-shrink: 0;
  width: 20px;
  margin-top: 1px;
}

.up-text {
  font-size: 11pt;
  color: var(--cf-text-muted);
  line-height: 1.45;
}

.up-text strong {
  color: var(--cf-text);
}

/* ── SLIDE 7 — JOURNEY PATH ──────────────────────────────────── */
.journey-path {
  display: flex;
  align-items: stretch;
  gap: 0;
  margin: 12px 0 16px;
  height: 420px;
}

.journey-step {
  flex: 1;
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 12px;
  padding: 22px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
}

.step-discover {
  border-top: 3px solid var(--cf-blue);
}

.step-validate {
  border-top: 3px solid var(--cf-yellow);
}

.step-deploy {
  border-top: 3px solid var(--cf-green);
}

.journey-step-num {
  font-family: 'DM Mono', monospace;
  font-size: 32pt;
  font-weight: 700;
  line-height: 1;
  opacity: 0.15;
  position: absolute;
  top: 14px;
  right: 18px;
  color: var(--cf-text);
}

.journey-step-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}

.journey-step-name {
  font-family: 'DM Mono', monospace;
  font-size: 14pt;
  font-weight: 700;
  letter-spacing: 2px;
}

.step-discover .journey-step-name { color: var(--cf-blue); }
.step-validate .journey-step-name { color: var(--cf-yellow); }
.step-deploy   .journey-step-name { color: var(--cf-green); }

.journey-step-weeks {
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  color: var(--cf-text-dim);
  letter-spacing: 1px;
  text-transform: uppercase;
}

.journey-step-deliverable {
  background: var(--cf-bg-card2);
  border: 1px solid var(--cf-border);
  border-radius: 8px;
  padding: 14px 16px;
  margin-top: 8px;
  flex: 1;
}

.jsd-label {
  font-family: 'DM Mono', monospace;
  font-size: 8pt;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--cf-orange);
  margin-bottom: 8px;
}

.jsd-text {
  font-size: 11.5pt;
  color: var(--cf-text-muted);
  line-height: 1.55;
}

.journey-connector {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 0 6px;
  flex-shrink: 0;
}

.jc-line {
  width: 2px;
  height: 60px;
  background: var(--cf-border);
}

.jc-arrow {
  color: var(--cf-orange);
  font-size: 14pt;
  margin: 2px 0;
}

/* Actually show horizontal connectors */
.journey-path {
  flex-direction: row;
}

.journey-connector {
  flex-direction: row;
  padding: 0;
  align-items: center;
  gap: 2px;
}

.jc-line {
  width: 24px;
  height: 2px;
  background: linear-gradient(90deg, var(--cf-border), var(--cf-orange));
}

.jc-arrow {
  font-size: 12pt;
  margin: 0;
}

/* Journey commitment */
.journey-commitment {
  background: var(--cf-orange-muted);
  border: 1px solid var(--cf-orange-border);
  border-radius: 10px;
  padding: 14px 22px;
  font-size: 13pt;
  color: var(--cf-text);
  line-height: 1.6;
  text-align: center;
}

.journey-commitment em {
  color: var(--cf-orange);
  font-weight: 600;
  font-style: normal;
}



/* ══════════════════════════════════════════════════════════════
   FORIS V5 — AGENTIC AI SECURITY ARCHITECTURE
   ══════════════════════════════════════════════════════════════ */

/* ── SLIDE 1: AGENT ATTACK SURFACE DIAGRAM ─────────────────── */
.agent-attack-diagram {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 8px 0 4px;
  gap: 0;
}

.attack-surface-row {
  display: flex;
  gap: 20px;
  justify-content: center;
  width: 100%;
  padding: 0 40px;
}

.attack-node {
  flex: 1;
  max-width: 168px;
  background: var(--cf-bg-card);
  border: 1px solid rgba(239, 68, 68, 0.3);
  border-radius: 10px;
  padding: 10px 12px;
  text-align: center;
  position: relative;
}

.attack-icon {
  font-size: 18pt;
  line-height: 1;
  margin-bottom: 4px;
}

.attack-label {
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  color: var(--cf-text-muted);
  letter-spacing: 0.5px;
  line-height: 1.3;
}

.red-dot-pulse {
  position: absolute;
  top: -5px;
  right: -5px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--cf-red);
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.25);
}

.attack-connectors {
  width: 760px;
  max-width: 100%;
  flex-shrink: 0;
}

.agent-center-row {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-top: -2px;
}

.agent-central-box {
  background: linear-gradient(135deg, #0f2a50, #0d1f3c);
  border: 2px solid var(--cf-orange);
  border-radius: 14px;
  padding: 14px 48px;
  text-align: center;
  box-shadow: 0 0 30px rgba(243, 128, 32, 0.15);
}

.agent-icon-large {
  font-size: 22pt;
  line-height: 1;
  margin-bottom: 4px;
}

.agent-central-label {
  font-family: 'DM Mono', monospace;
  font-size: 13pt;
  font-weight: 700;
  color: var(--cf-orange);
  letter-spacing: 3px;
  text-transform: uppercase;
}

.agent-central-sub {
  font-family: 'DM Mono', monospace;
  font-size: 8pt;
  color: rgba(243, 128, 32, 0.5);
  letter-spacing: 1px;
  margin-top: 4px;
}

/* Ambient stat bar */
.stat-ambient-bar {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  margin-top: 14px;
  font-family: 'DM Mono', monospace;
}

.stat-pill {
  font-size: 9.5pt;
  font-weight: 700;
  color: var(--cf-orange);
  letter-spacing: 0.5px;
  background: var(--cf-orange-muted);
  border: 1px solid var(--cf-orange-border);
  border-radius: 20px;
  padding: 4px 14px;
}

.stat-sep {
  color: var(--cf-text-dim);
  font-size: 12pt;
}

/* ── SLIDE 2: CONTROL PLANE DIAGRAM ────────────────────────── */
.cp-diagram {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 10px auto 0;
  gap: 0;
  width: 560px;
}

.cp-agents-row {
  display: flex;
  gap: 24px;
  justify-content: center;
  width: 100%;
}

.cp-agent-node {
  flex: 1;
  background: var(--cf-bg-card);
  border: 1.5px solid var(--cf-border);
  border-radius: 8px;
  padding: 9px 16px;
  font-family: 'DM Mono', monospace;
  font-size: 10pt;
  color: var(--cf-text-muted);
  text-align: center;
  font-weight: 500;
}

.cp-converge-wrap,
.cp-diverge-wrap {
  width: 500px;
  flex-shrink: 0;
}

.cp-plane-box {
  background: linear-gradient(135deg, #0f2a50, #0d1f3c);
  border: 2px solid var(--cf-orange);
  border-radius: 12px;
  width: 100%;
  box-shadow: 0 0 36px rgba(243, 128, 32, 0.18), inset 0 0 20px rgba(243, 128, 32, 0.04);
  overflow: hidden;
}

.cp-plane-label {
  font-family: 'DM Mono', monospace;
  font-size: 15pt;
  font-weight: 700;
  color: var(--cf-orange);
  letter-spacing: 4px;
  text-align: center;
  padding: 14px 0 10px;
}

.cp-capabilities {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  border-top: 1px solid rgba(255,255,255,0.07);
}

.cp-cap {
  padding: 12px 14px;
  text-align: center;
  border-right: 1px solid rgba(255,255,255,0.07);
}

.cp-cap:last-child {
  border-right: none;
}

.cp-cap-name {
  font-family: 'DM Mono', monospace;
  font-size: 9.5pt;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 3px;
}

.cp-cap-desc {
  font-size: 8pt;
  color: var(--cf-text-dim);
  letter-spacing: 0.3px;
}

.cp-cap-connect .cp-cap-name { color: var(--cf-blue); }
.cp-cap-scope   .cp-cap-name { color: var(--cf-orange); }
.cp-cap-observe .cp-cap-name { color: var(--cf-purple); }

.cp-resources-row {
  display: flex;
  gap: 24px;
  justify-content: center;
  width: 100%;
}

.cp-resource-node {
  flex: 1;
  background: var(--cf-bg-card);
  border-radius: 8px;
  padding: 9px 16px;
  font-family: 'DM Mono', monospace;
  font-size: 10pt;
  text-align: center;
  font-weight: 500;
  border: 1.5px solid;
}

.cp-resource-connect { color: var(--cf-blue);   border-color: rgba(59,130,246,0.3);  background: rgba(59,130,246,0.06); }
.cp-resource-scope   { color: var(--cf-orange);  border-color: var(--cf-orange-border); background: var(--cf-orange-muted); }
.cp-resource-observe { color: var(--cf-purple);  border-color: rgba(168,85,247,0.3);  background: rgba(168,85,247,0.06); }

.cp-coverage-note {
  margin-top: 14px;
  font-size: 10pt;
  text-align: center;
  color: var(--cf-text-dim);
  font-family: 'DM Mono', monospace;
  letter-spacing: 0.3px;
}

.coverage-green { color: var(--cf-green); font-weight: 600; }
.coverage-amber { color: var(--cf-yellow); font-weight: 600; }

/* ── SLIDE 3: CP DETAIL COLUMNS ─────────────────────────────── */
.cp-detail-cols {
  gap: 16px;
  margin-top: 12px;
  align-items: stretch;
}

.cp-detail-col {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 12px;
  padding: 18px 18px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.cp-detail-col-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 2px;
}

.cp-detail-icon {
  font-size: 15pt;
  opacity: 0.5;
}

.cp-detail-name {
  font-family: 'DM Mono', monospace;
  font-size: 11pt;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
}

.cp-detail-connect { border-top: 3px solid var(--cf-blue); }
.cp-detail-scope   { border-top: 3px solid var(--cf-orange); }
.cp-detail-observe { border-top: 3px solid var(--cf-purple); }

.connect-name { color: var(--cf-blue); }
.scope-name   { color: var(--cf-orange); }
.observe-name { color: var(--cf-purple); }

.connect-icon { color: var(--cf-blue); }
.scope-icon   { color: var(--cf-orange); }
.observe-icon { color: var(--cf-purple); }

.cp-detail-list {
  list-style: none;
  padding: 0;
  margin: 0;
  flex: 1;
}

.cp-detail-list li {
  font-size: 11pt;
  color: var(--cf-text-muted);
  padding-left: 16px;
  position: relative;
  margin-bottom: 7px;
  line-height: 1.5;
}

.cp-detail-list li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--cf-orange);
  font-size: 10pt;
  top: 1px;
}

.cp-detail-connect .cp-detail-list li::before { color: var(--cf-blue); }
.cp-detail-scope   .cp-detail-list li::before { color: var(--cf-orange); }
.cp-detail-observe .cp-detail-list li::before { color: var(--cf-purple); }

.cp-blast-radius {
  background: rgba(59, 130, 246, 0.07);
  border: 1px solid rgba(59, 130, 246, 0.2);
  border-radius: 6px;
  padding: 8px 12px;
  margin-top: 4px;
}

.cp-blast-amber {
  background: var(--cf-orange-muted);
  border-color: var(--cf-orange-border);
}

.cp-blast-purple {
  background: rgba(168, 85, 247, 0.07);
  border-color: rgba(168, 85, 247, 0.2);
}

.blast-label {
  font-family: 'DM Mono', monospace;
  font-size: 7.5pt;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--cf-text-dim);
  margin-bottom: 3px;
}

.blast-text {
  font-size: 10pt;
  color: var(--cf-text);
  font-weight: 500;
  line-height: 1.4;
}

/* ── SLIDE 4: GAP CARDS ─────────────────────────────────────── */
.gap-cols {
  gap: 24px;
  margin-top: 14px;
  align-items: stretch;
}

.gap-card {
  background: var(--cf-bg-card);
  border-radius: 12px;
  padding: 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.gap-card-amber {
  border: 1.5px solid rgba(245, 158, 11, 0.35);
  background: rgba(245, 158, 11, 0.04);
  border-left: 4px solid var(--cf-yellow);
}

.gap-card-eyebrow {
  font-family: 'DM Mono', monospace;
  font-size: 8.5pt;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  color: var(--cf-yellow);
}

.gap-card-headline {
  font-size: 18pt;
  font-weight: 700;
  color: var(--cf-text);
  line-height: 1.2;
  margin-bottom: 2px;
}

.gap-card-list {
  list-style: none;
  padding: 0;
  margin: 0;
  flex: 1;
}

.gap-card-list li {
  font-size: 12pt;
  color: var(--cf-text-muted);
  padding-left: 18px;
  position: relative;
  margin-bottom: 8px;
  line-height: 1.5;
}

.gap-card-list li::before {
  content: '·';
  position: absolute;
  left: 4px;
  color: var(--cf-yellow);
  font-size: 14pt;
  line-height: 1.2;
}

.gap-card-list li strong {
  color: var(--cf-text);
}

.gap-card-needs {
  background: rgba(245, 158, 11, 0.08);
  border: 1px solid rgba(245, 158, 11, 0.2);
  border-radius: 8px;
  padding: 10px 14px;
}

.gap-needs-label {
  font-family: 'DM Mono', monospace;
  font-size: 7.5pt;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--cf-yellow);
  margin-bottom: 5px;
}

.gap-needs-text {
  font-size: 10.5pt;
  color: var(--cf-text-muted);
  line-height: 1.5;
}

.gap-bottom-line {
  margin-top: 14px;
  font-size: 11.5pt;
  color: var(--cf-text-muted);
  text-align: center;
  line-height: 1.7;
  padding: 10px 20px;
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 8px;
}

.gap-bottom-line strong {
  color: var(--cf-text);
}

/* ── SLIDE 5: ACTION CARDS ──────────────────────────────────── */
.action-cards {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 14px;
}

.action-card {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 12px;
  padding: 16px 22px;
  display: flex;
  gap: 20px;
  align-items: flex-start;
}

.action-num {
  font-family: 'DM Mono', monospace;
  font-size: 26pt;
  font-weight: 700;
  color: var(--cf-orange);
  line-height: 1;
  flex-shrink: 0;
  width: 36px;
  opacity: 0.85;
}

.action-body {
  flex: 1;
}

.action-title {
  font-size: 13pt;
  font-weight: 700;
  color: var(--cf-text);
  margin-bottom: 5px;
  line-height: 1.3;
}

.action-desc {
  font-size: 11pt;
  color: var(--cf-text-muted);
  line-height: 1.6;
}

.closing-line {
  margin-top: 18px;
  text-align: center;
  font-size: 17pt;
  font-weight: 700;
  color: var(--cf-text);
  line-height: 1.5;
  border-top: 1px solid var(--cf-border);
  padding-top: 16px;
}

/* ══════════════════════════════════════════════════════════════
   V5.1 — NEW SLIDE COMPONENTS
   ══════════════════════════════════════════════════════════════ */

/* ── SLIDE 1: TITLE ──────────────────────────────────────────── */
.main-title {
  font-size: 48pt;
  font-weight: 700;
  color: var(--cf-text);
  line-height: 1.1;
  margin: 0 0 24px 0;
  letter-spacing: -1px;
}

.subtitle-block {
  margin-bottom: 32px;
}

.subtitle-name {
  font-size: 20pt;
  font-weight: 600;
  color: var(--cf-orange);
  margin-bottom: 4px;
}

.subtitle-role {
  font-size: 14pt;
  color: var(--cf-text-muted);
  margin-bottom: 2px;
}

.subtitle-date {
  font-size: 13pt;
  color: var(--cf-text-dim);
}

.epigraph {
  font-size: 14pt;
  font-style: italic;
  color: var(--cf-text-dim);
  border-top: 1px solid var(--cf-border);
  padding-top: 16px;
  margin-top: 16px;
}

/* ── SLIDE 2: LANDSCAPE STATS ─────────────────────────────── */
.landscape-stats {
  margin: 20px 0 16px;
}

.ls-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

.ls-stat {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 10px;
  padding: 16px 14px;
  text-align: center;
}

.ls-num {
  font-family: 'DM Mono', monospace;
  font-size: 32pt;
  font-weight: 700;
  color: var(--cf-orange);
  line-height: 1;
  margin-bottom: 6px;
}

.ls-label {
  font-size: 10pt;
  color: var(--cf-text-muted);
  line-height: 1.4;
}

.timeline-visual {
  margin: 18px 0 12px;
  padding: 12px 16px;
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 8px;
}

.tl-label {
  font-family: 'DM Mono', monospace;
  font-size: 8pt;
  font-weight: 600;
  color: var(--cf-text-dim);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 10px;
}

.tl-bar {
  position: relative;
  height: 48px;
  margin-bottom: 4px;
}

.tl-event {
  position: absolute;
  top: 0;
  font-size: 7.5pt;
  color: var(--cf-text-muted);
  line-height: 1.3;
  text-align: center;
  width: 80px;
  transform: translateX(-50%);
}

.tl-event::before {
  content: '';
  display: block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  margin: 0 auto 4px;
}

.tl-cve::before { background: var(--cf-red); }
.tl-supply::before { background: var(--cf-yellow); }
.tl-mythos::before { background: var(--cf-purple); }
.tl-now::before { background: var(--cf-orange); }

.tl-now {
  color: var(--cf-orange);
  font-weight: 600;
}

.tl-line {
  height: 2px;
  background: var(--cf-border);
  position: relative;
  margin-top: -2px;
}

.tl-line::after {
  content: '';
  position: absolute;
  right: 0;
  top: -3px;
  width: 8px;
  height: 8px;
  background: var(--cf-orange);
  border-radius: 50%;
}

.tl-stripes {
  height: 4px;
  background: repeating-linear-gradient(
    90deg,
    var(--cf-red) 0,
    var(--cf-red) 2px,
    transparent 2px,
    transparent 6px
  );
  opacity: 0.3;
  margin-top: 4px;
}

.landscape-takeaway {
  text-align: center;
  padding: 10px 16px;
}

.takeaway-text {
  font-size: 14pt;
  font-weight: 600;
  color: var(--cf-orange);
  font-style: italic;
}

/* ── SLIDE 3: STAKES ─────────────────────────────────────── */
.stakes-cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin: 14px 0;
}

.stakes-col {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 10px;
  padding: 20px 18px;
}

.stakes-col-icon {
  font-size: 24pt;
  margin-bottom: 8px;
}

.stakes-col-title {
  font-size: 13pt;
  font-weight: 700;
  color: var(--cf-text);
  margin-bottom: 10px;
}

.stakes-col-text {
  font-size: 11pt;
  color: var(--cf-text-muted);
  line-height: 1.6;
}

.stakes-bridge {
  text-align: center;
  padding: 12px 20px;
  background: var(--cf-orange-muted);
  border: 1px solid var(--cf-orange-border);
  border-radius: 8px;
}

.stakes-bridge span {
  font-size: 12pt;
  color: var(--cf-text);
  font-weight: 500;
  line-height: 1.5;
}

/* ── SLIDE 4: CONTROL PLANE DIAGRAM ──────────────────────── */
.slide-title-narrow {
  max-width: 80%;
}

.cp-full-diagram {
  margin: 10px auto;
  max-width: 90%;
}

.cp-row {
  display: grid;
  gap: 14px;
  justify-items: center;
}

.cp-row-agents {
  grid-template-columns: repeat(3, 1fr);
}

.cp-row-resources {
  grid-template-columns: repeat(3, 1fr);
}

.cp-node {
  padding: 10px 18px;
  border-radius: 8px;
  font-size: 12pt;
  font-weight: 600;
  text-align: center;
}

.cp-node-agent {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  color: var(--cf-text);
}

.cp-node-resource {
  background: var(--cf-bg-card2);
  border: 1px solid var(--cf-border);
  border-left: 3px solid;
  color: var(--cf-text);
  width: 100%;
}

.cp-flow-arrows {
  display: grid;
  gap: 0;
  justify-items: center;
  grid-template-columns: repeat(3, 1fr);
  height: 20px;
}

.cp-arrow-down {
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 12px solid;
}

.arrow-dim {
  border-top-color: rgba(255,255,255,0.15);
}

.cp-box {
  background: var(--cf-bg-card);
  border: 2px solid var(--cf-orange);
  border-radius: 12px;
  padding: 16px;
  margin: 4px 0;
}

.cp-box-label {
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  font-weight: 700;
  color: var(--cf-orange);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  margin-bottom: 12px;
}

.cp-box-inner {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.cp-cap {
  padding: 10px 12px;
  border-radius: 8px;
  background: var(--cf-bg-page);
  border: 1px solid var(--cf-border);
}

.cp-cap-header {
  font-family: 'DM Mono', monospace;
  font-size: 10pt;
  font-weight: 700;
  letter-spacing: 2px;
  margin-bottom: 6px;
}

.cp-cap-connect-h { color: var(--cf-blue); }
.cp-cap-scope-h { color: var(--cf-orange); }
.cp-cap-observe-h { color: var(--cf-purple); }

.cp-cap-body {
  font-size: 9pt;
  color: var(--cf-text-muted);
  line-height: 1.5;
}

.cp-principles {
  margin-top: 12px;
  padding: 10px 16px;
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 8px;
}

.cp-principle {
  font-size: 10pt;
  color: var(--cf-text-muted);
  line-height: 1.7;
}

.cp-principle + .cp-principle {
  margin-top: 4px;
}

.prin-label {
  color: var(--cf-orange);
  font-weight: 600;
}

/* ── SLIDE 5: COVERAGE MODEL ─────────────────────────────── */
.coverage-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin: 12px 0;
}

.cov-col {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 10px;
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
}

.cov-col-icon {
  font-size: 20pt;
  margin-bottom: 6px;
}

.cov-col-title {
  font-size: 12pt;
  font-weight: 700;
  color: var(--cf-text);
  margin-bottom: 10px;
}

.cov-items {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.cov-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 10pt;
  color: var(--cf-text-muted);
  line-height: 1.5;
}

.cov-check {
  color: var(--cf-green);
  font-weight: 700;
  font-size: 11pt;
  flex-shrink: 0;
  width: 16px;
}

.cov-warn {
  color: var(--cf-text-dim);
  font-size: 11pt;
  flex-shrink: 0;
  width: 16px;
}

.cov-col-gap {
  border-color: var(--cf-orange-border);
  background: var(--cf-orange-muted);
}

.cov-product-label {
  font-family: 'DM Mono', monospace;
  font-size: 7.5pt;
  color: var(--cf-text-dim);
  text-align: center;
  margin-top: 12px;
  padding-top: 8px;
  border-top: 1px solid var(--cf-border);
  letter-spacing: 0.5px;
}

.cov-line {
  text-align: center;
  padding: 10px 16px;
  margin-top: 6px;
}

.cov-line span {
  font-size: 11pt;
  color: var(--cf-text-muted);
  font-style: italic;
  line-height: 1.6;
}

/* ── SLIDE 6: PRINCIPLES ─────────────────────────────────── */
.principle-blocks {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 8px;
}

.principle-block {
  display: flex;
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 10px;
  overflow: hidden;
}

.principle-bar {
  width: 5px;
  flex-shrink: 0;
}

.principle-body {
  display: flex;
  gap: 14px;
  padding: 14px 18px;
  flex: 1;
  align-items: flex-start;
}

.principle-num {
  font-family: 'DM Mono', monospace;
  font-size: 28pt;
  font-weight: 700;
  color: var(--cf-orange);
  line-height: 1;
  opacity: 0.6;
  flex-shrink: 0;
  width: 32px;
  margin-top: 2px;
}

.principle-content {
  flex: 1;
}

.principle-headline {
  font-size: 13pt;
  font-weight: 700;
  color: var(--cf-text);
  margin-bottom: 6px;
  line-height: 1.3;
}

.principle-text {
  font-size: 10.5pt;
  color: var(--cf-text-muted);
  line-height: 1.6;
  margin-bottom: 8px;
}

.principle-question {
  font-size: 10pt;
  color: var(--cf-orange);
  font-style: italic;
  font-weight: 500;
}

/* ── SLIDE 7: CLOUDFLARE STACK ──────────────────────────── */
.cf-stack {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin: 10px 0;
}

.cf-layer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 8px;
  padding: 14px 20px;
}

.cf-layer + .cf-layer {
  margin-top: 0;
}

.cf-layer-edge {
  border-left: 4px solid var(--cf-red);
}

.cf-layer-gateway {
  border-left: 4px solid var(--cf-blue);
}

.cf-layer-workers {
  border-left: 4px solid var(--cf-green);
}

.cf-layer-zt {
  border-left: 4px solid var(--cf-orange);
}

.cf-layer-mesh {
  border-left: 4px solid var(--cf-purple);
}

.cf-layer-left {}

.cf-layer-name {
  font-size: 13pt;
  font-weight: 700;
  color: var(--cf-text);
  margin-bottom: 2px;
}

.cf-layer-desc {
  font-size: 10pt;
  color: var(--cf-text-muted);
}

.cf-layer-right {}

.cf-product-tag {
  font-family: 'DM Mono', monospace;
  font-size: 9pt;
  color: var(--cf-orange);
  background: var(--cf-orange-muted);
  border: 1px solid var(--cf-orange-border);
  border-radius: 4px;
  padding: 4px 10px;
  white-space: nowrap;
}

.cf-tag-wide {
  font-size: 8pt;
}

.cf-arrow-row {
  text-align: center;
  color: var(--cf-text-dim);
  font-size: 14pt;
  line-height: 0.8;
  padding: 2px 0;
}

.cf-bottom {
  text-align: center;
  padding: 8px 14px;
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 8px;
  margin-top: 4px;
}

.cf-bottom span {
  font-size: 10pt;
  color: var(--cf-text-dim);
  font-family: 'DM Mono', monospace;
}

/* ── SLIDE 8: CLOSE ──────────────────────────────────────── */
.action-bar {
  width: 5px;
  flex-shrink: 0;
}

.action-inner {
  display: flex;
  gap: 16px;
  padding: 16px 20px;
  flex: 1;
  align-items: flex-start;
}

.closing-block {
  text-align: center;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--cf-border);
}

.closing-line-main {
  font-size: 22pt;
  font-weight: 700;
  color: var(--cf-text);
  margin-bottom: 6px;
}

.closing-line-sub {
  font-size: 12pt;
  color: var(--cf-text-muted);
  font-style: italic;
}

/* ── SLIDE 6: THE FORK ──────────────────────────────────── */
.fork-cols {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 14px;
  align-items: center;
  margin: 10px 0;
}

.fork-col {
  border-radius: 12px;
  overflow: hidden;
}

.fork-header {
  font-family: 'DM Mono', monospace;
  font-size: 11pt;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  padding: 12px 18px;
  text-align: center;
}

.fork-header-bad {
  background: rgba(239, 68, 68, 0.15);
  color: var(--cf-red);
  border: 1px solid rgba(239, 68, 68, 0.3);
  border-bottom: none;
  border-radius: 12px 12px 0 0;
}

.fork-header-good {
  background: rgba(34, 197, 94, 0.12);
  color: var(--cf-green);
  border: 1px solid rgba(34, 197, 94, 0.3);
  border-bottom: none;
  border-radius: 12px 12px 0 0;
}

.fork-body {
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-top: none;
  border-radius: 0 0 12px 12px;
  padding: 18px 20px;
}

.fork-icon {
  font-size: 28pt;
  text-align: center;
  margin-bottom: 12px;
}

.fork-items {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 14px;
}

.fork-item {
  font-size: 11pt;
  line-height: 1.5;
  padding: 6px 10px;
  border-radius: 6px;
}

.fork-item-bad {
  background: rgba(239, 68, 68, 0.06);
  color: var(--cf-text-muted);
  border-left: 3px solid rgba(239, 68, 68, 0.4);
}

.fork-item-good {
  background: rgba(34, 197, 94, 0.06);
  color: var(--cf-text-muted);
  border-left: 3px solid rgba(34, 197, 94, 0.4);
}

.fork-result {
  background: var(--cf-bg-page);
  border: 1px solid var(--cf-border);
  border-radius: 8px;
  padding: 10px 14px;
  text-align: center;
}

.fork-result-label {
  font-family: 'DM Mono', monospace;
  font-size: 7.5pt;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--cf-text-dim);
  margin-bottom: 4px;
}

.fork-result-text {
  font-size: 10pt;
  color: var(--cf-text);
  font-weight: 600;
  line-height: 1.4;
}

.fork-vs {
  font-family: 'DM Mono', monospace;
  font-size: 14pt;
  font-weight: 700;
  color: var(--cf-orange);
  background: var(--cf-orange-muted);
  border: 1px solid var(--cf-orange-border);
  border-radius: 50%;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.fork-line {
  text-align: center;
  margin-top: 14px;
  padding: 10px 20px;
  background: var(--cf-bg-card);
  border: 1px solid var(--cf-border);
  border-radius: 8px;
}

.fork-line span {
  font-size: 12pt;
  color: var(--cf-text);
  font-weight: 600;
  line-height: 1.5;
}

/* ── SLIDE 9: ACTION BAR COLORS ─────────────────────────── */
.action-bar-blue { background: var(--cf-blue); }
.action-bar-orange { background: var(--cf-orange); }
.action-bar-purple { background: var(--cf-purple); }

/* ── RESPONSIVE / SAFETY ────────────────────────────────── */
@media (max-width: 1100px) {
  .ls-row { grid-template-columns: repeat(2, 1fr); }
  .stakes-cols { grid-template-columns: 1fr; }
  .coverage-grid { grid-template-columns: 1fr; }
  .cp-box-inner { grid-template-columns: 1fr; }
  .slide-title-narrow { max-width: 100%; }
}
