:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#111827;background:radial-gradient(circle at 10% 20%,#e0f2fe,#f8fafc 40%),radial-gradient(circle at 90% 80%,#e2e8f0,#f8fafc 50%)}*{box-sizing:border-box}body{margin:0;min-height:100vh}.page{min-height:100vh;padding:20px;display:grid;place-items:center}.card{width:min(1180px,100%);background:#ffffffe0;border:1px solid #cbd5e1;border-radius:18px;padding:20px;box-shadow:0 10px 24px #0f172a1a}.card h1{margin:0 0 10px}.card p{margin:8px 0}.muted{color:#475569}.home-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:12px 0}.stats-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}.stat-card{border:1px solid #cbd5e1;border-radius:12px;padding:10px;background:#f8fafc}.stat-card h3{margin:0 0 8px;font-size:14px;color:#334155}.stat-card p{margin:0;font-weight:700}.row{display:flex;gap:8px;margin:10px 0;flex-wrap:wrap}button,input{border:1px solid #94a3b8;border-radius:10px;padding:8px 12px;font:inherit}button{background:#f8fafc;cursor:pointer}button:hover{background:#eef2ff}input{flex:1;min-width:180px}.messages{margin:12px 0 0;border:1px solid #cbd5e1;border-radius:12px;background:#f8fafc;padding:12px;min-height:120px;max-height:240px;overflow:auto;white-space:pre-wrap;word-break:break-word}.hero-block{margin:14px 0;padding:14px;border-radius:14px;border:1px solid #cbd5e1;background:linear-gradient(140deg,#e0f2fe,#eef2ff)}.hero-button{width:100%;padding:14px 16px;font-size:18px;font-weight:700;border-radius:12px;border:1px solid #1d4ed8;background:linear-gradient(180deg,#2563eb,#1d4ed8);color:#fff}.hero-button:hover{background:linear-gradient(180deg,#1d4ed8,#1e40af)}.table-shell{margin-top:16px;border:1px solid #1e293b;border-radius:14px;padding:0;background:linear-gradient(180deg,#111827,#0b1220);overflow:hidden}.figma-board{display:flex;flex-direction:column}.game-topbar{display:flex;align-items:center;justify-content:center;gap:10px;min-height:72px;padding:10px 14px;background:linear-gradient(180deg,#10233e,#0b1c34);border-bottom:1px solid #24364d;position:relative}.mini-balls{display:flex;gap:5px}.mini-balls span{width:10px;height:10px;border-radius:999px;background:radial-gradient(circle at 30% 30%,#f8fafc,#64748b);border:1px solid #334155}.score-pill{background:linear-gradient(180deg,#fca43a,#dc7d19);color:#111827;font-weight:700;font-size:12px;border-radius:999px;padding:4px 10px}.player-badge{width:34px;height:34px;border-radius:999px;display:grid;place-items:center;font-weight:700;color:#fff;background:radial-gradient(circle at 30% 30%,#3b82f6,#4c1d95);border:2px solid #1d4ed8}.fullscreen-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);border-color:#334155;background:#0f172a;color:#e2e8f0;font-size:12px;padding:6px 10px}.game-status{text-align:center;color:#e2e8f0;font-size:13px;padding:8px 14px;background:linear-gradient(180deg,#10192a,#0c1626);border-bottom:1px solid #223041}.board-stage{display:grid;grid-template-columns:74px 1fr 64px;gap:10px;align-items:stretch;padding:12px;min-height:420px}.cue-rail,.balls-rail{border-radius:10px;background:linear-gradient(180deg,#122035,#0c1729);border:1px solid #223041;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}.cue-stick-visual{width:12px;height:78%;border-radius:999px;background:linear-gradient(180deg,#f2d04f,#ab7b20 30%,#6b3f1d);border:1px solid #7c2d12}.left-action{width:28px;height:28px;border-radius:999px;border:1px solid #16a34a;background:#16a34a;color:#fff;padding:0}.balls-rail-inner{width:38px;height:78%;border-radius:8px;border:1px solid #bb4d00;background:repeating-linear-gradient(to bottom,#b45309,#b45309 8px,#92400e 8px,#92400e 16px)}.canvas-wrap{border-radius:10px;border:1px solid #1f2937;background:#0b1220;padding:8px}.pool-canvas{width:100%;height:auto;border-radius:8px;border:1px solid #334155;touch-action:none;display:block}.bottom-actions{padding:12px;border-top:1px solid #223041;background:linear-gradient(180deg,#0d1829,#0a1424);display:flex;justify-content:center}.surrender-btn{width:min(460px,100%);color:#fff;border:1px solid #9f0712;border-radius:8px;background:linear-gradient(180deg,#dc2626,#b91c1c);font-weight:700}.table-shell:fullscreen{background:#0f172a;border:none;border-radius:0;padding:14px;display:flex;flex-direction:column;gap:0}.table-shell:fullscreen .pool-canvas{width:100%;height:100%;max-height:calc(100dvh - 110px);object-fit:contain;border-color:#334155}.table-shell.pseudo-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#0f172a;border:none;border-radius:0;padding:14px;display:flex;flex-direction:column;gap:0;margin:0}.table-shell.pseudo-fullscreen .pool-canvas{width:100%;height:100%;max-height:calc(100dvh - 110px);object-fit:contain;border-color:#334155}.leaderboard{border:1px solid #cbd5e1;border-radius:12px;padding:8px;background:#f8fafc}.leaderboard-item{display:grid;grid-template-columns:60px 1fr auto;gap:10px;padding:8px;border-radius:8px}.leaderboard-item:nth-child(odd){background:#eef2ff}@media (max-width: 640px){.stats-grid{grid-template-columns:1fr}.board-stage{grid-template-columns:48px 1fr 44px;gap:8px;padding:8px;min-height:260px}.game-topbar{min-height:64px;padding:8px}.fullscreen-btn{right:8px;font-size:11px}}
