:root{font-family:Manrope,Avenir Next,sans-serif;color:#f2efe8;background:radial-gradient(circle at 10% 10%,#1a3a42,#0f2028,#0a1318)}*{box-sizing:border-box}body{margin:0;height:var(--tg-viewport-stable-height, 100dvh);overflow:hidden;padding-top:env(safe-area-inset-top,0px)}.game-layout{display:grid;grid-template-rows:auto 1fr auto;height:var(--tg-viewport-stable-height, 100dvh);overflow:hidden}.game-canvas-wrap{display:flex;align-items:stretch;justify-content:center;padding:4px 8px;min-height:0;overflow:hidden}.table-canvas{display:block;width:100%;height:100%;border-radius:6px;touch-action:none;cursor:crosshair}.hud{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#0a161cd9;border-bottom:1px solid rgba(190,178,150,.15);gap:8px}.hud__player{display:flex;flex-direction:column;align-items:flex-start;gap:4px;min-width:0;flex:1;opacity:.55;transition:opacity .2s}.hud__player--right{align-items:flex-end}.hud__player--active{opacity:1}.hud__name{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#b6c8d3}.hud__player--active .hud__name{color:#7ee8c4}.hud__balls{display:flex;flex-wrap:wrap;gap:3px}.hud__ball{width:10px;height:10px;border-radius:50%;border:1px solid rgba(0,0,0,.4);transition:opacity .2s}.hud__ball--pocketed{opacity:.25}.hud__center{display:flex;flex-direction:column;align-items:center;gap:2px}.hud__timer{font-size:1.4rem;font-weight:700;color:#e0ddd6;min-width:50px;text-align:center;transition:color .3s}.hud__open{font-size:.65rem;color:#f0c060;font-weight:600;text-transform:uppercase}.game-controls{display:flex;align-items:center;justify-content:center;gap:12px;padding:6px 16px;padding-bottom:max(6px,env(safe-area-inset-bottom));background:#0a161ce6;border-top:1px solid rgba(190,178,150,.12)}.power-bar{display:flex;flex-direction:column;align-items:center;gap:4px;-webkit-user-select:none;user-select:none;cursor:ns-resize}.power-bar--disabled{opacity:.4;cursor:not-allowed}.power-bar__track{width:28px;height:80px;background:#ffffff14;border:1px solid rgba(255,255,255,.18);border-radius:14px;position:relative;overflow:hidden;display:flex;align-items:flex-end}.power-bar__fill{width:100%;background:linear-gradient(to top,#f66a00,#ffce00);border-radius:14px;transition:height .05s linear}.power-bar__label{font-size:.7rem;color:#a8bcc8;font-weight:600}.btn-shoot{padding:10px 24px;font-size:.95rem;font-weight:700;border-radius:12px;border:2px solid rgba(126,205,225,.6);background:linear-gradient(135deg,#2c8060,#1e5a45);color:#fff;cursor:pointer;letter-spacing:.06em;text-transform:uppercase;transition:transform .1s,opacity .2s;touch-action:manipulation}.btn-shoot:active:not(:disabled){transform:scale(.95)}.btn-shoot:disabled{opacity:.35;cursor:not-allowed}.pocket-selector{display:flex;flex-direction:column;align-items:center;gap:6px}.pocket-selector__label{font-size:.72rem;color:#b0c8d4}.pocket-selector__table{position:relative;width:80px;height:44px;background:#1e5a3799;border:1px solid rgba(190,178,150,.3);border-radius:4px}.pocket-btn{position:absolute;transform:translate(-50%,-50%);width:22px;height:22px;padding:0;border-radius:50%;border:1px solid rgba(255,255,255,.35);background:#0c1e26d9;color:#ccc;font-size:10px;cursor:pointer;line-height:1;touch-action:manipulation}.pocket-btn--active{background:#2c8060;border-color:#7ee8c4;color:#fff}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#081216d1;z-index:10;padding:24px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.overlay__title{font-size:1.5rem;font-weight:700}.overlay__reason{color:#b6c8d3;font-size:.95rem;text-align:center}.page{max-width:480px;margin:0 auto;padding:16px;display:grid;gap:14px}.panel{display:grid;gap:10px;padding:14px;border:1px solid rgba(194,182,148,.24);border-radius:14px;background:#0b181ed9}h1{margin:0;font-size:clamp(1.1rem,4vw,1.6rem)}h2,h3{margin:0}.sub{margin:2px 0 0;color:#b6c8d3;font-size:.9rem}label{display:grid;gap:6px;font-size:.9rem}input,textarea,select,button{width:100%;border-radius:8px;border:1px solid rgba(183,173,144,.35);background:#081419f2;color:#f0efe8;padding:9px 10px;font:inherit}button{cursor:pointer;background:linear-gradient(130deg,#2c7180,#215966);border-color:#7ecde180}button:disabled{opacity:.45;cursor:not-allowed}button.ghost{background:#0c1e26e6;border-color:#9db9c580}.btn-primary{padding:12px 24px;font-weight:600;background:linear-gradient(130deg,#2c8060,#1e5a45);border-color:#64dca099;border-radius:10px}small{color:#a8bcc8;font-size:.8rem}.error{border-color:#f66464cc;background:#581616a3}.debug{position:fixed;bottom:8px;right:8px;width:240px;font-size:.75rem;z-index:20}.debug ul{margin:0;padding-left:16px;display:grid;gap:3px;word-break:break-all}.topbar-debug{position:fixed;top:8px;right:8px;z-index:20}.topbar-debug button{width:auto;padding:4px 10px;font-size:.72rem;background:#0c1e26d9;border-color:#9db9c566}.loading-screen{display:flex;align-items:center;justify-content:center;height:100dvh;font-size:1.1rem;color:#b6c8d3}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.foul-toast{position:fixed;top:70px;left:50%;transform:translate(-50%);background:#c83232eb;color:#fff;padding:8px 18px;border-radius:20px;font-size:.85rem;font-weight:700;letter-spacing:.03em;z-index:30;animation:toast-in .2s ease;pointer-events:none;white-space:nowrap}.reconnect-banner{position:fixed;top:0;left:0;right:0;background:#143241f2;color:#7ee8c4;text-align:center;font-size:.8rem;font-weight:600;padding:6px;z-index:25;border-bottom:1px solid rgba(126,232,196,.3)}.btn-shoot:not(:disabled){box-shadow:0 0 14px #2c80608c}.btn-shoot:not(:disabled):active{box-shadow:0 0 6px #2c80604d}.hud__player--active .hud__name{text-shadow:0 0 8px rgba(126,232,196,.6)}.hud__ball--pocketed{opacity:.2;transform:scale(.8);transition:opacity .3s,transform .3s}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.hud__timer--low{color:#f66;animation:pulse .8s ease-in-out infinite}.power-bar__fill{transition:height .05s linear,filter .15s}.overlay--result{gap:16px}.confetti-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}@keyframes win-pop{0%{transform:scale(.7);opacity:0}60%{transform:scale(1.08)}to{transform:scale(1);opacity:1}}.overlay__title--win{animation:win-pop .45s cubic-bezier(.34,1.56,.64,1) forwards;color:#7ee8c4;text-shadow:0 0 20px rgba(126,232,196,.7)}
