@font-face{font-family:Early GameBoy;src:url(/fonts/Early%20GameBoy.ttf) format("truetype");font-weight:400;font-style:normal}:root{--color-bg: #1a1a1a;--color-bg-stripe: #252525;--color-accent: #80b027;--color-accent-dark: #648a1e;--color-text: #ffffff;--color-text-muted: #888888;--color-white-key: #ffffff;--color-white-key-pressed: var(--color-accent);--color-black-key: #1a1a1a;--color-black-key-pressed: var(--color-accent);--color-control-bg: #333333;--color-control-border: #444444;--white-key-width: 50px;--white-key-height: 200px;--black-key-width: 36px;--black-key-height: 110px;--control-height: 200px;font-family:Segoe UI,system-ui,sans-serif;font-size:14px;color:var(--color-text)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{background:var(--color-bg);background-image:repeating-linear-gradient(135deg,transparent,transparent 10px,var(--color-bg-stripe) 10px,var(--color-bg-stripe) 20px)}button,.key,.slider{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}@media(max-width:600px){:root{--white-key-width: 40px;--white-key-height: 140px;--black-key-width: 28px;--black-key-height: 85px;--control-height: 160px}}@media(min-width:1300px){:root{--white-key-width: 60px;--white-key-height: 200px;--black-key-width: 42px;--black-key-height: 120px}}@media(min-width:1680px){:root{--white-key-width: 70px;--white-key-height: 210px;--black-key-width: 48px;--black-key-height: 130px}}.key{position:absolute;top:0;border-radius:0 0 4px 4px;transition:background-color .05s ease-out;pointer-events:none}.key--white{width:var(--white-key-width);height:var(--white-key-height);background-color:var(--color-white-key);border:1px solid #ccc;z-index:1}.key--white.key--pressed{background-color:var(--color-white-key-pressed);border-color:var(--color-accent-dark)}.key--black{width:var(--black-key-width);height:var(--black-key-height);background-color:var(--color-black-key);border:1px solid #333;z-index:2}.key--black.key--pressed{background-color:var(--color-black-key-pressed);border-color:transparent}.keyboard{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:0 20px 20px;overflow:hidden;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.keyboard-keys{position:relative;height:var(--white-key-height);overflow:hidden;width:calc(11 * var(--white-key-width))}@media(min-width:600px){.keyboard-keys{width:calc(11 * var(--white-key-width))}}@media(min-width:950px){.keyboard-keys{width:calc(18 * var(--white-key-width))}}@media(min-width:1300px){.keyboard-keys{width:calc(21 * var(--white-key-width))}}@media(min-width:1440px){.keyboard-keys{width:calc(23 * var(--white-key-width))}}@media(min-width:1680px){.keyboard-keys{width:calc(23 * var(--white-key-width))}}.display-screen{width:130px;height:24px;background:#0a1a0a;border:2px solid #333;border-radius:3px;overflow:hidden;box-shadow:inset 0 1px 4px #0009,0 0 2px #00ff001a;position:relative;font-family:Courier New,Courier,monospace;font-size:.8rem;font-weight:700;color:var(--color-accent);text-shadow:0 0 4px rgba(51,255,51,.5);white-space:nowrap;line-height:24px}.display-screen__text{display:inline-block;padding-left:100%;animation:marquee-scroll 6s linear infinite}@keyframes marquee-scroll{0%{transform:translate(0)}to{transform:translate(-100%)}}.preset-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.preset-button{width:40px;height:40px;border:none;border-radius:4px;background:var(--color-control-bg);color:var(--color-text);font-family:Early GameBoy,monospace;font-size:1rem;font-weight:700;cursor:pointer;transition:background-color .1s ease}.preset-button:hover{background:var(--color-control-border)}.preset-button--active{background:var(--color-accent);color:#000}@media(max-width:600px){.preset-button{width:32px;height:32px;font-size:.85rem}}.sound-bank{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px;background:linear-gradient(135deg,#1f3d35,#1a2e2e);border-radius:4px;border:1px solid #3a4a47;min-width:60px;opacity:.6;transition:opacity .15s ease}.sound-bank--active{opacity:1;border-color:#27b09c;box-shadow:0 0 10px #27b09c4d}.sound-bank__label{font-size:.7rem;font-weight:700;color:var(--color-text-muted)}.sound-bank__volume,.sound-bank__loop{width:32px;height:32px;border:none;border-radius:4px;background:var(--color-bg);color:var(--color-text);font-size:.9rem;font-weight:700;cursor:pointer;transition:background-color .1s ease}.sound-bank__volume:hover,.sound-bank__loop:hover{background:var(--color-control-border)}.sound-bank__volume .volume-icon{width:18px;height:18px;filter:invert(1)}.volume--off{color:var(--color-text-muted)}.volume--off .volume-icon{filter:invert(.5)}.volume--low{background:#1e8a7a}.volume--high,.loop--active{background:#27b09c;color:#000}.sound-bank__loop .loop-icon{width:18px;height:18px;filter:invert(1)}.sound-bank__loop.loop--active .loop-icon{filter:invert(0)}.sound-bank__loop:disabled{opacity:.3;cursor:default;pointer-events:none}.sound-bank__pitch{display:flex;flex-direction:column;align-items:center;gap:2px}.pitch-slider{width:50px;accent-color:#27b09c}.pitch-slider:disabled{opacity:.4}.pitch-value{font-size:.65rem;color:var(--color-text-muted)}.synth-bank{display:flex;flex-direction:row;gap:10px;padding:10px;background:linear-gradient(135deg,#2d1f3d,#1a1a2e);border-radius:6px;border:1px solid #4a3560;opacity:.6;transition:opacity .15s ease}.synth-bank--active{opacity:1;border-color:#9c27b0;box-shadow:0 0 10px #9c27b04d}.synth-bank__buttons{display:flex;flex-direction:column;gap:6px}.synth-bank__volume{width:32px;height:32px;border:none;border-radius:4px;background:var(--color-bg);color:var(--color-text);font-size:.9rem;font-weight:700;cursor:pointer;transition:background-color .1s ease}.synth-bank__volume:hover{background:var(--color-control-border)}.synth-bank__volume .volume-icon{width:18px;height:18px;filter:invert(1)}.synth-bank__volume.volume--off{color:var(--color-text-muted)}.synth-bank__volume.volume--off .volume-icon{filter:invert(.5)}.synth-bank__volume.volume--low{background:#7b1fa2}.synth-bank__volume.volume--high{background:#9c27b0;color:#fff}.synth-bank__loop{width:32px;height:32px;border:none;border-radius:4px;background:var(--color-bg);color:var(--color-text);font-size:.9rem;font-weight:700;cursor:pointer;transition:background-color .1s ease}.synth-bank__loop:hover{background:var(--color-control-border)}.synth-bank__loop.loop--active{background:#9c27b0;color:#fff}.synth-bank__loop .loop-icon{width:18px;height:18px;filter:invert(1)}.synth-bank__loop.loop--active .loop-icon{filter:invert(0)}.synth-bank__loop:disabled{opacity:.3;cursor:default;pointer-events:none}.synth-bank__waveform{width:32px;height:32px;border:none;border-radius:4px;background:#4a148c;color:#e1bee7;font-size:.65rem;font-weight:700;cursor:pointer;transition:background-color .1s ease}.synth-bank__waveform:hover{background:#6a1b9a}.synth-bank__waveform:disabled{opacity:.3;cursor:default;pointer-events:none}.synth-bank__controls{display:flex;flex-direction:column;gap:6px;justify-content:center}.synth-bank__control{display:flex;flex-direction:row;align-items:center;gap:6px}.synth-bank__control-label{font-size:.6rem;color:#b39ddb;text-transform:uppercase;letter-spacing:.05em;width:38px}.synth-bank__slider{width:50px;accent-color:#9c27b0}.synth-bank__slider:disabled{opacity:.4}@media(max-width:600px){.synth-bank__slider{width:40px}}.effects-panel{display:flex;gap:16px}.effect{display:flex;flex-direction:column;gap:8px;padding:8px;background:linear-gradient(135deg,#3d3a1f,#2e2e1a);border-radius:4px;border:1px solid #4a4a3a;opacity:.6;transition:opacity .15s ease}.effect--active{opacity:1;border-color:var(--color-accent);box-shadow:0 0 10px #80b0274d}.effect__toggle{padding:8px 16px;border:none;border-radius:4px;background:var(--color-bg);color:var(--color-text);font-family:Early GameBoy,monospace;font-size:.8rem;font-weight:700;cursor:pointer;transition:background-color .1s ease}.effect__toggle:hover{background:var(--color-control-border)}.effect__toggle--active{background:var(--color-accent);color:#000}.effect__params{display:flex;flex-direction:column;gap:4px}.effect__param{display:flex;align-items:center;gap:8px}.effect__param label{font-size:.65rem;color:var(--color-text-muted);min-width:50px}.effect__param input[type=range]{width:60px;accent-color:var(--color-accent)}.effect__param input[type=range]:disabled{opacity:.4}.control-panel{display:flex;flex-wrap:wrap;gap:16px;padding:16px;background:#0000004d;min-height:var(--control-height)}.control-panel__section{display:flex;flex-direction:column;gap:8px}.control-panel__section h2{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin:0}.control-panel__header{display:flex;flex-direction:column;gap:12px}.logo{font-size:1.2rem;font-weight:700;color:var(--color-accent);margin:0;font-family:Early GameBoy,monospace;text-transform:uppercase;letter-spacing:-.05em}.master-volume{display:flex;align-items:center;gap:8px}.master-volume label{font-size:.75rem;color:var(--color-text-muted)}.master-volume input[type=range]{width:80px;accent-color:var(--color-accent)}.sound-banks{display:flex;gap:12px}@media(max-width:800px){.control-panel{padding:12px;gap:12px}.sound-banks{flex-wrap:wrap}}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--color-bg)}.loading-content{text-align:center}.loading-title{font-size:3rem;font-weight:700;color:var(--color-accent);margin-bottom:2rem;font-family:monospace;text-transform:uppercase;letter-spacing:.2em}.loading-bar-container{width:300px;height:8px;background:var(--color-control-bg);border-radius:4px;overflow:hidden;margin:0 auto 1rem}.loading-bar{height:100%;background:var(--color-accent);transition:width .1s ease-out}.loading-text{color:var(--color-text-muted);font-size:.9rem}.app{display:flex;flex-direction:column;height:100%;max-height:100vh;overflow:hidden}
