:root {
  color-scheme: dark;
  --bg: #101114;
  --panel: #191d22;
  --line: #303640;
  --text: #f4efe6;
  --muted: #b8b1a6;
  --gold: #d9a948;
  --green: #65b7a6;
  --danger: #df736b;
}
* { box-sizing: border-box; }
body { margin: 0; min-height: 100vh; background: var(--bg); color: var(--text); font-family: Inter, ui-sans-serif, system-ui, sans-serif; }
.topbar, main { width: min(1180px, calc(100% - 32px)); margin: 0 auto; }
.topbar { display: flex; justify-content: space-between; gap: 20px; align-items: end; padding: 30px 0 18px; border-bottom: 1px solid var(--line); }
h1, h2, h3, p { margin: 0; }
h1 { font-size: 34px; line-height: 1.1; }
h2 { font-size: 22px; }
.eyebrow { color: var(--green); font-size: 13px; font-weight: 800; text-transform: uppercase; }
main, #campaign-panel { display: grid; gap: 22px; padding: 22px 0 48px; }
#campaign-panel { padding: 0; }
.panel, .notice, .card { border: 1px solid var(--line); border-radius: 8px; background: var(--panel); }
.panel { padding: 18px; }
.notice { display: grid; gap: 6px; padding: 14px; color: var(--muted); }
.hidden { display: none !important; }
.section-head, #auth, .actions, .inline-form, .file-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 14px; margin-top: 14px; }
.card { padding: 15px; min-height: 132px; display: grid; gap: 10px; }
.card p, #option-hint { color: var(--muted); }
button, .button-link { min-height: 38px; border: 1px solid var(--line); border-radius: 6px; background: #242a31; color: var(--text); padding: 8px 12px; font-weight: 800; text-decoration: none; cursor: pointer; }
button:hover, .button-link:hover { border-color: var(--gold); }
.form-grid, .rules-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 14px; }
.rules-grid { grid-template-columns: repeat(2, 1fr); }
label { display: grid; gap: 6px; color: var(--muted); font-weight: 700; }
input, textarea, pre { width: 100%; border: 1px solid var(--line); border-radius: 6px; background: #111419; color: var(--text); padding: 10px; font: inherit; }
textarea { min-height: 96px; resize: vertical; }
pre { min-height: 120px; overflow: auto; white-space: pre-wrap; color: var(--muted); }
.form-grid textarea, .form-grid button, .wide, .wide-text { grid-column: 1 / -1; }
.file-list { display: grid; gap: 8px; margin-top: 14px; }
.file-row { min-height: 42px; border: 1px solid var(--line); border-radius: 6px; padding: 8px 10px; color: var(--muted); }
.file-row span:first-child { color: var(--text); font-weight: 700; }
.empty { color: var(--muted); }
@media (max-width: 760px) {
  .topbar, .section-head, #auth, .inline-form, .file-row { display: grid; align-items: start; }
  .form-grid, .rules-grid { grid-template-columns: 1fr; }
}
.card-title { display: flex; align-items: start; justify-content: space-between; gap: 10px; }
.status { border: 1px solid var(--line); border-radius: 999px; padding: 3px 8px; color: var(--muted); font-size: 12px; font-weight: 800; text-transform: capitalize; }
.status.approved { border-color: var(--green); color: var(--green); }
.status.changes_requested { border-color: var(--danger); color: var(--danger); }
.status.submitted { border-color: var(--gold); color: var(--gold); }
.dm-note { border-left: 3px solid var(--gold); padding-left: 10px; }
.character-card .actions { justify-content: start; }
