:root{--bg: #1a0f0a;--panel: #2a1a12;--accent: #ffa37f;--accent2: #ffd97b;--wall: #7a4a2c;--text: #fff3e9;--muted: #c9a88f}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background:linear-gradient(#140c0873,#140c08b3),url(/assets/background.svg) center / cover no-repeat,radial-gradient(circle at 50% -10%,#3a2114,var(--bg) 60%);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-tap-highlight-color:transparent;overflow:hidden}#app{height:100%;display:flex;align-items:center;justify-content:center}.screen{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:24px}.title{font-size:clamp(28px,7vw,56px);font-weight:900;letter-spacing:-1px;color:var(--accent);text-shadow:0 3px 0 #7a2e16,0 0 24px rgba(255,120,80,.4);text-align:center;line-height:1}.subtitle{color:var(--muted);font-size:15px;margin-top:-8px}.menu{display:flex;flex-direction:column;gap:12px;width:min(320px,86vw)}button.btn{font:inherit;font-weight:700;font-size:17px;padding:14px 18px;border:none;border-radius:14px;background:linear-gradient(180deg,var(--accent),#e8794f);color:#2a1208;cursor:pointer;box-shadow:0 4px #a8512c;transition:transform .05s,box-shadow .05s}button.btn:active{transform:translateY(3px);box-shadow:0 1px #a8512c}button.btn.secondary{background:linear-gradient(180deg,#5a3a28,#432a1c);color:var(--text);box-shadow:0 4px #2a1a12}button.btn:disabled{opacity:.5;cursor:not-allowed}button.btn.with-icon{display:inline-flex;align-items:center;justify-content:center;gap:10px}.btn-icon{width:30px;height:30px;object-fit:contain;flex:0 0 auto;pointer-events:none;filter:drop-shadow(0 1px 1px rgba(0,0,0,.35))}.play{flex-direction:column;gap:10px}.play-top{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.play.anchored{display:block;padding:0;position:relative;width:100%;height:100%}.play.anchored .play-top{position:absolute;top:0;left:0;right:0;z-index:3;padding:10px 16px 0;pointer-events:none}.play.anchored .play-top>*{pointer-events:auto}.play.anchored .canvas-wrap{position:absolute;transform:translate(-50%)}.hud{width:min(360px,92vw);display:flex;align-items:center;justify-content:space-between;gap:12px}.hud .stat{display:flex;flex-direction:column;line-height:1.1}.hud .stat .label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.hud .stat .value{font-size:22px;font-weight:800}.hud .next{display:flex;flex-direction:column;align-items:center;gap:2px}.hud .next canvas{width:44px;height:44px}.combo{color:var(--accent2);font-weight:800;min-height:20px;font-size:15px}.canvas-wrap{position:relative}canvas.board{width:min(440px,94vw,calc(74vh * var(--board-aspect, .74)));background:transparent;touch-action:none;cursor:pointer;filter:drop-shadow(0 14px 26px rgba(0,0,0,.55))}.overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:#0a0604d1;border-radius:16px;text-align:center;padding:20px}.overlay.hidden{display:none}.overlay h2{font-size:28px;color:var(--accent)}.overlay .big{font-size:40px;font-weight:900}.topbar{width:min(360px,92vw);display:flex;justify-content:space-between;align-items:center}.icon-btn{background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer}.field{width:min(320px,86vw);display:flex;flex-direction:column;gap:6px}.field input{font:inherit;padding:12px;border-radius:10px;border:2px solid var(--wall);background:var(--panel);color:var(--text)}table.lb{width:min(360px,92vw);border-collapse:collapse}table.lb td,table.lb th{padding:8px 10px;text-align:left;border-bottom:1px solid #3a2114}table.lb td.rank{color:var(--accent2);font-weight:800;width:36px}table.lb td.score{text-align:right;font-weight:800}.note{color:var(--muted);font-size:13px;text-align:center;max-width:320px}.opp-panel{position:fixed;right:8px;top:50%;transform:translateY(-50%);z-index:5;display:flex;flex-direction:column;align-items:center;gap:3px;background:#140c0880;padding:8px;border-radius:12px;max-width:32vw}.opp-panel .opp-name{font-size:12px;font-weight:700;color:var(--text)}.opp-panel .opp-score{font-size:18px;font-weight:800;color:var(--accent2)}.opp-panel canvas.mini{width:clamp(78px,22vw,130px);height:auto;display:block}.vs-timer{position:fixed;top:8px;left:50%;transform:translate(-50%);z-index:5;font-size:22px;font-weight:900;color:var(--accent2);background:#140c0880;padding:2px 14px;border-radius:12px}@media (max-aspect-ratio: 1/1),(max-width: 560px){.opp-panel{inset:auto auto 6px 50%;transform:translate(-50%);flex-direction:row;align-items:center;gap:8px;max-width:none;padding:5px 10px}.opp-panel .opp-name{max-width:30vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.opp-panel canvas.mini{width:clamp(44px,16vw,72px)}.vs-timer{font-size:18px;padding:2px 12px}}
