@import"https://fonts.googleapis.com/css2?family=Press+Start+2P&display=swap";:root{--gb-darkest: #0f380f;--gb-dark: #306230;--gb-light: #8bac0f;--gb-lightest: #9bbc0f;--shell-color: #b0b0b0;--shell-dark: #8a8a8a;--shell-light: #d0d0d0}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{background:#1a1a2e;background-image:radial-gradient(ellipse at 50% 30%,#2a2a4e,#1a1a2e 70%);font-family:"Press Start 2P",monospace;display:flex;align-items:center;justify-content:center}.gb-wrapper{display:flex;align-items:center;justify-content:center;width:100%;height:100%;perspective:800px}.gb-shell{position:relative;width:380px;background:linear-gradient(145deg,var(--shell-light),var(--shell-color) 30%,var(--shell-dark) 100%);border-radius:12px 12px 12px 60px;padding:16px 20px 24px;box-shadow:0 8px 32px #0009,0 2px 4px #0000004d,inset 0 1px #ffffff4d,inset 0 -2px #0003;-webkit-user-select:none;user-select:none}.gb-shell:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border-radius:inherit;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.02) 2px,rgba(0,0,0,.02) 4px);pointer-events:none}.gb-top-bar{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding:0 4px}.gb-power-led{width:6px;height:6px;border-radius:50%;background:#444;border:1px solid #333;transition:all .3s}.gb-power-led.on{background:#e74c3c;box-shadow:0 0 6px #e74c3c,0 0 12px #e74c3c66}.gb-label{font-family:"Press Start 2P",monospace;font-size:6px;color:#666;letter-spacing:.5px;text-transform:uppercase}.gb-screen-bezel{background:#5a5a6a;border-radius:8px;padding:16px 14px 20px;margin-bottom:12px;box-shadow:inset 0 2px 6px #00000080,0 1px #ffffff26;position:relative}.gb-screen-bezel:before{content:"DOT MATRIX WITH STEREO SOUND";position:absolute;top:4px;left:14px;font-family:"Press Start 2P",monospace;font-size:4px;color:#888;letter-spacing:.5px}.gb-screen-inner{position:relative;width:100%;aspect-ratio:160 / 144;background:var(--gb-lightest);border-radius:4px;overflow:hidden;box-shadow:inset 0 0 20px #0f380f4d,inset 0 0 4px #0003}.gb-canvas{width:100%;height:100%;display:block;image-rendering:pixelated;image-rendering:crisp-edges}.gb-scanlines{position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(0deg,transparent,transparent 1px,rgba(0,0,0,.06) 1px,rgba(0,0,0,.06) 2px);pointer-events:none;z-index:2}.gb-lcd-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 30% 20%,rgba(255,255,255,.08) 0%,transparent 60%),radial-gradient(ellipse at 70% 80%,rgba(0,0,0,.05) 0%,transparent 50%);pointer-events:none;z-index:3}.gb-start-prompt{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--gb-darkest);cursor:pointer;gap:8px}.gb-start-logo{font-family:"Press Start 2P",monospace;font-size:12px;color:var(--gb-lightest);text-align:center;line-height:1.6;text-shadow:2px 2px 0 var(--gb-dark)}.gb-start-sub{font-family:"Press Start 2P",monospace;font-size:7px;color:var(--gb-light);margin-top:4px}.gb-start-blink{font-family:"Press Start 2P",monospace;font-size:7px;color:var(--gb-lightest);margin-top:16px;animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.gb-speakers{position:absolute;right:16px;bottom:80px;display:grid;grid-template-columns:repeat(3,1fr);gap:4px;transform:rotate(-25deg)}.gb-speaker-hole{width:8px;height:8px;border-radius:50%;background:var(--shell-dark);box-shadow:inset 0 1px 2px #0006}.gb-controls-area{display:flex;align-items:center;justify-content:space-between;padding:8px 20px 0}.gb-dpad{position:relative;width:60px;height:60px;cursor:pointer;touch-action:none}.gb-dpad-h{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:56px;height:18px;background:#3a3a3a;border-radius:3px;box-shadow:inset 0 1px #ffffff1a,0 2px 4px #0000004d}.gb-dpad-v{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:18px;height:56px;background:#3a3a3a;border-radius:3px;box-shadow:inset 0 1px #ffffff1a,0 2px 4px #0000004d}.gb-dpad-h:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:18px;height:18px;background:#3a3a3a;border-radius:2px}.gb-meta-buttons{display:flex;flex-direction:column;align-items:center;gap:6px;transform:rotate(-25deg)}.gb-meta-btn{border:none;padding:0;cursor:pointer;background:transparent;outline:none}.gb-meta-btn span{display:block;width:38px;height:10px;background:linear-gradient(145deg,#7a7a7a,#5a5a5a);border-radius:5px;box-shadow:0 2px 3px #00000059,inset 0 1px #ffffff1f;font-family:"Press Start 2P",monospace;font-size:4px;color:#ffffff8c;display:flex;align-items:center;justify-content:center;letter-spacing:.5px;-webkit-user-select:none;user-select:none;transition:transform .08s,box-shadow .08s}.gb-meta-btn:active span{transform:translateY(1px);box-shadow:0 1px 2px #0000004d}.gb-buttons{display:flex;gap:10px;transform:rotate(-25deg)}.gb-btn{width:36px;height:36px;border-radius:50%;background:linear-gradient(145deg,#c04060,#a03050);box-shadow:0 3px 6px #0006,inset 0 1px #fff3;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .1s}.gb-btn:active{transform:translateY(2px);box-shadow:0 1px 3px #0006}.gb-btn span{font-family:"Press Start 2P",monospace;font-size:8px;color:#fffc;margin-top:-1px}.gb-btn-a{margin-top:-8px}.gb-bottom-label{display:flex;flex-direction:column;align-items:center;gap:4px;margin-top:8px;padding-top:4px}.gb-battery{font-family:"Press Start 2P",monospace;font-size:5px;color:#888;letter-spacing:1px}.gb-battery-indicator{display:flex;gap:3px}.gb-battery-dot{width:4px;height:4px;border-radius:50%;background:#666}.gb-battery-dot.active{background:#4a4;box-shadow:0 0 3px #4a4}.gb-controls-hint{font-family:"Press Start 2P",monospace;font-size:5px;color:#777;margin-top:4px;text-align:center;line-height:1.6}@media(max-height:700px){.gb-shell{transform:scale(.8);transform-origin:center}}@media(max-height:550px){.gb-shell{transform:scale(.65)}}@media(max-width:420px){.gb-shell{width:340px;padding:12px 16px 20px}.gb-screen-bezel{padding:14px 12px 18px}}
