:root{--bg: #08111a;--panel: rgba(13, 25, 37, .92);--line: rgba(107, 144, 182, .28);--text: #ebf3ff;--muted: #9bb2ce;--accent: #86d9ff;--tracker-ball-size: 28px;--tracker-ball-font-size: .78rem}*{box-sizing:border-box}html,body{margin:0;min-height:100%;width:100%;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;color:var(--text);background:radial-gradient(circle at top left,rgba(51,90,143,.36),transparent 30%),radial-gradient(circle at 80% 20%,rgba(33,128,116,.24),transparent 32%),linear-gradient(180deg,#0b1622,#060b11 72%)}body{padding:10px}body.mobile-landscape{padding:6px}.page{width:min(1240px,100%);min-height:calc(100dvh - 20px);margin:0 auto;display:grid;gap:10px;grid-template-rows:auto minmax(0,1fr)}.panel{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:10px 12px;box-shadow:0 14px 40px #00000047;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.top-panel{display:grid;gap:6px;padding-block:8px 10px}.top-panel-copy{display:grid;gap:3px}.top-panel-copy p{margin:0;font-size:.87rem;line-height:1.28}h1{margin:0;letter-spacing:.02em}p{margin:6px 0 10px;color:var(--muted)}.stats,.state-strip{display:flex;flex-wrap:wrap;gap:6px}.top-hud-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px 10px}.stats span,.state-pill{background:#07101beb;padding:6px 10px;border-radius:999px;border:1px solid rgba(105,142,178,.24);color:#dbe8fb;font-size:.84rem;font-weight:700;line-height:1.15}.stats span{line-height:1.1}#ballsLeft{padding-block:5px;font-size:.88rem;line-height:1.05}@media(min-width:701px){#ballsLeft{max-width:min(46vw,560px)}}.state-strip{margin-top:0;flex:1 1 420px;align-items:center}.state-pill{font-weight:700;background:#0a1420db}.state-strip .state-pill{min-height:38px;display:inline-flex;align-items:center}.top-hud-bar .controls,.top-hud-bar .mode-picker select,.top-hud-bar button,.top-hud-bar .state-pill{font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;font-size:.84rem;font-weight:700;line-height:1.15;letter-spacing:.01em}#turnBadge{color:#fff4cc;border-color:#ffd37d47;background:#30250cb3}#suitBadge{color:#d9f4ff;border-color:#86d9ff3d}#shotStateBadge[data-tone=ready]{color:#d6effa}#shotStateBadge[data-tone=break]{color:#ffe39d;background:#392a0dc2;border-color:#ffd37d47}#shotStateBadge[data-tone=place]{color:#9ce9ff;background:#0e2935c2;border-color:#86d9ff4d}#shotStateBadge[data-tone=aim]{color:#d5f3ff;background:#123044cc;border-color:#86d9ff4d}#shotStateBadge[data-tone=live]{color:#c9ffd6;background:#113722c7;border-color:#71e69847}#shotStateBadge[data-tone=over]{color:#ffd1d1;background:#411717cc;border-color:#ff8c8c42}.game-wrap{padding:6px 8px 8px;min-height:0;display:flex;flex-direction:column;align-items:center;gap:6px}#poolCanvas{width:100%;max-width:100%;aspect-ratio:2.08 / 1;max-height:min(82dvh,960px);display:block;margin-inline:auto;border-radius:18px;background:#0d5638;border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 0 0 1px #ffffff0a,0 20px 50px #00000052;touch-action:none}.controls{width:100%;display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;gap:8px;padding:6px 8px;border:1px solid rgba(105,142,178,.16);border-radius:14px;background:#060e1894}.top-hud-bar .controls{width:auto;flex:0 1 auto;justify-content:flex-end;padding:0;border:0;background:transparent}.top-hud-bar .controls>*{flex:0 0 auto}.header-controls{margin-top:0}.mode-picker{position:relative;display:inline-flex;align-items:center;min-width:0}.mode-picker>span{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.mode-picker select{appearance:none;border:0;border-radius:999px;background:linear-gradient(135deg,#8ce4ff,#7ea6ff);color:#06111d;font:inherit;font-weight:800;letter-spacing:.01em;padding:8px 38px 8px 14px;cursor:pointer;box-shadow:0 10px 24px #5888ff3d}.top-hud-bar .mode-picker select,.top-hud-bar button,.top-hud-bar .state-pill{min-height:38px;box-shadow:0 8px 18px #0000002e}.top-hud-bar .mode-picker select{padding:6px 36px 6px 14px}.top-hud-bar button{padding:6px 13px}.mode-picker:after{content:"▾";position:absolute;right:14px;top:50%;transform:translateY(-50%);color:#06111d;font-size:.8rem;font-weight:900;pointer-events:none}.top-hud-bar .mode-picker:after{right:13px}.mode-picker select:hover,button:hover{filter:brightness(1.04)}.mode-picker select:disabled{opacity:.55;cursor:default}button{appearance:none;border:0;border-radius:999px;background:linear-gradient(135deg,#8ce4ff,#7ea6ff);color:#06111d;font-weight:800;letter-spacing:.01em;padding:8px 13px;cursor:pointer;box-shadow:0 10px 24px #5888ff3d}.secondary-btn{background:linear-gradient(135deg,#8ce4ff,#7ea6ff);color:#06111d;border:0;box-shadow:0 10px 24px #5888ff3d}.secondary-btn[disabled]{opacity:.5;cursor:default}@media(min-width:1025px){.top-hud-bar{flex-wrap:nowrap}.top-hud-bar .state-strip,.top-hud-bar .controls{flex-wrap:nowrap;min-width:0}}@media(max-width:960px){.top-hud-bar{flex-direction:column;align-items:stretch}.top-hud-bar .controls{width:100%;justify-content:flex-start;flex-wrap:wrap}}.rack-overview{width:100%;border:1px solid rgba(105,142,178,.2);border-radius:16px;background:#07101b9e;padding:7px 9px 8px}.hud-rack-overview{margin-top:0}.rack-overview-head{display:flex;justify-content:space-between;gap:12px;align-items:baseline;margin-bottom:8px}.rack-overview-head h2{margin:0;font-size:.92rem}.rack-overview-note{color:var(--muted);font-size:.76rem}.player-ball-tracks{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.player-track{display:grid;grid-template-columns:minmax(0,auto) minmax(0,1fr);align-items:center;gap:8px;border:1px solid rgba(105,142,178,.16);border-radius:16px;padding:7px 9px;background:linear-gradient(180deg,#0b1623f5,#09131fe0);min-width:0}.player-track.active{border-color:#ffd37d61;box-shadow:inset 0 0 0 1px #ffd37d29,0 0 0 1px #ffd37d14,0 10px 24px #0000002e}.player-track-meta{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;min-width:0}.player-track-copy{display:grid;gap:2px;min-width:0}.player-name{font-weight:800;font-size:.95rem;letter-spacing:.01em}.player-group{color:var(--muted);font-size:.74rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-count{display:inline-grid;place-items:center;min-width:52px;padding:5px 8px 6px;border-radius:12px;background:#fff4cc14;border:1px solid rgba(255,211,125,.22);color:#fff4cc;text-align:center;line-height:1;box-shadow:inset 0 1px #ffffff0a}.player-count strong{display:block;font-size:1.22rem;font-weight:900}.player-count small{display:block;margin-top:2px;font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#fff4ccd6}.ball-pips{display:flex;flex-wrap:nowrap;gap:4px;min-width:0;overflow-x:auto;padding-bottom:2px;margin-left:auto;align-self:center}.ball-pip{flex:0 0 auto;width:var(--tracker-ball-size);height:var(--tracker-ball-size);border-radius:50%;border:1px solid rgba(255,255,255,.18);position:relative;box-shadow:inset 0 -2px 5px #00000047}.ball-pip:after{content:attr(data-ball);position:absolute;inset:0;display:grid;place-items:center;font-size:var(--tracker-ball-font-size);font-weight:900;color:#111}.ball-pip.stripe{background:linear-gradient(180deg,#f4f7fb 0 28%,var(--ball-color) 28% 72%,#f4f7fb 72% 100%)}.ball-pip.solid{background:var(--ball-color)}.ball-pip.pocketed{opacity:.28;filter:grayscale(.9)}.ball-pip.unassigned{background:#ffffff0a;border-style:dashed;border-color:#9bb2ce47;box-shadow:none}.ball-pip.unassigned:after{color:#9bb2ce}.event-log-panel{width:100%;border:1px solid rgba(105,142,178,.24);border-radius:16px;background:#07101bbd;overflow:hidden}.event-log-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px 14px 10px;border-bottom:1px solid rgba(105,142,178,.18)}.event-log-header h2{margin:0;font-size:1rem}.event-log-header p{margin:4px 0 0;font-size:.88rem}.event-log-meta{flex:0 0 auto;color:var(--accent);background:#86d9ff1f;border:1px solid rgba(134,217,255,.16);padding:6px 10px;border-radius:999px;font-size:.82rem;white-space:nowrap}.event-log{list-style:none;margin:0;padding:0;max-height:min(22dvh,220px);overflow:auto}.event-log li{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:start;padding:11px 14px;border-top:1px solid rgba(105,142,178,.12)}.event-log li:first-child{border-top:0}.log-shot{color:var(--accent);font-weight:700;font-size:.83rem}.log-text{color:#e8f2ff;line-height:1.4;font-size:.92rem}.log-text strong{color:#fff}@media(max-width:700px){:root{--tracker-ball-size: 25px;--tracker-ball-font-size: .7rem}.player-ball-tracks{grid-template-columns:1fr}body{padding:4px}.page{min-height:calc(100dvh - 8px);gap:6px;grid-template-rows:auto minmax(0,1fr)}.panel{padding:8px 10px;border-radius:14px}.top-panel{gap:6px}h1{font-size:1.02rem}p{margin:4px 0 6px;font-size:.84rem;line-height:1.3}.stats,.state-strip{gap:6px}.stats span,.state-pill{flex:1 1 calc(50% - 6px);min-width:0;border-radius:12px;font-size:.82rem;padding:6px 8px}.game-wrap{padding:5px 6px 6px;justify-content:flex-start}#poolCanvas{aspect-ratio:auto;min-height:280px;border-radius:14px}.rack-overview{padding:8px 9px 9px;border-radius:14px}.rack-overview-head{flex-direction:column;align-items:flex-start;gap:3px}.player-track{gap:7px;padding:8px 9px;border-radius:14px}.player-track-meta{gap:7px}.player-name{font-size:.92rem}.player-group{max-width:32vw}.player-count{min-width:52px;padding-inline:8px}.player-count strong{font-size:1.08rem}.ball-pips{gap:3px}.controls{width:100%;gap:8px;padding:8px 9px;justify-content:stretch}.controls>*{flex:1 1 140px;min-width:0}.mode-picker{font-size:.82rem}.mode-picker select{padding:8px 11px}button{padding:9px 13px;flex:0 0 auto}.event-log-panel{margin-top:4px;border-radius:14px}.event-log-header{padding:10px 11px 9px;flex-direction:column;gap:8px}.event-log-header h2{font-size:.94rem}.event-log-header p,.event-log-meta,.log-shot,.log-text{font-size:.8rem}.event-log{max-height:min(18dvh,180px)}.event-log li{gap:8px;padding:9px 11px}}@media(max-width:420px){:root{--tracker-ball-size: 22px;--tracker-ball-font-size: .66rem}body{padding:2px}.page{min-height:calc(100dvh - 4px);gap:4px}.panel{padding:7px 8px;border-radius:12px}.stats span,.state-pill{font-size:.78rem;padding:5px 7px}.game-wrap{padding:4px}#poolCanvas{min-height:248px;border-radius:12px}.player-track{grid-template-columns:1fr;row-gap:6px}.player-track-meta{width:100%}.player-group{max-width:48vw}.player-count{min-width:48px}.player-count strong{font-size:1rem}.ball-pips{width:100%;margin-left:0}.controls{gap:6px}.controls>*{flex-basis:100%}button{padding:8px 12px}.event-log{max-height:150px}.event-log li{grid-template-columns:1fr;gap:4px}}@media(max-width:960px)and (orientation:landscape){:root{--tracker-ball-size: 22px;--tracker-ball-font-size: .66rem}body{padding:4px}.page{width:min(1480px,100%);min-height:calc(100dvh - 8px);grid-template-columns:minmax(260px,.68fr) minmax(0,1.32fr);grid-template-rows:1fr;align-items:stretch;gap:6px}.top-panel{min-height:0;gap:5px;padding:7px 9px 8px;overflow:auto;align-content:start}.top-panel-copy p{font-size:.78rem;line-height:1.2}h1{font-size:.98rem}.stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:5px}.stats span,.state-pill{padding:5px 8px;font-size:.76rem;min-height:34px}.top-hud-bar{gap:6px}.state-strip{gap:5px;flex:1 1 auto}.top-hud-bar .controls{width:100%;justify-content:stretch;gap:6px}.top-hud-bar .controls>*{flex:1 1 128px;min-width:0}.top-hud-bar .mode-picker select,.top-hud-bar button,.top-hud-bar .state-pill{min-height:34px;font-size:.76rem}.top-hud-bar .mode-picker select,.top-hud-bar button{padding-top:5px;padding-bottom:5px}.rack-overview{padding:6px 8px 7px}.rack-overview-head{margin-bottom:6px}.player-ball-tracks{grid-template-columns:1fr;gap:6px}.player-track{gap:6px;padding:6px 8px}.player-name{font-size:.84rem}.player-group{font-size:.68rem}.player-count{min-width:46px;padding:4px 6px 5px}.player-count strong{font-size:.96rem}.game-wrap{padding:5px 6px 6px;gap:5px;justify-content:flex-start}#poolCanvas{height:min(68dvh,560px);min-height:0;aspect-ratio:auto;border-radius:16px}.event-log-panel{margin-top:0}.event-log-header{padding:9px 11px 8px}.event-log-header h2{font-size:.9rem}.event-log-header p,.event-log-meta,.log-shot,.log-text{font-size:.76rem}.event-log{max-height:min(18dvh,150px)}.event-log li{padding:8px 11px}}
