@import"https://fonts.googleapis.com/css2?family=Press+Start+2P&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;width:100%;height:100vh;overflow:hidden}*{margin:0;padding:0;box-sizing:border-box}body{overflow:hidden;font-family:Arial,Helvetica,sans-serif;background-color:#080b14}#root{width:100%;height:100vh}.game-container{width:100%;height:100%;position:relative}.container{background-color:#00000080;border:2px solid white;border-radius:10px;overflow:hidden}button:focus{outline:none}canvas{width:100%;height:100%;display:block;background:linear-gradient(to bottom,#0a1629,#071429)}.portal-hint{position:fixed;bottom:30px;left:50%;transform:translate(-50%);background-color:#000000b3;color:#0cf;padding:10px 20px;border-radius:8px;font-family:"Press Start 2P",monospace;font-size:14px;text-align:center;animation:pulse 2s infinite;z-index:1000}.key-hint{display:inline-block;background-color:#0cf;color:#000;padding:2px 8px;border-radius:4px;margin:0 4px;font-weight:700}@keyframes pulse{0%{opacity:.7}50%{opacity:1}to{opacity:.7}}.fps-counter{position:fixed!important;bottom:0!important;left:0!important;top:unset!important;right:unset!important}:root{--pixel-font: "Press Start 2P", monospace;--ui-primary: #ffffff;--ui-secondary: #4a4a4a;--ui-accent: #ff0040;--ui-background: rgba(0, 0, 0, .7);--ui-border: #ffffff}.pixel-ui{font-family:var(--pixel-font);color:var(--ui-primary);text-shadow:2px 2px 0px rgba(0,0,0,.5);image-rendering:pixelated}.pixel-panel{background:var(--ui-background);border:2px solid var(--ui-border);padding:1rem;box-shadow:4px 4px #00000080;image-rendering:pixelated}.pixel-panel.translucent{background:#0006}.pixel-text{font-family:var(--pixel-font);font-size:16px;line-height:1.5;letter-spacing:1px}.pixel-score{font-family:var(--pixel-font);font-size:24px;color:var(--ui-accent);text-shadow:2px 2px 0px rgba(0,0,0,.5)}.pixel-button{font-family:var(--pixel-font);background:var(--ui-background);border:2px solid var(--ui-border);color:var(--ui-primary);padding:.5rem 1rem;cursor:pointer;transition:all .1s ease}.pixel-button:hover{transform:translate(-2px,-2px);box-shadow:4px 4px #00000080}.pixel-button:active{transform:translate(2px,2px);box-shadow:none}.game-hud{position:fixed;top:0;left:0;right:0;padding:1rem;display:flex;justify-content:space-between;pointer-events:none}.game-score{padding:.5rem 1rem;background:var(--ui-background);border:2px solid var(--ui-border);border-radius:4px}.game-menu{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;max-width:90%;width:500px}@keyframes pixel-pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.pixel-pulse{animation:pixel-pulse 1s infinite}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .5s ease-out}.modal-content{background-color:var(--ui-background);border:2px solid var(--ui-border);padding:30px;width:90%;max-width:500px;text-align:center;box-shadow:4px 4px #00000080;animation:scaleIn .3s ease-out}.final-score{margin-bottom:30px}.modal-buttons{display:flex;flex-direction:column;gap:15px;margin-top:20px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%) translateY(20px)}10%{opacity:1;transform:translate(-50%) translateY(0)}80%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-10px)}}@media (max-width: 768px){.game-hud{padding:.5rem}.game-score{padding:.3rem .7rem}.pixel-text{font-size:12px}.pixel-score{font-size:18px}.modal-content{padding:15px}.modal-content h2{font-size:28px!important;margin-bottom:15px!important}.modal-content .pixel-score{font-size:24px!important}.modal-content .pixel-button{padding:8px 15px!important;font-size:14px!important}.game-menu h1{font-size:32px!important}.game-menu .pixel-text{font-size:10px!important;line-height:1.8!important}.game-menu button{padding:8px 15px!important;font-size:14px!important}}@media (max-width: 480px){.game-hud{padding:.3rem}.game-score{padding:.2rem .5rem}.pixel-text{font-size:10px}.pixel-score{font-size:14px}.modal-content h2,.game-menu h1{font-size:24px!important}}.mobile-controls{position:fixed;bottom:0;left:0;right:0;height:30vh;display:flex;pointer-events:none;touch-action:none;-webkit-user-select:none;user-select:none}body.mobile-device{position:fixed;width:100%;height:100%;overflow:hidden}html,body{overscroll-behavior-y:contain}.joystick-area{position:absolute;left:0;bottom:0;width:50%;height:100%;display:flex;justify-content:flex-start;align-items:center;pointer-events:none}.fire-button-area{position:absolute;right:0;bottom:0;width:50%;height:100%;display:flex;justify-content:flex-end;align-items:center;padding-right:40px;padding-bottom:40px;pointer-events:none}.joystick{position:relative;width:120px;height:120px;background-color:#0000004d;border:3px solid rgba(255,255,255,.3);border-radius:50%;margin-left:40px;margin-bottom:40px;pointer-events:auto}.joystick-knob{position:absolute;top:50%;left:50%;width:60px;height:60px;background-color:#ffffff4d;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none}.fire-button{width:40px;height:40px;border-radius:50%;background-color:#0000004d;border:3px solid rgba(255,255,255,.3);cursor:pointer;pointer-events:auto;position:relative;overflow:hidden}.fire-button:active{background-color:#002864b3;transform:scale(.95)}.fire-button:after{font-family:"Press Start 2P",cursive;content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#d6000099;border-radius:50%;opacity:.7}.fire-button:active:after{background-color:#d60000cc;transform:scale(1.1)}.camera-toggle-button{position:absolute;bottom:140px;right:40px;width:40px;height:40px;background:#0006;border:3px solid rgba(255,255,255,.3);border-radius:50%;display:flex;justify-content:center;align-items:center;font-size:20px;color:#fff;pointer-events:auto;box-shadow:0 0 10px #0000004d;z-index:1100}.camera-toggle-button:active{background:#000000b3;transform:scale(.95)}@media (orientation: landscape){.mobile-controls{height:120px}.joystick{width:100px;height:100px;margin-left:30px;margin-bottom:30px}.joystick-knob{width:50px;height:50px}.fire-button{width:80px;height:80px}.fire-button:after{width:40px;height:40px}.fire-button-area{padding-right:30px;padding-bottom:30px}}@media (orientation: portrait){.mobile-controls{height:180px}.joystick-area{justify-content:center;align-items:flex-end;padding-bottom:20px;padding-left:0;width:50%}.joystick{width:100px;height:100px;margin-left:0;margin-bottom:0}.joystick-knob{width:50px;height:50px}.fire-button-area{justify-content:center;align-items:flex-end;padding-bottom:20px;padding-right:0;width:50%}.fire-button{width:80px;height:80px;margin:0}.fire-button:after{width:40px;height:40px}}@media (min-width: 1024px){.mobile-controls{display:none}}
