/* Spor marketing homepage — built entirely on the Spor design tokens.
 * No hex, no raw color: every value reads from a var(--*) token.
 * Marketing license: display type runs larger than product UI, but the
 * system (cool neutrals, one glacial-teal voice <10%, mono for figures,
 * flat at rest, density with hierarchy) is the product's. */

/* canvas backdrop follows the theme so dark artboards don't sit on warm gray */
:root  { --sp-canvas: oklch(0.93 0.004 220); }
html.dark { --sp-canvas: oklch(0.125 0.010 235); }

.sp-home {
  width: 100%;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--sans);
  font-size: var(--text-base);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  font-variant-numeric: tabular-nums;
}
.sp-home *, .sp-home *::before, .sp-home *::after { box-sizing: border-box; }
.sp-mono { font-family: var(--mono); font-variant-numeric: tabular-nums; }

.sp-wrap { max-width: 1120px; margin: 0 auto; padding: 0 64px; }

/* ── topbar ───────────────────────────────────────────────── */
.sp-nav {
  position: sticky; top: 0; z-index: var(--z-sticky);
  border-bottom: 1px solid var(--line);
  background: color-mix(in oklch, var(--bg) 80%, transparent);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
}
.sp-nav-inner { display: flex; align-items: center; gap: var(--sp-6); height: 60px; }
.sp-navtheme {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; border-radius: var(--r-2); cursor: pointer;
  background: transparent; border: 1px solid var(--line); color: var(--fg);
  font-size: 13px; line-height: 1; transition: border-color var(--dur-fast) var(--ease-out);
}
.sp-navtheme:hover { border-color: var(--mut); }
.sp-brand { display: flex; align-items: center; gap: 10px; }
.sp-brand-mark { display: block; }
.sp-brand-word {
  font-family: var(--sans); font-weight: 650; font-size: 1.18rem;
  letter-spacing: -0.01em; color: var(--accent-deep);
}
.sp-nav-links { display: flex; align-items: center; gap: var(--sp-6); margin-left: var(--sp-4); }
.sp-nav-link {
  color: var(--mut); text-decoration: none; font-size: var(--text-sm);
  font-weight: 500; transition: color var(--dur-fast) var(--ease-out);
}
.sp-nav-link:hover { color: var(--fg); }
.sp-nav-link[data-active] { color: var(--accent); }
.sp-nav-spacer { flex: 1; }
.sp-nav-meta { font-size: var(--text-xs); color: var(--mut); }

/* ── buttons ──────────────────────────────────────────────── */
.sp-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--sans); font-size: var(--text-sm); font-weight: 600;
  padding: 9px 16px; border-radius: var(--r-2); border: 1px solid transparent;
  cursor: pointer; white-space: nowrap; line-height: 1;
  transition: background var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out);
}
.sp-btn-primary { background: var(--accent); color: var(--on-accent); }
.sp-btn-primary:hover { background: var(--accent-deep); }
.sp-btn-ghost { background: transparent; color: var(--fg); border-color: var(--line); }
.sp-btn-ghost:hover { border-color: var(--mut); }
.sp-btn-sm { padding: 7px 13px; font-size: var(--text-xs); }

/* ── kicker (a node marker + mono label) ──────────────────── */
.sp-kicker {
  display: inline-flex; align-items: center; gap: 9px; white-space: nowrap;
  font-family: var(--mono); font-size: var(--text-xs); font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--mut);
}
.sp-kicker::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent); flex: 0 0 auto;
}

/* ── type scale (marketing display) ───────────────────────── */
.sp-h1 {
  font-size: 3.15rem; line-height: 1.04; font-weight: 600;
  letter-spacing: -0.022em; color: var(--fg); text-wrap: balance;
  margin: 0;
}
.sp-h2 {
  font-size: 2.1rem; line-height: 1.1; font-weight: 600;
  letter-spacing: -0.018em; color: var(--fg); text-wrap: balance; margin: 0;
}
.sp-h3 { font-size: var(--text-lg); font-weight: 600; letter-spacing: -0.01em; color: var(--fg); margin: 0; }
.sp-lead {
  font-size: 1.15rem; line-height: 1.6; color: var(--mut);
  max-width: 34em; margin: 0; text-wrap: pretty;
}
.sp-accent-ink { color: var(--accent-deep); }
html.dark .sp-accent-ink { color: var(--accent); }

/* ── section rhythm ───────────────────────────────────────── */
.sp-section { padding: 96px 0; }
.sp-section-tight { padding: 64px 0; }
.sp-section + .sp-section { border-top: 1px solid var(--line); }
.sp-band { background: var(--card); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.sp-section-head { display: flex; flex-direction: column; gap: 16px; max-width: 44em; }
.sp-section-head .sp-lead { max-width: 44em; }

/* ── hero ─────────────────────────────────────────────────── */
.sp-hero { padding: 84px 0 96px; }
.sp-hero-grid { display: grid; grid-template-columns: 0.92fr 1.08fr; gap: 56px; align-items: center; }
.sp-hero-copy { display: flex; flex-direction: column; gap: 26px; }
.sp-hero-cta { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.sp-hero-note { font-size: var(--text-xs); color: var(--mut); font-family: var(--mono); }

/* inline waitlist field */
.sp-field { display: flex; align-items: stretch; gap: 10px; flex-wrap: wrap; }
.sp-input {
  font-family: var(--sans); font-size: var(--text-sm); color: var(--fg);
  background: var(--card); border: 1px solid var(--line); border-radius: var(--r-2);
  padding: 9px 13px; min-width: 240px; transition: border-color var(--dur-fast) var(--ease-out);
}
.sp-input::placeholder { color: var(--mut); }
.sp-input:focus { outline: none; border-color: var(--accent); }

/* ── card / panel (flat at rest, border before shadow) ────── */
.sp-panel {
  background: var(--card); border: 1px solid var(--line); border-radius: var(--r-2);
  overflow: hidden;
}
.sp-panel-head {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 16px; border-bottom: 1px solid var(--line);
}
.sp-panel-title { font-family: var(--mono); font-size: var(--text-xs); color: var(--mut); letter-spacing: 0.04em; white-space: nowrap; }
.sp-panel-meta { margin-left: auto; font-family: var(--mono); font-size: var(--text-xs); color: var(--mut); white-space: nowrap; }

/* node-type identity dot */
.sp-dot { width: 8px; height: 8px; border-radius: 50%; flex: 0 0 auto;
  background: oklch(var(--type-mark-l) 0.09 var(--h, 240)); }

/* a node reference */
.sp-ref { display: inline-flex; align-items: baseline; gap: 8px; min-width: 0; }
.sp-ref-id { font-family: var(--mono); font-size: var(--text-xs); color: var(--mut); }
.sp-ref-title { color: var(--fg); font-weight: 500; }

/* ── status chip (bound triple, always labelled) ──────────── */
.sp-chip {
  font-family: var(--mono); font-size: 0.62rem; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 2px 7px; border-radius: var(--r-1); border: 1px solid;
  display: inline-flex; align-items: center; line-height: 1.5; white-space: nowrap;
}
.sp-chip[data-cat="queued"]   { color: var(--cat-queued-fg);   background: var(--cat-queued-bg);   border-color: var(--cat-queued-bd); }
.sp-chip[data-cat="active"]   { color: var(--cat-active-fg);   background: var(--cat-active-bg);   border-color: var(--cat-active-bd); }
.sp-chip[data-cat="warning"]  { color: var(--cat-warning-fg);  background: var(--cat-warning-bg);  border-color: var(--cat-warning-bd); }
.sp-chip[data-cat="positive"] { color: var(--cat-positive-fg); background: var(--cat-positive-bg); border-color: var(--cat-positive-bd); }
.sp-chip[data-cat="negative"] { color: var(--cat-negative-fg); background: var(--cat-negative-bg); border-color: var(--cat-negative-bd); }
.sp-chip[data-cat="neutral"]  { color: var(--cat-neutral-fg);  background: var(--cat-neutral-bg);  border-color: var(--cat-neutral-bd); }

/* ── queue rows ───────────────────────────────────────────── */
.sp-q { display: flex; flex-direction: column; }
.sp-q-row {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: 13px 16px; border-bottom: 1px solid var(--line-soft);
  transition: background var(--dur-fast) var(--ease-out);
}
.sp-q-row:last-child { border-bottom: 0; }
.sp-q-row:hover { background: var(--accent-soft); }
.sp-q-title { flex: 1; color: var(--fg); font-weight: 500; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sp-q-age { font-family: var(--mono); font-size: var(--text-xs); color: var(--mut); flex: 0 0 auto; }
.sp-q-sub {
  display: flex; flex-direction: column; gap: 7px;
  padding: 0 16px 14px 42px; border-bottom: 1px solid var(--line-soft);
}
.sp-q-context { font-size: var(--text-sm); color: var(--mut); line-height: 1.5; }
.sp-q-evidence { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.sp-tag {
  display: inline-flex; align-items: center; gap: 6px; white-space: nowrap;
  font-family: var(--mono); font-size: var(--text-xs); color: var(--mut);
  border: 1px solid var(--line); border-radius: var(--r-1); padding: 2px 7px;
}

/* ── lineage trail ────────────────────────────────────────── */
.sp-trail { display: flex; flex-direction: column; padding: 8px 18px 16px; }
.sp-trail-node {
  display: flex; align-items: center; gap: 12px; padding: 11px 12px;
  border: 1px solid transparent; border-radius: var(--r-2);
}
.sp-trail-node[data-cur] { border-color: var(--accent); background: var(--accent-soft); }
.sp-trail-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; flex: 1 1 auto; }
.sp-trail-title { color: var(--fg); font-weight: 550; font-size: var(--text-base); }
.sp-trail-node[data-cur] .sp-trail-title { color: var(--accent-deep); }
html.dark .sp-trail-node[data-cur] .sp-trail-title { color: var(--accent); }
.sp-trail-id { font-family: var(--mono); font-size: var(--text-xs); color: var(--mut); white-space: nowrap; }
.sp-trail-here { margin-left: auto; font-family: var(--mono); font-size: 0.6rem; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); }
.sp-edge {
  display: flex; align-items: center; gap: 10px; height: 26px;
  padding-left: 22px; position: relative;
}
.sp-edge::before {
  content: ""; position: absolute; left: 23px; top: -3px; bottom: -3px;
  width: 1px; background: var(--line);
}
.sp-edge-label { font-family: var(--mono); font-size: var(--text-xs); color: var(--mut); letter-spacing: 0.02em; white-space: nowrap; }
.sp-edge-label::before { content: "\2193 "; opacity: 0.55; }

/* ── how it works ─────────────────────────────────────────── */
.sp-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.sp-step { display: flex; flex-direction: column; gap: 12px; padding: 24px; }
.sp-step-num { font-family: var(--mono); font-size: var(--text-sm); color: var(--accent); font-weight: 600; letter-spacing: 0.04em; }
.sp-step-body { color: var(--mut); font-size: var(--text-base); line-height: 1.6; }

/* ── lens switcher ────────────────────────────────────────── */
.sp-lenstabs { display: flex; gap: 4px; padding: 8px; border-bottom: 1px solid var(--line); }
.sp-lenstab {
  font-family: var(--mono); font-size: var(--text-xs); font-weight: 600;
  letter-spacing: 0.04em; padding: 6px 12px; border-radius: var(--r-1);
  color: var(--mut); background: transparent; border: 1px solid transparent; cursor: default;
}
.sp-lenstab[data-active] { color: var(--accent-deep); background: var(--accent-soft); border-color: var(--accent); }
html.dark .sp-lenstab[data-active] { color: var(--accent); }
.sp-board { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; }
.sp-board-col { padding: 14px; border-right: 1px solid var(--line-soft); display: flex; flex-direction: column; gap: 10px; }
.sp-board-col:last-child { border-right: 0; }
.sp-board-colhead { display: flex; align-items: center; gap: 8px; margin-bottom: 2px; }
.sp-board-count { font-family: var(--mono); font-size: var(--text-xs); color: var(--mut); }
.sp-minicard {
  background: var(--bg); border: 1px solid var(--line); border-radius: var(--r-2);
  padding: 10px 11px; display: flex; flex-direction: column; gap: 7px;
}
.sp-minicard-title { font-size: var(--text-sm); color: var(--fg); font-weight: 500; line-height: 1.35; }
.sp-minicard-foot { display: flex; align-items: center; gap: 7px; }
.sp-minicard-id { font-family: var(--mono); font-size: 0.66rem; color: var(--mut); }

/* ── agent strip ──────────────────────────────────────────── */
.sp-agents { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.sp-agents-label { font-size: var(--text-sm); color: var(--mut); }
.sp-agents-list { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.sp-agent { font-family: var(--mono); font-size: var(--text-sm); color: var(--fg); font-weight: 500; opacity: 0.82; }
.sp-agents-list .sp-agent + .sp-agent::before { content: "·"; margin-right: 16px; color: var(--mut); opacity: 0.5; }

/* ── stat row ─────────────────────────────────────────────── */
.sp-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.sp-stat { display: flex; flex-direction: column; gap: 6px; }
.sp-stat-num { font-family: var(--mono); font-size: 2.2rem; font-weight: 600; color: var(--fg); letter-spacing: -0.02em; line-height: 1; }
.sp-stat-label { font-size: var(--text-sm); color: var(--mut); }

/* ── CTA ──────────────────────────────────────────────────── */
.sp-cta { display: flex; flex-direction: column; align-items: center; gap: 22px; text-align: center; }
.sp-cta .sp-lead { max-width: 38em; }

/* ── footer ───────────────────────────────────────────────── */
.sp-footer { padding: 48px 0 56px; border-top: 1px solid var(--line); }
.sp-footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 32px; align-items: start; }
.sp-footer-tag { color: var(--mut); font-size: var(--text-sm); max-width: 26em; margin-top: 12px; line-height: 1.55; }
.sp-footer-col { display: flex; flex-direction: column; gap: 10px; }
.sp-footer-h { font-family: var(--mono); font-size: var(--text-xs); letter-spacing: 0.1em; text-transform: uppercase; color: var(--mut); }
.sp-footer-col a { color: var(--fg); text-decoration: none; font-size: var(--text-sm); opacity: 0.85; }
.sp-footer-col a:hover { color: var(--accent); opacity: 1; }
.sp-footer-meta { margin-top: 36px; padding-top: 20px; border-top: 1px solid var(--line-soft);
  display: flex; align-items: center; gap: 14px; font-family: var(--mono); font-size: var(--text-xs); color: var(--mut); }

/* ── responsive: collapse columns, shrink display type (real site) ── */
@media (max-width: 980px) {
  .sp-wrap { padding: 0 40px; }
  .sp-hero-grid { grid-template-columns: 1fr !important; gap: 40px; }
  .sp-hero-grid > .sp-hero-copy { order: -1; }
  .sp-h1 { font-size: 2.6rem; }
  .sp-steps { grid-template-columns: 1fr 1fr !important; }
  .sp-twoviews { grid-template-columns: 1fr; }
  .sp-section { padding: 76px 0; }
  .sp-hero { padding: 60px 0 76px; }
}
@media (max-width: 680px) {
  .sp-wrap { padding: 0 22px; }
  .sp-nav-links, .sp-nav-meta { display: none; }
  .sp-h1 { font-size: 2.15rem; }
  .sp-h2 { font-size: 1.7rem; }
  .sp-steps { grid-template-columns: 1fr !important; }
  .sp-board { grid-template-columns: 1fr; }
  .sp-board-col { border-right: 0; border-bottom: 1px solid var(--line-soft); }
  .sp-board-col:last-child { border-bottom: 0; }
  .sp-footer-grid { grid-template-columns: 1fr; gap: 28px; }
  .sp-input { min-width: 0; flex: 1; }
  .sp-field { flex-wrap: nowrap; }
}

/* ── MCP Apps widget — Spor rendered inside a real claude.ai turn ─── */
.sp-mcp-visual { display: flex; flex-direction: column; gap: 16px; }

.cw {
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--r-3); overflow: hidden;
  display: flex; flex-direction: column;
}
.cw-bar {
  display: flex; align-items: center; gap: 7px;
  padding: 10px 14px; border-bottom: 1px solid var(--line); background: var(--bg);
}
.cw-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--line); }
.cw-host { margin-left: 8px; font-family: var(--mono); font-size: var(--text-xs); color: var(--mut); letter-spacing: 0.02em; }
.cw-replay {
  margin-left: auto; display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--mut); background: transparent; border: 1px solid var(--line);
  border-radius: var(--r-1); padding: 3px 8px; cursor: pointer;
  transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
}
.cw-replay:hover { color: var(--accent); border-color: var(--accent); }

.cw-thread {
  padding: 20px 18px 8px; background: var(--bg);
  display: flex; flex-direction: column; gap: 16px;
}

/* shared reveal animation */
.cw-reveal { opacity: 0; transform: translateY(8px); transition: opacity .5s var(--ease-out), transform .5s var(--ease-out); }
.cw-reveal.cw-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .cw-reveal { opacity: 1; transform: none; transition: none; } }
/* once the turn has played out, lock the final visible state (robust even when the compositor pauses transitions) */
.cw-settled .cw-reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
.cw-settled .cw-answer > * { animation: none !important; opacity: 1 !important; transform: none !important; }

/* user turn — right-aligned bubble, meta + action icons below */
.cw-userwrap { display: flex; flex-direction: column; align-items: flex-end; gap: 7px; }
.cw-user {
  max-width: 80%; background: var(--card); border: 1px solid var(--line);
  border-radius: 14px; padding: 9px 15px; font-size: var(--text-base);
  color: var(--fg); font-weight: 550; line-height: 1.45;
}
.cw-user-meta { display: flex; align-items: center; gap: 12px; color: var(--mut); font-size: var(--text-xs); padding-right: 2px; }
.cw-mbtn { display: inline-flex; background: transparent; border: 0; color: var(--mut); cursor: pointer; padding: 2px; line-height: 0; opacity: .7; transition: opacity var(--dur-fast); }
.cw-mbtn:hover { opacity: 1; color: var(--fg); }

/* collapsed thinking row */
.cw-thought { font-size: var(--text-base); color: var(--mut); }
.cw-chev { display: inline-block; transform: translateY(-1px); }

/* app pill — the Spor app announcing itself */
.cw-app { display: flex; align-items: center; gap: 8px; }
.cw-app-avatar { width: 20px; height: 20px; border-radius: 50%; background: var(--accent); display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.cw-app-name { font-weight: 650; color: var(--fg); font-size: var(--text-base); }
.cw-app-tool { font-family: var(--mono); font-size: var(--text-sm); color: var(--mut); }
.cw-app-code { margin-left: auto; font-family: var(--mono); font-size: var(--text-sm); color: var(--mut); }

/* the inline Spor widget */
.cw-widget { background: var(--card); border: 1px solid var(--line); border-radius: var(--r-2); overflow: hidden; }
.cw-widget-head { display: flex; align-items: center; gap: 8px; padding: 13px 14px 0; }
.cw-widget-title { font-weight: 650; font-size: var(--text-base); color: var(--fg); white-space: nowrap; }
.cw-count {
  font-family: var(--mono); font-size: 0.58rem; font-weight: 600; letter-spacing: 0.04em;
  color: var(--accent); background: var(--accent-soft); border: 1px solid var(--accent-soft);
  border-radius: var(--r-1); padding: 2px 6px; white-space: nowrap;
}
.cw-refresh {
  margin-left: auto; display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--sans); font-size: 0.68rem; color: var(--mut);
  background: transparent; border: 1px solid var(--line); border-radius: var(--r-1);
  padding: 3px 8px; cursor: default; white-space: nowrap; flex: 0 0 auto;
}
.cw-widget-sub { padding: 6px 14px 12px; font-family: var(--mono); font-size: var(--text-xs); color: var(--mut); }

.cw-tasks {
  max-height: 326px; overflow-y: auto; border-top: 1px solid var(--line);
  display: flex; flex-direction: column;
  scrollbar-width: thin; scrollbar-color: var(--line) transparent;
}
.cw-tasks::-webkit-scrollbar { width: 9px; }
.cw-tasks::-webkit-scrollbar-thumb { background: var(--line); border-radius: 6px; border: 2px solid var(--card); }

.cw-task { padding: 13px 15px; border-bottom: 1px solid var(--line-soft); display: flex; flex-direction: column; gap: 6px; }
.cw-task:last-child { border-bottom: 0; }
.cw-task-top { display: flex; align-items: flex-start; gap: 9px; }
.cw-task-kind { display: inline-flex; align-items: center; gap: 5px; font-family: var(--mono); font-size: var(--text-xs); color: var(--mut); flex: 0 0 auto; padding-top: 2px; }
.cw-task-name { flex: 1; min-width: 0; color: var(--fg); font-weight: 600; font-size: var(--text-base); line-height: 1.4; }
.cw-score {
  flex: 0 0 auto; font-family: var(--mono); font-size: var(--text-sm); font-weight: 600;
  color: var(--accent); background: var(--accent-soft);
  border-radius: var(--r-1); padding: 1px 7px; letter-spacing: 0.01em;
}
.cw-task-id { display: flex; align-items: baseline; gap: 9px; }
.cw-task-age { font-family: var(--mono); font-size: var(--text-xs); color: var(--mut); }
.cw-task-note { font-size: var(--text-sm); color: var(--mut); line-height: 1.45; }
.cw-start {
  align-self: flex-start; margin-top: 2px; font-family: var(--sans); font-size: var(--text-xs);
  color: var(--fg); background: var(--bg); border: 1px solid var(--line);
  border-radius: var(--r-1); padding: 4px 12px; cursor: default;
}
.cw-code {
  font-family: var(--mono); font-size: 0.86em; color: var(--accent);
  background: var(--accent-soft); border-radius: 4px; padding: 0.5px 5px;
  white-space: nowrap;
}

/* prose answer — serif copy, like claude.ai */
.cw-answer { font-family: Georgia, "Times New Roman", serif; color: var(--fg); font-size: var(--text-lg); line-height: 1.58; }
.cw-answer p { margin: 0 0 12px; }
.cw-answer strong { font-weight: 700; }
.cw-answer ul { margin: 0; padding-left: 20px; }
.cw-answer li { margin: 0; }
.cw-answer .cw-code { font-size: 0.82em; }
/* stagger the paragraphs as the answer streams in */
.cw-answer.cw-in > * { animation: cw-rise .5s var(--ease-out) both; }
.cw-answer.cw-in > *:nth-child(1) { animation-delay: 0ms; }
.cw-answer.cw-in > *:nth-child(2) { animation-delay: 220ms; }
.cw-answer.cw-in > *:nth-child(3) { animation-delay: 520ms; }
.cw-answer.cw-in > *:nth-child(4) { animation-delay: 820ms; }
@keyframes cw-rise { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .cw-answer.cw-in > * { animation: none; } }

/* composer */
.cw-composer {
  margin: 10px 14px 14px; display: flex; align-items: center; gap: 10px;
  background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 10px 12px 10px 16px;
}
.cw-input { flex: 1; min-width: 0; font-size: var(--text-base); color: var(--fg); min-height: 20px; line-height: 20px; }
.cw-ph { color: var(--mut); }
.cw-caret { display: inline-block; width: 1.5px; height: 1.05em; background: var(--accent); margin-left: 1px; transform: translateY(2px); animation: cw-blink 1s steps(1) infinite; }
@keyframes cw-blink { 50% { opacity: 0; } }
.cw-send {
  flex: 0 0 auto; width: 30px; height: 30px; border-radius: 50%; border: 0; cursor: default;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--line); color: var(--mut);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
.cw-send-on { background: var(--accent); color: var(--on-accent); }

.sp-hosts { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.sp-host { display: inline-flex; align-items: center; gap: 7px; font-family: var(--mono); font-size: var(--text-sm); color: var(--fg); opacity: 0.85; }
.sp-host::before { content: "\2713"; color: var(--cat-positive-fg); font-size: 0.8em; }

/* ── what you see / what your agent sees ──────────────────── */
.sp-twoviews { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; align-items: stretch; }
.sp-twoviews .sp-panel { height: 100%; display: flex; flex-direction: column; }
.sp-decision { padding: 18px; display: flex; flex-direction: column; gap: 14px; flex: 1; }
.sp-decision-sum { color: var(--mut); font-size: var(--text-base); line-height: 1.55; margin: 0; }
.sp-decision-actions { display: flex; gap: 10px; margin-top: auto; padding-top: 4px; }
.sp-record {
  padding: 18px; flex: 1; display: grid; grid-template-columns: auto 1fr;
  gap: 11px 18px; align-content: start;
  font-family: var(--mono); font-size: var(--text-sm); line-height: 1.4;
}
.sp-record-k { color: var(--mut); white-space: nowrap; }
.sp-record-v { color: var(--fg); display: flex; align-items: center; gap: 7px; white-space: nowrap; }
.sp-record-v[data-accent] { color: var(--accent); }
.sp-views-foot {
  margin-top: 24px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  font-family: var(--mono); font-size: var(--text-xs); color: var(--mut);
}
.sp-views-foot span + span::before { content: "·"; margin-right: 14px; opacity: 0.5; }
