:root{--bg: #1f2430;--fg: #cbccc6;--border: #313244;--accent: #65bddb;--accent-red: #f08778;--panel: #232834}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:Fantasque Sans Mono,ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:15px;overflow:hidden}#root{min-height:100vh;display:flex;flex-direction:column;align-items:center;gap:14px}.title{font-weight:700;color:var(--accent);letter-spacing:.05em}.title .dim{color:var(--fg);opacity:.5}.table-wrap{position:relative;line-height:0}canvas{border-radius:8px;box-shadow:0 12px 40px #0000008c;touch-action:none}.table-cue{position:absolute;left:0;top:0;transform-origin:50% 0;pointer-events:none;will-change:transform,left,top}.hud{display:flex;flex-wrap:wrap;gap:10px 18px;align-items:center;justify-content:center;width:100%;max-width:940px}.play-row{display:flex;width:100%;align-items:center;justify-content:space-evenly;gap:0}.cue-col{display:flex;flex-direction:column;align-items:center;gap:12px;padding:12px 0}.cue-power{width:76px;flex:1 1 auto;min-height:90px;touch-action:none;cursor:grab}.cue-power:active{cursor:grabbing}.tune-ball{padding:0;cursor:pointer}.pick-modal{position:fixed;z-index:12;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:0 20px 60px #0009}.pick-modal .pm-title{font-weight:700;color:var(--accent)}.pick-modal .pm-done{min-width:140px;padding:10px}.tune-grid{display:flex;gap:28px;align-items:flex-start;flex-wrap:wrap;justify-content:center}.tune-cell{display:flex;flex-direction:column;align-items:center;gap:8px;font-size:12px;opacity:.9}.pick-modal .spin{width:140px;height:140px}.pick-modal .spin .dot{width:16px;height:16px;margin:-8px 0 0 -8px}.pick-modal .cue-elev{width:150px;height:150px}.hamburger{align-self:flex-start;margin-top:20px;flex:none;width:30px;height:30px;font-size:16px;line-height:1;padding:0;display:flex;align-items:center;justify-content:center}.menu-modal{min-width:220px}.menu-modal .pm-done{width:100%}.menu-modal .resign{color:var(--accent-red)}.turn-recap{position:absolute;top:2ch;left:50%;transform:translate(-50%);z-index:20;max-width:90%;padding:1ch 2ch;text-align:center;color:var(--accent);background:var(--bg);border:1px solid var(--border);pointer-events:none;animation:recap-in .18s ease-out}@keyframes recap-in{0%{opacity:0;transform:translate(-50%,-.8ch)}to{opacity:1;transform:translate(-50%)}}.cue-col .spin{width:68px;height:68px;flex:none}.cue-col .cue-elev{width:76px;height:76px;flex:none}.game-root{flex:1;align-self:stretch;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}@media(orientation:portrait)and (max-width:700px){.game-root.rot90{position:fixed;top:50%;left:50%;width:100vh;height:100vw;transform:translate(-50%,-50%) rotate(90deg);transform-origin:center}}.main-menu{position:fixed;inset:0;z-index:11;overflow-y:auto;background:var(--bg);padding:24px clamp(16px,6vw,80px);display:flex;flex-direction:column;gap:14px}.mm-start{padding:10px 20px}.mm-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.mm-load{cursor:pointer;display:inline-flex;align-items:center}.lobby{width:100%;max-width:460px;display:flex;flex-direction:column;gap:6px}.lobby-head{font-size:12px;opacity:.7;margin-bottom:2px}.lobby-empty{opacity:.5;padding:8px 2px}.lobby-row{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:8px 12px}.lobby-code{font-weight:700;letter-spacing:1px}.menu-backdrop{position:fixed;inset:0;background:#0000008c;z-index:10}.menu-panel{position:fixed;z-index:11;top:50%;left:50%;transform:translate(-50%,-50%);width:min(94vw,720px);max-height:88vh;overflow-y:auto;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:12px;box-shadow:0 20px 60px #0009}.menu-head{display:flex;justify-content:space-between;align-items:center;font-weight:700;color:var(--accent)}.menu-close{background:transparent;border:none;color:var(--fg);font-size:18px;padding:4px 8px}button{font:inherit;color:var(--fg);background:#2c313d;border:1px solid var(--border);border-radius:6px;padding:7px 12px;cursor:pointer}button:hover:not(:disabled){border-color:var(--accent)}button:disabled{opacity:.4;cursor:default}button.primary{background:var(--accent);color:#10202a;font-weight:700;border-color:var(--accent)}.spin{width:66px;height:66px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#fff,#c9ccc6 70%,#9aa09a);border:1px solid var(--border);position:relative;cursor:crosshair;touch-action:none}.spin .axis{position:absolute;background:#0000002e}.spin .axis.h{left:8%;right:8%;top:50%;height:1px}.spin .axis.v{top:8%;bottom:8%;left:50%;width:1px}.spin .dot{position:absolute;width:12px;height:12px;margin:-6px 0 0 -6px;border-radius:50%;background:var(--accent-red);box-shadow:0 0 0 2px #00000040;pointer-events:none}.cue-elev{width:100px;height:76px;background:var(--panel);border:1px solid var(--border);border-radius:8px;cursor:ns-resize;touch-action:none}.cue-elev .surface{stroke:#15603b;stroke-width:3;stroke-linecap:round}.cue-elev .shadow{fill:#0000004d}.cue-elev .ball{fill:#f4f1ea}.cue-elev .cue{stroke:#c79a5b;stroke-width:3.6;stroke-linecap:round}.cue-elev .tip{fill:#3a6ea5}.cue-elev .arc{fill:none;stroke:var(--accent, #65bddb);stroke-width:1.4;stroke-dasharray:3 2.5;opacity:.6}.cue-elev .arc-head{fill:var(--accent, #65bddb);opacity:.6}a{color:var(--accent)}
