:root{--ink:#10261d;--ink-soft:#3d574b;--panel:#f2f6f4;--panel-strong:#e4ece8;--line:#b6c5bc;--accent:#0b6e4f;--accent-soft:#d8ece4;--warn:#b37a09;--page-background:radial-gradient(circle at 20% 20%, #f9fdfb 0%, #edf4f0 45%, #e0e9e4 100%);color:var(--ink);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Avenir Next,Trebuchet MS,Segoe UI,sans-serif;line-height:1.35}*{box-sizing:border-box}html,body,#root{width:100%;min-height:100dvh;margin:0}body{background:#e8eee9}.app-shell{background:var(--page-background);grid-template-rows:auto 1fr;gap:10px;min-height:100dvh;max-height:100dvh;padding:10px;display:grid}.topbar{background:color-mix(in oklab, var(--panel), white 28%);border:1px solid var(--line);border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:8px 10px;display:flex;box-shadow:0 6px 14px #10261d12}.title-block{min-width:0}.topbar h1{letter-spacing:.02em;color:var(--ink);margin:0;font-size:clamp(1rem,2vw,1.45rem)}.topbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.toggle-hud{border:1px solid var(--line);color:var(--ink);cursor:pointer;background:#fff;border-radius:999px;padding:6px 10px;font-size:.84rem}.network-panel{grid-template-columns:repeat(2,minmax(0,1fr));align-items:center;gap:8px;min-width:0;display:grid}.network-panel input{border:1px solid var(--line);text-transform:uppercase;letter-spacing:.08em;background:#fff;border-radius:9px;padding:8px 9px;font-size:.88rem;font-weight:600}.network-panel button{border:1px solid var(--line);color:var(--ink);cursor:pointer;background:#fff;border-radius:999px;padding:7px 10px;font-size:.88rem}.network-panel button:disabled{opacity:.5;cursor:default}.ws-pill,.room-pill{border:1px solid var(--line);white-space:nowrap;border-radius:999px;width:fit-content;padding:5px 9px;font-size:.8rem}.ws-pill.disconnected{color:#3f3f46;background:#f4f4f5}.ws-pill.connecting{color:#854d0e;background:#fef9c3}.ws-pill.connected{color:#166534;background:#dcfce7}.room-pill{color:#3730a3;background:#eef2ff}.network-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:8px 10px;font-size:.86rem}.winner-banner{color:#92400e;background:#fffbeb;border:1px solid #d97706;border-radius:10px;padding:8px 10px;font-size:.9rem;font-weight:700}.board-wrapper{border:1px solid var(--line);background:#f5f9f7;border-radius:12px;min-height:0;position:relative;overflow:hidden}.board{touch-action:none;cursor:grab;width:100%;height:100%;display:block}.board:active{cursor:grabbing}.board.board-locked{cursor:not-allowed}.board-dock{pointer-events:none;align-content:end;justify-items:start;gap:8px;display:grid;position:absolute;bottom:10px;left:10px;right:10px}.board-dock-toggle{border:1px solid var(--line);background:color-mix(in oklab, var(--panel), white 24%);color:var(--ink);letter-spacing:.02em;cursor:pointer;pointer-events:auto;border-radius:999px;padding:7px 12px;font-size:.82rem;box-shadow:0 6px 14px #0c221824}.board-dock-shell{border:1px solid var(--line);background:color-mix(in oklab, var(--panel), white 28%);pointer-events:auto;border-radius:12px;gap:8px;width:min(100%,520px);max-height:min(62vh,640px);padding:8px;display:grid;overflow:auto;box-shadow:0 8px 18px #0c22181f}.compact-status-row{flex-wrap:wrap;gap:6px;display:flex}.compact-status-row span{border:1px solid var(--line);color:var(--ink-soft);background:#fff;border-radius:999px;padding:4px 10px;font-size:.79rem}.dock-panel summary,.tuning-panel summary{color:var(--ink)}.rules-modal-backdrop{z-index:20;background:#0f172a73;place-items:center;padding:14px;display:grid;position:fixed;inset:0}.rules-modal{border:1px solid var(--line);background:#fff;border-radius:12px;gap:8px;width:min(460px,100%);padding:14px;display:grid;box-shadow:0 16px 30px #0f172a33}.rules-modal h2{margin:0;font-size:1.04rem}.rules-modal p{color:var(--ink-soft);margin:0;font-size:.9rem}.controls{background:color-mix(in oklab, var(--panel-strong), white 35%);border:0;border-radius:0;grid-template-columns:1fr;align-items:center;gap:10px;padding:10px;display:grid}.stat{border:1px solid var(--line);background:var(--panel);color:var(--ink);border-radius:10px;gap:4px;min-height:62px;padding:8px 10px;display:grid}.stat span{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);font-size:.75rem}.stat strong{overflow-wrap:anywhere;color:var(--ink);font-size:.88rem;line-height:1.25}.button-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.play-as{border:1px solid var(--line);color:var(--ink-soft);background:#fff;border-radius:999px;align-items:center;gap:6px;padding:5px 10px;font-size:.86rem;display:inline-flex}.play-as select{border:1px solid var(--line);color:var(--ink);background:#fff;border-radius:999px;padding:2px 8px;font-size:.85rem}.button-row button{border:1px solid var(--line);color:var(--ink);cursor:pointer;background:#fff;border-radius:999px;padding:6px 12px;font-size:.9rem}.button-row button:disabled{opacity:.45;cursor:default}.button-row button:hover{border-color:var(--accent)}.button-row button.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);font-weight:600}.button-row button.plan-x{border-color:#8b5cf6}.button-row button.plan-x.active{color:#6d28d9;background:#ede9fe}.button-row button.plan-o{border-color:#f97316}.button-row button.plan-o.active{color:#c2410c;background:#ffedd5}.auto-bot-group{border:1px solid var(--line);background:#fff;border-radius:999px;flex-wrap:wrap;gap:2px;padding:2px;display:inline-flex}.auto-bot-group button{color:var(--ink-soft);cursor:pointer;background:0 0;border:0;border-radius:999px;padding:5px 10px;font-size:.84rem}.auto-bot-group button.active{background:var(--accent-soft);color:var(--accent);font-weight:700}.auto-bot-group button.auto-easy{color:var(--accent)}.zoom-readout,.drag-readout{color:var(--ink-soft);margin-left:4px;padding:0 4px;font-size:.86rem}.bot-panel{gap:10px;display:grid}.compute-panel{border:1px solid var(--line);background:#fff;border-radius:10px;gap:6px;padding:8px 10px;display:grid}.compute-label{color:var(--ink-soft);align-items:center;gap:6px;font-size:.86rem;display:inline-flex}.compute-panel input[type=range]{width:100%}.compute-meta{color:var(--ink-soft);font-size:.82rem}.tuning-panel{border:1px solid var(--line);background:#fff;border-radius:10px;padding:8px 10px}.tuning-panel summary{cursor:pointer;font-weight:600}.tuning-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;margin-top:8px;display:grid}.tuning-grid label{color:var(--ink-soft);gap:4px;font-size:.8rem;display:grid}.tuning-label-text{align-items:center;gap:4px;display:inline-flex}.hint-pill{border:1px solid var(--line);width:16px;height:16px;color:var(--ink-soft);cursor:default;vertical-align:middle;background:#f8fafc;border-radius:999px;outline:none;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:inline-flex;position:relative}.hint-pill:after{content:attr(data-tip);border:1px solid var(--line);width:min(260px,68vw);color:var(--ink);text-align:left;opacity:0;pointer-events:none;z-index:4;background:#fff;border-radius:8px;padding:6px 8px;font-size:.78rem;line-height:1.25;transition:opacity .1s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 8px 20px #0f172a26}.hint-pill:hover:after,.hint-pill:focus-visible:after{opacity:1}.tuning-grid input{border:1px solid var(--line);color:var(--ink);border-radius:8px;padding:5px 7px;font-size:.85rem}.bot-metrics{grid-template-columns:repeat(2,minmax(150px,1fr));gap:8px;display:grid}.threat-line-x{color:var(--threat-x-text)}.threat-line-o{color:var(--threat-o-text)}.app-shell.theme-dark .toggle-hud,.app-shell.theme-dark .network-panel button,.app-shell.theme-dark .network-panel input,.app-shell.theme-dark .button-row button,.app-shell.theme-dark .play-as,.app-shell.theme-dark .play-as select,.app-shell.theme-dark .auto-bot-group,.app-shell.theme-dark .compute-panel,.app-shell.theme-dark .tuning-panel,.app-shell.theme-dark .hint-pill{background:color-mix(in oklab, var(--panel), black 20%);color:var(--ink);border-color:var(--line)}.app-shell.theme-dark .tuning-grid input{background:color-mix(in oklab, var(--panel), black 22%);color:var(--ink);border-color:var(--line)}.app-shell.theme-dark .auto-bot-group button{color:var(--ink-soft)}.app-shell.theme-dark .auto-bot-group button.active{background:var(--accent-soft);color:var(--accent)}.app-shell.theme-dark .rules-modal,.app-shell.theme-dark .hint-pill:after{background:color-mix(in oklab, var(--panel), black 12%)}.app-shell.theme-dark .compact-status-row span{color:#0f172a;background:#fff;border-color:#cbd5e1}@media (width<=1080px){.topbar{flex-direction:column;align-items:flex-start}.network-panel{grid-template-columns:repeat(2,minmax(0,1fr));width:100%}.board-dock-shell{max-height:min(58vh,620px)}}@media (width<=860px){.app-shell{gap:8px;padding:8px}.topbar-actions{justify-content:flex-start;width:100%}.board-dock{bottom:8px;left:8px;right:8px}.bot-metrics,.tuning-grid{grid-template-columns:1fr}.zoom-readout,.drag-readout{width:100%;margin-left:0;padding-left:0}.button-row button,.toggle-hud{font-size:.82rem}}
