/* DungeonWiz - NES / early-80s pixel aesthetic.
   Restricted palette, square corners, chunky 2-color pixel borders, scanlines. */
:root {
  --bg: #0b0f1a;
  --panel: #10182a;
  --panel2: #16223a;
  --ink: #e7e9d3;       /* off-white */
  --muted: #7d8bb0;
  --gold: #fbd44c;
  --gold-dim: #b8860b;
  --green: #62c370;
  --red: #e2554a;
  --blue: #4f9df0;
  --black: #05070d;
  --border: #2a3a59;
}
* { box-sizing: border-box; }
html, body { height: 100%; margin: 0; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: "VT323", "Courier New", monospace;
  font-size: 20px; line-height: 1.35;
  image-rendering: pixelated;
  -webkit-font-smoothing: none;
}
/* scanline + CRT overlay */
body::after {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 50;
  background: repeating-linear-gradient(to bottom, rgba(0,0,0,0) 0, rgba(0,0,0,0) 2px, rgba(0,0,0,0.16) 3px, rgba(0,0,0,0) 4px);
  mix-blend-mode: multiply;
}
.pixel, .brand, .badge, .who, h3, .dlg-head h2, .score b, .abil b { font-family: "Press Start 2P", monospace; }

/* chunky pixel border helper via box-shadow (no anti-aliasing) */
.panel, section, aside .card, .die, .badge, button, .btn, #input-bar input, #lib-q, .field input, .field textarea, dialog, .abil, .score, .tag, .chip, .hpbar {
  border-radius: 0 !important;
}

header.topbar {
  display: flex; align-items: center; gap: 16px;
  padding: 10px 14px; background: var(--panel);
  border-bottom: 4px solid var(--black);
  position: sticky; top: 0; z-index: 10;
}
.brand { color: var(--gold); font-size: 18px; letter-spacing: 1px; text-decoration: none; text-shadow: 2px 2px 0 var(--black); }
.brand small { color: var(--muted); font-size: 7px; display: block; margin-top: 5px; letter-spacing: 0; }
.topbar .meta { color: var(--muted); margin-left: auto; display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.badge { background: var(--panel2); border: 2px solid var(--border); padding: 5px 8px; color: var(--ink); font-size: 9px; }
.badge.mode { color: var(--gold); border-color: var(--gold-dim); }

button, .btn {
  font-family: "Press Start 2P", monospace; font-size: 10px; cursor: pointer; color: var(--ink);
  background: var(--panel2); border: 2px solid var(--ink); box-shadow: 3px 3px 0 var(--black);
  padding: 9px 11px; text-transform: uppercase;
}
button:hover, .btn:hover { background: #1f3050; }
button:active { transform: translate(2px, 2px); box-shadow: 1px 1px 0 var(--black); }
button.primary { background: var(--gold); color: var(--black); border-color: var(--black); }
button:disabled { opacity: .5; cursor: not-allowed; }

main#app { display: grid; grid-template-columns: 1fr 332px; gap: 14px; padding: 14px; max-width: 1180px; margin: 0 auto; align-items: start; }
@media (max-width: 880px) { main#app { grid-template-columns: 1fr; } aside#side { order: -1; } }

section, aside .card { background: var(--panel); border: 4px solid var(--black); box-shadow: inset 0 0 0 2px var(--border); }

#story { display: flex; flex-direction: column; min-height: 72vh; }
#log { padding: 16px; overflow-y: auto; flex: 1; display: flex; flex-direction: column; gap: 12px; max-height: 62vh; }
.msg { padding: 10px 12px; max-width: 94%; border: 2px solid var(--border); }
.msg.gm { background: #13203a; border-left: 6px solid var(--gold); }
.msg.player { background: #102338; border-left: 6px solid var(--blue); align-self: flex-end; }
.msg.system { background: transparent; color: var(--muted); border: 0; align-self: center; text-align: center; }
.msg .who { font-size: 8px; color: var(--muted); margin-bottom: 7px; display: block; }
.msg.gm .who { color: var(--gold); }

#dice-tray { display: flex; flex-wrap: wrap; gap: 8px; padding: 10px 16px 0; }
.die { display: flex; flex-direction: column; gap: 3px; align-items: center; background: var(--black); border: 2px solid var(--border); padding: 8px 10px; min-width: 96px; }
.die .d20 { font-family: "Press Start 2P", monospace; font-size: 16px; color: var(--ink); }
.die .lbl { font-size: 14px; color: var(--muted); text-align: center; line-height: 1.1; }
.die .res { font-size: 14px; font-weight: 700; }
.die.hit, .die.success { border-color: var(--green); } .die.hit .res, .die.success .res { color: var(--green); }
.die.miss, .die.fail { border-color: var(--red); } .die.miss .res, .die.fail .res { color: var(--red); }
.die.rolling .d20 { animation: blink .5s steps(2) infinite; }
@keyframes blink { 50% { color: var(--gold); } }

#suggestions { display: flex; flex-wrap: wrap; gap: 8px; padding: 12px 16px 0; }
.chip { background: #13203a; border: 2px solid var(--gold-dim); color: var(--gold); padding: 7px 12px; font-size: 16px; cursor: pointer; font-family: "VT323", monospace; }
.chip:hover { background: #1b2c4a; }
#input-bar { display: flex; gap: 8px; padding: 14px 16px; border-top: 2px solid var(--border); }
#input-bar input { flex: 1; background: var(--black); border: 2px solid var(--border); color: var(--ink); padding: 10px 12px; font-size: 19px; font-family: "VT323", monospace; }
#input-bar input:focus { outline: none; border-color: var(--gold); }

aside#side { display: flex; flex-direction: column; gap: 14px; }
aside .card { padding: 12px 14px; }
aside h3 { font-size: 10px; color: var(--gold); margin: 0 0 10px; }
#map { width: 100%; height: 150px; display: block; background: #05070d; border: 2px solid var(--border); image-rendering: pixelated; }
#scene-meta { font-size: 17px; color: var(--muted); margin-top: 8px; }

.sheet-row { display: flex; justify-content: space-between; padding: 2px 0; border-bottom: 2px dotted var(--border); }
.sheet-name { font-family: "Press Start 2P", monospace; font-size: 11px; color: var(--gold); margin-bottom: 4px; }
.hpbar { height: 16px; background: #2a1414; border: 2px solid var(--border); overflow: hidden; margin: 7px 0; }
.hpbar > span { display: block; height: 100%; background: var(--green); transition: width .3s steps(8); }
.abil-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; margin-top: 8px; }
.abil { background: var(--black); border: 2px solid var(--border); padding: 6px; text-align: center; }
.abil b { display: block; font-size: 13px; color: var(--gold); }
.abil small { color: var(--muted); font-size: 13px; }
.tags { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 8px; }
.tag { background: var(--black); border: 2px solid var(--border); font-size: 14px; padding: 2px 6px; color: var(--muted); }
.purse { display: flex; gap: 6px; margin: 10px 0 4px; }
.coin { flex: 1; text-align: center; border: 2px solid var(--border); background: var(--black); padding: 5px 0; font-family: "Press Start 2P", monospace; font-size: 9px; }
.coin.gp { color: var(--gold); border-color: var(--gold-dim); }
.coin.sp { color: #cdd6e6; }
.coin.cp { color: #c9824f; }
.inv-title { font-family: "Press Start 2P", monospace; font-size: 9px; color: var(--muted); margin: 12px 0 6px; }
.inv-list { display: flex; flex-wrap: wrap; gap: 5px; max-height: 140px; overflow-y: auto; }

#lib-q { width: 100%; background: var(--black); border: 2px solid var(--border); color: var(--ink); padding: 8px; font-size: 17px; margin-bottom: 8px; font-family: "VT323", monospace; }
.lib-hit { font-size: 16px; padding: 7px 0; border-top: 2px solid var(--border); }
.lib-hit b { color: var(--gold); }

dialog { background: var(--panel); color: var(--ink); border: 4px solid var(--gold); box-shadow: 0 0 0 4px var(--black); max-width: 560px; width: 92%; padding: 0; }
dialog::backdrop { background: rgba(3,5,10,.85); }
.dlg-head { padding: 16px 18px; border-bottom: 2px solid var(--border); }
.dlg-head h2 { margin: 0; font-size: 13px; color: var(--gold); }
.dlg-body { padding: 16px 18px; max-height: 64vh; overflow-y: auto; }
.dlg-foot { padding: 14px 18px; border-top: 2px solid var(--border); display: flex; justify-content: space-between; gap: 10px; }
.field { margin-bottom: 14px; }
.field label { display: block; font-size: 15px; color: var(--muted); margin-bottom: 6px; }
.field input, .field textarea { width: 100%; background: var(--black); border: 2px solid var(--border); color: var(--ink); padding: 9px; font-size: 18px; font-family: "VT323", monospace; }
.cards { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.pick { text-align: left; padding: 10px; font-family: "VT323", monospace; font-size: 16px; text-transform: none; }
.pick.active { border-color: var(--gold); box-shadow: 3px 3px 0 var(--gold-dim); }
.pick b { color: var(--gold); display: block; margin-bottom: 4px; font-family: "Press Start 2P", monospace; font-size: 10px; }
.pick small { color: var(--muted); font-size: 15px; line-height: 1.25; }
.warn { color: var(--red); font-size: 16px; margin-top: 8px; }
.roll-scores { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin: 10px 0; }
.score { background: var(--black); border: 2px solid var(--border); padding: 8px; text-align: center; }
.score b { display: block; font-size: 14px; color: var(--gold); }
.score small { color: var(--muted); font-size: 13px; }
.hint { color: var(--muted); font-size: 16px; }
a.link { color: var(--gold); }
