:root{--bg: #0e1118;--panel: #171c27;--panel-2: #1f2632;--line: #2b3340;--text: #e6ebf2;--muted: #93a0b3;--accent: #3da5ff;--accent-2: #ff5a4d;--good: #5ad65a;--warn: #e8c33a}*{box-sizing:border-box}html,body{margin:0;height:100%;background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,-apple-system,sans-serif;overflow:hidden;user-select:none}#app{position:fixed;inset:0}.screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(900px 500px at 30% 10%,rgba(61,165,255,.12),transparent),radial-gradient(800px 500px at 80% 90%,rgba(255,90,77,.1),transparent),var(--bg)}.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:28px 30px;width:min(560px,92vw);box-shadow:0 24px 60px #00000073}.title{font-size:40px;font-weight:800;letter-spacing:1px;margin:0 0 2px}.title .dot{color:var(--accent)}.title .dot2{color:var(--accent-2)}.subtitle{color:var(--muted);margin:0 0 22px;font-size:14px}label.field{display:block;font-size:12px;color:var(--muted);margin:14px 0 6px;text-transform:uppercase;letter-spacing:.5px}input[type=text]{width:100%;background:var(--panel-2);border:1px solid var(--line);color:var(--text);border-radius:8px;padding:10px 12px;font-size:15px}.row{display:flex;gap:10px;flex-wrap:wrap}.row>*{flex:1}button{background:var(--panel-2);color:var(--text);border:1px solid var(--line);border-radius:8px;padding:11px 14px;font-size:14px;font-weight:600;cursor:pointer;transition:.12s}button:hover{border-color:var(--accent)}button.primary{background:var(--accent);border-color:var(--accent);color:#04101e}button.primary:hover{filter:brightness(1.08)}button.danger{border-color:var(--accent-2);color:var(--accent-2)}button:disabled{opacity:.5;cursor:not-allowed}.seg{display:flex;gap:6px;margin-top:6px}.seg button{flex:1}.seg button.active{background:var(--accent);border-color:var(--accent);color:#04101e}.divider{height:1px;background:var(--line);margin:22px 0}.muted{color:var(--muted);font-size:13px}.room-list{max-height:260px;overflow-y:auto;margin-top:8px;border:1px solid var(--line);border-radius:8px}.room-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--line)}.room-item:last-child{border-bottom:none}.room-item .meta{color:var(--muted);font-size:12px}.empty{padding:18px;text-align:center;color:var(--muted)}.seats{display:flex;gap:10px;margin:14px 0}.seat{flex:1;border:1px solid var(--line);border-radius:10px;padding:14px;text-align:center}.seat.p1{border-color:var(--accent)}.seat.p2{border-color:var(--accent-2)}.seat .name{font-weight:700;margin-top:6px}.seat .status{font-size:12px;color:var(--muted);margin-top:4px}.seat .status.ready{color:var(--good)}.banner{margin-top:12px;padding:8px 12px;border-radius:8px;background:#ff5a4d1f;border:1px solid var(--accent-2);color:#ffd0cb;font-size:13px}#game-canvas{position:fixed;inset:0;width:100%;height:100%;cursor:crosshair;display:block}.hud{position:fixed;top:12px;left:12px;display:flex;gap:10px;pointer-events:none}.hud .chip{background:#10141cd1;border:1px solid var(--line);border-radius:8px;padding:7px 12px;font-size:13px;font-variant-numeric:tabular-nums}.hud .chip b{color:var(--accent)}.hud .chip .net{color:var(--good);font-size:11px}.hud .chip .net.neg{color:var(--accent-2)}.hud .chip.warn-chip{border-color:var(--warn);color:var(--warn)}#minimap-wrap{position:fixed;left:12px;bottom:12px}#minimap{display:block;width:192px;height:128px;border:1px solid var(--line);border-radius:8px;background:#10141ce6;cursor:pointer;box-shadow:0 8px 24px #0006}#minimap-close{position:absolute;top:-8px;right:-8px;width:22px;height:22px;padding:0;border-radius:50%;font-size:12px;line-height:1;background:var(--panel-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center}#minimap-close:hover{border-color:var(--accent-2);color:var(--accent-2)}#minimap-show{position:fixed;left:12px;bottom:12px;font-size:12px;padding:7px 12px;background:#10141ce6}.selbar{position:fixed;top:54px;left:12px;display:none;background:#10141cd1;border:1px solid var(--accent);color:var(--text);border-radius:8px;padding:5px 12px;font-size:13px;font-variant-numeric:tabular-nums}.selbar.show{display:block}.help-row{margin:2px 0}.winbar{position:fixed;top:54px;left:50%;transform:translate(-50%);background:#10141cd1;border:1px solid var(--line);border-radius:8px;padding:7px 14px;font-size:13px}.winbar .track{display:inline-block;width:160px;height:8px;background:var(--panel-2);border-radius:5px;overflow:hidden;vertical-align:middle;margin:0 8px}.winbar .fill{height:100%;background:var(--good)}.production{position:fixed;bottom:16px;left:50%;transform:translate(-50%);display:none;gap:10px;background:#10141ce6;border:1px solid var(--line);border-radius:12px;padding:10px 12px}.production.show{display:flex}.production .pbtn{display:flex;flex-direction:column;align-items:center;min-width:92px}.production .pbtn small{color:var(--muted);font-weight:500;margin-top:2px}.production .pbtn.active{background:var(--accent);border-color:var(--accent);color:#04101e}.production .pbtn.active small{color:#04101eb3}.prod-title{align-self:center;font-size:13px;font-weight:700;color:var(--text);padding-right:4px}.help{position:fixed;bottom:16px;right:16px;background:#10141cd1;border:1px solid var(--line);border-radius:8px;padding:10px 12px;font-size:12px;color:var(--muted);max-width:260px;line-height:1.5}.help b{color:var(--text)}.overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#080a0eb3;backdrop-filter:blur(3px)}.overlay .card{text-align:center}.result{font-size:34px;font-weight:800;margin:0 0 6px}.result.win{color:var(--good)}.result.lose{color:var(--accent-2)}.toast{position:fixed;bottom:16px;left:50%;transform:translate(-50%);background:var(--accent-2);color:#fff;padding:8px 14px;border-radius:8px;font-size:13px;z-index:50}.statusbar{position:fixed;top:10px;right:14px;font-size:12px;color:var(--muted)}.dotind{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--warn);margin-right:6px}.dotind.on{background:var(--good)}
