@import"https://fonts.googleapis.com/css2?family=Press+Start+2P&display=swap";*{box-sizing:border-box;margin:0;padding:0}body{font-family:"Press Start 2P",monospace;background:#1a1a2e;background-image:radial-gradient(ellipse at 50% 0%,#16213e,#1a1a2e 70%),repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(255,255,255,.015) 2px,rgba(255,255,255,.015) 4px);color:#fff;min-height:100vh;overflow:hidden}#root{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:1rem}.game-wrapper{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:800px}.game-title{font-size:.7rem;color:#e03030;text-shadow:0 0 10px rgba(224,48,48,.5),2px 2px 0 #000;letter-spacing:.15em;text-transform:uppercase;animation:titlePulse 3s ease-in-out infinite}@keyframes titlePulse{0%,to{opacity:1}50%{opacity:.7}}.game-frame{position:relative;border-radius:8px;padding:6px;background:linear-gradient(145deg,#2a2a4a,#1a1a2e);box-shadow:0 0 0 2px #3a3a5a,0 0 0 4px #1a1a2e,0 8px 32px #0009,inset 0 1px #ffffff0d}.game-frame:before{content:"";position:absolute;top:-1px;left:20px;right:20px;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}.game-canvas{display:block;image-rendering:pixelated;image-rendering:crisp-edges;border-radius:4px;background:#5c94fc;box-shadow:inset 0 0 20px #0000004d;max-width:100%;height:auto}.controls-bar{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;width:100%;max-width:600px}.control-key{display:inline-flex;align-items:center;gap:.4rem;font-size:.5rem;color:#88a;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:4px;padding:.35rem .6rem;transition:color .2s,border-color .2s;white-space:nowrap}.control-key:hover{color:#aac;border-color:#ffffff1f}.control-key kbd{font-family:"Press Start 2P",monospace;font-size:.45rem;color:#fca044;background:#fca0441a;border:1px solid rgba(252,160,68,.2);border-radius:3px;padding:.15rem .35rem}.footer-hint{font-size:.4rem;color:#446;text-align:center;letter-spacing:.1em}.touch-controls{display:none;width:100%;max-width:600px;justify-content:space-between;align-items:flex-end;padding:.5rem 1rem;user-select:none;-webkit-user-select:none;touch-action:none}.touch-dpad{display:flex;flex-direction:column;gap:2px}.dpad-row{display:flex;gap:2px}.touch-btn{width:60px;height:60px;border-radius:50%;background:#ffffff14;border:2px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-family:"Press Start 2P",monospace;font-size:.5rem;color:#ffffff80;position:relative;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:none}.touch-btn:before{content:"";position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border-radius:50%}.touch-btn:after{content:attr(data-label);font-family:"Press Start 2P",monospace;font-size:.5rem;color:#ffffff80}.touch-btn:active,.touch-btn.active{background:#fff3;border-color:#ffffff59}.dpad-up,.dpad-down,.dpad-left,.dpad-right,.dpad-center{width:56px;height:56px}.touch-action{display:flex;flex-direction:column;align-items:center;gap:10px}.action-row{display:flex;gap:12px}.touch-a{width:60px;height:60px;background:#e0303040;border-color:#e0303080}.touch-a:active{background:#e0303080}.touch-b{width:52px;height:52px;background:#3030f033;border-color:#3030f066}.touch-b:active{background:#3030f073}.touch-start{width:64px;height:32px;border-radius:16px;font-size:.4rem}@media(hover:none)and (pointer:coarse){.touch-controls{display:flex}.controls-bar,.footer-hint{display:none}#root{padding:.5rem;justify-content:flex-start}.game-title{font-size:.55rem}.game-canvas{max-height:45vh;width:auto}}
