*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{position:fixed;width:100%;height:100%;overflow:hidden;overscroll-behavior:none;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}body{background:#0a1a0d;font-family:"Press Start 2P",monospace}canvas#game-canvas{display:block;width:100vw;height:100vh;image-rendering:pixelated;image-rendering:crisp-edges;touch-action:none}#title-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#0a1a0dd9}.title-content,.ts-content,.result-content,.goal-content,.pause-content{text-align:center}.cf-title{font-size:2rem;color:#39ff14;text-shadow:0 0 10px #39ff14,0 0 30px #39ff14;margin-bottom:12px}.cf-sub{font-size:.5rem;color:#ffffff80;margin-bottom:24px}.cf-controls{font-size:.45rem;color:#fff6;line-height:2.2;margin-bottom:28px}.cf-controls .key{display:inline-block;background:#39ff141f;border:1px solid rgba(57,255,20,.3);border-radius:4px;padding:2px 6px;color:#39ff14;font-size:.4rem}.cf-start{font-size:.6rem;color:#ffe600;text-shadow:0 0 8px #ffe600}.blink{animation:blink 1s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}#team-select{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#0a1a0de6}.ts-title{font-size:1rem;color:#ffe600;text-shadow:0 0 10px #ffe600;margin-bottom:24px}.ts-cards{display:flex;gap:24px;justify-content:center;margin-bottom:20px}.team-card{background:#ffffff0a;border:2px solid rgba(255,255,255,.1);border-radius:12px;padding:20px 24px;cursor:pointer;transition:transform .2s,border-color .2s,box-shadow .2s;text-align:center;min-width:130px}.team-card:hover,.team-card.tc-selected{border-color:var(--tc);box-shadow:0 0 20px var(--tc);transform:scale(1.05)}.tc-cube{width:48px;height:48px;border:3px solid;border-radius:4px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center}.tc-num{font-size:.8rem;color:#fff;font-weight:700}.tc-name{font-size:.55rem;margin-bottom:6px}.tc-star{font-size:.35rem;color:#fff6;margin-bottom:10px}.tc-stats{display:flex;flex-direction:column;gap:5px;margin-top:6px}.tc-stat-row{display:flex;align-items:center;gap:6px}.tc-stat-label{font-size:.3rem;color:#ffffff73;width:32px;text-align:right;flex-shrink:0}.tc-stat-track{flex:1;height:4px;background:#ffffff14;border-radius:2px;overflow:hidden}.tc-stat-fill{height:100%;border-radius:2px;transition:width .3s}.ts-hint{font-size:.4rem;color:#ffffff59}#hud{position:fixed;top:0;left:0;width:100%;z-index:50;pointer-events:none}.hud-bar{display:flex;align-items:center;justify-content:center;gap:16px;padding:6px 16px;background:#00000080}.hud-team{display:flex;align-items:center;gap:8px}.hud-team-name{font-size:.45rem;color:#7ec8e3}.hud-score{font-size:1rem;color:#fff;text-shadow:0 0 6px rgba(255,255,255,.5);min-width:20px;text-align:center}.hud-timer{font-size:.7rem;color:#ffe600;text-shadow:0 0 6px #ffe600;min-width:60px;text-align:center}.hud-timer.timer-low{color:#f33;text-shadow:0 0 8px #ff3333;animation:blink .5s ease-in-out infinite}#goal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:flex;align-items:center;justify-content:center;background:#0006}.goal-text{font-size:2.5rem;color:#ffe600;text-shadow:0 0 15px #ffe600,0 0 40px #ffe600;animation:goalPop .5s ease-out}.goal-team{font-size:.6rem;margin-top:8px}@keyframes goalPop{0%{transform:scale(.3);opacity:0}60%{transform:scale(1.2);opacity:1}to{transform:scale(1)}}#result-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#0a1a0de6}.result-title{font-size:1.8rem;text-shadow:0 0 15px currentColor;margin-bottom:16px}.result-score{font-size:1.2rem;color:#fff;margin-bottom:24px}#pause-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;display:flex;align-items:center;justify-content:center;background:#000000b3}.cf-pause-title{font-size:1.5rem;color:#ffe600;text-shadow:0 0 10px #ffe600;margin-bottom:12px}.pause-keyboard{font-size:.4rem;color:#ffffff80}.pause-touch-btns{display:none;flex-direction:column;gap:10px;align-items:center;margin-top:16px}.touch-pause-btn{font-family:"Press Start 2P",monospace;font-size:.5rem;padding:12px 24px;border:2px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff14;color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-width:160px}.touch-pause-btn:active{background:#fff3}.pause-resume-btn{border-color:#39ff1480;color:#39ff14}.pause-quit-btn{border-color:#ff333380;color:#f33}#touch-controls{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;pointer-events:none}.joystick-zone{pointer-events:auto;position:absolute;bottom:0;left:0;width:45%;height:45%;padding-bottom:env(safe-area-inset-bottom,0px)}.joystick-base{position:absolute;bottom:calc(24px + env(safe-area-inset-bottom,0px));left:24px;width:120px;height:120px;border-radius:50%;background:#ffffff0f;border:2px solid rgba(57,255,20,.2)}.joystick-thumb{position:absolute;width:52px;height:52px;border-radius:50%;background:#39ff1426;border:2px solid rgba(57,255,20,.5);box-shadow:0 0 12px #39ff1426;transform:translate(-50%,-50%);left:84px;top:calc(100% - 84px - env(safe-area-inset-bottom,0px));transition:background .08s,box-shadow .08s;pointer-events:none}.joystick-thumb.active{background:#39ff144d;border-color:#39ff14cc;box-shadow:0 0 20px #39ff1466}.touch-pause{pointer-events:auto;position:absolute;top:calc(42px + env(safe-area-inset-top,0px));right:12px;width:44px;height:44px;border-radius:50%;border:2px solid rgba(255,255,255,.2);background:#ffffff0f;color:#fff9;font-size:.7rem;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.touch-pause:active{background:#39ff1433;border-color:#39ff1499}@media (hover: hover) and (pointer: fine){#touch-controls,.pause-touch-btns{display:none!important}.pause-keyboard{display:block!important}}@media (hover: none),(pointer: coarse){.pause-touch-btns{display:flex!important}.pause-keyboard{display:none!important}}@media (max-width: 600px){.cf-title{font-size:1.3rem}.cf-sub{font-size:.4rem}.cf-controls{display:none}.cf-start{font-size:.5rem}.ts-title{font-size:.7rem}.ts-cards{gap:12px}.team-card{padding:14px 16px;min-width:100px}.tc-cube{width:36px;height:36px}.tc-num{font-size:.6rem}.tc-name{font-size:.4rem}.ts-hint{font-size:.35rem}.hud-bar{padding:4px 10px;gap:10px}.hud-team-name{font-size:.35rem}.hud-score{font-size:.7rem}.hud-timer{font-size:.5rem}.goal-text{font-size:1.5rem}.result-title{font-size:1.2rem}.result-score{font-size:.8rem}.cf-pause-title{font-size:1rem}}
