.board-grid{display:grid;gap:2px;width:min(94vw,34rem);aspect-ratio:1;background:#2a323e;padding:2px;border-radius:.4rem;-webkit-user-select:none;user-select:none;touch-action:manipulation}.bg-cell{position:relative;border:none;border-radius:2px;padding:0;display:flex;align-items:center;justify-content:center;cursor:default;min-width:0}.bg-cell.field{background:#e9e2cf}.bg-cell.forest{background:#7f8f6e}.bg-cell.alt-0{filter:brightness(.84)}.bg-cell.alt-1{filter:brightness(1)}.bg-cell.alt-2{filter:brightness(1.18)}.bg-cell.interactive{cursor:pointer}.bg-cell.dimmed{opacity:.5}.bg-cell.zone-red{outline:2px solid #e5534b;outline-offset:-2px}.bg-cell.zone-blue{outline:2px solid #4c8dff;outline-offset:-2px}.bg-cell.selected{outline:3px solid #f0c040;outline-offset:-3px;z-index:1}.bg-cell.hl-legal:after{content:"";position:absolute;top:22%;right:22%;bottom:22%;left:22%;border-radius:50%;background:#3fb9508c}.bg-cell.hl-from{outline:3px solid #f0c040;outline-offset:-3px}.bg-cell.hl-to{outline:3px dashed #6ea8fe;outline-offset:-3px}.alt-badge{position:absolute;top:1px;right:2px;font-size:.62rem;font-weight:800;color:#fff;text-shadow:0 0 2px rgba(0,0,0,.95),0 0 3px rgba(0,0,0,.8);line-height:1}.piece{display:flex;align-items:center;justify-content:center;width:78%;height:78%;border-radius:4px;font-size:.8rem;font-weight:800;color:#fff;letter-spacing:-.03em}.piece.red{background:#c2362f;box-shadow:inset 0 0 0 1px #e5534b}.piece.blue{background:#2f5fc2;box-shadow:inset 0 0 0 1px #4c8dff}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#080a0e99;display:flex;align-items:flex-end;justify-content:center;z-index:10}.modal{background:#1c222c;border:1px solid #2a323e;border-radius:.75rem .75rem 0 0;width:min(100%,26rem);max-height:80vh;overflow:auto;padding:.75rem}@media (min-width: 30rem){.modal-backdrop{align-items:center}.modal{border-radius:.75rem}}.modal-head{display:flex;align-items:center;justify-content:space-between;font-weight:700;margin-bottom:.6rem}.modal-head .x{background:none;border:none;color:#8b97a6;font-size:1rem;cursor:pointer}.picker{display:flex;flex-direction:column;gap:.4rem}.picker .pick,.picker .back{display:flex;align-items:center;gap:.6rem;padding:.7rem .8rem;background:#11151b;border:1px solid #2a323e;border-radius:.5rem;color:#e8edf2;font-size:.95rem;cursor:pointer;text-align:left}.picker .pick:disabled{opacity:.4;cursor:not-allowed}.picker .pick .sym{font-size:1.1rem;width:1.4rem;text-align:center}.picker .pick .lbl{flex:1;text-transform:capitalize}.picker .pick .cnt{font-weight:800;font-variant-numeric:tabular-nums;background:#2a323e;border-radius:.4rem;padding:.05rem .45rem;min-width:1.6rem;text-align:center}.picker .pick .arrow{color:#8b97a6}.picker .back{justify-content:flex-start;color:#8b97a6}.occupied{display:flex;flex-direction:column;align-items:center;gap:.8rem;padding:.5rem 0 .8rem}.occupied .piece{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:6px;font-size:1.1rem;font-weight:800;color:#fff}.occupied .piece.red{background:#c2362f}.occupied .piece.blue{background:#2f5fc2}.danger{background:#c2362f;color:#fff;border:none;border-radius:.5rem;padding:.55rem 1.1rem;font-weight:700;cursor:pointer}.resolution{position:relative;display:flex;flex-direction:column;align-items:center;gap:.6rem;width:100%}.res-title{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:5;pointer-events:none}.res-title span{font-size:clamp(2.5rem,9vw,5rem);font-weight:900;letter-spacing:.06em;color:#f0c040;text-shadow:0 4px 18px rgba(0,0,0,.6);animation:title-pop .4s ease-out}@keyframes title-pop{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.res-banner .next{background:#3b82f6;color:#fff;border:none;border-radius:.4rem;padding:.35rem .7rem;font-weight:700;cursor:pointer;white-space:nowrap}.res-banner{display:flex;align-items:center;gap:.75rem;width:min(94vw,34rem);box-sizing:border-box;padding:.6rem .9rem;border-radius:.5rem;background:#1c222c;border:1px solid #2a323e;border-left:5px solid #5a6678;min-height:2.7rem;transition:border-color .2s,background .2s}.display .res-banner{width:min(96vw,48rem)}.res-banner .res-msg{flex:1;font-weight:700;font-size:1.02rem;color:#e8edf2}.res-banner .res-msg .seg.red{color:#ff6b63;font-weight:800}.res-banner .res-msg .seg.blue{color:#6ea8fe;font-weight:800}.res-banner.tone-clash{border-left-color:#f0c040;background:linear-gradient(90deg,#f0c0402e,#1c222c 65%)}.res-banner.tone-clash .res-msg{color:#ffdf8a}.res-banner.tone-artillery{border-left-color:#f0913a;background:linear-gradient(90deg,#f0913a2e,#1c222c 65%)}.res-banner.tone-artillery .res-msg{color:#ffc28a}.res-banner .skip{background:#2a323e;color:#e8edf2;border:none;border-radius:.4rem;padding:.35rem .7rem;font-weight:600;cursor:pointer;white-space:nowrap}.res-tally{font-size:.85rem;color:#8b97a6}.res-dots{display:flex;align-items:center;justify-content:center;gap:.45rem;min-height:.7rem}.res-dots .dot{width:.6rem;height:.6rem;border-radius:50%;background:#f0c040;animation:dot-pop .2s ease-out}@keyframes dot-pop{0%{transform:scale(.4);opacity:.4}to{transform:scale(1);opacity:1}}.res-board{position:relative;width:min(94vw,34rem);aspect-ratio:1}.display .res-board{width:min(96vw,48rem)}.res-bg{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;gap:2px;background:#2a323e;padding:2px;border-radius:.4rem}.res-bg .bg-cell{border-radius:2px}.res-bg .bg-cell.field{background:#e9e2cf}.res-bg .bg-cell.forest{background:#7f8f6e}.res-bg .bg-cell.alt-0{filter:brightness(.84)}.res-bg .bg-cell.alt-1{filter:brightness(1)}.res-bg .bg-cell.alt-2{filter:brightness(1.18)}.res-bg .bg-cell.hl-clash{outline:3px solid #f0c040;outline-offset:-3px;animation:clash-pulse 1s ease-in-out infinite;z-index:2}.res-bg .bg-cell.hl-range{outline:2px solid rgba(240,160,40,.7);outline-offset:-2px;box-shadow:inset 0 0 0 100px #f0962847;z-index:1}.res-bg .bg-cell.hl-target{outline:3px solid #e5534b;outline-offset:-3px;box-shadow:inset 0 0 0 100px #e5534b59;z-index:2}@keyframes clash-pulse{0%,to{box-shadow:inset 0 0 0 3px #f0c04059}50%{box-shadow:inset 0 0 0 3px #f0c040f2}}.res-pieces{position:absolute;top:2px;right:2px;bottom:2px;left:2px;pointer-events:none}.res-slot{position:absolute;display:flex;align-items:center;justify-content:center;transition:left .42s cubic-bezier(.4,0,.2,1),top .42s cubic-bezier(.4,0,.2,1),opacity .4s ease,transform .4s ease}.res-slot.removing{opacity:0;transform:scale(.3)}.res-slot .piece{display:flex;align-items:center;justify-content:center;width:78%;height:78%;border-radius:4px;font-size:.8rem;font-weight:800;color:#fff;letter-spacing:-.03em}.res-slot .piece.red{background:#c2362f;box-shadow:inset 0 0 0 1px #e5534b}.res-slot .piece.blue{background:#2f5fc2;box-shadow:inset 0 0 0 1px #4c8dff}.res-slot .piece.split-tl{width:100%;height:100%;border-radius:2px;clip-path:polygon(0 0,100% 0,0 100%);align-items:flex-start;justify-content:flex-start;padding:12% 0 0 12%}.res-slot .piece.split-br{width:100%;height:100%;border-radius:2px;clip-path:polygon(100% 0,100% 100%,0 100%);align-items:flex-end;justify-content:flex-end;padding:0 12% 12% 0}.game-bar{display:flex;align-items:center;gap:.6rem;width:min(94vw,34rem);margin:0 auto .6rem;padding:.4rem .6rem;background:#1c222c;border:1px solid #2a323e;border-radius:.5rem}.game-bar .gb-code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;letter-spacing:.12em;font-weight:700;color:#c7d0da}.game-bar .gb-side{font-size:.7rem;font-weight:800;letter-spacing:.05em;padding:.15rem .45rem;border-radius:.35rem;color:#fff}.game-bar .gb-side.red{background:#c2362f}.game-bar .gb-side.blue{background:#2f5fc2}.game-bar .gb-warn{font-size:.75rem;color:#d2a04a}.game-bar .leave{margin-left:auto;background:none;border:1px solid #4a2a2a;color:#c98a8a;border-radius:.4rem;padding:.3rem .7rem;font-size:.8rem;cursor:pointer}.game-bar .leave:hover{background:#2a1a1a}.deploy,.play{display:flex;flex-direction:column;align-items:center;gap:.9rem;width:100%}.deploy-status,.play-status{display:flex;align-items:center;gap:.8rem;width:min(94vw,34rem)}.side-badge{font-weight:800;font-size:.8rem;letter-spacing:.05em;padding:.25rem .55rem;border-radius:.4rem;color:#fff}.side-badge.red{background:#c2362f}.side-badge.blue{background:#2f5fc2}.deploy-status .count,.play-status .count{font-variant-numeric:tabular-nums;color:#c7d0da}.play-status .lock,.play-status .fill{margin-left:auto;padding:.5rem 1rem;font-weight:700;border:none;border-radius:.5rem;cursor:pointer}.play-status .lock{background:#3fb950;color:#08210e}.play-status .fill{background:#2a323e;color:#e8edf2}.day-banner{font-weight:800;letter-spacing:.04em;color:#c7d0da}.result-banner{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;background:#1c222c;border:1px solid #2a323e;border-radius:.5rem;padding:.5rem .75rem;font-size:.85rem;color:#c7d0da;max-width:min(94vw,34rem)}.result-banner .chips{display:flex;flex-wrap:wrap;gap:.25rem}.result-banner .mini{display:inline-flex;align-items:center;justify-content:center;min-width:1.4rem;height:1.4rem;padding:0 .25rem;border-radius:.3rem;font-size:.7rem;font-weight:800;color:#fff}.result-banner .mini.red{background:#c2362f}.result-banner .mini.blue{background:#2f5fc2}.moves-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.35rem;width:min(94vw,34rem)}.moves-list li{display:flex;align-items:center;gap:.3rem;background:#11151b;border:1px solid #2a323e;border-radius:.4rem;padding:.2rem .5rem;font-size:.8rem;font-variant-numeric:tabular-nums}.moves-list li button{background:none;border:none;color:#8b97a6;cursor:pointer;font-size:.8rem;padding:0}.deploy-status .fill{margin-left:auto;padding:.5rem .9rem;font-weight:600;border:1px solid #2a323e;border-radius:.5rem;background:#2a323e;color:#e8edf2;cursor:pointer}.deploy-status .fill:hover{filter:brightness(1.1)}.deploy-status .lock{padding:.5rem 1rem;font-weight:700;border:none;border-radius:.5rem;background:#3fb950;color:#08210e;cursor:pointer}.deploy-status .lock:disabled{background:#2a323e;color:#8b97a6;cursor:not-allowed}.hint{font-size:.8rem;color:#8b97a6;text-align:center;max-width:34rem}.waiting{background:#1c222c;border:1px solid #2a323e;border-radius:.5rem;padding:.75rem 1rem;color:#c7d0da}.status.err{color:#f0a0a0}.play h2{margin:0}.surrender{background:none;border:1px solid #4a2a2a;color:#c98a8a;border-radius:.4rem;padding:.35rem .8rem;font-size:.8rem;cursor:pointer}.surrender:hover{background:#2a1a1a}.end-actions{display:flex;gap:.6rem;justify-content:center}.end-actions .lock{padding:.6rem 1.4rem;font-weight:700;border:none;border-radius:.5rem;background:#3fb950;color:#08210e;cursor:pointer}.end-actions .lock:disabled{background:#2a323e;color:#8b97a6;cursor:not-allowed}.display{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%}.scoreboard{display:flex;align-items:stretch;gap:1rem;width:min(96vw,48rem)}.side-card{flex:1;display:flex;flex-direction:column;gap:.2rem;padding:.7rem 1rem;border-radius:.6rem;background:#1c222c;border:1px solid #2a323e}.side-card.red{border-left:5px solid #c2362f}.side-card.blue{border-right:5px solid #2f5fc2;text-align:right;align-items:flex-end}.side-card.empty{opacity:.5}.side-card .badge{font-size:.75rem;font-weight:800;letter-spacing:.08em;color:#8b97a6}.side-card .pname{font-size:1.3rem;font-weight:700}.side-card .sub{font-size:.85rem;color:#c7d0da}.scoreboard .middle{display:flex;align-items:center;justify-content:center;min-width:6rem;font-size:1.2rem;font-weight:800;letter-spacing:.04em;color:#c7d0da}.scoreboard .middle .result{color:#f0c040}.display .board-grid{width:min(96vw,48rem)}.help-panel{background:#1c222c;border:1px solid #2a323e;border-radius:.75rem;width:min(100%,32rem);max-height:86vh;display:flex;flex-direction:column;overflow:hidden}.help-head{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;border-bottom:1px solid #2a323e}.help-head h2{margin:0;font-size:1.15rem}.help-head .x{background:none;border:none;color:#8b97a6;font-size:1rem;cursor:pointer}.help-intro{padding:.75rem 1rem;font-size:.85rem;color:#c7d0da;border-bottom:1px solid #2a323e}.help-intro p{margin:0 0 .5rem}.help-intro p:last-child{margin-bottom:0}.help-cards{overflow-y:auto;padding:.75rem 1rem 1rem;display:flex;flex-direction:column;gap:.6rem}.ref-card{background:#11151b;border:1px solid #2a323e;border-radius:.5rem;padding:.6rem .75rem}.ref-head{display:flex;align-items:center;gap:.5rem;font-weight:800;margin-bottom:.35rem}.ref-sym{display:inline-flex;align-items:center;justify-content:center;width:1.6rem;height:1.6rem;border-radius:.35rem;background:#2a323e;font-size:1rem}.ref-line{font-size:.82rem;color:#d6dde5;margin:.15rem 0}.ref-line .k{display:inline-block;min-width:4.5rem;font-weight:700;color:#8b97a6}.ref-line .k.win{color:#5fd47a}.ref-line .k.lose{color:#e87b73}.ref-note{font-size:.76rem;color:#8b97a6;margin:.1rem 0 0 .3rem}:root{color-scheme:dark;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body{margin:0;background:#14181f;color:#e8edf2}.app{max-width:30rem;margin:0 auto;padding:2rem 1.25rem;display:flex;flex-direction:column;gap:1.5rem;min-height:100vh}.app.app-wide{max-width:60rem}.title-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.views{display:flex;gap:.4rem}.views button{padding:.4rem .8rem;font-size:.85rem;font-weight:600;background:#2a323e;color:#e8edf2;border:1px solid transparent;border-radius:.4rem;cursor:pointer}.views button.on{background:#3b82f6;border-color:#6ea8fe}.views button.mute{background:transparent;font-size:1rem;padding:.4rem .5rem}header h1{margin:0;font-size:1.9rem;letter-spacing:.02em}.tagline{margin:.25rem 0 0;color:#8b97a6;font-size:.9rem}.card{background:#1c222c;border:1px solid #2a323e;border-radius:.75rem;padding:1.25rem;display:flex;flex-direction:column;gap:.75rem}label{font-size:.85rem;color:#8b97a6}input{padding:.6rem .75rem;border-radius:.5rem;border:1px solid #2a323e;background:#11151b;color:inherit;font-size:1rem}button{padding:.65rem 1rem;border:none;border-radius:.5rem;background:#3b82f6;color:#fff;font-size:1rem;font-weight:600;cursor:pointer}button.secondary{background:#2a323e}button:hover{filter:brightness(1.08)}.players{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.players li{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;background:#11151b;border-radius:.5rem}.dot{width:.6rem;height:.6rem;border-radius:50%;background:#3fb950}.players li.offline{opacity:.55}.players li.offline .dot{background:#d29922}.status{margin-top:auto;font-size:.85rem;color:#8b97a6;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.join-card .or{text-align:center;font-size:.8rem;color:#8b97a6;margin:.25rem 0}.join-row{display:flex;gap:.5rem}.code-input{flex:1;text-transform:uppercase;letter-spacing:.25em;font-weight:700;text-align:center;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.code-display{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:2.6rem;font-weight:800;letter-spacing:.3em;text-align:center;background:#11151b;border:1px solid #2a323e;border-radius:.6rem;padding:.75rem .5rem .75rem .8rem;color:#f0c040}.code-chip{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;letter-spacing:.2em;color:#f0c040}
