:root{color:#1b1b1d;background-color:#9fa3a7;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{font-family:Trebuchet MS,Segoe UI,sans-serif;color:#1b1b1d;background-color:#9fa3a7}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:linear-gradient(180deg,#b5b8be,#9a9ea3);overscroll-behavior:none;touch-action:none}#root{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:16px}.app-shell{width:100%;display:flex;justify-content:center;align-items:center}.app-shell__content{width:100%;display:flex;flex-direction:column;align-items:center;gap:20px}.app-shell__header{text-align:center;color:#2f3138}.app-shell__header h1{margin:0;font-size:20px;letter-spacing:1px}.app-shell__header p{margin:6px 0 0;font-size:12px;color:#5f636c}button{font-family:inherit;border:none;background:none;cursor:pointer;touch-action:none;-webkit-user-select:none;user-select:none}.app{width:100%;display:flex;justify-content:center;position:relative}.emulator-layout{width:100%;display:flex;flex-direction:column;align-items:center;gap:24px}.gameboy{width:min(92vw,420px);background:linear-gradient(165deg,#d7d8dc,#c7c8cc 35%,#b0b2b7);border-radius:28px 28px 64px;padding:22px 20px 28px;box-shadow:inset 0 6px 12px #fff6,inset 0 -8px 14px #00000026,0 24px 40px #00000059;position:relative}.gameboy-top{display:flex;flex-direction:column;gap:14px}.power-indicator{display:flex;align-items:center;gap:8px;font-size:11px;text-transform:uppercase;letter-spacing:1px;color:#4a4a50}.power-led{width:10px;height:10px;border-radius:50%;background:#3b1b1b;box-shadow:inset 0 0 2px #0009}.power-led--on{background:#ff2a2a;box-shadow:0 0 6px #ff2a2ae6,0 0 12px #ff2a2a99}.screen-bezel{background:#4b4c52;border-radius:16px;padding:16px 16px 20px;box-shadow:inset 0 6px 8px #0006}.screen-label{font-size:9px;letter-spacing:1.5px;text-align:center;color:#cdd0d4;margin-bottom:8px}.screen-window{background:#1b1b1b;border-radius:8px;padding:10px;box-shadow:inset 0 0 12px #000c;aspect-ratio:4 / 3;position:relative;overflow:hidden}.gameboy--desktop .screen-window{padding:14px}.screen-canvas{width:100%;height:100%;display:block;image-rendering:pixelated;border-radius:4px}#emulatorjs-container canvas{width:100%!important;height:100%!important;image-rendering:pixelated}.screen-overlay{position:absolute;inset:10px;display:flex;align-items:center;justify-content:center;background:#0a0a0aa6;color:#f2f2f2;font-size:12px;text-transform:uppercase;letter-spacing:1px;border-radius:6px;text-align:center}.screen-meta{margin-top:8px;font-size:11px;text-align:center;color:#5b5e66}.gameboy-controls{margin-top:18px;display:flex;flex-direction:column;gap:18px}.shoulder-row{display:flex;justify-content:space-between;gap:12px}.shoulder-button{flex:1;height:28px;border-radius:999px;background:linear-gradient(180deg,#444750,#2a2c32);color:#f2f2f4;font-size:12px;text-transform:uppercase;letter-spacing:1px;box-shadow:inset 0 2px #fff3,inset 0 -2px #00000080}.select-game{width:110px;margin:0 auto;background:linear-gradient(180deg,#3b495a,#293444);color:#eef0f2;padding:10px 12px;border-radius:12px;text-transform:uppercase;font-size:12px;letter-spacing:1px;box-shadow:inset 0 2px #fff3,0 6px 10px #00000040}.controls-row{display:flex;justify-content:space-between;align-items:center;gap:14px}.dpad{width:120px;height:120px;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:6px}.dpad-button{background:linear-gradient(180deg,#3b3b3d,#1f1f1f);border-radius:8px;box-shadow:inset 0 2px #ffffff1a,inset 0 -4px #000000b3,0 6px 8px #0000004d}.dpad-center{grid-column:2 / 3;grid-row:2 / 3;background:radial-gradient(circle,#2a2a2a,#121212 80%);border-radius:50%;box-shadow:inset 0 2px 3px #ffffff1a}.dpad-button--up{grid-column:2 / 3;grid-row:1 / 2}.dpad-button--left{grid-column:1 / 2;grid-row:2 / 3}.dpad-button--right{grid-column:3 / 4;grid-row:2 / 3}.dpad-button--down{grid-column:2 / 3;grid-row:3 / 4}.center-controls{display:flex;flex-direction:column;align-items:center;gap:12px}.system-buttons{display:flex;flex-direction:column;gap:10px}.system-button{width:72px;height:16px;border-radius:999px;background:linear-gradient(180deg,#6e6f74,#45464a);color:#f1f1f1;font-size:10px;text-transform:uppercase;letter-spacing:1px;box-shadow:inset 0 2px #ffffff59,inset 0 -2px #00000080}.ab-buttons{display:flex;justify-content:center;align-items:center}.action-grid{display:grid;grid-template-columns:repeat(2,56px);grid-template-rows:repeat(2,56px);gap:10px;transform:rotate(-12deg)}.action-button{width:56px;height:56px;border-radius:50%;background:linear-gradient(180deg,#7a1c36,#4f0d1f);color:#f6f1f2;font-size:16px;font-weight:700;text-transform:uppercase;box-shadow:inset 0 3px #fff3,inset 0 -6px #00000080,0 8px 12px #00000059}.ab-plate{display:flex;gap:16px;transform:rotate(-12deg)}.ab-button{width:60px;height:60px;border-radius:50%;background:linear-gradient(180deg,#8f1a3a,#5f0f25);color:#f6f1f2;font-size:18px;font-weight:700;text-transform:uppercase;box-shadow:inset 0 3px #fff3,inset 0 -6px #00000080,0 8px 12px #00000059}.is-pressed{transform:translateY(2px);box-shadow:inset 0 1px #fff3,inset 0 -2px #0009,0 2px 4px #00000059}.rom-input{display:none}.aux-row{display:flex;justify-content:center;gap:8px}.aux-button{padding:6px 10px;border-radius:999px;background:#2f3b4a;color:#f5f6f8;font-size:11px;letter-spacing:.5px;box-shadow:inset 0 1px #fff3}.aux-button.is-active{background:#1f8f55}.aux-button:disabled{opacity:.6;cursor:not-allowed}.control-panel{width:min(360px,92vw);background:#eef0f4;border-radius:20px;padding:18px;box-shadow:inset 0 2px 6px #fff9,0 18px 28px #0003;display:flex;flex-direction:column;gap:18px}.control-panel__header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.control-panel__title{font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#3c3f46}.control-panel__subtitle{margin:6px 0 0;font-size:12px;color:#6a6d76}.select-game--panel{width:auto;min-width:140px;padding:8px 14px;font-size:11px}.keymap h3{margin:0;font-size:14px;color:#3a3d45}.keymap-hint{margin:6px 0 0;font-size:11px;color:#7a7d86}.keymap-table{width:100%;border-collapse:collapse;margin-top:10px;font-size:12px}.keymap-table th,.keymap-table td{text-align:left;padding:8px 6px;border-bottom:1px solid rgba(60,63,70,.12)}.keymap-table th{color:#585b63;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.keymap-code{font-family:SF Mono,Roboto Mono,monospace;color:#30333a}.keymap-edit{background:#2f3b4a;color:#f5f6f8;padding:6px 12px;border-radius:999px;font-size:11px;letter-spacing:.5px;box-shadow:inset 0 1px #fff3}.keymap-edit:disabled{opacity:.6;cursor:not-allowed}.keymap-table tr.is-editing td{color:#1f2b3a;font-weight:600}.settings-actions{display:flex;flex-wrap:wrap;gap:8px}.settings-error{background:#ffe4e4;color:#8a2a2a;padding:8px 10px;border-radius:10px;font-size:12px}.gamepad-status{display:flex;align-items:center;gap:10px;font-size:12px;color:#4b4f58}.status-dot{width:10px;height:10px;border-radius:50%;background:#b43a3a;box-shadow:inset 0 0 2px #0006}.status-dot--on{background:#2bbf6a;box-shadow:0 0 6px #2bbf6ab3}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.settings-button{position:fixed;top:18px;right:18px;z-index:20;width:44px;height:44px;border-radius:12px;background:#2c333dd9;color:#f4f5f7;font-size:18px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 14px #00000040;opacity:.4;transition:opacity .2s ease}.settings-button:hover,.settings-button:focus-visible{opacity:1}.screen-window.cursor-hidden{cursor:none}.settings-overlay{position:fixed;inset:0;background:#12141ab3;display:flex;align-items:center;justify-content:center;padding:20px;z-index:30;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.settings-modal{width:min(92vw,520px);max-height:90vh;overflow-y:auto;background:#eef0f4;border-radius:18px;padding:20px;box-shadow:0 22px 40px #00000059;display:flex;flex-direction:column;gap:16px}.settings-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.settings-close{width:36px;height:36px;border-radius:10px;background:#2f3b4a;color:#f5f6f8;font-size:14px}.settings-instructions h4{margin:0 0 8px;font-size:13px;color:#3a3d45}.settings-instructions ul{margin:0;padding-left:18px;font-size:12px;color:#595d66;display:grid;gap:6px}@media(max-width:480px){.gameboy{width:94vw}.dpad{width:104px;height:104px}.ab-button{width:54px;height:54px}}@media(max-width:1023px){.gameboy{width:100vw;max-width:100vw;min-height:100vh;border-radius:0;display:flex;flex-direction:column}.gameboy-controls{margin-top:auto;padding-bottom:120px}#root{padding:0}}@media(min-width:1024px){.gameboy-controls{display:none}}@media(min-width:900px){.emulator-layout{flex-direction:row;align-items:flex-start}}@media(min-width:1025px){body{background:#000}#root{padding:0}.app--desktop{min-height:100vh;background:#000}.emulator-layout{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;gap:0}.gameboy{width:auto;background:none;padding:0;box-shadow:none;border-radius:0}.gameboy-top{gap:0}.power-indicator,.screen-label{display:none}.screen-bezel{background:none;padding:0;box-shadow:none;border-radius:0}.screen-window{background:#000;padding:0;box-shadow:none;border-radius:0;height:100vh;width:calc(100vh * 4 / 3);max-width:100vw;max-height:100vh;display:flex;align-items:center;justify-content:center}.screen-canvas{width:100%;height:100%;max-width:100vw;max-height:100vh;image-rendering:pixelated;object-fit:contain}}
