:root{color-scheme:dark;--page-bg: #0f1012;--bg: #131417;--panel: #1c1e23;--panel-2: #282b32;--border: #3a3d45;--text: #e7e8ea;--muted: #9296a0;--accent: #d83a52;--accent-2: #5db734;--primary: #8f2436;--danger: #e24a5e;--warn: #d8a23a;--uncertain: #a878e8;--font: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--display: "Palatino Linotype", "Book Antiqua", Palatino, "URW Palladio L", Palatino, serif;--mono: ui-monospace, "SF Mono", Menlo, monospace}*{box-sizing:border-box}button,input,select,textarea{font-family:var(--display)}body{user-select:none;-webkit-user-select:none}.notif,.chat-log,.chat-line,.chat-input{user-select:text;-webkit-user-select:text}html,body{margin:0;height:100%;background:var(--bg);color:var(--text);font-family:var(--display);font-size:13px}#app{height:100%}.player{display:flex;flex-direction:column;height:100%}.hud{display:flex;align-items:center;gap:12px;padding:6px 12px;background:var(--panel);border-bottom:1px solid var(--border);flex:0 0 auto;height:46px}.hud .brand{font-family:var(--display);text-transform:uppercase;font-weight:400;font-size:14px;letter-spacing:.06em;color:var(--accent)}.hud .spacer{flex:1}.faction-chip{display:inline-flex;align-items:center;gap:6px;font-weight:600;padding:3px 9px;border-radius:6px;border:1px solid var(--border);background:var(--panel-2)}.faction-dot{width:12px;height:12px;border-radius:3px;border:1px solid rgba(0,0,0,.4)}.hud-stat{color:var(--muted)}.hud-stat b{color:var(--text);font-variant-numeric:tabular-nums}.turn-timer{position:absolute;right:18px;bottom:16px;z-index:80;padding:6px 14px;border-radius:10px;background:#0d1117a8;border:1px solid var(--border);backdrop-filter:blur(4px);font-family:ui-monospace,SF Mono,Roboto Mono,Menlo,monospace;font-size:44px;font-weight:800;line-height:1;letter-spacing:.01em;font-variant-numeric:tabular-nums;color:var(--text);pointer-events:none;user-select:none}.turn-timer.urgent{color:var(--danger);border-color:var(--danger)}.btn{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:5px 12px;cursor:pointer;font-size:13px}.btn:hover{border-color:var(--accent)}.btn:disabled{opacity:.45;cursor:default}.btn.primary{background:var(--accent-2);border-color:var(--accent-2);color:#0e2207}.workspace{flex:1;display:flex;min-height:0}.canvas-wrap{flex:1;position:relative;min-width:0;background:repeating-conic-gradient(#0a0e14 0% 25%,#0c1119 0% 50%) 50% / 24px 24px;overflow:hidden}.board{position:absolute;inset:0;width:100%;height:100%;display:block;cursor:crosshair}.board.panning{cursor:grabbing}.board-bg{fill:#0e2a3a}.territory{fill:#6b7280;fill-opacity:.16;stroke:#c9d4e0;stroke-width:var(--border-w, 1.2px);vector-effect:non-scaling-stroke}.nogo{fill:#000;fill-opacity:.25;stroke:#0009;stroke-width:var(--border-w, 1.2px);stroke-dasharray:6 4;vector-effect:non-scaling-stroke}.city{fill:#f0c040;stroke:#1a1a1a;stroke-width:1.5}.city.capital{fill:gold;stroke:#000;stroke-width:2}.city.controlled{stroke-width:2.5}.city-ring{fill:none;stroke-width:2}.city-garrison{stroke:#0b0e12;stroke-width:1.5}.city-garrison-num{fill:#fff;font-size:11px;font-weight:700;text-anchor:middle;paint-order:stroke;stroke:#000;stroke-width:2.5px;pointer-events:none}.city-label{fill:#e6edf3;font-size:11px;paint-order:stroke;stroke:#000;stroke-width:3}.formation{stroke:#04101f;stroke-width:1.5;cursor:pointer}.formation.selected{stroke:#fff;stroke-width:2.5}.formation.pinnedByPlan{opacity:.5}.formation-count{fill:#fff;font-size:11px;font-weight:700;text-anchor:middle;paint-order:stroke;stroke:#000;stroke-width:2;pointer-events:none}.wall-link{stroke-width:3;stroke-linecap:round;opacity:.85}.ghost{fill:none;stroke-width:2.5;marker-end:url(#arrow)}.ghost.move{stroke:#9aa4b2}.ghost.merge{stroke:var(--accent-2)}.ghost.attack{stroke:var(--danger);stroke-dasharray:6 4}.ghost.uncertain{stroke:var(--uncertain);stroke-dasharray:4 4}.range-ring{fill:#39ff140d;stroke:#39ff14;stroke-width:2;stroke-dasharray:7 6;opacity:.9;pointer-events:none;filter:drop-shadow(0 0 4px rgba(57,255,20,.85))}.drag-line{fill:none;stroke:#fff;stroke-width:2.5;stroke-dasharray:6 5;stroke-linecap:round;pointer-events:none}.drag-line.illegal{stroke:var(--danger)}.ghost-coin{opacity:.62;pointer-events:none}.ghost-coin .formation{stroke:#fff;stroke-width:1.5;stroke-dasharray:3 3}.ghost-coin-rect.illegal,.ghost-coin.attack .formation{stroke:var(--danger)}.ghost-coin.merge .formation{stroke:var(--accent-2)}.range-ring.clamped{opacity:1;filter:drop-shadow(0 0 6px rgba(57,255,20,1))}.target-halo{fill:none;stroke-width:3;pointer-events:none}.target-halo.attack{stroke:var(--danger);filter:drop-shadow(0 0 5px var(--danger))}.target-halo.merge{stroke:#fff;filter:drop-shadow(0 0 5px rgba(255,255,255,.85))}.target-halo.peace{stroke:var(--accent-2);filter:drop-shadow(0 0 5px var(--accent-2))}.players-menu{position:relative}.players-btn.active{border-color:var(--accent)}.players-dropdown{position:absolute;top:calc(100% + 6px);left:0;z-index:30;min-width:240px;background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:0 10px 30px #00000080;padding:6px}.player-row{display:flex;align-items:center;gap:8px;padding:5px 6px}.player-row .player-name{flex:1;font-size:13px}.player-row .peace-offered{color:var(--accent-2);font-size:12px;white-space:nowrap}.player-row .diplo-btn{font-size:12px;padding:3px 8px}.player-row .diplo-btn.declare-war{color:var(--danger);border-color:var(--danger)}.player-row .diplo-btn.offer-peace{color:var(--accent-2);border-color:var(--accent-2)}.attack-x{stroke:#ff3b30;stroke-linecap:round;pointer-events:none}.attack-x-halo{stroke:#000;stroke-linecap:round;pointer-events:none;opacity:.8}.battle-marker{cursor:pointer}.battle-marker-hit{fill:transparent}.battle-marker:hover .attack-x{stroke:#ff6b60}.attacker-coin{cursor:help}.attacker-coin .formation{stroke:#fff;stroke-width:1.5}.target-reticle{fill:none;stroke:var(--danger);stroke-width:2}.merge-reticle{fill:none;stroke:var(--accent-2);stroke-width:2}.side-panel{flex:0 0 290px;display:flex;flex-direction:column;background:var(--panel);border-left:1px solid var(--border);min-height:0}.panel-section{border-bottom:1px solid var(--border);display:flex;flex-direction:column;min-height:0}.panel-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:8px 12px;display:flex;justify-content:space-between;align-items:center}.move-list{overflow-y:auto;padding:0 6px 8px;display:flex;flex-direction:column;gap:3px;min-height:0}.move-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border:1px solid transparent;border-radius:6px;background:var(--panel-2);cursor:pointer}.move-row:hover{border-color:var(--border)}.move-row.selected{border-color:var(--accent)}.move-row.flagged{opacity:.7;border-color:var(--warn)}.move-row.uncertain{border-color:var(--uncertain);border-style:dashed}.move-row.cascaded{opacity:.4;text-decoration:line-through}.move-glyph{width:20px;text-align:center;flex:none}.move-desc{flex:1;min-width:0;font-size:12px;white-space:normal;overflow-wrap:anywhere}.move-idx{color:var(--muted);font-size:11px;font-variant-numeric:tabular-nums}.move-x{background:none;border:none;color:var(--muted);cursor:pointer;font-size:13px;padding:0 2px}.move-x:hover{color:var(--danger)}.move-empty{color:var(--muted);padding:10px 12px;font-size:12px}.end-turn-bar{margin-top:auto;padding:10px 12px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px}.end-turn-btn{flex:1;padding:9px;font-size:14px;font-weight:600;border-color:var(--accent)}.end-turn-btn.ready{background:#19682f;border-color:var(--accent-2);color:#e6ffe9}.end-turn-btn.start-turn{background:var(--gold, #e8b923);border-color:var(--gold, #e8b923);color:#1a1a1a}.ready-count{color:var(--muted);font-size:12px;font-variant-numeric:tabular-nums;white-space:nowrap}.panel-title-right{display:flex;align-items:center;gap:8px}.side-collapse{background:none;border:none;color:var(--muted);cursor:pointer;font-size:15px;line-height:1;padding:0 2px}.side-collapse:hover{color:var(--text)}.sidebar-restore{position:absolute;top:12px;right:12px;z-index:70;background:var(--panel);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:6px 11px;cursor:pointer;font-size:13px;box-shadow:0 4px 16px #00000073}.sidebar-restore:hover{border-color:var(--accent)}.produce-body{padding:10px 12px;display:flex;flex-direction:column;gap:8px}.produce-row{display:flex;align-items:center;gap:8px}.produce-row label{flex:1}.produce-row input{width:56px;background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:5px;padding:4px 6px}.produce-meta{color:var(--muted);font-size:11px}.popup-layer{position:absolute;inset:0;pointer-events:none;z-index:55}.mini-window{position:absolute;pointer-events:auto;width:280px;background:var(--panel);border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 30px #00000080}.mw-head{display:flex;align-items:center;gap:8px;padding:9px 12px;border-bottom:1px solid var(--border)}.mw-title{font-family:var(--display);text-transform:uppercase;letter-spacing:.05em;font-weight:400;flex:1;font-size:13px}.mw-x{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;line-height:1;padding:0 2px}.mw-x:hover{color:var(--text)}.mw-body{padding:10px 12px;display:flex;flex-direction:column;gap:8px}.mw-row{display:flex;align-items:center;gap:10px}.mw-label{flex:1;font-size:13px}.mw-step{display:inline-flex;align-items:center;gap:2px}.mw-btn{width:24px;height:24px;border-radius:6px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);cursor:pointer;font-size:15px;line-height:1}.mw-btn:hover:not(:disabled){border-color:var(--accent)}.mw-btn:disabled{opacity:.4;cursor:default}.mw-num{min-width:22px;text-align:center;font-variant-numeric:tabular-nums}.mw-meta{color:var(--muted);font-size:11px}.mw-owner{font-weight:600;gap:8px}.mw-actions{display:flex;gap:8px;align-items:center}.mw-actions .spacer{flex:1}.mw-have{font-size:12px;color:var(--accent);min-width:28px;text-align:right;font-variant-numeric:tabular-nums}.mw-cost{font-size:11px;color:var(--muted);min-width:36px;text-align:right}.mw-move-btn{width:100%;justify-content:center}.mv-slider{flex:1;min-width:0;accent-color:var(--accent);cursor:pointer}.mv-num{font-size:12px;color:var(--muted);min-width:40px;text-align:right;font-variant-numeric:tabular-nums}.etl-item{display:flex;flex-direction:column}.etl-thumb{width:26px;height:26px;border-radius:4px;border:1px solid var(--border);background:var(--panel-2);flex:none}.etl-chevron{color:var(--muted);font-size:10px;flex:none;transition:transform .12s}.etl-detail{display:grid;grid-template-columns:repeat(3,1fr);gap:2px 10px;padding:5px 0 2px 36px;font-size:12px;color:var(--text)}.etl-stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.03em;font-size:11px;margin-right:3px}details.etl-item>summary{display:flex;align-items:center;gap:10px;list-style:none;cursor:pointer}details.etl-item>summary::-webkit-details-marker{display:none}details.etl-item[open] .etl-chevron{transform:rotate(180deg)}.notifications{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:4px;pointer-events:auto;max-width:480px;width:max-content;z-index:60}.notif{padding:7px 36px 7px 12px;border-radius:6px;font-size:12px;border-left:3px solid;position:relative;backdrop-filter:blur(4px)}.notif-error{background:#f851492e;border-color:var(--danger);color:#fca5a5}.notif-warning{background:#d299222e;border-color:var(--warn);color:#fbbf24}.notif-info{background:#2ea0432e;border-color:var(--accent-2);color:#86efac}.overlay-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--muted);z-index:70;background:#0d111799}.overlay-center h2{margin:0;color:var(--text)}.launcher{height:100%;display:flex;align-items:center;justify-content:center;padding:24px;overflow:auto}.launcher-card{width:min(820px,100%);background:var(--panel);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:0 12px 40px #00000073}.launcher-head{padding:18px 22px;border-bottom:1px solid var(--border);display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;gap:12px}.launcher-head h1{margin:0;font-size:20px;letter-spacing:-.01em}.launcher-sub{margin:0;color:var(--muted);font-size:13px}.launcher-conn{font-size:12px;padding:3px 9px;border-radius:999px;border:1px solid var(--border);white-space:nowrap}.launcher-conn.on{color:#86efac;border-color:#2ea04380}.launcher-conn.off{color:var(--muted)}.launcher-body{display:grid;grid-template-columns:1fr 1.2fr;min-height:320px}.launcher-maps{border-right:1px solid var(--border);padding:14px;min-width:0}.launcher-col-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:10px}.map-list{display:flex;flex-direction:column;gap:6px}.map-item{display:flex;flex-direction:column;align-items:flex-start;gap:1px;text-align:left;padding:9px 11px;border-radius:8px;cursor:pointer;background:var(--panel-2);color:var(--text);border:1px solid var(--border)}.map-item:hover:not(:disabled){border-color:var(--accent)}.map-item.selected{border-color:var(--accent);background:#2a1519}.map-item:disabled{opacity:.6;cursor:default}.map-item-name{font-weight:600}.map-item-id{font-size:11px;color:var(--muted)}.launcher-detail{padding:16px 20px;min-width:0}.launcher-empty{color:var(--muted);display:flex;flex-direction:column;gap:10px;align-items:flex-start;padding:12px 0}.launcher-empty p{margin:0}.muted{color:var(--muted)}.detail-body{display:flex;flex-direction:column;gap:14px}.detail-meta{display:flex;flex-wrap:wrap;gap:8px 16px;color:var(--muted);font-size:12px}.detail-field-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.faction-picker,.turn-picker{display:flex;flex-wrap:wrap;gap:8px}.faction-opt,.turn-opt{display:inline-flex;align-items:center;gap:7px;padding:6px 11px;border-radius:8px;cursor:pointer;background:var(--panel-2);color:var(--text);border:1px solid var(--border);font-size:13px}.faction-opt:hover:not(:disabled),.turn-opt:hover:not(:disabled){border-color:var(--accent)}.faction-opt.selected,.turn-opt.selected{border-color:var(--accent);background:#2a1519}.faction-opt:disabled,.turn-opt:disabled{opacity:.6;cursor:default}.faction-swatch{width:13px;height:13px;border-radius:4px;border:1px solid rgba(0,0,0,.4)}.detail-actions{display:flex;flex-direction:column;gap:8px;margin-top:6px}.launch-btn{align-self:flex-start;padding:9px 22px;font-size:14px}.launch-note{margin:0;font-size:12px;max-width:46ch}.launcher-error{margin:0 20px 16px;padding:9px 12px;border-radius:8px;font-size:12px;background:#f8514929;border:1px solid rgba(248,81,73,.5);color:#fca5a5}@media(max-width:640px){.launcher-body{grid-template-columns:1fr}.launcher-maps{border-right:none;border-bottom:1px solid var(--border)}}.selector{height:100%;display:flex;align-items:center;justify-content:center;padding:24px;overflow:auto}.selector-card{width:min(420px,100%);background:var(--panel);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:0 12px 40px #00000073}.selector-head{padding:18px 22px;border-bottom:1px solid var(--border)}.selector-head h1{margin:0;font-size:20px;letter-spacing:-.01em}.selector-sub{margin:4px 0 0;color:var(--muted);font-size:13px}.selector-list{display:flex;flex-direction:column;gap:8px;padding:16px}.identity-item{display:flex;align-items:baseline;justify-content:space-between;gap:10px;text-align:left;padding:14px 16px;border-radius:10px;cursor:pointer;background:var(--panel-2);color:var(--text);border:1px solid var(--border)}.identity-item:hover{border-color:var(--accent);background:#2a1519}.identity-name{font-weight:600;font-size:16px}.identity-token{font-size:11px;color:var(--muted);font-family:ui-monospace,SF Mono,Menlo,monospace}.selector-error{margin:0 16px 16px;padding:9px 12px;border-radius:8px;font-size:12px;background:#f8514929;border:1px solid rgba(248,81,73,.5);color:#fca5a5}.faction-preview{display:flex;flex-wrap:wrap;gap:8px}.faction-chip-lg{display:inline-flex;align-items:center;gap:7px;padding:5px 10px;border-radius:8px;background:var(--panel-2);border:1px solid var(--border);font-size:12px}.lobby,.picking{--crimson: #e0533d;--gold: #e8b923}.lobby .btn.primary,.picking .btn.primary{background:#b23a2e;border-color:var(--crimson)}.lobby .btn.primary:hover:not(:disabled),.picking .btn.primary:hover:not(:disabled){background:#c9402f}.lobby .btn.primary:disabled,.picking .btn.primary:disabled{opacity:.45}.slot-chip{width:15px;height:15px;border-radius:4px;border:1px solid rgba(0,0,0,.45);flex:0 0 auto}.slot-handle{font-weight:600}.slot-tag{font-size:10px;text-transform:uppercase;letter-spacing:.05em;padding:1px 6px;border-radius:999px;border:1px solid var(--border)}.slot-tag.host{color:var(--gold);border-color:#e8b92380}.slot-tag.you{color:var(--crimson);border-color:#e0533d80}.lobby{height:100%;display:flex;align-items:center;justify-content:center;padding:24px;overflow:auto}.lobby-card{width:min(880px,100%);background:var(--panel);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:0 12px 40px #00000073}.lobby-head{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border)}.lobby-head h1{margin:0;font-size:20px}.lobby-head .spacer{flex:1}.lobby-map{font-size:12px;color:var(--muted);padding:3px 10px;border-radius:999px;border:1px solid var(--border);background:var(--panel-2)}.invite-btn{font-size:12px}.lobby-body{display:grid;grid-template-columns:1.1fr 1fr;min-height:300px}.lobby-players{padding:14px 16px;border-right:1px solid var(--border)}.lobby-col-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:10px}.lobby-slot{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:8px;background:var(--panel-2);border:1px solid var(--border);margin-bottom:6px}.lobby-chat{padding:14px 16px;display:flex;flex-direction:column;min-height:0}.chat-log{flex:1;min-height:140px;max-height:280px;overflow-y:auto;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:8px 10px;display:flex;flex-direction:column;gap:3px}.chat-line{font-size:12px}.chat-line b{color:var(--crimson)}.chat-empty{color:var(--muted);font-size:12px}.chat-row{display:flex;gap:6px;margin-top:8px}.chat-input{flex:1;background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:6px 9px;font-size:13px}.chat-input:focus{outline:none;border-color:var(--crimson)}.lobby-foot{display:flex;align-items:center;gap:10px;padding:14px 20px;border-top:1px solid var(--border)}.lobby-foot .spacer{flex:1}.lobby-note{font-size:12px}.lobby-note.error{color:#fca5a5}.lobby-note.warning{color:#fbbf24}.picking{flex:1;display:flex;min-height:0;height:100%}.picking .canvas-wrap{flex:1}.pick-side{flex:0 0 300px;display:flex;flex-direction:column;gap:10px;padding:14px 16px;background:var(--panel);border-left:1px solid var(--border);min-height:0}.pick-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.pick-banner{padding:10px 12px;border-radius:8px;background:var(--panel-2);border:1px solid var(--border);font-size:13px}.pick-banner.you{border-color:var(--crimson);background:#e0533d24;color:#ffd9d0;font-weight:600}.pick-banner.done{border-color:var(--accent-2);background:#2ea04324;color:#86efac}.pick-order{display:flex;flex-direction:column;gap:6px;overflow-y:auto;min-height:0}.pick-seat{display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:8px;background:var(--panel-2);border:1px solid var(--border)}.pick-seat .spacer{flex:1}.pick-seat.current{border-color:var(--gold);box-shadow:0 0 0 1px #e8b92340 inset}.seat-faction{font-size:11px;color:var(--muted)}.pick-foot{margin-top:auto;padding-top:8px}.pick-foot .btn.primary{width:100%;padding:9px;font-size:14px}.pick-overlay{position:absolute;inset:0;pointer-events:none;z-index:50}.pick-popup{position:absolute;pointer-events:auto;min-width:168px;max-width:240px;background:var(--panel);border:1px solid var(--border);border-radius:9px;box-shadow:0 8px 26px #00000080;padding:10px 12px;display:flex;flex-direction:column;gap:7px}.popup-head{display:flex;align-items:center;gap:8px}.popup-name{font-family:var(--display);text-transform:uppercase;letter-spacing:.05em;font-weight:400;flex:1}.popup-x{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;line-height:1;padding:0 2px}.popup-x:hover{color:var(--text)}.popup-row{display:flex;align-items:center;gap:7px;font-size:12px}.popup-note{font-size:12px;color:var(--muted);padding-top:2px}.popup-pick{width:100%;padding:7px;margin-top:2px}.battle-row{justify-content:space-between}.battle-open{color:var(--muted);font-size:11px}.battle-row:hover .battle-open{color:var(--accent)}.battle-layer{z-index:65;pointer-events:none}.battle-overlay{position:absolute;pointer-events:auto;width:360px;max-width:94vw;max-height:80vh;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--border);border-radius:12px;box-shadow:0 18px 54px #0000009e}.battle-head{display:flex;align-items:center;gap:8px;padding:11px 14px;border-bottom:1px solid var(--border)}.battle-title{font-family:var(--display);text-transform:uppercase;letter-spacing:.05em;font-weight:400;flex:1;font-size:14px}.battle-arena{display:flex;align-items:flex-start;gap:10px;padding:14px;overflow-y:auto}.battle-col{flex:1;min-width:0;display:flex;gap:8px}.battle-col.atk{flex-direction:row}.battle-col.def{flex-direction:row;justify-content:flex-end}.battle-vs{align-self:center;color:var(--muted);font-size:12px;font-weight:700}.battle-side-roll{width:44px;flex:none;display:flex;justify-content:center;padding-top:4px}.unit-stack{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.unit-box{border:1px solid var(--border);border-left-width:3px;border-radius:7px;background:var(--panel-2);padding:6px 8px;display:flex;flex-direction:column;gap:4px;transition:opacity .15s,box-shadow .15s}.unit-box.roller{box-shadow:0 0 0 1px var(--accent) inset}.unit-box.hit{box-shadow:0 0 0 1px var(--danger) inset}.unit-box.dead{opacity:.32}.unit-head{display:flex;align-items:center;gap:7px}.unit-thumb{width:20px;height:20px;border-radius:4px;border:1px solid var(--border);background:var(--bg);flex:none}.unit-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unit-hpbar{height:5px;border-radius:3px;background:#ffffff1a;overflow:hidden}.unit-hpfill{height:100%;border-radius:3px;transition:width .2s}.unit-hp{font-size:10px;color:var(--muted);font-variant-numeric:tabular-nums}.unit-empty{color:var(--muted);font-size:12px;padding:6px 2px}.roll-badge{display:inline-flex;align-items:center;gap:1px;padding:3px 7px;border-radius:999px;background:var(--panel-2);border:1px solid var(--accent);color:var(--text);font-weight:700;font-variant-numeric:tabular-nums;font-size:14px;height:max-content}.roll-badge.crit{border-color:var(--gold, #e8b923);color:var(--gold, #e8b923)}.roll-crit{font-size:11px}.battle-status{padding:4px 14px 0;color:var(--muted);font-size:12px;min-height:16px}.battle-controls{display:flex;align-items:center;gap:6px;padding:12px 14px;border-top:1px solid var(--border)}.battle-controls .btn{padding:6px 9px}.battle-controls .battle-play{flex:1;background:var(--primary);border-color:var(--accent);color:var(--text)}.battle-step{color:var(--muted);font-size:12px;font-variant-numeric:tabular-nums;white-space:nowrap}
