:root{--bg: #0e1714;--fg: #f4f1e8;--accent: #ffd23f;--accent-2: #ff6b35;--team-a: #4cc9f0;--team-b: #ff6b35;--sand: #e8d8b7;--grass: #2d4a2b;--danger: #ff3b30;--ok: #34c759}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0;font-family:-apple-system,system-ui,sans-serif;background:var(--bg);color:var(--fg);overflow-x:hidden;overscroll-behavior:none}body{min-height:100dvh;display:flex;flex-direction:column}h1,h2,h3{font-weight:800;letter-spacing:-.02em;margin:0}button{font:inherit;font-weight:700;padding:14px 22px;border:0;border-radius:12px;background:var(--accent);color:#1c1c1e;cursor:pointer;touch-action:manipulation}button:disabled{opacity:.4}button.secondary{background:transparent;color:var(--fg);border:2px solid var(--fg)}input[type=text]{font:inherit;font-weight:700;padding:14px;border-radius:12px;border:2px solid var(--fg);background:transparent;color:var(--fg);text-align:center;text-transform:uppercase;letter-spacing:.2em}.lobby{display:flex;flex-direction:column;gap:20px;padding:32px 24px;flex:1;justify-content:center;max-width:480px;margin:0 auto;width:100%}.lobby h1{font-size:48px;text-align:center}.lobby .tagline{text-align:center;opacity:.7}.lobby form{display:flex;flex-direction:column;gap:12px}.lobby .divider{text-align:center;opacity:.5;margin:8px 0}.host{flex:1;display:flex;flex-direction:column}.host header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#0006}.host .room-code{font-size:32px;font-weight:900;letter-spacing:.15em;color:var(--accent)}.play-link{display:inline-block;margin-left:12px;font-weight:700;color:var(--fg);text-decoration:none;border:2px solid var(--fg);padding:6px 12px;border-radius:8px;font-size:14px}.host .turn-banner{text-align:center;font-size:22px;font-weight:700;padding:12px;background:#0000004d}.host .pitch{flex:1;display:flex;justify-content:center;align-items:center;padding:8px;background:linear-gradient(180deg,#d8c590,#c4ad6e)}.host canvas{background:#d8c590;border-radius:8px;width:100%;height:100%;max-width:100vw;max-height:100%;display:block}.host .controls{display:flex;gap:12px;padding:12px 16px;justify-content:center}.player{flex:1;display:flex;flex-direction:column}.player header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#0006}.player .badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:10px;font-weight:800;background:var(--team-a);color:#0e1714}.player .badge.team-B{background:var(--team-b);color:#fff}.player .status{flex:0 0 auto;text-align:center;font-size:18px;padding:12px;font-weight:700}.player .status.my-turn{background:var(--accent);color:#1c1c1e}.player .throw-area{flex:1;position:relative;background:#1f2925;-webkit-user-select:none;user-select:none;touch-action:none}.player .throw-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;justify-content:center;align-items:center;font-size:20px;opacity:.6;pointer-events:none;text-align:center;padding:0 32px}.player .kubb-list{display:flex;gap:10px;padding:12px;overflow-x:auto}.player .kubb-list button{padding:10px 16px}.player .kubb-list button.selected{background:var(--accent-2);color:#fff}.connection-banner{position:fixed;top:0;left:0;right:0;padding:8px;background:var(--danger);color:#fff;text-align:center;font-weight:700;z-index:100;display:none}.connection-banner.show{display:block}.solo{flex:1;display:flex;flex-direction:column;min-height:100dvh}.solo-status{padding:12px;text-align:center;font-weight:700;font-size:18px;background:#0006}.solo-status.team-A{background:var(--team-a);color:#0e1714}.solo-status.team-B{background:var(--team-b);color:#fff}.solo-pitch{flex:1;min-height:40vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(180deg,#d8c590,#c4ad6e);padding:4px}.solo-pitch canvas{width:100%;height:100%;display:block}.solo-kubb-list{display:flex;gap:8px;padding:8px 12px;overflow-x:auto;background:#0000004d}.solo-kubb-list:empty{display:none}.solo-kubb-list button{padding:8px 14px;font-size:14px}.solo-kubb-list button.selected{background:var(--accent-2);color:#fff}.solo-throw{height:28vh;min-height:180px;position:relative;background:#1f2925;touch-action:none}.solo-controls{display:flex;gap:8px;padding:10px 12px;justify-content:center;background:#0006}.solo-controls:empty{display:none}.solo-link{display:block;text-align:center;padding:14px;border-radius:12px;border:2px solid var(--fg);color:var(--fg);font-weight:700;text-decoration:none}
