:root{
  --bg:#0d1117; --panel:#161b22; --panel2:#1c2330; --line:#2a3340; --ink:#e6edf3;
  --dim:#8b97a6; --accent:#4ea1ff; --accent2:#7ee787; --warn:#ff7b72; --gold:#ffd479;
  --party:#4ea1ff; --enemy:#ff7b72; --mp:#a371f7; --atb:#ffd479; --limit:#7ee787;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;background:var(--bg);color:var(--ink);
  font:13px/1.45 -apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
body{display:flex;flex-direction:column}
h3{margin:14px 0 6px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--dim)}
button{font:inherit;color:var(--ink);background:var(--panel2);border:1px solid var(--line);
  border-radius:6px;padding:6px 10px;cursor:pointer}
button:hover{border-color:var(--accent)}
button.primary{background:var(--accent);border-color:var(--accent);color:#08131f;font-weight:600}
button.ghost{background:transparent;border-style:dashed;color:var(--dim);width:100%}
button:disabled{opacity:.4;cursor:not-allowed}
button.hidden,.hidden{display:none!important}
input,select{font:inherit;color:var(--ink);background:#0b0f14;border:1px solid var(--line);
  border-radius:6px;padding:5px 7px;width:100%}
label{display:block;margin:6px 0;color:var(--dim);font-size:12px}
label input,label select{margin-top:3px}
.row{display:flex;gap:8px}.row>label{flex:1}

/* top bar */
#topbar{display:flex;align-items:center;gap:18px;padding:0 16px;height:48px;
  background:linear-gradient(180deg,#11161d,#0d1117);border-bottom:1px solid var(--line)}
.brand{font-weight:800;letter-spacing:.04em}.brand span{color:var(--accent)}
.tabs{display:flex;gap:4px;flex:1}
.tab{background:transparent;border:none;color:var(--dim);padding:8px 12px;border-radius:6px}
.tab.active{color:var(--ink);background:var(--panel2)}
.status{font-size:12px;color:var(--dim);padding:4px 10px;border:1px solid var(--line);border-radius:20px}
.status.ok{color:var(--accent2);border-color:#21452b}
.status.bad{color:var(--warn);border-color:#5a2a26}

/* views */
.view{flex:1;display:none;grid-template-columns:300px 1fr 340px;min-height:0}
.view.active{display:grid}
.panel{background:var(--panel);border-right:1px solid var(--line);padding:12px;overflow:auto}
.panel.right{border-right:none;border-left:1px solid var(--line)}
.stage{position:relative;min-width:0;min-height:0;background:radial-gradient(circle at 50% 30%,#10161f,#0a0d12)}
.stage.scroll{overflow:auto;background:var(--bg)}
.msg,.info{font-size:12px;color:var(--dim);margin-top:8px;white-space:pre-wrap}
.actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.actions button{flex:1}

/* battle stage */
#battle-canvas,#field-canvas{position:absolute;inset:0}
#battle-canvas canvas,#field-canvas canvas{display:block}
#battle-hud{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.unit-hud{position:absolute;transform:translate(-50%,-100%);width:96px;text-align:center;
  font-size:11px;filter:drop-shadow(0 1px 2px #000)}
.unit-hud .nm{font-weight:600;white-space:nowrap}
.unit-hud.enemy .nm{color:var(--enemy)}.unit-hud.party .nm{color:var(--party)}
.unit-hud.down{opacity:.35}
.bar{height:4px;border-radius:3px;background:#0009;margin-top:2px;overflow:hidden}
.bar>i{display:block;height:100%}
.bar.hp>i{background:var(--accent2)} .bar.mp>i{background:var(--mp)}
.bar.atb>i{background:var(--atb)} .bar.limit>i{background:var(--limit)}
.hud-status{font-size:9px;color:var(--gold)}
.float{position:absolute;transform:translate(-50%,-50%);font-weight:800;pointer-events:none;
  text-shadow:0 2px 4px #000;animation:floatup 1s ease-out forwards}
.float.dmg{color:#fff}.float.crit{color:var(--gold);font-size:20px}.float.heal{color:var(--accent2)}
.float.miss{color:var(--dim)}.float.weak{color:var(--warn)}
@keyframes floatup{0%{opacity:0;transform:translate(-50%,0)}15%{opacity:1}100%{opacity:0;transform:translate(-50%,-40px)}}

.transport{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;gap:6px;
  padding:8px 10px;background:#0b0f14ee;border-top:1px solid var(--line);flex-wrap:wrap}
.transport .sep{flex:0 0 1px;height:20px;background:var(--line);margin:0 4px}
.transport select{width:auto;min-width:120px}
.prompt{color:var(--dim)}.prompt.ready{color:var(--gold);font-weight:600}
.outcome{margin-left:auto;font-weight:700}
.outcome.win{color:var(--accent2)}.outcome.lose{color:var(--warn)}

/* inspector */
.subtabs,.data-types{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}
.subtab{background:transparent;border:none;color:var(--dim);padding:6px 9px;border-radius:6px;font-size:12px}
.subtab.active{color:var(--ink);background:var(--panel2)}
.subview{display:none}.subview.active{display:block}
.unit-card{border:1px solid var(--line);border-radius:8px;padding:8px;margin-bottom:8px;background:var(--panel2)}
.unit-card.ready{border-color:var(--gold)}
.unit-card .top{display:flex;justify-content:space-between;align-items:center}
.unit-card .nm{font-weight:600}.unit-card.enemy .nm{color:var(--enemy)}.unit-card.party .nm{color:var(--party)}
.unit-card .meta{font-size:11px;color:var(--dim)}
.kv{display:flex;justify-content:space-between;font-size:11px;color:var(--dim);margin-top:3px}
.tags{margin-top:4px}.tag{display:inline-block;font-size:10px;background:#0009;color:var(--gold);
  border:1px solid var(--line);border-radius:4px;padding:1px 5px;margin:1px}
#event-log{font-family:ui-monospace,Consolas,monospace;font-size:11px;line-height:1.6}
.ev{padding:1px 4px;border-left:2px solid transparent}
.ev.DamageDealt{border-color:var(--enemy)} .ev.Healed{border-color:var(--accent2)}
.ev.Missed{border-color:var(--dim);color:var(--dim)} .ev.Died{border-color:#fff;color:#fff}
.ev.StatusApplied{border-color:var(--gold);color:var(--gold)}
.ev.ActionUsed{color:var(--accent)} .ev.BattleStart,.ev.BattleWon{color:var(--accent2)} .ev.BattleLost{color:var(--warn)}
.ev .crit{color:var(--gold)} .ev .weak{color:var(--warn)}
pre#raw-state{font-family:ui-monospace,Consolas,monospace;font-size:11px;white-space:pre-wrap;color:var(--dim)}

/* party builder */
.member{border:1px solid var(--line);border-radius:8px;padding:8px;margin-bottom:8px;background:var(--panel2)}
.member .mh{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.member .grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.member .grid label{margin:2px 0;font-size:11px}
.member .spells{margin-top:4px}
.chip{display:inline-block;font-size:10px;border:1px solid var(--line);border-radius:4px;
  padding:1px 6px;margin:1px;cursor:pointer;color:var(--dim)}
.chip.on{background:var(--accent);color:#08131f;border-color:var(--accent)}
.x{cursor:pointer;color:var(--warn);font-weight:700}

/* field */
.enc-list .enc{border:1px solid var(--line);border-radius:6px;padding:6px;margin-bottom:5px;cursor:pointer;font-size:12px}
.enc-list .enc:hover{border-color:var(--accent)}
.enc .bid{color:var(--dim);font-size:10px}
.legend{position:absolute;top:10px;left:10px;font-size:11px;background:#0b0f14cc;border:1px solid var(--line);
  border-radius:6px;padding:6px 8px;color:var(--dim)}
.legend b{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:5px;vertical-align:middle}
.script{font-family:ui-monospace,Consolas,monospace;font-size:11px;overflow:auto;max-height:calc(100vh - 180px)}
.script .op{white-space:nowrap}.script .opn{color:var(--accent)}.script .by{color:var(--dim)}
.script .sc{margin:6px 0 2px;color:var(--gold);font-size:11px}

/* data browser */
.data-types button{display:block;width:100%;text-align:left;margin-bottom:3px;background:transparent;border:none;color:var(--dim)}
.data-types button.active{background:var(--panel2);color:var(--ink)}
.data-filter{max-width:320px;margin:10px}
table.data{width:100%;border-collapse:collapse;font-size:12px}
table.data th,table.data td{border-bottom:1px solid var(--line);padding:4px 8px;text-align:left;vertical-align:top}
table.data th{position:sticky;top:0;background:var(--panel);color:var(--dim);cursor:pointer}
table.data tr:hover td{background:var(--panel2)}
.scroll::-webkit-scrollbar,.panel::-webkit-scrollbar,.script::-webkit-scrollbar{width:9px;height:9px}
.scroll::-webkit-scrollbar-thumb,.panel::-webkit-scrollbar-thumb,.script::-webkit-scrollbar-thumb{background:#2a3340;border-radius:5px}
