/* ── One-Shots Companion — dark fantasy, candlelit, highly readable ── */

:root {
  --bg: #16130f;
  --bg-raise: #1f1a14;
  --bg-card: #241e17;
  --bg-inset: #120f0b;
  --ink: #e8ddc8;          /* warm parchment text on dark */
  --ink-dim: #a89878;
  --ink-faint: #6f6350;
  --gold: #c9a227;
  --gold-soft: #e3c668;
  --ember: #c4572a;
  --blood: #8e2f2f;
  --arcane: #7e6bb0;
  --forest: #5a7a4f;
  --line: #3a3127;
  --line-soft: #2c251d;
  --shadow: 0 2px 14px rgba(0,0,0,.45);
  /* Readability first: proven system stacks, generous sizes */
  --serif: Georgia, 'Iowan Old Style', 'Palatino Linotype', Palatino, 'Book Antiqua', serif;
  --sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --mono: 'SF Mono', SFMono-Regular, Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }
body {
  background: var(--bg);
  background-image:
    radial-gradient(ellipse 1200px 700px at 70% -10%, rgba(201,162,39,.05), transparent),
    radial-gradient(ellipse 900px 600px at 0% 100%, rgba(196,87,42,.04), transparent);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.6;
}

#shell { display: flex; min-height: 100vh; }

/* ── Sidebar ── */
#sidebar {
  width: 232px; flex: 0 0 232px;
  background: var(--bg-inset);
  border-right: 1px solid var(--line);
  padding: 20px 0 12px;
  position: sticky; top: 0; height: 100vh; overflow-y: auto;
}
.brand { padding: 0 20px 16px; border-bottom: 1px solid var(--line-soft); margin-bottom: 10px; }
.brand-title {
  font-family: var(--serif); font-size: 21px; font-weight: 700;
  letter-spacing: .04em; color: var(--gold-soft); line-height: 1.2;
}
.brand-sub { font-size: 11.5px; color: var(--ink-faint); margin-top: 6px; letter-spacing: .05em; }
.nav-group { padding: 8px 10px 2px; }
.nav-label {
  font-size: 10.5px; text-transform: uppercase; letter-spacing: .14em;
  color: var(--ink-faint); padding: 6px 10px 2px;
}
#sidebar a {
  display: block; padding: 7px 10px; margin: 1px 0;
  color: var(--ink-dim); text-decoration: none; border-radius: 6px;
  font-size: 14.5px;
}
#sidebar a:hover { color: var(--ink); background: var(--bg-raise); }
#sidebar a.active { color: var(--gold-soft); background: var(--bg-card); box-shadow: inset 2px 0 0 var(--gold); }
.nav-foot { padding: 18px 20px 8px; font-size: 11px; color: var(--ink-faint); letter-spacing: .06em; }

/* ── Main ── */
#main { flex: 1; min-width: 0; padding: 32px 44px 80px; max-width: 1060px; }
.loading { color: var(--ink-faint); font-style: italic; padding: 40px 0; }

h1, h2, h3, h4 { font-family: var(--serif); color: var(--ink); line-height: 1.25; }
.page-title {
  font-size: 30px; margin: 0 0 4px; color: var(--gold-soft); letter-spacing: .02em;
}
.page-sub { color: var(--ink-dim); margin: 0 0 26px; font-size: 15px; }
.rule {
  border: 0; height: 1px; margin: 24px 0;
  background: linear-gradient(90deg, var(--gold) 0%, var(--line) 40%, transparent 100%);
  opacity: .5;
}

/* ── Cards & grids ── */
.grid { display: grid; gap: 14px; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); }
.grid.wide { grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); }
.card {
  background: var(--bg-card); border: 1px solid var(--line); border-radius: 10px;
  padding: 16px 18px; box-shadow: var(--shadow);
  transition: border-color .15s;
}
a.card { display: block; color: inherit; text-decoration: none; }
a.card:hover { border-color: var(--gold); }
.card h3 { margin: 0 0 6px; font-size: 18px; color: var(--gold-soft); }
.card .meta { font-size: 12.5px; color: var(--ink-faint); margin-bottom: 6px; letter-spacing: .03em; }
.card p { margin: 4px 0 0; font-size: 14px; color: var(--ink-dim); }
.card .thumb {
  width: 100%; height: 150px; object-fit: cover; object-position: top; border-radius: 6px;
  margin-bottom: 10px; border: 1px solid var(--line);
  background: var(--bg-inset);
}
.card .thumb.placeholder {
  display: flex; align-items: center; justify-content: center;
  color: var(--ink-faint); font-size: 13px; font-style: italic;
}

.badge {
  display: inline-block; font-size: 11px; padding: 2px 9px; border-radius: 10px;
  border: 1px solid var(--line); color: var(--ink-dim); margin-right: 5px;
  letter-spacing: .04em; vertical-align: middle;
}
.badge.gold { color: var(--gold-soft); border-color: rgba(201,162,39,.5); }
.badge.ember { color: #e08a5e; border-color: rgba(196,87,42,.55); }
.badge.arcane { color: #a797d4; border-color: rgba(126,107,176,.55); }
.badge.forest { color: #92b585; border-color: rgba(90,122,79,.6); }
.badge.blood { color: #cf7b7b; border-color: rgba(142,47,47,.6); }

/* ── Buttons / forms ── */
button, .btn {
  font-family: var(--sans); font-size: 14px; cursor: pointer;
  background: var(--bg-raise); color: var(--ink); border: 1px solid var(--line);
  padding: 8px 16px; border-radius: 7px;
}
button:hover, .btn:hover { border-color: var(--gold); color: var(--gold-soft); }
button.primary { background: linear-gradient(180deg, #5b4a17, #46390f); border-color: #8a702a; color: #f0e3b2; font-weight: 600; }
button.primary:hover { border-color: var(--gold); color: #fff4cf; }
button.danger:hover { border-color: var(--blood); color: #cf7b7b; }
button.small { font-size: 12.5px; padding: 4px 11px; }
button:disabled { opacity: .45; cursor: default; }

input[type=text], input[type=number], input[type=date], select, textarea {
  width: 100%; background: var(--bg-inset); color: var(--ink);
  border: 1px solid var(--line); border-radius: 7px; padding: 9px 12px;
  font-family: var(--sans); font-size: 14.5px;
}
textarea { min-height: 90px; line-height: 1.55; resize: vertical; }
textarea.code { font-family: var(--mono); font-size: 13px; }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--gold); }
label.f { display: block; margin: 14px 0 0; }
label.f > span {
  display: block; font-size: 12px; text-transform: uppercase; letter-spacing: .1em;
  color: var(--ink-dim); margin-bottom: 5px;
}
.hint { font-size: 12.5px; color: var(--ink-faint); margin-top: 4px; }
.frow { display: flex; gap: 14px; flex-wrap: wrap; }
.frow > * { flex: 1; min-width: 130px; }
fieldset { border: 1px solid var(--line); border-radius: 10px; margin: 18px 0; padding: 6px 18px 16px; }
legend { font-family: var(--serif); color: var(--gold-soft); padding: 0 8px; font-size: 16px; }

/* choice chips */
.chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 6px; }
.chip {
  border: 1px solid var(--line); border-radius: 18px; padding: 6px 15px;
  font-size: 13.5px; color: var(--ink-dim); cursor: pointer; background: var(--bg-inset);
  user-select: none;
}
.chip:hover { border-color: var(--gold); color: var(--ink); }
.chip.on { border-color: var(--gold); color: var(--gold-soft); background: rgba(201,162,39,.08); }

/* ── Rendered markdown ── */
.md { max-width: 780px; }
.md h1 { font-size: 27px; color: var(--gold-soft); border-bottom: 1px solid var(--line); padding-bottom: 8px; }
.md h2 { font-size: 22px; margin-top: 34px; color: var(--gold-soft); }
.md h3 { font-size: 18px; margin-top: 26px; }
.md h4 { font-size: 16px; margin-top: 20px; color: var(--ink-dim); }
.md p, .md li { font-size: 15.5px; }
.md a { color: var(--gold-soft); text-decoration: none; border-bottom: 1px dotted rgba(201,162,39,.5); }
.md a:hover { border-bottom-style: solid; }
.md blockquote {
  margin: 14px 0; padding: 10px 18px; border-left: 3px solid var(--gold);
  background: rgba(201,162,39,.05); border-radius: 0 8px 8px 0;
  color: var(--ink-dim); font-style: italic;
}
.md code { font-family: var(--mono); font-size: 13px; background: var(--bg-inset); padding: 2px 6px; border-radius: 5px; color: var(--gold-soft); }
.md pre { background: var(--bg-inset); border: 1px solid var(--line); border-radius: 8px; padding: 14px 16px; overflow-x: auto; }
.md pre code { background: none; padding: 0; color: var(--ink); }
.md table { border-collapse: collapse; margin: 16px 0; width: 100%; font-size: 14px; }
.md th { font-family: var(--serif); text-align: left; color: var(--gold-soft); border-bottom: 2px solid var(--line); padding: 7px 10px; }
.md td { border-bottom: 1px solid var(--line-soft); padding: 7px 10px; vertical-align: top; }
.md tr:hover td { background: rgba(255,255,255,.02); }
.md hr { border: 0; height: 1px; background: var(--line); margin: 26px 0; }
.md img { max-width: 100%; border-radius: 8px; border: 1px solid var(--line); }
.md ul, .md ol { padding-left: 26px; }
.md .readaloud {
  font-family: var(--serif); font-size: 16.5px; font-style: italic;
  background: rgba(126,107,176,.07); border-left: 3px solid var(--arcane);
}

/* ── Tabs ── */
.tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--line); margin: 18px 0 22px; flex-wrap: wrap; }
.tab {
  padding: 8px 18px; cursor: pointer; color: var(--ink-dim); font-size: 14px;
  border: 1px solid transparent; border-bottom: none; border-radius: 8px 8px 0 0;
  position: relative; top: 1px; user-select: none;
}
.tab:hover { color: var(--ink); }
.tab.on { color: var(--gold-soft); background: var(--bg-card); border-color: var(--line); }

/* ── Toolbars / edit mode ── */
.toolbar { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin: 0 0 18px; }
.toolbar .spacer { flex: 1; }
.editor-area { width: 100%; min-height: 60vh; font-family: var(--mono); font-size: 13.5px; line-height: 1.6; }
.path-chip {
  font-family: var(--mono); font-size: 11.5px; color: var(--ink-faint);
  background: var(--bg-inset); padding: 3px 10px; border-radius: 6px; border: 1px solid var(--line-soft);
}

/* ── Prompt blocks ── */
.promptbox {
  background: var(--bg-inset); border: 1px solid var(--line); border-radius: 10px;
  padding: 14px 16px; margin: 12px 0; position: relative;
}
.promptbox h4 { margin: 0 0 8px; font-size: 14px; color: var(--gold-soft); }
.promptbox pre {
  white-space: pre-wrap; font-family: var(--sans); font-size: 13.5px; color: var(--ink);
  margin: 0; line-height: 1.55;
}
.promptbox .copy { position: absolute; top: 10px; right: 10px; }
.droppath {
  font-family: var(--mono); font-size: 12px; color: var(--forest);
  background: rgba(90,122,79,.1); border: 1px dashed rgba(90,122,79,.5);
  padding: 6px 12px; border-radius: 7px; display: inline-block; margin-top: 8px;
}

/* ── Soundboard ── */
.sb-track {
  display: flex; align-items: center; gap: 12px;
  background: var(--bg-card); border: 1px solid var(--line); border-radius: 9px;
  padding: 10px 14px; margin: 7px 0;
}
.sb-track.playing { border-color: var(--gold); box-shadow: 0 0 14px rgba(201,162,39,.15); }
.sb-cat {
  font-size: 10.5px; text-transform: uppercase; letter-spacing: .1em;
  width: 86px; flex: 0 0 86px; color: var(--ink-faint);
}
.sb-name { flex: 1; font-size: 14.5px; }
.sb-controls { display: flex; gap: 6px; align-items: center; }
.eq { display: inline-flex; gap: 2px; align-items: flex-end; height: 14px; margin-right: 4px; }
.eq span { width: 3px; background: var(--gold); animation: eq 1s infinite ease-in-out; }
.eq span:nth-child(2) { animation-delay: .2s; } .eq span:nth-child(3) { animation-delay: .4s; }
@keyframes eq { 0%,100% { height: 4px; } 50% { height: 14px; } }

/* ── Wizard ── */
.wiz-drafts { margin: 0 0 12px; align-items: center; }
.wiz-drafts .hint { font-size: 12.5px; }
.wiz-draftlist { width: 100%; margin-top: 6px; background: var(--bg-card); border: 1px solid var(--line); border-radius: 9px; padding: 8px 12px; }
.wiz-draftlist summary { cursor: pointer; color: var(--gold-soft); font-size: 13px; }
.wiz-steps { display: flex; gap: 0; margin-bottom: 28px; flex-wrap: wrap; }
.wiz-step {
  font-size: 12.5px; color: var(--ink-faint); padding: 5px 14px;
  border-bottom: 2px solid var(--line);
}
.wiz-step.on { color: var(--gold-soft); border-bottom-color: var(--gold); }
.wiz-step.done { color: var(--forest); border-bottom-color: var(--forest); }
.bigchoice { display: grid; gap: 14px; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); margin: 18px 0; }
.bigchoice .card { cursor: pointer; }
.bigchoice .card:hover, .bigchoice .card.on { border-color: var(--gold); }
.bigchoice .card.on { background: rgba(201,162,39,.06); }
.class-grid { display: grid; gap: 10px; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); margin: 12px 0 4px; }
.class-grid .class-pick { cursor: pointer; padding: 10px 14px; }
.class-grid .class-pick:hover { border-color: var(--gold); background: rgba(201,162,39,.05); }
.class-grid .class-pick h3 { margin: 0 0 4px; font-size: 16px; }
.class-grid .class-pick p { margin: 0; font-size: 13px; color: var(--ink-dim); }
.beginner-star { color: var(--gold-soft); }
legend[title], .f > span[title] { cursor: help; text-decoration: underline dotted var(--ink-faint); text-underline-offset: 3px; }

.statgrid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 10px; margin: 14px 0; }
.statbox { text-align: center; background: var(--bg-inset); border: 1px solid var(--line); border-radius: 9px; padding: 10px 4px; }
.statbox .ab { font-size: 11px; letter-spacing: .12em; color: var(--ink-dim); }
.statbox .val { font-family: var(--serif); font-size: 24px; color: var(--gold-soft); }
.statbox .mod { font-size: 12.5px; color: var(--ink-dim); }
.statbox select { margin-top: 6px; padding: 4px; font-size: 13px; text-align: center; }

/* ── Misc ── */
#toast {
  position: fixed; bottom: 26px; right: 26px; z-index: 50;
  display: flex; flex-direction: column; gap: 8px;
}
.toast-msg {
  background: var(--bg-card); border: 1px solid var(--gold); color: var(--ink);
  border-radius: 9px; padding: 11px 18px; box-shadow: var(--shadow); font-size: 14px;
  animation: toastin .2s ease-out;
}
.toast-msg.err { border-color: var(--blood); color: #d9a0a0; }
@keyframes toastin { from { transform: translateY(8px); opacity: 0; } }

.empty {
  border: 1px dashed var(--line); border-radius: 10px; padding: 26px;
  color: var(--ink-faint); font-style: italic; text-align: center;
}
.kv { display: grid; grid-template-columns: 170px 1fr; gap: 4px 16px; font-size: 14px; margin: 10px 0; }
.kv dt { color: var(--ink-faint); } .kv dd { margin: 0; }
.two-col { display: grid; grid-template-columns: 1fr 320px; gap: 30px; align-items: start; }
@media (max-width: 980px) { .two-col { grid-template-columns: 1fr; } }
.side-panel { position: sticky; top: 24px; }
.portrait-lg {
  width: 100%; border-radius: 10px; border: 1px solid var(--line); box-shadow: var(--shadow);
}
.gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)); gap: 12px; }
.gallery img { width: 100%; height: 150px; object-fit: cover; object-position: top; border-radius: 8px; border: 1px solid var(--line); cursor: pointer; }

audio { width: 100%; }
details { margin: 10px 0; }
summary { cursor: pointer; color: var(--gold-soft); font-family: var(--serif); font-size: 16px; }

/* ── Print / handout mode ── */
@media print {
  :root { --bg: #fff; --ink: #111; }
  body { background: #fff !important; background-image: none !important; color: #111; font-size: 11.5pt; }
  #sidebar, .toolbar, .tabs, button, .btn, .no-print, #toast, .promptbox .copy, .wiz-steps { display: none !important; }
  #main { padding: 0; max-width: none; }
  #shell { display: block; }
  .md, .md p, .md li, .md td, .card, .card p { color: #111 !important; }
  .md h1, .md h2, .md h3, .md h4, h1, h2, h3, .page-title, .card h3 { color: #000 !important; }
  .md a { color: #111 !important; border-bottom: none; }
  .md th { color: #000 !important; border-bottom: 2px solid #333; }
  .md td { border-bottom: 1px solid #bbb; }
  .md blockquote { background: #f3f3f3 !important; border-left: 3px solid #555; color: #222 !important; }
  .md code, .md pre { background: #f3f3f3 !important; color: #111 !important; border-color: #ccc; }
  .card { background: #fff; border: 1px solid #999; box-shadow: none; }
  .badge { color: #333 !important; border-color: #999; }
  .page-sub, .hint, .meta { color: #444 !important; }
  .two-col { grid-template-columns: 1fr; }
  .side-panel .promptbox, .side-panel button, .side-panel .card { display: none; }
  .md { max-width: none; }
  /* Reference handouts (spells / abilities): tidy cut-friendly cards */
  .ref-results .ref-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .ref-card { break-inside: avoid; border: 1px solid #999; box-shadow: none; }
  .ref-card.flash { animation: none; }
  .ref-group { break-after: avoid; }
  input[type=search], .chips { display: none !important; }
  /* CB-O2: tidy character-sheet / handout printing */
  .md h1, .md h2, .md h3, .md h4 { break-after: avoid; }
  .md table, .md blockquote, .md pre, .md ul, .md ol { break-inside: avoid; }
}

/* spell cards: cut-line card grid when printing */
.printcard { /* screen: invisible wrapper */ }
@media print {
  .cardified { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
  .cardified > .precard { display: none; }
  .printcard {
    border: 1.5px dashed #777; padding: 10px 14px; margin: 0;
    break-inside: avoid; page-break-inside: avoid; font-size: 10pt;
  }
  .printcard h2 { font-size: 13pt; margin: 2px 0 6px; }
  .printcard hr { display: none; }
}

/* ── Prop notes (printable found-notes) ── */
.prop-note {
  background: #f4e9d3; color: #2a2018;
  border: 1px solid #c9b68a; border-radius: 4px;
  padding: 38px 44px; margin: 20px auto; max-width: 620px;
  font-family: Georgia, 'Iowan Old Style', serif;
  box-shadow: 0 4px 18px rgba(0,0,0,.4);
  position: relative;
}
.prop-note.handwritten { font-style: italic; font-size: 18px; line-height: 1.9; }
.prop-note.formal { font-size: 15.5px; line-height: 1.8; letter-spacing: .02em; }
.prop-note.scrawled { font-style: italic; font-size: 20px; line-height: 1.7; transform: rotate(-.6deg); }
.prop-note h2 { font-size: 22px; margin: 0 0 18px; color: #2a2018; text-align: center; letter-spacing: .06em; }
.prop-note .signoff { text-align: right; margin-top: 26px; font-style: italic; }
.prop-note::before, .prop-note::after {
  content: ''; position: absolute; left: 0; right: 0; height: 8px;
  background: radial-gradient(circle at 10px -4px, transparent 7px, #f4e9d3 8px) repeat-x;
  background-size: 20px 12px;
}
.prop-note.torn::before { top: -6px; }
.prop-note.torn::after { bottom: -6px; transform: scaleY(-1); }
@media print {
  .prop-note { box-shadow: none; border: 1px solid #a89468; background: #f8f0dd !important;
    -webkit-print-color-adjust: exact; print-color-adjust: exact; }
}

@media (max-width: 760px) {
  #shell { flex-direction: column; }
  #sidebar { width: 100%; height: auto; position: static; flex: none; }
  #main { padding: 20px 18px 60px; }
  .statgrid { grid-template-columns: repeat(3, 1fr); }
}

/* ── Buttons: anchor variants ── */
.btn.small { font-size: 12.5px; padding: 4px 11px; }
.btn.primary { background: linear-gradient(180deg, #5b4a17, #46390f); border-color: #8a702a; color: #f0e3b2; font-weight: 600; }
.btn.primary:hover { border-color: var(--gold); color: #fff4cf; }
button.tiny, .tiny {
  font-size: 11px; padding: 2px 7px; border-radius: 6px; line-height: 1.3;
  background: var(--bg-inset); border: 1px solid var(--line); color: var(--ink-dim);
}
button.tiny:hover, .tiny:hover { border-color: var(--gold); color: var(--gold-soft); }
button.tiny.on { border-color: var(--gold); color: var(--gold-soft); background: rgba(201,162,39,.12); }

/* ── Rules & Spells reference ── */
.ref-group { font-family: var(--serif); color: var(--gold-soft); font-size: 19px;
  margin: 26px 0 12px; border-bottom: 1px solid var(--line-soft); padding-bottom: 6px; }
.ref-group .count { color: var(--ink-faint); font-size: 13px; font-weight: 400; }
.ref-grid { display: grid; gap: 14px; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); }
.ref-card { background: var(--bg-card); border: 1px solid var(--line); border-radius: 11px;
  padding: 12px 16px; box-shadow: var(--shadow); }
.ref-card h3 { margin: 0 0 6px; color: var(--gold-soft); font-size: 17px; }
.ref-card p { margin: 6px 0; font-size: 14px; }
.chip-label { font-size: 11px; text-transform: uppercase; letter-spacing: .1em;
  color: var(--ink-faint); align-self: center; margin-right: 2px; }
a.spell-link { color: var(--arcane); border-bottom: 1px dotted var(--arcane); text-decoration: none; }
a.spell-link:hover { color: var(--gold-soft); border-bottom-color: var(--gold); }
.ref-card.flash { animation: refflash 1.6s ease-out; }
@keyframes refflash { 0% { box-shadow: 0 0 0 2px var(--gold) inset, 0 0 18px rgba(201,162,39,.4); } 100% { box-shadow: none; } }
a.ref-card.search-hit { display: block; color: inherit; text-decoration: none; }
a.ref-card.search-hit:hover { border-color: var(--gold); }
a.ref-card.search-hit .meta { color: var(--ink-dim); font-size: 13px; margin-bottom: 6px; }
a.ref-card.search-hit p { margin: 0; color: var(--ink-dim); font-size: 13.5px; }

/* ── Stat-block cards ── */
.statblock { display: flex; flex-direction: column; }
.statblock .sb-head { display: flex; align-items: center; gap: 10px; }
.statblock .sb-head h3 { margin: 0; flex: 1; }
.sb-type { font-style: italic; color: var(--ink-dim); font-size: 13.5px; margin: 2px 0 8px; }
.sb-vitals { display: flex; gap: 16px; flex-wrap: wrap; font-size: 14px;
  padding: 7px 0; border-top: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft); }
.sb-vitals strong { color: var(--gold-soft); }
.sb-grid { grid-template-columns: repeat(6, 1fr); gap: 6px; margin: 12px 0; }
.sb-grid .statbox { padding: 6px 2px; }
.sb-grid .val { font-size: 18px; }
.sb-field { margin: 3px 0; font-size: 13.5px; color: var(--ink-dim); }
.sb-field strong { color: var(--ink); }
.sb-block { margin: 9px 0 0; }
.sb-block-h { font-size: 11px; text-transform: uppercase; letter-spacing: .1em;
  color: var(--ember); border-bottom: 1px solid var(--line-soft); padding-bottom: 3px; margin-bottom: 4px; }
.sb-item { font-size: 13.5px; margin: 3px 0; }
.sb-item p { margin: 2px 0; }
.sb-tactics { font-size: 13.5px; color: var(--ink-dim); margin: 10px 0 4px;
  background: var(--bg-inset); border-left: 3px solid var(--gold); padding: 7px 11px; border-radius: 0 7px 7px 0; }
.sb-foot { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; margin-top: 10px;
  padding-top: 9px; border-top: 1px solid var(--line-soft); }
.sb-area { min-height: 70px; font-family: var(--mono); font-size: 13px; }

/* ── Encounter tracker ── */
.enc-controls { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 16px; }
.enc-title { flex: 1; min-width: 180px; font-family: var(--serif); font-size: 17px; color: var(--gold-soft); }
.enc-round { font-size: 14px; color: var(--ink-dim); padding: 0 6px; }
.enc-round strong { color: var(--gold-soft); font-size: 18px; }
.enc-table { display: flex; flex-direction: column; gap: 6px; margin-bottom: 22px; }
.enc-row { display: grid; grid-template-columns: 58px 1.4fr 1.5fr 1.6fr auto; gap: 10px; align-items: center;
  background: var(--bg-card); border: 1px solid var(--line); border-left-width: 4px; border-radius: 9px; padding: 8px 12px; }
.enc-row.side-pc { border-left-color: var(--forest); }
.enc-row.side-monster { border-left-color: var(--blood); }
.enc-row.side-npc { border-left-color: var(--arcane); }
.enc-row.current { box-shadow: 0 0 0 2px var(--gold) inset; background: rgba(201,162,39,.06); }
.enc-row.down { opacity: .62; }
.enc-init { text-align: center; }
.enc-init .init-val { font-family: var(--serif); font-size: 22px; color: var(--gold-soft); line-height: 1; }
.enc-name .nm { font-weight: 600; display: flex; align-items: center; gap: 6px; }
.ac-mods { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 4px; }
.ac-mods .tiny { font-size: 10.5px; padding: 1px 6px; }
.enc-hp .hp-num { font-size: 14px; }
.enc-hp .hp-num .temp { color: var(--arcane); font-weight: 600; }
.hpbar { height: 6px; background: var(--bg-inset); border-radius: 4px; overflow: hidden; margin: 4px 0; }
.hpfill { height: 100%; background: linear-gradient(90deg, var(--blood), var(--ember)); }
.enc-row.side-pc .hpfill { background: linear-gradient(90deg, #3d5e36, var(--forest)); }
.hp-ctl { display: flex; gap: 4px; align-items: center; flex-wrap: wrap; }
.hp-ctl .dmg:hover { border-color: var(--blood); color: #cf7b7b; }
.hp-ctl .heal:hover { border-color: var(--forest); color: #92b585; }
.enc-cond { display: flex; gap: 4px; align-items: center; flex-wrap: wrap; }
.cond-chip { font-size: 11px; padding: 2px 6px; border-radius: 6px; background: var(--bg-inset);
  border: 1px solid var(--line); color: var(--ink-dim); display: inline-flex; align-items: center; gap: 3px; }
.cond-chip .x { border: none; background: none; padding: 0 2px; color: var(--ink-faint); font-size: 13px; }
.cond-add { font-size: 11px; padding: 2px 4px; }
.enc-tail { display: flex; flex-direction: column; gap: 5px; align-items: flex-end; }
.deathsaves { display: flex; gap: 3px; align-items: center; }
.ds-label { font-size: 10px; text-transform: uppercase; letter-spacing: .08em; color: var(--ink-faint); margin-right: 3px; }
.pip { width: 13px; height: 13px; border-radius: 50%; border: 1px solid var(--line); cursor: pointer; display: inline-block; }
.pip.succ.on { background: var(--forest); border-color: var(--forest); }
.pip.fail.on { background: var(--blood); border-color: var(--blood); }
.verdict { font-size: 11px; font-weight: 700; letter-spacing: .05em; margin-left: 5px; }
.verdict.stable { color: #92b585; }
.verdict.dead { color: #cf7b7b; }
.remove:hover { border-color: var(--blood); color: #cf7b7b; }
.enc-add { display: flex; flex-direction: column; gap: 8px; }
.enc-add > details { background: var(--bg-card); border: 1px solid var(--line); border-radius: 9px; padding: 10px 14px; }
.enc-add summary { cursor: pointer; color: var(--gold-soft); font-size: 14px; }
.enc-roster-h { font-size: 11px; text-transform: uppercase; letter-spacing: .1em;
  color: var(--ember); margin: 14px 0 2px; }
button.tiny.edit { color: var(--ink-faint); }
button.tiny.edit:hover { color: var(--gold-soft); }

/* Defeated combatants (auto-skipped in turn order) */
.enc-row.defeated { opacity: .5; filter: grayscale(.5); }
.enc-row.defeated .init-val { text-decoration: line-through; }

/* Inline edit row */
.enc-row.editing { display: block; }
.enc-editgrid { display: flex; gap: 10px; flex-wrap: wrap; align-items: flex-end; }
.enc-editgrid label { display: flex; flex-direction: column; gap: 2px; }
.enc-editgrid input, .enc-editgrid select { margin: 0; }
.enc-editbtns { display: flex; gap: 6px; align-self: flex-end; }

/* Tracked concentration save prompt */
.conc-save { display: flex; gap: 6px; align-items: center; margin-top: 4px;
  font-size: 12px; color: var(--arcane); }

/* Legendary action counter (A8) */
.legendary { display: flex; gap: 4px; align-items: center; margin-top: 4px; }
.legendary .lg-label { font-size: 10px; text-transform: uppercase; letter-spacing: .08em; color: var(--ink-faint); margin-right: 3px; }
.pip.lg { border-color: rgba(201,162,39,.6); cursor: pointer; }
.pip.lg.on { background: var(--gold); border-color: var(--gold); }

/* F1: bigger touch targets on tablets / touch devices */
@media (pointer: coarse) {
  button.tiny, .tiny { padding: 5px 10px; font-size: 12.5px; }
  .pip { width: 18px; height: 18px; }
  .cond-add, .enc-hpfield, .enc-init .init-val { min-height: 30px; }
  .enc-row { gap: 12px; padding: 10px 12px; }
}

/* Minion groups */
.enc-group { border: 1px solid var(--line); border-radius: 9px; overflow: hidden; }
.enc-group-h { display: flex; gap: 8px; align-items: center; padding: 6px 10px;
  background: var(--bg-inset); border-bottom: 1px solid var(--line-soft); }
.enc-group-h strong { color: var(--gold-soft); }
.enc-group-h .spacer { flex: 1; }
.enc-group .enc-row { border: none; border-bottom: 1px solid var(--line-soft); border-radius: 0; }
.enc-group .enc-row:last-child { border-bottom: none; }
.enc-group-mini { padding: 7px 12px; font-size: 12.5px; color: var(--ink-dim); }

/* Difficulty readout (vs party strength) */
.enc-diff { display: flex; gap: 12px; align-items: center; flex-wrap: wrap;
  padding: 8px 12px; margin-bottom: 14px; border: 1px solid var(--line);
  border-left-width: 4px; border-radius: 9px; background: var(--bg-card); }
.enc-diff .diff-band { font-weight: 700; letter-spacing: .05em; font-size: 14px; }
.enc-diff .diff-detail { font-size: 13px; }
.enc-diff .spacer { flex: 1; }
.enc-diff.band-trivial { border-left-color: var(--ink-faint); }
.enc-diff.band-trivial .diff-band { color: var(--ink-faint); }
.enc-diff.band-easy { border-left-color: var(--forest); }
.enc-diff.band-easy .diff-band { color: #92b585; }
.enc-diff.band-medium { border-left-color: var(--gold); }
.enc-diff.band-medium .diff-band { color: var(--gold-soft); }
.enc-diff.band-hard { border-left-color: var(--ember); }
.enc-diff.band-hard .diff-band { color: #e08a5e; }
.enc-diff.band-deadly { border-left-color: var(--blood); }
.enc-diff.band-deadly .diff-band { color: #cf7b7b; }
.enc-picker { display: flex; flex-direction: column; gap: 4px; margin-top: 10px; max-height: 320px; overflow-y: auto; }
.enc-pick-row { display: flex; gap: 8px; align-items: center; padding: 5px 8px; border-bottom: 1px solid var(--line-soft); }
.enc-pick-row .spacer { flex: 1; }
@media (max-width: 880px) {
  .enc-row { grid-template-columns: 48px 1fr; }
  .enc-row > .enc-hp, .enc-row > .enc-cond, .enc-row > .enc-tail { grid-column: 2; }
}

/* ── Build-Night Kit (CB-A1) ── */
.kit-section { margin: 0 0 30px; }
.kit-section-head { display: flex; align-items: center; gap: 10px; margin-bottom: 6px; }
.kit-section-head h2 { margin: 0; font-family: var(--serif); color: var(--gold-soft); }
.kit-print-title { display: none; }
.kit-note { color: var(--ink-dim); font-size: 13px; margin: 0 0 12px; }
.kit-grid { display: grid; gap: 10px; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
.kit-card { padding: 10px 14px; }
.kit-card h3 { margin: 0 0 4px; font-size: 16px; color: var(--gold-soft); }
.kit-group { font-family: var(--serif); font-size: 15px; color: var(--ember); margin: 18px 0 8px; border-bottom: 1px dotted var(--line-soft); padding-bottom: 3px; }
.kit-group:first-child { margin-top: 4px; }
.kit-book { display: inline-block; font-size: 10px; font-weight: 600; letter-spacing: .04em; padding: 0 5px; border: 1px solid var(--line); border-radius: 4px; color: var(--ink-faint); vertical-align: middle; }
.kit-feel { margin: 0 0 6px; font-size: 13px; color: var(--ink-dim); }
.kit-meta { font-size: 12.5px; color: var(--ink-faint); }
.kit-tag { font-size: 11px; color: var(--arcane); }
.kit-subs { margin-top: 8px; }
.kit-subs-h { font-size: 10.5px; text-transform: uppercase; letter-spacing: .08em; color: var(--ember); margin-bottom: 2px; }
.kit-sub { font-size: 12px; margin: 3px 0; color: var(--ink-dim); }
.kit-bglist p { margin: 6px 0; font-size: 14px; }
.kit-field { margin: 12px 0; }
.kit-label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 2px; }
.kit-hint { display: block; font-size: 11.5px; font-style: italic; color: var(--ink-faint); margin: 0 0 5px; }
.kit-blank { display: block; height: 22px; border-bottom: 1px solid var(--ink-faint); }
.kit-blank.tall { height: 46px; }
.kit-circle { font-size: 13px; color: var(--ink-dim); }
.kit-intake { columns: 2; column-gap: 28px; }
.kit-intake .kit-field { break-inside: avoid; margin: 9px 0; }
@media (max-width: 720px) { .kit-intake { columns: 1; } }

@media print {
  .kit-print-title { display: block; font-family: var(--serif); color: #000 !important; margin: 0 0 6px; }
  .kit-section { break-before: page; }
  .kit-section:first-of-type { break-before: avoid; }
  .kit-card { break-inside: avoid; border: 1px solid #999; background: #fff; }
  .kit-card h3, .kit-section-head h2, .kit-print-title { color: #000 !important; }
  .kit-feel, .kit-meta, .kit-sub, .kit-note, .kit-circle { color: #333 !important; }
  .kit-subs-h { color: #000 !important; }
  .kit-group { color: #000 !important; break-after: avoid; }
  .kit-book { border-color: #999; color: #333 !important; }
  .kit-blank { border-bottom: 1px solid #333; }
  /* Reliable multi-column cheat-sheets in print (grid auto-fill isn't universal) */
  .kit-grid { display: block; columns: 2; column-gap: 16px; }
  .kit-grid .kit-card { break-inside: avoid; margin: 0 0 10px; }
  body.kit-printing .kit-section:not(.kit-print-target) { display: none !important; }
  body.kit-printing .kit-print-target { break-before: avoid; }
  #mode-chip { display: none !important; }
}

/* Published-mode chrome — provenance & read-only affordances (spec §7). */
#mode-chip {
  margin: 16px 10px 4px; padding: 10px 12px; border-radius: 8px;
  border: 1px solid rgba(201,162,39,.4); background: var(--bg-card);
}
#mode-chip .mc-tag { font-family: var(--serif); color: var(--gold-soft); font-size: 14px; margin-bottom: 4px; }
#mode-chip .mc-msg { font-size: 12px; line-height: 1.35; margin-bottom: 9px; }
#mode-chip button { width: 100%; }
.card .badge.prov { margin: 0 0 6px; }
