:root {
  color-scheme: light;
  --bg: #ffffff;
  --bg-2: #fafafa;
  --panel: #ffffff;
  --ink: #0f1011;
  --text: #0f1011;
  --muted: #6c7078;
  --dim: #a6a9af;
  --line: #e8e8ea;
  --line-2: #d6d6d9;
  --allow: #16774a;
  --pending: #946400;
  --deny: #bd2f23;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
  /* dark console palette, also used by the dark snippets outside the console */
  --d-bg: #0d1117;
  --d-bg2: #010409;
  --d-line: #21262d;
  --d-line2: #30363d;
  --d-text: #e6edf3;
  --d-muted: #8b949e;
  --d-dim: #6e7681;
  --d-key: #79c0ff;
  --d-str: #7ee787;
  --d-num: #ffa657;
  --d-green: #3fb950;
  --d-amber: #d29922;
  --d-red: #f85149;
  --d-blue: #1f6feb;
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--mono);
  font-size: 13.5px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* no decorative background: flat and minimal */
.grain {
  display: none;
}

main {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 32px 96px;
}

/* top bar */
.bar {
  max-width: 1080px;
  margin: 0 auto;
  padding: 22px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--line);
}
.bar-left {
  display: flex;
  align-items: baseline;
  gap: 14px;
}
.logo {
  font-weight: 700;
  letter-spacing: 0;
  font-size: 13px;
  color: var(--ink);
}
.tag {
  font-size: 10px;
  letter-spacing: 0;
  text-transform: uppercase;
  color: var(--muted);
  border: 1px solid var(--line-2);
  padding: 2px 7px;
}
.bar-right {
  display: flex;
  align-items: center;
  gap: 18px;
  font-size: 12px;
  color: var(--muted);
}
.bar-right a {
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid var(--ink);
  padding-bottom: 1px;
}
.bar-right a:hover {
  opacity: 0.6;
}
.dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--pending);
  animation: pulse 1.7s infinite;
}
.dot.ready {
  background: var(--allow);
  animation: none;
}
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}

/* hero */
.hero {
  align-items: start;
  display: grid;
  gap: 28px;
  grid-template-columns: minmax(0, 1.45fr) minmax(280px, 0.75fr);
  padding: 44px 0 26px;
}
.hero-copy {
  max-width: 760px;
}
.eyebrow {
  color: var(--muted);
  font-size: 12px;
  letter-spacing: 0;
  margin: 0 0 12px;
}
h1 {
  font-weight: 800;
  font-size: clamp(28px, 4vw, 38px);
  line-height: 1.1;
  letter-spacing: 0;
  margin: 0 0 14px;
  color: var(--ink);
}
.caret {
  font-weight: 400;
  color: var(--dim);
  animation: blink 1.2s steps(1) infinite;
}
@keyframes blink {
  50% { opacity: 0; }
}
.lede {
  color: #3f4248;
  font-size: 14px;
  max-width: 620px;
  margin: 0;
}
.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}
.primary-link,
.secondary-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  border-radius: 6px;
  padding: 10px 14px;
  font-weight: 700;
  text-decoration: none;
}
.primary-link {
  background: var(--ink);
  color: #fff;
}
.secondary-link {
  border: 1px solid var(--line-2);
  color: var(--ink);
}
.primary-link:hover,
.secondary-link:hover {
  opacity: 0.82;
}
.proof-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}
.proof-strip span {
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  font-size: 11px;
  padding: 4px 10px;
  background: var(--bg-2);
}
.truth-card {
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--bg-2);
  padding: 18px;
}
.truth-card h2 {
  color: var(--muted);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0;
  margin: 0 0 16px;
  text-transform: uppercase;
}
.truth-row {
  display: grid;
  gap: 10px;
  grid-template-columns: 10px 1fr;
  padding: 12px 0;
}
.truth-row + .truth-row {
  border-top: 1px solid var(--line);
}
.truth-dot {
  border-radius: 50%;
  height: 8px;
  margin-top: 8px;
  width: 8px;
}
.truth-dot.real {
  background: var(--allow);
}
.truth-dot.simulated {
  background: var(--pending);
}
.truth-row strong {
  color: var(--ink);
  display: block;
  font-size: 12px;
  margin-bottom: 3px;
}
.truth-row p {
  color: var(--muted);
  font-size: 11.5px;
  line-height: 1.55;
  margin: 0;
}

/* install strip */
.install-strip {
  border: 1px solid var(--line);
  border-radius: 6px;
  display: grid;
  gap: 0;
  grid-template-columns: 1.35fr 0.65fr;
  margin: 10px 0 28px;
  overflow: hidden;
}
.install-strip > div {
  align-items: center;
  display: flex;
  gap: 12px;
  min-width: 0;
  padding: 14px 16px;
}
.install-strip > div + div {
  border-left: 1px solid var(--line);
}
.install-label {
  color: var(--muted);
  flex: 0 0 auto;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
}
.install-strip code {
  color: #2f3339;
  font: 12px/1.5 var(--mono);
  overflow-wrap: anywhere;
}

/* console */
.console {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 24px;
  margin-top: 8px;
}
@media (max-width: 860px) {
  .hero,
  .console {
    grid-template-columns: minmax(0, 1fr);
  }
  .install-strip {
    grid-template-columns: 1fr;
  }
  .install-strip > div + div {
    border-left: none;
    border-top: 1px solid var(--line);
  }
}

.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 24px;
  min-width: 0;
}
.panel-title {
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0 0 20px;
}

/* scenarios */
.scenarios {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 20px;
}
.scn {
  text-align: left;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 14px;
  color: var(--ink);
  font-family: var(--mono);
  font-size: 13px;
  cursor: pointer;
  transition: border-color 0.12s, background 0.12s, transform 0.12s;
  display: grid;
  grid-template-columns: 18px 1fr auto;
  align-items: center;
  gap: 13px;
}
.scn:hover {
  background: var(--bg-2);
  border-color: var(--line-2);
  transform: translateY(-1px);
}
.scn[aria-selected="true"] {
  background: var(--bg-2);
  border-color: var(--ink);
  box-shadow: inset 3px 0 0 var(--ink);
}
.scn .glyph {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  width: 16px;
  height: 16px;
  flex: 0 0 16px;
}
.scn[aria-selected="true"] .glyph {
  color: var(--ink);
}
.scn-copy {
  min-width: 0;
}
.scn-title,
.scn .scn-sub {
  display: block;
}
.scn-title {
  font-weight: 700;
}
.scn .scn-sub {
  color: var(--muted);
  font-size: 11px;
}
.scn-decision {
  border: 1px solid var(--line-2);
  border-radius: 999px;
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0;
  padding: 3px 8px;
  text-transform: uppercase;
  white-space: nowrap;
}
.scn-decision[data-decision="approve"] {
  border-color: color-mix(in srgb, var(--allow), #fff 55%);
  color: var(--allow);
}
.scn-decision[data-decision="deny"] {
  border-color: color-mix(in srgb, var(--deny), #fff 55%);
  color: var(--deny);
}

/* action card */
.action-card {
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 18px;
  background: var(--bg-2);
}
.action-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}
.kv {
  display: flex;
  gap: 8px;
  font-size: 13px;
}
.muted {
  color: var(--muted);
}
.risk {
  font-size: 10px;
  letter-spacing: 0;
  text-transform: uppercase;
  padding: 2px 8px;
  border: 1px solid var(--line-2);
  color: var(--muted);
}
.risk[data-risk="high"] { color: var(--deny); border-color: var(--deny); }
.risk[data-risk="medium"] { color: var(--pending); border-color: var(--pending); }
.risk[data-risk="low"] { color: var(--allow); border-color: var(--allow); }

.label {
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0;
  margin: 14px 0 6px;
  text-transform: uppercase;
}
.summary {
  color: #2f3339;
  font-size: 13px;
  margin: 0 0 12px;
}
.recommendation {
  align-items: center;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 6px;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  margin: 0 0 14px;
  padding: 10px 12px;
}
.recommendation span {
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0;
  text-transform: uppercase;
}
.recommendation strong {
  color: var(--ink);
  font-size: 12px;
  line-height: 1.35;
  text-align: right;
}
.purpose {
  font-size: 12px;
  color: #3f4248;
  margin: 0 0 12px;
}

.json {
  margin: 0;
  font-size: 12px;
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 13px;
  overflow-x: auto;
  color: #44474d;
  white-space: pre-wrap;
  word-break: break-word;
}
.json .k { color: var(--ink); font-weight: 600; }
.json .s { color: var(--allow); }
.json .n { color: var(--pending); }

.input-details {
  margin-top: 14px;
}
.input-details summary {
  color: var(--muted);
  cursor: pointer;
  font-size: 11px;
  font-weight: 700;
  list-style-position: inside;
  padding: 6px 0;
}
.input-details .json {
  margin-top: 6px;
}

.run {
  margin-top: 18px;
  width: 100%;
  background: var(--ink);
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 13px;
  font-family: var(--mono);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0;
  cursor: pointer;
  transition: opacity 0.15s, transform 0.05s;
}
.run:hover:not(:disabled) { opacity: 0.82; }
.run:active:not(:disabled) { transform: translateY(1px); }
.run:disabled {
  background: #ececee;
  color: var(--dim);
  cursor: not-allowed;
}

/* the rail */
.rail {
  list-style: none;
  margin: 0 0 22px;
  padding: 0 0 0 6px;
  position: relative;
}
.rail::before {
  content: "";
  position: absolute;
  left: 11px;
  top: 10px;
  bottom: 10px;
  width: 1px;
  background: var(--line-2);
}
.stage {
  position: relative;
  padding: 4px 0 24px 32px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 14px;
}
.stage:last-child { padding-bottom: 0; }
.node {
  position: absolute;
  left: 6px;
  top: 7px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--bg);
  border: 1.5px solid var(--dim);
  transition: all 0.2s;
}
.stage[data-status="active"] .node {
  border-color: var(--pending);
}
.stage[data-status="done"] .node {
  border-color: var(--allow);
  background: var(--allow);
}
.stage[data-status="blocked"] .node {
  border-color: var(--deny);
  background: var(--deny);
}
.stage-body {
  display: flex;
  flex-direction: column;
}
.stage-name {
  font-weight: 700;
  font-size: 13px;
}
.stage-note {
  color: var(--muted);
  font-size: 11px;
}
.stage[data-status="done"] .stage-name { color: var(--allow); }
.stage[data-status="blocked"] .stage-name { color: var(--deny); }

.stage-actions {
  display: flex;
  gap: 8px;
  margin-left: auto;
}
.mini {
  background: var(--bg);
  border: 1px solid var(--line-2);
  color: var(--ink);
  border-radius: 6px;
  padding: 7px 13px;
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.12s;
}
.mini:hover { border-color: var(--ink); }
.mini.approve:hover, .mini.go:hover { border-color: var(--allow); color: var(--allow); }
.mini.deny:hover, .mini.replay:hover { border-color: var(--deny); color: var(--deny); }
.mini[data-recommended="true"] {
  background: var(--ink);
  border-color: var(--ink);
  color: #fff;
}
.mini.deny[data-recommended="true"] {
  background: var(--deny);
  border-color: var(--deny);
}
.mini.approve[data-recommended="true"] {
  background: var(--allow);
  border-color: var(--allow);
}
.mini[data-recommended="true"]:hover {
  color: #fff;
  opacity: 0.86;
}

/* readout */
.readout {
  border-top: 1px solid var(--line);
  padding-top: 20px;
}
.readout-head {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 12px;
}
.readout-head span:first-child {
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0;
  text-transform: uppercase;
}
.readout-head span:last-child {
  color: var(--dim);
  font-size: 11px;
}
.verdict {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 14px;
}
.verdict-label {
  font-size: 10px;
  letter-spacing: 0;
  text-transform: uppercase;
  color: var(--muted);
}
.verdict-value {
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0;
}
.verdict[data-state="idle"] .verdict-value { color: var(--dim); }
.verdict[data-state="require_proof"] .verdict-value { color: var(--pending); }
.verdict[data-state="allow"] .verdict-value,
.verdict[data-state="allowed"] .verdict-value { color: var(--allow); }
.verdict[data-state="deny"] .verdict-value,
.verdict[data-state="blocked"] .verdict-value { color: var(--deny); }
.out {
  max-height: 300px;
  overflow: auto;
}

/* audit */
.audit {
  margin-top: 40px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: var(--panel);
  padding: 24px;
}
.audit-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}
.count {
  font-size: 12px;
  color: var(--muted);
}
.audit-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.empty {
  color: var(--dim);
  font-size: 13px;
  margin: 0;
}
.receipt {
  display: grid;
  grid-template-columns: 14px 1fr auto;
  gap: 12px;
  align-items: center;
  border-bottom: 1px solid var(--line);
  padding: 12px 4px;
  font-size: 12px;
  animation: slidein 0.25s ease;
}
.receipt:last-child { border-bottom: none; }
@keyframes slidein {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}
.receipt .pill {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}
.receipt.allowed .pill { background: var(--allow); }
.receipt.denied .pill { background: var(--deny); }
.receipt .rid { color: var(--ink); }
.receipt .rhash { color: var(--dim); font-size: 11px; }
.receipt .rdec {
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0;
  text-transform: uppercase;
}
.receipt.allowed .rdec { color: var(--allow); }
.receipt.denied .rdec { color: var(--deny); }

.foot {
  margin-top: 56px;
  padding-top: 22px;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  color: var(--muted);
}

@media (max-width: 720px) {
  body {
    font-size: 13px;
  }
  main {
    padding: 0 16px 64px;
  }
  .bar {
    align-items: flex-start;
    gap: 14px;
    padding: 16px;
  }
  .bar,
  .bar-right {
    flex-wrap: wrap;
  }
  .bar-left {
    flex-wrap: wrap;
    gap: 8px;
  }
  .bar-right {
    gap: 10px 14px;
  }
  .hero {
    padding: 34px 0 30px;
  }
  h1 {
    font-size: 32px;
    line-height: 1.12;
    margin-bottom: 18px;
  }
  .lede {
    font-size: 13px;
  }
  .hero-actions {
    margin-top: 20px;
  }
  .primary-link,
  .secondary-link {
    flex: 1 1 100%;
    min-height: 46px;
  }
  .proof-strip {
    margin-top: 18px;
  }
  .truth-card {
    padding: 16px;
  }
  .install-strip {
    margin-bottom: 22px;
  }
  .install-strip > div {
    align-items: flex-start;
    flex-direction: column;
    gap: 5px;
    padding: 13px;
  }
  .panel,
  .audit {
    padding: 16px;
  }
  .console {
    gap: 18px;
  }
  .panel-title {
    margin-bottom: 14px;
  }
  .scn {
    grid-template-columns: 18px 1fr;
    min-height: 74px;
    padding: 12px;
  }
  .scn-decision {
    grid-column: 2;
    justify-self: flex-start;
  }
  .action-card {
    padding: 16px;
  }
  .action-head,
  .recommendation,
  .audit-head,
  .readout-head,
  .foot {
    align-items: flex-start;
    flex-direction: column;
  }
  .recommendation strong {
    text-align: left;
  }
  .action-card .json {
    max-height: 190px;
  }
  .run {
    min-height: 48px;
    margin-top: 14px;
  }
  .input-details {
    margin-top: 12px;
  }
  .input-details summary {
    min-height: 40px;
    padding: 10px 0;
  }
  .stage-actions {
    flex-direction: column;
    margin-left: 0;
    margin-top: 4px;
    width: 100%;
  }
  .mini {
    min-height: 44px;
    width: 100%;
  }
  .out {
    max-height: 260px;
  }
  .receipt {
    grid-template-columns: 10px minmax(0, 1fr);
    gap: 10px;
  }
  .receipt .rid {
    min-width: 0;
    overflow-wrap: anywhere;
  }
  .receipt .rdec {
    grid-column: 2;
  }
}

/* playground: editor, mcp chips, verify + tamper, mcp config */
.action-head-right {
  display: flex;
  align-items: center;
  gap: 10px;
}
.ghost {
  background: none;
  border: 1px solid var(--line-2);
  border-radius: 6px;
  color: var(--muted);
  font-family: var(--mono);
  font-size: 11px;
  padding: 3px 10px;
  cursor: pointer;
  transition: border-color 0.12s, color 0.12s;
}
.ghost:hover {
  border-color: var(--ink);
  color: var(--ink);
}

.editor {
  margin-bottom: 4px;
}
.editor textarea {
  width: 100%;
  resize: vertical;
  min-height: 210px;
  font: 12px/1.6 var(--mono);
  color: #2f3339;
  background: #fff;
  border: 1px solid var(--line-2);
  border-radius: 6px;
  padding: 12px;
  white-space: pre;
  tab-size: 2;
}
.editor textarea:focus {
  outline: none;
  border-color: var(--ink);
}
.editor-actions {
  display: flex;
  gap: 8px;
  margin-top: 10px;
}
.editor-error {
  color: var(--deny);
  font-size: 11.5px;
  margin: 8px 0 0;
}

.mcp-chip {
  font-size: 10px;
  letter-spacing: 0;
  color: var(--muted);
  border: 1px solid var(--line-2);
  border-radius: 999px;
  padding: 2px 8px;
  background: var(--bg-2);
  white-space: nowrap;
}
.readout-meta {
  display: flex;
  align-items: center;
  gap: 8px;
}

.verify {
  margin-top: 16px;
  border-top: 1px solid var(--line);
  padding-top: 16px;
}
.verify-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.verify-head span:first-child {
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0;
  text-transform: uppercase;
}
.verify-actions {
  display: flex;
  gap: 8px;
  margin-bottom: 10px;
}
.mini#tamperBtn[data-on="true"] {
  border-color: var(--deny);
  color: var(--deny);
}

.mcp-config {
  margin: 0 0 28px;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 0 16px;
  background: var(--bg-2);
}
.mcp-config > summary {
  cursor: pointer;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  list-style-position: inside;
  padding: 12px 0;
}
.mcp-config .json {
  margin: 0 0 14px;
}

@media (max-width: 720px) {
  .editor-actions {
    flex-direction: column;
  }
}

/* copy buttons (light surfaces) */
.copy-btn {
  flex: 0 0 auto;
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  color: var(--muted);
  border-radius: 6px;
  padding: 5px 11px;
  font: 11px var(--mono);
  cursor: pointer;
  transition: color 0.12s, border-color 0.12s;
}
.copy-btn:hover {
  color: var(--ink);
  border-color: var(--ink);
}
.copy-btn[data-copied] {
  color: var(--allow);
  border-color: var(--allow);
}
.install-strip code {
  flex: 1;
}
.copy-wrap {
  position: relative;
}
.copy-wrap .copy-btn {
  position: absolute;
  top: 9px;
  right: 9px;
  z-index: 2;
}

/* ===== dark API explorer ===== */
.explorer {
  margin-top: 30px;
}
.explorer-intro {
  margin-bottom: 16px;
}
.explorer-intro h2 {
  font-size: clamp(20px, 3vw, 26px);
  font-weight: 800;
  letter-spacing: 0;
  color: var(--ink);
  margin: 0 0 6px;
}
.explorer-intro p {
  color: #3f4248;
  font-size: 13.5px;
  max-width: 720px;
  margin: 0;
}

.flow-steps {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  list-style: none;
  margin: 0 0 14px;
  padding: 0;
}
.flow-step {
  align-items: center;
  background: #0d1117;
  border: 1px solid #21262d;
  border-radius: 9px;
  color: #8b949e;
  display: flex;
  gap: 8px;
  min-width: 0;
  padding: 9px 10px;
  transition: border-color 0.18s, background 0.18s, color 0.18s, transform 0.18s;
}
.flow-step span {
  align-items: center;
  border: 1px solid #30363d;
  border-radius: 999px;
  display: inline-flex;
  flex: 0 0 22px;
  height: 22px;
  justify-content: center;
  font-size: 10px;
  font-weight: 800;
}
.flow-step strong {
  font-size: 11px;
  overflow: hidden;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}
.flow-step[data-state="active"] {
  background: #dbeafe;
  border-color: #1f6feb;
  color: var(--ink);
  transform: translateY(-1px);
}
.flow-step[data-state="active"] span {
  border-color: #58a6ff;
  color: #1f6feb;
}

.console-window {
  --d-bg: #0d1117;
  --d-bg2: #010409;
  --d-line: #21262d;
  --d-line2: #30363d;
  --d-text: #e6edf3;
  --d-muted: #8b949e;
  --d-dim: #6e7681;
  --d-key: #79c0ff;
  --d-str: #7ee787;
  --d-num: #ffa657;
  --d-green: #3fb950;
  --d-amber: #d29922;
  --d-red: #f85149;
  --d-blue: #1f6feb;
  background: var(--d-bg);
  border: 1px solid #010409;
  border-radius: 12px;
  overflow: hidden;
  color: var(--d-text);
  box-shadow: 0 24px 60px -30px rgba(1, 4, 9, 0.55);
}

.cw-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 16px;
  background: #161b22;
  border-bottom: 1px solid var(--d-line);
}
.cw-dots {
  display: flex;
  gap: 7px;
}
.cw-dots i {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  display: block;
}
.cw-dots i:nth-child(1) { background: #ff5f57; }
.cw-dots i:nth-child(2) { background: #febc2e; }
.cw-dots i:nth-child(3) { background: #28c840; }
.cw-title {
  color: var(--d-muted);
  font-size: 12px;
}
.cw-live {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--d-muted);
  font-size: 12px;
}
.cw-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--d-amber);
  animation: pulse 1.7s infinite;
}
.cw-dot.ready {
  background: var(--d-green);
  animation: none;
}

.cw-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}
.cw-pane {
  padding: 18px;
  min-width: 0;
}
.cw-req {
  border-right: 1px solid var(--d-line);
}

.cw-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  min-height: 26px;
}
.cw-label {
  color: var(--d-muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.cw-head .cw-muted {
  border: 1px solid rgba(139, 148, 158, 0.38);
  border-radius: 999px;
  color: #c9d1d9;
  font-size: 10px;
  font-weight: 700;
  margin-left: auto;
  padding: 2px 8px;
  text-transform: uppercase;
}
.scenario-picker {
  align-items: start;
  background: rgba(230, 237, 243, 0.045);
  border: 1px solid rgba(139, 148, 158, 0.28);
  border-radius: 10px;
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, 1fr);
  margin-bottom: 14px;
  padding: 12px;
}
.scenario-copy strong {
  color: #f0f6fc;
  display: block;
  font-size: 12px;
  margin-bottom: 3px;
}
.scenario-copy p {
  color: #c9d1d9;
  font-size: 11.5px;
  line-height: 1.5;
  margin: 0;
}
.cw-presets {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-left: 0;
  justify-content: stretch;
}
.preset {
  background: rgba(230, 237, 243, 0.07);
  border: 1px solid rgba(139, 148, 158, 0.55);
  color: var(--d-text);
  border-radius: 6px;
  padding: 6px 9px;
  font: 700 11px var(--mono);
  cursor: pointer;
  text-align: center;
  transition: color 0.12s, border-color 0.12s, background 0.12s, transform 0.12s;
}
.preset:hover {
  background: rgba(88, 166, 255, 0.12);
  border-color: #58a6ff;
  transform: translateY(-1px);
}
.preset[aria-pressed="true"] {
  background: #0d419d;
  border-color: #58a6ff;
  color: #ffffff;
  box-shadow: 0 0 0 3px rgba(31, 111, 235, 0.18);
}

.cw-endpoint {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 9px;
  font-size: 12.5px;
}
.cw-endpoint .method {
  background: var(--d-green);
  color: #04130a;
  font-weight: 700;
  border-radius: 4px;
  padding: 2px 7px;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.cw-endpoint .ep {
  color: var(--d-text);
}

.request-guide {
  background: rgba(31, 111, 235, 0.14);
  border: 1px solid rgba(88, 166, 255, 0.48);
  border-radius: 8px;
  margin: 0 0 10px;
  padding: 10px 12px;
  transition: border-color 0.18s, background 0.18s, box-shadow 0.18s;
}
.request-guide > div {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 3px;
}
.request-guide strong {
  color: var(--d-text);
  font-size: 12px;
}
.request-guide p {
  color: #c9d1d9;
  font-size: 11.5px;
  line-height: 1.55;
  margin: 0;
}
.edit-spark {
  background: #58a6ff;
  border-radius: 50%;
  box-shadow: 0 0 0 4px rgba(88, 166, 255, 0.14);
  display: inline-block;
  height: 7px;
  width: 7px;
}
.editor-state {
  border: 1px solid rgba(139, 148, 158, 0.5);
  border-radius: 999px;
  color: #c9d1d9;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  text-transform: uppercase;
}
.editor-state[data-state="editing"],
.editor-state[data-state="edited"] {
  border-color: #1f6feb;
  color: #79c0ff;
}
.cw-req.is-editing .request-guide {
  background: rgba(31, 111, 235, 0.16);
  border-color: #1f6feb;
  box-shadow: 0 0 0 3px rgba(31, 111, 235, 0.14);
}

.code-editor {
  width: 100%;
  min-height: 234px;
  resize: vertical;
  background: var(--d-bg2);
  color: var(--d-text);
  border: 1px solid var(--d-line2);
  border-radius: 8px;
  padding: 13px;
  font: 12.5px/1.6 var(--mono);
  white-space: pre;
  tab-size: 2;
  -webkit-font-smoothing: antialiased;
}
.code-editor:focus {
  outline: none;
  border-color: var(--d-blue);
  box-shadow: 0 0 0 3px rgba(31, 111, 235, 0.25);
}
.req-error {
  color: var(--d-red);
  font-size: 12px;
  margin: 8px 0 0;
}

.cw-run {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 13px;
}
.run-btn {
  background: var(--d-green);
  color: #04130a;
  border: 1px solid transparent;
  border-radius: 7px;
  padding: 10px 20px;
  font: 700 13px var(--mono);
  cursor: pointer;
  transition: filter 0.12s, transform 0.05s;
}
.run-btn:hover:not(:disabled) { filter: brightness(1.08); }
.run-btn:active:not(:disabled) { transform: translateY(1px); }
.run-btn:disabled {
  background: #21262d;
  color: var(--d-dim);
  cursor: not-allowed;
}
.run-btn[data-mode="approval"]:disabled,
.run-btn[data-mode="execute"]:disabled,
.run-btn[data-mode="receipt"]:disabled {
  background: rgba(187, 128, 9, 0.13);
  border-color: rgba(210, 153, 34, 0.55);
  color: var(--d-amber);
}
.call-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  min-width: 0;
}
.call-actions[data-state="active"] {
  animation: riseIn 0.22s ease both;
}
.call-btn {
  background: #161b22;
  border: 1px solid var(--d-line2);
  color: var(--d-text);
  border-radius: 7px;
  padding: 9px 13px;
  font: 600 12.5px var(--mono);
  cursor: pointer;
  transition: color 0.12s, border-color 0.12s;
}
.call-btn:hover { border-color: var(--d-dim); }
.call-btn.approve {
  background: rgba(35, 134, 54, 0.18);
  border-color: rgba(63, 185, 80, 0.75);
}
.call-btn.go {
  background: rgba(35, 134, 54, 0.16);
  border-color: rgba(63, 185, 80, 0.65);
}
.call-btn.deny,
.call-btn.replay {
  background: rgba(248, 81, 73, 0.1);
  border-color: rgba(248, 81, 73, 0.45);
}
.call-btn.approve:hover, .call-btn.go:hover { border-color: var(--d-green); color: var(--d-green); }
.call-btn.deny:hover, .call-btn.replay:hover { border-color: var(--d-red); color: var(--d-red); }
.call-btn.tamper.on { border-color: var(--d-red); color: var(--d-red); }
.cw-hint {
  color: var(--d-dim);
  font-size: 11.5px;
  margin: 11px 0 0;
}

.cw-status {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 9px;
}
.status-pill {
  font-size: 10.5px;
  font-weight: 700;
  border-radius: 999px;
  padding: 3px 10px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  border: 1px solid var(--d-line2);
  color: var(--d-muted);
  white-space: nowrap;
}
.status-pill[data-kind="allow"] { color: var(--d-green); border-color: #238636; background: rgba(35, 134, 54, 0.15); }
.status-pill[data-kind="pending"] { color: var(--d-amber); border-color: #9e6a03; background: rgba(187, 128, 9, 0.15); }
.status-pill[data-kind="deny"] { color: var(--d-red); border-color: #da3633; background: rgba(218, 54, 51, 0.15); }
.latency {
  color: var(--d-dim);
  font-size: 11.5px;
  white-space: nowrap;
}

.code-view {
  background: var(--d-bg2);
  border: 1px solid var(--d-line);
  border-radius: 8px;
  padding: 13px;
  margin: 0;
  font: 12px/1.6 var(--mono);
  color: var(--d-text);
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 320px;
  overflow: auto;
}
.code-view.small { max-height: 150px; }
.console-window .code-view .k { color: var(--d-key); font-weight: 400; }
.console-window .code-view .s { color: var(--d-str); }
.console-window .code-view .n { color: var(--d-num); }

.cw-subhead {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 16px 0 8px;
  color: var(--d-muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.cw-muted { color: var(--d-dim); }
.copy-btn.dark {
  background: #1b2230;
  border-color: var(--d-line2);
  color: #e6edf3;
}
.copy-btn.dark:hover { color: #ffffff; border-color: var(--d-dim); }
.copy-btn.dark[data-copied] { color: var(--d-green); border-color: var(--d-green); }

.call-log {
  border: 1px solid var(--d-line);
  border-radius: 8px;
  overflow: hidden;
}
.cw-empty {
  color: var(--d-dim);
  font-size: 12px;
  margin: 0;
  padding: 12px 13px;
}
.log-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 12px;
  align-items: center;
  padding: 9px 13px;
  border-bottom: 1px solid var(--d-line);
  font-size: 12px;
  animation: slidein 0.2s ease;
}
.log-row:last-child { border-bottom: none; }
.lg-tool {
  color: var(--d-text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.lg-status {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.lg-status[data-kind="allow"] { color: var(--d-green); }
.lg-status[data-kind="pending"] { color: var(--d-amber); }
.lg-status[data-kind="deny"] { color: var(--d-red); }
.lg-ms { color: var(--d-dim); font-size: 11px; white-space: nowrap; }

@keyframes riseIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes focusPulse {
  0% { box-shadow: 0 0 0 0 rgba(88, 166, 255, 0); }
  35% { box-shadow: 0 0 0 4px rgba(88, 166, 255, 0.22); }
  100% { box-shadow: 0 0 0 0 rgba(88, 166, 255, 0); }
}
.focus-pulse {
  animation: focusPulse 0.72s ease;
}

@media (prefers-reduced-motion: reduce) {
  .call-actions[data-state="active"],
  .focus-pulse {
    animation: none;
  }
  .flow-step,
  .request-guide {
    transition: none;
  }
}

@media (max-width: 860px) {
  .cw-body { grid-template-columns: minmax(0, 1fr); }
  .cw-req { border-right: none; border-bottom: 1px solid var(--d-line); }
  .scenario-picker {
    grid-template-columns: minmax(0, 1fr);
  }
}
@media (max-width: 720px) {
  .flow-steps {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .cw-bar { flex-wrap: wrap; }
  .cw-head { flex-wrap: wrap; }
  .scenario-picker {
    padding: 11px;
  }
  .cw-presets {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .preset {
    min-height: 38px;
  }
  .run-btn { min-height: 46px; flex: 1; }
  .run-btn[data-mode="approval"]:disabled,
  .run-btn[data-mode="execute"]:disabled,
  .run-btn[data-mode="receipt"]:disabled {
    flex-basis: 100%;
  }
  .call-actions {
    width: 100%;
  }
  .call-btn { min-height: 44px; flex: 1; }
  .code-editor {
    font-size: 16px;
    line-height: 1.55;
    min-height: 260px;
  }
  .cw-endpoint {
    align-items: flex-start;
    flex-direction: column;
  }
  .copy-btn { min-height: 33px; }
}

/* ===== polish: copy feedback, dark snippets, spinner, real-feel ===== */
.copy-btn[data-copied] {
  color: #ffffff;
  background: var(--allow);
  border-color: var(--allow);
}
.copy-btn.dark[data-copied] {
  color: #04130a;
  background: var(--d-green);
  border-color: var(--d-green);
}

/* dark terminal snippets for the install commands */
.install-strip code {
  background: #0d1117;
  color: #e6edf3;
  border: 1px solid #21262d;
  border-radius: 7px;
  padding: 9px 12px;
  display: block;
}
.install-strip code::before {
  content: "$ ";
  color: #7ee787;
}

/* dark MCP config card, matches the console */
.mcp-config {
  background: #0d1117;
  border-color: #21262d;
}
.mcp-config > summary {
  color: #e6edf3;
  font-size: 12px;
}
.mcp-config > summary:hover { color: #e6edf3; }
.mcp-config .json {
  background: #010409;
  color: #e6edf3;
  border-color: #21262d;
}

/* inline code inside the truth card */
.truth-row code {
  font-size: 11.5px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 1px 5px;
  color: var(--ink);
}

/* in-flight spinner + running pill (scoped inside the dark console) */
.spinner {
  width: 13px;
  height: 13px;
  border: 2px solid var(--d-line2);
  border-top-color: var(--d-green);
  border-radius: 50%;
  display: inline-block;
  animation: spin 0.6s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.status-pill[data-kind="running"] {
  color: #cae3ff;
  border-color: var(--d-blue);
  background: rgba(31, 111, 235, 0.15);
}

/* copied state: white text on green, both surfaces (authoritative) */
.copy-btn[data-copied] {
  color: #ffffff !important;
  background: var(--allow) !important;
  border-color: var(--allow) !important;
}
.copy-btn.dark[data-copied] {
  color: #ffffff !important;
  background: var(--d-green) !important;
  border-color: var(--d-green) !important;
}

/* header nav links stay together; on mobile they drop to their own row as a group */
.bar-links {
  display: flex;
  align-items: center;
  gap: 18px;
}
/* request editor wraps long lines instead of clipping them */
.code-editor {
  white-space: pre-wrap;
  overflow-wrap: break-word;
}
/* long endpoint id never clips */
.cw-endpoint {
  flex-wrap: wrap;
}
.cw-endpoint .ep {
  overflow-wrap: anywhere;
  min-width: 0;
}
@media (max-width: 720px) {
  .bar-links {
    flex-basis: 100%;
    gap: 16px;
  }
  .cw-endpoint { font-size: 11px; }
}
