*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0c;--fg: #e8e8ec;--fg-muted: #6b6b76;--accent: #4a4a5a;--surface: #101012;--border: #222224;--font-sans: "Silkscreen", cursive;--font-mono: "Silkscreen", cursive;--sidebar-width: 240px;--transition-fast: .15s ease;--transition-normal: .3s ease}[data-theme=light]{--bg: #f5f5f7;--fg: #1a1a1c;--fg-muted: #6b6b76;--accent: #a0a0aa;--surface: #ffffff;--border: #e0e0e4}html,body{height:100%;overflow:hidden;font-family:var(--font-sans);font-size:14px;line-height:1.5;color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased}#canvas{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:0}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100%;background:var(--surface);border-right:1px solid var(--border);z-index:10;display:flex;flex-direction:column;transform:translate(0);transition:transform var(--transition-normal);-webkit-user-select:none;user-select:none}.sidebar.hidden{transform:translate(-100%)}.sidebar:not(.hidden)~.drum-sequencer{left:calc(var(--sidebar-width) + 12px)}.sidebar-header{padding:24px 20px 16px;border-bottom:1px solid var(--border)}.sidebar-header h1{font-size:16px;font-weight:500;letter-spacing:-.02em}.sidebar-controls{flex:1;padding:20px 12px 20px 20px;overflow-y:auto;display:flex;flex-direction:column;gap:16px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.sidebar-controls::-webkit-scrollbar{width:6px}.sidebar-controls::-webkit-scrollbar-track{background:transparent;margin:8px 0}.sidebar-controls::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.sidebar-controls::-webkit-scrollbar-thumb:hover{background:var(--fg-muted)}.sidebar-footer{padding:16px 20px;border-top:1px solid var(--border)}.hint{font-size:11px;color:var(--fg-muted);font-family:var(--font-mono)}.control-group{display:flex;flex-direction:column;gap:6px}.control-group label{font-size:12px;color:var(--fg-muted);text-transform:lowercase}.control-group select,.control-group input[type=range]{margin-top:0}.control-row{display:flex;gap:8px;margin-top:8px}.control-divider{height:1px;background:var(--border);margin-top:8px;margin-bottom:-8px}.control-label{font-size:11px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:-4px}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;background:var(--border);border-radius:0;outline:none;cursor:pointer}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;background:var(--fg);border-radius:0;cursor:pointer;box-shadow:2px 2px 0 var(--border)}input[type=range]::-moz-range-thumb{width:12px;height:12px;background:var(--fg);border-radius:0;border:none;cursor:pointer;box-shadow:2px 2px 0 var(--border)}.wavetable-group{gap:6px}.wavetable-labels,.slide-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--fg-muted);font-family:var(--font-mono);padding:0 2px}.checkbox-group{flex-direction:row;align-items:center}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:12px;color:var(--fg-muted)}.checkbox-label input[type=checkbox]{width:14px;height:14px;accent-color:var(--fg);cursor:pointer}select{width:100%;padding:8px 32px 8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:0;color:var(--fg);font-family:var(--font-mono);font-size:12px;cursor:pointer;outline:none;transition:border-color var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23888' d='M2 4h8L6 9z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:10px}select:hover,select:focus{border-color:var(--fg-muted)}.control-btn{flex:1;padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--fg);font-family:var(--font-sans);font-size:12px;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:6px}.control-btn:hover{background:var(--border);border-color:var(--fg-muted)}#theme-btn{flex:0 0 36px;padding:8px}.player-controls{position:fixed;bottom:20px;right:20px;display:flex;align-items:center;gap:12px;z-index:20}.volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:60px;height:4px;background:var(--border);border:none;outline:none;cursor:pointer}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;background:var(--fg);border:none;border-radius:0;cursor:pointer;box-shadow:2px 2px 0 var(--border)}.volume-slider::-moz-range-thumb{width:12px;height:12px;background:var(--fg);border:none;border-radius:0;cursor:pointer;box-shadow:2px 2px 0 var(--border)}.start-btn{width:36px;height:36px;aspect-ratio:1;border-radius:0;border:2px solid var(--fg);background:var(--bg);color:var(--fg);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:none;image-rendering:pixelated;box-shadow:3px 3px 0 var(--fg)}.start-btn:hover{background:var(--fg);color:var(--bg)}.start-btn:active{box-shadow:1px 1px 0 var(--fg);transform:translate(2px,2px)}.start-btn.hidden{opacity:0;pointer-events:none}.intro{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:var(--bg);opacity:1;transition:opacity 1.5s cubic-bezier(.4,0,.2,1);pointer-events:all}.intro.fade-out{opacity:0;pointer-events:none}.intro.hidden{display:none}.intro-content{text-align:center;opacity:0;transform:translateY(20px);animation:intro-fade-in 1.2s cubic-bezier(.4,0,.2,1) .3s forwards}.intro-title{font-size:48px;font-weight:400;letter-spacing:.1em;margin-bottom:32px;color:var(--fg)}.intro-controls{font-size:10px;color:var(--fg-muted);font-family:var(--font-mono);display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center;gap:16px}.intro-controls div{display:flex;align-items:center;gap:6px}.intro-controls span{display:inline-block;padding:2px 6px;background:var(--surface);border:1px solid var(--border);color:var(--fg);text-align:center;font-size:9px}@keyframes intro-fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.drum-sequencer{position:fixed;bottom:12px;left:12px;z-index:15;padding:8px;display:flex;flex-direction:row;gap:12px;align-items:stretch;pointer-events:none;transition:left var(--transition-normal);-webkit-user-select:none;user-select:none}.drum-sequencer>*{pointer-events:auto}.drum-sequencer.hidden{display:none}.seq-grid{display:flex;flex-direction:column;gap:2px}.seq-track{display:flex;align-items:center;gap:6px}.seq-label{width:16px;font-family:var(--font-mono);font-size:9px;color:var(--fg-muted);text-align:right;opacity:.6}.seq-steps{display:flex;gap:2px}.seq-step{width:18px;height:18px;background:transparent;border:1px solid var(--border);cursor:pointer;transition:none;opacity:.4}.seq-step:hover{opacity:.7;background:var(--fg-muted)}.seq-step.active{background:var(--fg);opacity:.9}.seq-step.playing{border-color:var(--fg);opacity:1}.seq-step[data-subdiv="2"]:after,.seq-step[data-subdiv="3"]:after,.seq-step[data-subdiv="4"]:after{content:"";position:absolute;bottom:2px;left:50%;transform:translate(-50%);display:flex;gap:1px}.seq-step{position:relative}.seq-step[data-subdiv="2"]:after{content:"··";font-size:8px;line-height:1;color:var(--bg)}.seq-step[data-subdiv="3"]:after{content:"···";font-size:8px;line-height:1;color:var(--bg)}.seq-step[data-subdiv="4"]:after{content:"····";font-size:8px;line-height:1;color:var(--bg)}.seq-step:nth-child(4n+1){margin-left:3px}.seq-step:nth-child(1){margin-left:0}.seq-controls{display:flex;align-items:center;gap:8px;padding-top:4px}.seq-btn{font-family:var(--font-mono);font-size:8px;padding:3px 6px;text-align:center;background:transparent;border:1px solid var(--border);color:var(--fg);cursor:pointer;opacity:.6}#seq-play{width:32px;padding:3px 0}.seq-btn:hover,.seq-btn:active{opacity:1}.seq-btn.playing{background:var(--fg);color:var(--bg);opacity:1}.seq-slider-group{display:flex;align-items:center;gap:4px}.seq-slider-group label{font-family:var(--font-mono);font-size:8px;color:var(--fg-muted);opacity:.7}.seq-slider-group input[type=range]{width:50px;opacity:.7}.seq-slider-group input[type=range]:hover{opacity:1}.seq-slider-group span{font-family:var(--font-mono);font-size:8px;color:var(--fg-muted);width:20px;opacity:.7}.seq-main{display:flex;flex-direction:column;gap:6px}.seq-xy-pad{align-self:stretch;aspect-ratio:1;border:1px solid var(--border);position:relative;cursor:crosshair;opacity:.5;flex-shrink:0}.seq-xy-pad:hover{opacity:.8}.seq-xy-pad.active{opacity:1;border-color:var(--fg)}.seq-xy-line-h{position:absolute;left:0;right:0;height:1px;background:var(--fg);top:100%;pointer-events:none}.seq-xy-line-v{position:absolute;top:0;bottom:0;width:1px;background:var(--fg);left:0;pointer-events:none}.seq-xy-label-x{position:absolute;bottom:3px;right:4px;font-family:var(--font-mono);font-size:7px;color:var(--fg-muted);opacity:.5}.seq-xy-label-y{position:absolute;top:3px;left:4px;font-family:var(--font-mono);font-size:7px;color:var(--fg-muted);opacity:.5}.seq-xy-title{position:absolute;top:3px;right:4px;font-family:var(--font-mono);font-size:8px;color:var(--fg);opacity:.4}
