/* NRSG8 — Generalised regulator-Q&A core.
 *
 * 6th distinct aesthetic surface (CLAUDE.md variety rule):
 *
 *   index.html        cyberpunk / Scandinavian
 *   panel.html        utilitarian dashboard
 *   regn0d/web        Swedish-newspaper Q&A
 *   regn0d/kg.html    engineering schematic
 *   healthlog         terminal sparklines
 *   docs.html         warm-paper editorial
 *   metacyc.html      orrery (cycle of cycles)
 *   syskg.html        sys-kg gallery
 *   timeline.html     observatory logbook
 *   ssmailab.html     SSM-magenta governmental light
 *
 *   nrs.html          ── IAEA QUIET / DIPLOMATIC SLATE ──
 *
 * Register: calm civic typography, generous whitespace, slate-blue ink
 * on warm-cool ivory. Dual-meaning copy (Nuclear Reactor Safety /
 * Nuclear Regulators Streamliner) gets a quiet but unmissable display.
 * The atomic-orbital decor is slate-on-ivory — not the SSM purple sky.
 *
 * Tokens deliberately distinct from ssmailab.css. NO innerHTML; the
 * sibling nrs.js mutates DOM via createElement only.
 */

:root {
  --slate-0:        #3a5577;   /* primary slate-blue */
  --slate-deep:     #243349;   /* deepest, headers */
  --slate-darker:   #2c4060;
  --slate-mid:      #5d7395;
  --slate-soft:     #8b9bb6;
  --slate-tint:     #d6dfee;
  --slate-pale:     #eaecf2;

  --brass:          #d4a017;   /* warm accent (atom nucleus) */
  --brass-deep:     #a87c1f;
  --brass-mid:      #c79236;

  --coral:          #c4624a;   /* alert / cta-accent */
  --coral-soft:     #e6a395;
  --safety-green:   #4f8859;
  --hazard-red:     #b3382b;

  --bg-page:        #f4f4f0;   /* warm cool ivory */
  --bg-card:        #ffffff;
  --bg-soft:        #eef0f5;
  --bg-faint:       #f8f8f4;

  --line-soft:      #e4e6ec;
  --line-mid:       #d0d4dc;
  --line-strong:    #b1b8c6;

  --ink-0:          #1d2a3d;
  --ink-1:          #3d4a5e;
  --ink-2:          #5a6680;
  --ink-3:          #8b94a8;
  --ink-4:          #b1b8c6;

  --font-display:   'Major Mono Display', 'IBM Plex Mono', monospace;
  --font-sans:      'Familjen Grotesk', system-ui, sans-serif;
  --font-mono:      'IBM Plex Mono', 'JetBrains Mono', ui-monospace, monospace;

  --pad:            24px;
  --card-max:       960px;
}

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

body {
  background: var(--bg-page);
  color: var(--ink-1);
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  letter-spacing: 0.005em;
}

a { color: var(--slate-0); text-decoration: none; }
a:hover { color: var(--slate-deep); text-decoration: underline; }

/* ── top strip ─────────────────────────────────────────────────── */
.iaea-strip {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 28px;
  background: var(--bg-card);
  border-bottom: 1px solid var(--line-mid);
  position: sticky;
  top: 0;
  z-index: 10;
  backdrop-filter: blur(8px);
}

.strip-left, .strip-right {
  display: flex;
  align-items: center;
  gap: 14px;
}

.brand {
  font-family: var(--font-display);
  font-size: 18px;
  letter-spacing: 0.16em;
  color: var(--slate-deep);
}

.strip-sep {
  color: var(--ink-4);
  font-size: 13px;
}

.surface-tag {
  font-family: var(--font-mono);
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--slate-mid);
  border: 1px solid var(--line-mid);
  padding: 2px 10px;
  border-radius: 2px;
  background: var(--bg-faint);
}

.session-tag {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--ink-3);
}

.signin-btn {
  background: transparent;
  border: 1px solid var(--slate-0);
  color: var(--slate-0);
  font-family: var(--font-sans);
  font-size: 13px;
  padding: 6px 14px;
  border-radius: 2px;
  cursor: pointer;
  letter-spacing: 0.04em;
  transition: background 140ms, color 140ms;
}
.signin-btn:hover {
  background: var(--slate-0);
  color: var(--bg-card);
}

.lang-wrap {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px 4px 8px;
  border: 1px solid var(--line-mid);
  border-radius: 2px;
  background: var(--bg-faint);
  cursor: pointer;
  transition: border-color 140ms;
}
.lang-wrap:hover { border-color: var(--slate-soft); }
.lang-wrap:focus-within { border-color: var(--slate-0); }

.lang-glyph {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--slate-mid);
  line-height: 1;
}

.lang-select {
  background: transparent;
  border: none;
  outline: none;
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--slate-deep);
  letter-spacing: 0.04em;
  cursor: pointer;
  padding: 1px 2px;
  -webkit-appearance: none;
  appearance: none;
}
.lang-select option {
  background: var(--bg-card);
  color: var(--ink-0);
}

/* ── stage ─────────────────────────────────────────────────────── */
.boosterware-stage {
  position: relative;
  max-width: var(--card-max);
  margin: 0 auto;
  padding: 36px var(--pad) 64px;
}

.bg-decor {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
  opacity: 0.55;
}

.hero, .prompt-card, .output-region, .experts-directory,
.ensemble-compose, .plugin-pitch, .callout {
  position: relative;
  z-index: 1;
}

/* ── hero ──────────────────────────────────────────────────────── */
.hero {
  text-align: center;
  padding: 40px 0 30px;
}

.kicker {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.22em;
  color: var(--slate-mid);
  margin: 0 0 16px;
  text-transform: uppercase;
}

.display-mark {
  font-family: var(--font-display);
  font-size: clamp(58px, 11vw, 132px);
  font-weight: 400;
  color: var(--slate-deep);
  line-height: 0.95;
  letter-spacing: 0.04em;
  margin: 0 0 20px;
}
.display-mark .sep {
  color: var(--brass);
  font-size: 0.5em;
  vertical-align: 0.4em;
  margin: 0 0.05em;
}

.dual-meaning {
  max-width: 580px;
  margin: 26px auto 22px;
  padding: 18px 22px;
  background: var(--bg-card);
  border: 1px solid var(--line-mid);
  border-radius: 4px;
  text-align: left;
  box-shadow: 0 1px 0 var(--line-soft);
}
.dual-meaning::before {
  /* a small ledger-tab on the upper-left to mark it as "annotation" */
  content: '◖';
  display: block;
  position: absolute;
  font-size: 13px;
  color: var(--brass);
  transform: translate(-10px, -28px);
}

.dm-row {
  display: grid;
  grid-template-columns: 60px 24px 1fr;
  gap: 10px;
  align-items: baseline;
  padding: 6px 0;
  font-family: var(--font-mono);
  font-size: 13px;
}
.dm-row + .dm-row {
  border-top: 1px dotted var(--line-soft);
}

.dm-prefix {
  color: var(--slate-deep);
  font-weight: 500;
  letter-spacing: 0.1em;
}
.dm-arrow {
  color: var(--brass);
  text-align: center;
}
.dm-expansion {
  color: var(--ink-1);
  font-family: var(--font-sans);
  font-size: 15px;
  letter-spacing: 0.01em;
}

.dm-note {
  margin: 14px 0 0;
  padding-top: 12px;
  border-top: 1px solid var(--line-soft);
  font-family: var(--font-sans);
  font-size: 13.5px;
  color: var(--ink-2);
  line-height: 1.5;
}
.dm-note em {
  color: var(--slate-deep);
  font-style: italic;
}

.lede {
  font-size: 17px;
  line-height: 1.55;
  color: var(--ink-1);
  max-width: 620px;
  margin: 24px auto 0;
}

/* ── prompt card ───────────────────────────────────────────────── */
.prompt-card {
  background: var(--bg-card);
  border: 1px solid var(--line-mid);
  border-radius: 4px;
  padding: 26px 26px 24px;
  margin: 32px 0 30px;
  box-shadow: 0 1px 0 var(--line-soft), 0 2px 12px rgba(29,42,61,0.04);
}

.field-label {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 12px;
}
.label-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--slate-mid);
  background: var(--bg-soft);
  padding: 2px 8px;
  border-radius: 2px;
}
.label-text {
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--slate-deep);
}

#prompt-input {
  width: 100%;
  display: block;
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.5;
  color: var(--ink-0);
  background: var(--bg-faint);
  border: 1px solid var(--line-mid);
  border-radius: 3px;
  padding: 14px 16px;
  resize: vertical;
  min-height: 110px;
  outline: none;
  transition: border-color 160ms, background 160ms;
}
#prompt-input:focus {
  border-color: var(--slate-0);
  background: var(--bg-card);
  box-shadow: 0 0 0 3px rgba(58,85,119,0.08);
}

.prompt-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 10px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--ink-3);
}

.char-count { font-variant-numeric: tabular-nums; }

.state-pill {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--slate-mid);
  border: 1px solid var(--line-mid);
  background: var(--bg-faint);
  padding: 2px 9px;
  border-radius: 12px;
}

.augment-row {
  margin-top: 10px;
  display: grid;
  gap: 10px;
}

.dropzone {
  border: 1px dashed var(--line-strong);
  border-radius: 3px;
  background: var(--bg-soft);
  padding: 10px 12px;
  transition: border-color 140ms, background 140ms;
}

.dropzone.is-over {
  border-color: var(--slate-0);
  background: #f3f7ff;
}

.dropzone-main {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-bottom: 8px;
}

.dropzone-main strong {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--slate-deep);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.dropzone-sub {
  font-size: 12.5px;
  color: var(--ink-3);
}

.dropzone-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
}

.ghost-btn {
  background: transparent;
  border: 1px solid var(--line-mid);
  color: var(--slate-mid);
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 4px 9px;
  border-radius: 2px;
  cursor: pointer;
  transition: background 120ms, color 120ms, border-color 120ms;
}

.ghost-btn:hover {
  background: var(--slate-tint);
  color: var(--slate-deep);
  border-color: var(--slate-soft);
}

.attachment-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 4px;
}

.attachment-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 8px;
  align-items: baseline;
  font-family: var(--font-mono);
  font-size: 11.5px;
  border-top: 1px dotted var(--line-soft);
  padding-top: 4px;
}

.attachment-empty {
  color: var(--ink-3);
  font-family: var(--font-mono);
  font-size: 11.5px;
}

.attachment-kind {
  color: var(--slate-mid);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.attachment-name {
  color: var(--ink-1);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.attachment-size {
  color: var(--ink-3);
}

.voice-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.voice-state {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--ink-3);
  letter-spacing: 0.04em;
}

.voice-state[data-live="on"] {
  color: var(--safety-green);
}

.assist-row {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 10px;
}

.assist-opt {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--ink-2);
}

.assist-opt input {
  accent-color: var(--slate-0);
}

.mode-row {
  border: 1px solid var(--line-mid);
  border-radius: 3px;
  padding: 10px 14px 12px;
  margin: 14px 0 0;
  background: var(--bg-faint);
}
.mode-row legend {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--slate-mid);
  padding: 0 6px;
}
.mode-opt {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 5px 0;
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--ink-1);
}
.mode-opt input { accent-color: var(--slate-0); }
.mode-label small {
  color: var(--ink-3);
  font-size: 12.5px;
  margin-left: 4px;
}

.lens-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 760px) {
  .lens-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1200px) {
  .lens-grid { grid-template-columns: repeat(4, 1fr); }
}

.lens-card {
  background: var(--bg-card);
  border: 1px solid var(--line-mid);
  border-radius: 3px;
  padding: 14px 14px 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  border-top: 3px solid var(--slate-soft);
}
.lens-card[data-lane="paid-frontier"] { border-top-color: var(--brass); }
.lens-card[data-lane="foss-local"]    { border-top-color: var(--safety-green); }
.lens-card[data-ok="false"]           { opacity: 0.7; }

.lens-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-bottom: 1px dotted var(--line-soft);
  padding-bottom: 6px;
}
.lens-id {
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: 0.04em;
  color: var(--slate-deep);
}
.lens-lane {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.lens-card[data-lane="paid-frontier"] .lens-lane { color: var(--brass-deep); }
.lens-card[data-lane="foss-local"]    .lens-lane { color: var(--safety-green); }

.lens-model {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--ink-3);
  word-break: break-all;
}
.lens-text {
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--ink-1);
  line-height: 1.5;
  white-space: pre-wrap;
  min-height: 60px;
}
.lens-text.error {
  color: var(--hazard-red);
  font-family: var(--font-mono);
  font-size: 12.5px;
  background: rgba(179,56,43,0.05);
  border-left: 3px solid var(--hazard-red);
  padding: 6px 10px;
}

.lens-links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-3);
}

.lens-links-label {
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.lens-link {
  border: 1px solid var(--line-mid);
  border-radius: 2px;
  padding: 1px 6px;
  color: var(--slate-mid);
}

.lens-link:hover {
  background: var(--slate-tint);
  color: var(--slate-deep);
  text-decoration: none;
}

.lens-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 6px;
  border-top: 1px dotted var(--line-soft);
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-3);
  gap: 8px;
  flex-wrap: wrap;
}
.lens-latency { white-space: nowrap; }
.lens-filters {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.lens-filter {
  border: 1px solid var(--line-mid);
  border-radius: 2px;
  padding: 1px 6px;
  font-size: 10.5px;
  letter-spacing: 0.06em;
  color: var(--ink-3);
}
.lens-filter[data-state="ok"]     { color: var(--safety-green); border-color: rgba(79,136,89,0.4); }
.lens-filter[data-state="warn"]   { color: var(--brass-deep); border-color: var(--brass-mid); }
.lens-filter[data-state="err"]    { color: var(--hazard-red); border-color: rgba(179,56,43,0.4); }
.lens-filter[data-state="info"]   { color: var(--ink-3); border-color: var(--line-mid); }
.lens-filter[data-state="absent"] { color: var(--ink-4); border-color: var(--line-soft); font-style: italic; }

.lens-rating {
  display: flex;
  gap: 2px;
}
.lens-star {
  background: transparent;
  border: none;
  color: var(--ink-4);
  font-size: 15px;
  cursor: pointer;
  padding: 0 1px;
  line-height: 1;
}
.lens-star[data-on="1"] { color: var(--brass); }
.lens-star:hover { color: var(--brass-mid); }

.primary-button {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 16px;
  background: var(--slate-deep);
  color: var(--bg-card);
  font-family: var(--font-sans);
  font-size: 15px;
  letter-spacing: 0.04em;
  border: 1px solid var(--slate-deep);
  padding: 11px 22px;
  border-radius: 2px;
  cursor: pointer;
  transition: background 160ms, transform 160ms;
}
.primary-button:hover {
  background: var(--slate-0);
  border-color: var(--slate-0);
}
.primary-button:active {
  transform: translateY(1px);
}
.primary-button:disabled {
  background: var(--ink-4);
  border-color: var(--ink-4);
  cursor: not-allowed;
}
.primary-button.small {
  font-size: 13px;
  padding: 7px 14px;
  margin-top: 0;
}

.btn-key {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 12px;
  background: rgba(255,255,255,0.12);
  padding: 1px 7px;
  border-radius: 2px;
  border: 1px solid rgba(255,255,255,0.25);
}

/* ── output region ────────────────────────────────────────────── */
.output-region {
  margin: 30px 0;
}

.output-header {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding: 0 0 14px;
  border-bottom: 1px solid var(--line-mid);
  margin-bottom: 18px;
}

.output-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--slate-mid);
  background: var(--bg-soft);
  padding: 2px 8px;
  border-radius: 2px;
}

.output-title {
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--slate-deep);
  flex: 1;
}

.output-state {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-3);
  letter-spacing: 0.04em;
  padding: 2px 9px;
  border-radius: 12px;
  border: 1px solid var(--line-mid);
  background: var(--bg-faint);
}
.output-state[data-state="running"] {
  color: var(--brass-deep);
  border-color: var(--brass-mid);
  background: rgba(212,160,23,0.06);
}
.output-state[data-state="complete"] {
  color: var(--safety-green);
  border-color: rgba(79,136,89,0.4);
  background: rgba(79,136,89,0.05);
}
.output-state[data-state="error"] {
  color: var(--hazard-red);
  border-color: rgba(179,56,43,0.4);
  background: rgba(179,56,43,0.05);
}

.output-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  position: relative;
}
@media (min-width: 720px) {
  .output-grid { grid-template-columns: repeat(2, 1fr); }
}

.output-grid > .lens-card,
.output-grid > .expert-card {
  transform-origin: top center;
  animation: print-roll 420ms cubic-bezier(0.17, 0.67, 0.28, 1.03) both;
  animation-delay: calc(var(--print-order, 0) * 85ms);
}

@keyframes print-roll {
  0% {
    opacity: 0;
    transform: translateY(-16px) scaleY(0.6);
    filter: blur(1px);
  }
  65% {
    opacity: 1;
    transform: translateY(2px) scaleY(1.02);
    filter: blur(0);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scaleY(1);
    filter: blur(0);
  }
}

.expert-card {
  background: var(--bg-card);
  border: 1px solid var(--line-mid);
  border-radius: 3px;
  padding: 16px 16px 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: border-color 200ms, opacity 200ms;
}
.expert-card.hidden-expert { opacity: 0.45; }

.expert-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-bottom: 1px dotted var(--line-soft);
  padding-bottom: 8px;
}

.expert-id {
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--slate-deep);
  letter-spacing: 0.04em;
  font-weight: 500;
}
.expert-style {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--ink-3);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.expert-text {
  font-family: var(--font-sans);
  font-size: 14.5px;
  color: var(--ink-1);
  line-height: 1.55;
  white-space: pre-wrap;
}

.expert-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 8px;
  border-top: 1px dotted var(--line-soft);
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-3);
}

.expert-actions {
  display: flex;
  gap: 6px;
}

.expert-action {
  background: transparent;
  border: 1px solid var(--line-mid);
  color: var(--slate-mid);
  font-family: var(--font-mono);
  font-size: 11.5px;
  padding: 3px 8px;
  border-radius: 2px;
  cursor: pointer;
  letter-spacing: 0.04em;
  transition: background 140ms, color 140ms, border-color 140ms;
}
.expert-action:hover {
  background: var(--slate-tint);
  color: var(--slate-deep);
  border-color: var(--slate-soft);
}
.expert-action[data-keep="1"] {
  border-color: var(--safety-green);
  color: var(--safety-green);
}
.expert-action[data-hide="1"] {
  border-color: var(--coral);
  color: var(--coral);
}

.expert-rating {
  display: flex;
  gap: 4px;
  align-items: center;
}
.rating-star {
  background: transparent;
  border: none;
  color: var(--ink-4);
  font-size: 16px;
  cursor: pointer;
  padding: 0 1px;
  line-height: 1;
}
.rating-star[data-on="1"] { color: var(--brass); }
.rating-star:hover { color: var(--brass-mid); }

.expert-error {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--hazard-red);
  background: rgba(179,56,43,0.05);
  border-left: 3px solid var(--hazard-red);
  padding: 8px 10px;
}

.output-hint {
  margin: 14px 0 0;
  font-size: 13px;
  color: var(--ink-3);
  font-style: italic;
}

.printout-tray {
  margin-top: 10px;
  border-top: 2px solid var(--line-mid);
  padding-top: 8px;
  display: grid;
  gap: 6px;
}

.printout-sheet {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
  background: #fff;
  border: 1px solid var(--line-soft);
  border-left: 3px solid var(--slate-soft);
  border-radius: 2px;
  padding: 7px 10px;
  animation: tray-roll 360ms ease-out both;
}

.printout-sheet[data-kind="lens"] {
  border-left-color: var(--brass-mid);
}

.printout-sheet[data-kind="ensemble"] {
  border-left-color: var(--slate-soft);
}

.printout-label {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--ink-2);
}

.printout-link {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--slate-mid);
  border: 1px solid var(--line-mid);
  padding: 3px 8px;
  border-radius: 2px;
}

.printout-link:hover {
  background: var(--slate-tint);
  color: var(--slate-deep);
  text-decoration: none;
}

@keyframes tray-roll {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ── experts directory ────────────────────────────────────────── */
.experts-directory,
.ensemble-compose,
.plugin-pitch {
  background: var(--bg-card);
  border: 1px solid var(--line-mid);
  border-radius: 4px;
  padding: 20px 22px;
  margin: 22px 0;
}

.directory-title {
  margin: 0 0 8px;
  font-family: var(--font-display);
  font-size: 18px;
  letter-spacing: 0.06em;
  color: var(--slate-deep);
  font-weight: 400;
}

.directory-lede {
  margin: 0 0 16px;
  font-size: 13.5px;
  color: var(--ink-2);
  line-height: 1.5;
}

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

.directory-row {
  display: grid;
  grid-template-columns: 110px 1fr 120px auto;
  gap: 14px;
  align-items: baseline;
  padding: 10px 0;
  border-top: 1px dotted var(--line-soft);
  font-family: var(--font-mono);
  font-size: 12.5px;
}
.directory-row:first-child { border-top: none; }

.directory-row .dir-id {
  color: var(--slate-deep);
  font-weight: 500;
  letter-spacing: 0.04em;
}
.directory-row .dir-model { color: var(--ink-0); }
.directory-row .dir-style {
  color: var(--ink-3);
  font-size: 11.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.directory-row .dir-contact {
  color: var(--slate-mid);
  font-size: 11.5px;
  text-decoration: none;
  border: 1px solid var(--line-mid);
  padding: 3px 8px;
  border-radius: 2px;
  transition: background 140ms;
  justify-self: end;
}
.directory-row .dir-contact:hover {
  background: var(--slate-tint);
  color: var(--slate-deep);
}

.directory-placeholder {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-3);
  padding: 14px 0;
  text-align: center;
  font-style: italic;
}

@media (max-width: 640px) {
  .directory-row {
    grid-template-columns: 1fr;
    gap: 4px;
  }
  .directory-row .dir-contact { justify-self: start; }
}

/* ── ensembles ────────────────────────────────────────────────── */
.ensemble-active-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 0;
  margin-bottom: 10px;
  border-bottom: 1px dotted var(--line-soft);
  font-family: var(--font-mono);
  font-size: 13px;
}

.ensemble-active-label {
  color: var(--ink-3);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.ensemble-active-name {
  color: var(--slate-deep);
  font-weight: 500;
  flex: 1;
}

.ensemble-action-btn {
  background: transparent;
  border: 1px solid var(--line-mid);
  color: var(--slate-mid);
  font-family: var(--font-mono);
  font-size: 11.5px;
  padding: 3px 9px;
  border-radius: 2px;
  cursor: pointer;
}
.ensemble-action-btn:hover {
  background: var(--slate-tint);
  color: var(--slate-deep);
}

.ensemble-list {
  list-style: none;
  margin: 0 0 14px;
  padding: 0;
}

.ensemble-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 10px;
  align-items: center;
  padding: 8px 0;
  border-top: 1px dotted var(--line-soft);
  font-family: var(--font-mono);
  font-size: 12.5px;
}
.ensemble-row:first-child { border-top: none; }

.ensemble-row .ens-name {
  color: var(--slate-deep);
  font-weight: 500;
}
.ensemble-row .ens-meta {
  color: var(--ink-3);
  font-size: 11.5px;
}

.ensemble-save-row {
  display: flex;
  gap: 10px;
  align-items: stretch;
  margin-top: 10px;
}

.ensemble-name-input {
  flex: 1;
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--ink-0);
  background: var(--bg-faint);
  border: 1px solid var(--line-mid);
  border-radius: 2px;
  padding: 7px 10px;
  outline: none;
}
.ensemble-name-input:focus {
  border-color: var(--slate-0);
  background: var(--bg-card);
}

.ensemble-hint {
  margin: 10px 0 0;
  font-size: 12.5px;
  color: var(--ink-3);
  font-style: italic;
}

/* ── plugin pitch ─────────────────────────────────────────────── */
.plugin-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.plugin-row {
  display: grid;
  grid-template-columns: 120px 1fr auto;
  gap: 14px;
  align-items: baseline;
  padding: 11px 0;
  border-top: 1px dotted var(--line-soft);
  font-family: var(--font-mono);
  font-size: 12.5px;
}
.plugin-row:first-child { border-top: none; }
.plugin-row.pending { opacity: 0.7; }

.plugin-id {
  color: var(--slate-deep);
  font-weight: 500;
  letter-spacing: 0.06em;
}
.plugin-meta { color: var(--ink-2); }
.plugin-state {
  color: var(--brass-deep);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

@media (max-width: 640px) {
  .plugin-row { grid-template-columns: 1fr; gap: 4px; }
}

/* ── callout ──────────────────────────────────────────────────── */
.callout {
  background: var(--bg-soft);
  border: 1px solid var(--line-mid);
  border-radius: 3px;
  padding: 16px 18px;
  margin: 30px 0 0;
  display: grid;
  gap: 6px;
}

.callout-row {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 14px;
  padding: 6px 0;
  border-top: 1px dotted var(--line-soft);
  font-size: 13.5px;
}
.callout-row:first-child { border-top: none; }

.callout-label {
  font-family: var(--font-mono);
  color: var(--slate-mid);
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 0.14em;
}
.callout-value { color: var(--ink-1); }

/* ── footer ──────────────────────────────────────────────────── */
.iaea-foot {
  text-align: center;
  margin: 50px auto 26px;
  padding: 16px var(--pad) 0;
  border-top: 1px solid var(--line-mid);
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-3);
  letter-spacing: 0.12em;
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}

.install-hint {
  color: var(--brass-deep);
  cursor: pointer;
}

/* ── responsive overrides ────────────────────────────────────── */
@media (max-width: 540px) {
  .iaea-strip { padding: 10px 16px; }
  .boosterware-stage { padding: 24px 18px 48px; }
  .prompt-card { padding: 22px 18px 22px; }
  .display-mark { font-size: clamp(48px, 16vw, 92px); }
}
