@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400..800&family=JetBrains+Mono:wght@400;500;600&family=Outfit:wght@300;400;500;600;700&display=swap";:root{color-scheme:dark;--bg-void: #05080f;--bg: #0a1020;--surface-1: #101830;--surface-2: #16203c;--surface-3: #1d2a4d;--line: rgba(148, 175, 230, .1);--line-strong: rgba(148, 175, 230, .22);--sonar: #38bdf8;--sonar-bright:#7dd3fc;--sonar-soft: rgba(56, 189, 248, .1);--sonar-glow: rgba(56, 189, 248, .28);--alert: #fbbf24;--alert-soft: rgba(251, 191, 36, .14);--hit: #f43f5e;--hit-soft: rgba(244, 63, 94, .15);--sunk: #fb923c;--sunk-soft: rgba(251, 146, 60, .18);--miss: #64748b;--miss-soft: rgba(100, 116, 139, .18);--ship: #2dd4bf;--ship-soft: rgba(45, 212, 191, .18);--ok: #34d399;--ink: #e2e8f0;--ink-bright: #f8fafc;--ink-muted: #94a3b8;--ink-dim: #64748b;--font-display: "Bricolage Grotesque", ui-sans-serif, system-ui, sans-serif;--font-body: "Outfit", ui-sans-serif, system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--r-sm: 6px;--r: 10px;--r-lg: 14px}:root[data-theme=light]{--bg: #f4f7fb;--panel: #ffffff;--panel-soft: #eef4fb;--panel-strong: #dbeafe;--text: #102033;--muted: #52677f;--border: #c8d7ea;--accent: #0ea5e9;--accent-strong: #0284c7;--success: #047857;--danger: #dc2626;--warning: #ca8a04;--cell: #38bdf8;--cell-dark: #0ea5e9;--ship: #16a34a}:root[data-theme=light] body{background:linear-gradient(rgba(15,23,42,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(15,23,42,.04) 1px,transparent 1px),var(--bg);color:var(--text)}:root[data-theme=light] input,:root[data-theme=light] select{background:#fff;color:var(--text);border-color:var(--border)}:root[data-theme=light] .panel,:root[data-theme=light] .board-card,:root[data-theme=light] .game-card,:root[data-theme=light] .summary-card,:root[data-theme=light] .stat,:root[data-theme=light] .player-pill,:root[data-theme=light] .log-item{background:var(--panel);border-color:var(--border)}:root[data-theme=light] .cell{background:#38bdf8}:root[data-theme=light] .cell.ship{background:#16a34a}:root[data-theme=light] .cell.hit,:root[data-theme=light] .cell.sunk{background:#dc2626}:root[data-theme=light] .cell.miss{background:#93c5fd}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}body{min-height:100vh;font-family:var(--font-body);font-size:14px;line-height:1.5;color:var(--ink);background-color:var(--bg);background-image:linear-gradient(to right,rgba(56,189,248,.035) 1px,transparent 1px),linear-gradient(to bottom,rgba(56,189,248,.035) 1px,transparent 1px);background-size:40px 40px;background-attachment:fixed}h1,h2,h3{margin:0;font-family:var(--font-display);font-weight:700;letter-spacing:-.01em;color:var(--ink-bright);line-height:1.15}h1{font-size:1.9rem;letter-spacing:-.02em}h2{font-size:1.05rem;font-weight:600}h3{font-size:.95rem;font-weight:600}p{margin:0}.eyebrow{display:inline-block;font-family:var(--font-mono);font-size:.68rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--sonar)}.small{font-size:.83rem;color:var(--ink-muted)}.mono{font-family:var(--font-mono)}.wrap{overflow-wrap:anywhere;word-break:break-all}#app{max-width:1560px;margin:0 auto;padding:1.75rem 1.5rem 3rem}.hero{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-bottom:1.25rem;border-bottom:1px solid var(--line);margin-bottom:1.5rem}.hero>div:first-child h1{margin-top:.25rem}.hero p{margin-top:.3rem;color:var(--ink-muted);font-size:.9rem}.layout{display:grid;grid-template-columns:340px minmax(0,1fr);gap:1.75rem;align-items:start}.sidebar{grid-column:1;display:flex;flex-direction:column;gap:1rem;min-width:0}.identity-col,.lobby-col{display:flex;flex-direction:column;gap:1rem;min-width:0}.game-col,main.stack{grid-column:2;display:flex;flex-direction:column;gap:1rem;min-width:0}aside.stack{display:flex;flex-direction:column;gap:1rem;min-width:0}.panel{background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.1rem;display:flex;flex-direction:column;gap:.9rem;min-width:0}.panel h2{display:flex;align-items:center;gap:.55rem}.panel h2:before{content:"";width:3px;height:1em;background:var(--sonar);border-radius:2px;display:inline-block;flex-shrink:0}.section-head{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.section-head h2{margin:0}.stack{display:flex;flex-direction:column;gap:.9rem;min-width:0}.row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}label{display:flex;flex-direction:column;gap:.35rem;font-family:var(--font-mono);font-size:.7rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted)}input,select{width:100%;font-family:var(--font-body);font-size:.95rem;font-weight:400;letter-spacing:0;text-transform:none;color:var(--ink);background:var(--bg-void);border:1px solid var(--line-strong);border-radius:var(--r);padding:.7rem .85rem;outline:none;transition:border-color .14s,box-shadow .14s}input::placeholder{color:var(--ink-dim)}input:focus,select:focus{border-color:var(--sonar);box-shadow:0 0 0 3px var(--sonar-soft)}button{font-family:var(--font-body);font-size:.88rem;font-weight:600;padding:.65rem 1rem;border-radius:var(--r);border:1px solid transparent;cursor:pointer;transition:background .14s,border-color .14s,color .14s,transform 60ms;letter-spacing:0}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.45;cursor:not-allowed}button[type=submit],button:not(.ghost):not(.secondary){background:var(--sonar);color:var(--bg-void);border-color:var(--sonar)}button[type=submit]:hover:not(:disabled),button:not(.ghost):not(.secondary):hover:not(:disabled){background:var(--sonar-bright);border-color:var(--sonar-bright)}button.secondary{background:var(--surface-2);color:var(--ink);border-color:var(--line-strong)}button.secondary:hover:not(:disabled){background:var(--surface-3);border-color:var(--sonar)}button.ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}button.ghost:hover:not(:disabled){background:var(--surface-2);border-color:var(--sonar);color:var(--sonar-bright)}button.small-button{padding:.4rem .7rem;font-size:.78rem}.actions{display:flex;gap:.6rem;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--font-mono);font-size:.7rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:.3rem .6rem;border-radius:999px;border:1px solid var(--line-strong);color:var(--ink-muted);background:var(--surface-2);white-space:nowrap}.badge.active{color:var(--bg-void);background:var(--sonar);border-color:var(--sonar)}.callout{background:var(--sonar-soft);border:1px solid var(--sonar-glow);border-radius:var(--r);padding:.7rem .85rem;font-size:.87rem}.callout strong{color:var(--ink-bright)}.message{padding:.75rem .9rem;border-radius:var(--r);font-weight:500;margin-bottom:1rem;border:1px solid transparent}.message.error{background:var(--hit-soft);border-color:#f43f5e66;color:#fecaca}.message.success{background:#34d3991f;border-color:#34d39966;color:#a7f3d0}.message.info{background:var(--sonar-soft);border-color:var(--sonar-glow);color:var(--sonar-bright)}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.55rem}.stat{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);padding:.65rem .75rem;min-width:0}.stat .label{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted)}.stat .value{margin-top:.3rem;font-family:var(--font-mono);font-size:1.1rem;font-weight:600;color:var(--ink-bright);overflow-wrap:anywhere}.game-list,.leaderboard-list{display:flex;flex-direction:column;gap:.55rem}.game-card{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);padding:.75rem .85rem;display:flex;flex-direction:column;gap:.55rem;transition:border-color .14s,background .14s}.game-card:hover{border-color:var(--line-strong)}.game-card.current{border-color:var(--sonar);background:var(--sonar-soft)}.game-card strong{color:var(--ink-bright);font-weight:600}.game-actions{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.game-actions button{padding:.38rem .7rem;font-size:.78rem}.leaderboard-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.55rem .75rem;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r)}.leaderboard-row strong{font-family:var(--font-display);color:var(--ink-bright);font-weight:600}.leaderboard-row.me{border-color:var(--ok);background:#34d39914}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.6rem}.summary-card{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);padding:.7rem .85rem;display:flex;flex-direction:column;gap:.4rem;min-width:0}.summary-card .label{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted)}.summary-card .value{font-family:var(--font-mono);font-size:1.05rem;font-weight:600;color:var(--ink-bright);overflow-wrap:anywhere}.summary-card-emphasis{border-color:var(--sonar);background:var(--sonar-soft)}.summary-actions{margin-top:.25rem}.players-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.6rem}.player-pill{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);padding:.7rem .85rem;display:flex;justify-content:space-between;align-items:center;gap:.5rem;min-width:0;position:relative}.player-pill strong{color:var(--ink-bright);font-family:var(--font-display);font-weight:600}.player-pill.turn{border-color:var(--alert);background:var(--alert-soft)}.player-pill.turn:after{content:"";position:absolute;top:.65rem;right:.7rem;width:8px;height:8px;border-radius:50%;background:var(--alert);box-shadow:0 0 8px var(--alert);animation:pulse 1.5s ease-in-out infinite}.player-pill.eliminated{opacity:.55;border-style:dashed}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.4)}}.boards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:1rem}.board-card{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:.9rem;display:flex;flex-direction:column;gap:.75rem;min-width:0}.board-head{display:flex;justify-content:space-between;align-items:center;gap:.75rem;flex-wrap:wrap}.board-head h3{font-family:var(--font-display);font-weight:700}.board{display:inline-grid;gap:3px;background:var(--bg-void);padding:8px;border-radius:var(--r);border:1px solid var(--line-strong);width:fit-content;max-width:100%;overflow:auto}.board-row{display:flex;gap:3px}.cell,.axis-cell{width:34px;height:34px;display:grid;place-items:center;border-radius:5px;font-family:var(--font-mono);font-size:.78rem;font-weight:500;-webkit-user-select:none;user-select:none;flex-shrink:0}.axis-cell{background:transparent;color:var(--ink-dim);font-weight:500}.cell{background:#0a1835;border:1px solid rgba(96,165,250,.18);color:transparent;transition:background .1s,border-color .1s}.cell.interactive{cursor:crosshair}.cell.interactive:hover{background:var(--sonar-soft);border-color:var(--sonar)}.board-self .cell.ship{background:#22c55e;border-color:#05080f8c;box-shadow:inset 0 0 0 1px #22c55e99}.board-self .cell.hit{background:#ef4444;border-color:#b91c1c;box-shadow:none}.board-self .cell.hit:after{content:"✕";color:#fff;font-weight:700}.board-self .cell.sunk{background:#7f1d1d;border-color:#450a0a;box-shadow:none}.board-self .cell.sunk:after{content:"✕";color:#fca5a5;font-weight:700}.board-target .cell.hit{background:#f97316;border-color:#9a3412}.board-target .cell.hit:after{content:"✕";color:#fff7ed;font-weight:700}.board-target .cell.sunk{background:#ef4444;border-color:#7f1d1d}.board-target .cell.sunk:after{content:"✕";color:#fff;font-weight:700}.cell.miss{background:var(--miss-soft);border-color:var(--miss)}.cell.miss:after{content:"·";color:var(--miss);font-size:1.3rem;line-height:0}.cell.disabled{opacity:.55;cursor:not-allowed}.cell.droppable{outline:1px dashed rgba(56,189,248,.35);outline-offset:-4px}.fleet-builder{gap:.9rem}.fleet-list{display:flex;flex-direction:column;gap:.55rem}.fleet-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem .9rem;background:var(--surface-1);border:1px solid var(--line-strong);border-radius:var(--r);min-width:0;cursor:grab;min-height:52px}.fleet-row:active{cursor:grabbing}.fleet-row.placed{border-color:var(--ship);background:#2dd4bf14}.ship-graphic{display:flex;align-items:center;justify-content:flex-start;min-width:0;flex-shrink:1;overflow:hidden}.ship-svg{display:block;filter:drop-shadow(0 1px 2px rgba(0,0,0,.35));pointer-events:none}.fleet-row-actions{display:flex;gap:.4rem;flex-shrink:0}.pill-tags{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center}.log-head{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.25rem}.log{max-height:320px;overflow-y:auto;display:flex;flex-direction:column;gap:.45rem;padding-right:.3rem}.log-item{background:var(--surface-2);border:1px solid var(--line);border-left:2px solid var(--line-strong);border-radius:var(--r-sm);padding:.55rem .7rem;font-size:.86rem}.log-item strong{color:var(--ink-bright)}.log::-webkit-scrollbar{width:6px}.log::-webkit-scrollbar-track{background:transparent}.log::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:3px}.empty-state{text-align:center;padding:3rem 1.5rem;display:flex;flex-direction:column;align-items:center;gap:.75rem}.empty-state h2{font-family:var(--font-display);font-size:1.4rem;color:var(--ink-bright)}.empty-state:before{content:"";width:72px;height:72px;border-radius:50%;background:radial-gradient(circle at center,var(--sonar) 0 6%,transparent 7%),radial-gradient(circle at center,transparent 0 28%,var(--sonar-glow) 29% 31%,transparent 32%),radial-gradient(circle at center,transparent 0 58%,var(--sonar-glow) 59% 61%,transparent 62%);opacity:.7;margin-bottom:.5rem}.empty-state p{color:var(--ink-muted);max-width:42ch}.compact-form{padding-bottom:.3rem;border-bottom:1px solid var(--line)}@media (max-width: 1000px){.layout{grid-template-columns:1fr}.sidebar,.game-col,main.stack{grid-column:auto}.hero{flex-direction:column;align-items:flex-start}.boards-grid{grid-template-columns:1fr}}@media (max-width: 560px){#app{padding:1rem .9rem 2rem}.cell,.axis-cell{width:28px;height:28px;font-size:.7rem}.row,.info-grid,.summary-grid{grid-template-columns:1fr 1fr}}
