@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500;600;700;800&family=Share+Tech+Mono&display=swap";:root{--bg-darkest: #050a05;--bg-dark: #0a0f0a;--bg-medium: #0f1a0f;--bg-light: #1a2a1a;--bg-hover: #1f3520;--bg-active: #2a4a2a;--accent-primary: #00ff41;--accent-secondary: #ffb000;--accent-tertiary: #00ffff;--accent-success: #00ff41;--accent-warning: #ffb000;--accent-error: #ff0033;--glow-primary: 0 0 5px rgba(0, 255, 65, .6), 0 0 15px rgba(0, 255, 65, .3), 0 0 30px rgba(0, 255, 65, .1);--glow-secondary: 0 0 5px rgba(255, 176, 0, .6), 0 0 15px rgba(255, 176, 0, .3), 0 0 30px rgba(255, 176, 0, .1);--glow-tertiary: 0 0 5px rgba(0, 255, 255, .6), 0 0 15px rgba(0, 255, 255, .3), 0 0 30px rgba(0, 255, 255, .1);--glow-success: 0 0 5px rgba(0, 255, 65, .6), 0 0 15px rgba(0, 255, 65, .3), 0 0 30px rgba(0, 255, 65, .1);--glow-error: 0 0 5px rgba(255, 0, 51, .6), 0 0 15px rgba(255, 0, 51, .3), 0 0 30px rgba(255, 0, 51, .1);--glow-intense: 0 0 5px #00ff41, 0 0 10px #00ff41, 0 0 20px #00ff41, 0 0 40px #00aa28, 0 0 80px rgba(0, 170, 40, .3);--text-primary: #00ff41;--text-secondary: #4a9a4a;--text-muted: #2d5a2d;--text-accent: var(--accent-primary);--text-amber: #ffb000;--text-cyan: #00ffff;--border-color: #1a3a1a;--border-light: #2a5a2a;--border-accent: rgba(0, 255, 65, .25);--border-bright: rgba(0, 255, 65, .5);--channel-1: #00ff41;--channel-2: #00ffff;--channel-3: #ffb000;--channel-4: #33ff77;--channel-5: #00ccff;--channel-6: #ff0033;--channel-7: #66ff99;--channel-8: #ffcc00;--transport-height: 52px;--sidebar-width: 220px;--effects-width: 280px;--mixer-height: 200px;--border-radius: 0px;--border-radius-sm: 0px;--border-radius-lg: 0px;--transition-fast: 80ms ease;--transition-normal: .15s ease;--transition-slow: .3s ease;--font-mono: "JetBrains Mono", "Share Tech Mono", "Fira Code", "SF Mono", "Courier New", monospace;--font-sans: "JetBrains Mono", "Share Tech Mono", monospace;--font-size-xs: 10px;--font-size-sm: 11px;--font-size-md: 13px;--font-size-lg: 16px;--font-size-xl: 20px;--font-size-xxl: 28px;--shadow-sm: 0 1px 3px rgba(0, 20, 0, .6);--shadow-md: 0 4px 12px rgba(0, 20, 0, .7);--shadow-lg: 0 8px 24px rgba(0, 20, 0, .8);--shadow-inset: inset 0 1px 3px rgba(0, 20, 0, .7);--shadow-crt: inset 0 0 80px rgba(0, 255, 65, .02), 0 0 20px rgba(0, 255, 65, .05);--knob-size: 40px;--knob-size-sm: 32px;--knob-size-lg: 52px;--fader-width: 6px;--fader-height: 120px;--fader-thumb-width: 28px;--fader-thumb-height: 12px;--z-base: 1;--z-panel: 10;--z-overlay: 100;--z-modal: 200;--z-transport: 300;--z-tooltip: 400;--z-scanlines: 9999;--scrollbar-width: 4px;--scrollbar-track: var(--bg-darkest);--scrollbar-thumb: #1a3a1a;--scrollbar-thumb-hover: #2a5a2a}@keyframes crt-flicker{0%{opacity:.97}2%{opacity:.94}4%{opacity:.98}8%{opacity:.93}11%{opacity:.99}14%{opacity:.96}20%{opacity:.98}50%{opacity:.97}55%{opacity:.95}60%{opacity:.98}80%{opacity:.96}90%{opacity:.99}to{opacity:.97}}@keyframes glitch{0%{transform:translate(0);filter:none}2%{transform:translate(-2px,1px);filter:hue-rotate(90deg)}4%{transform:translate(2px,-1px);filter:hue-rotate(-90deg)}6%{transform:translate(-1px,-2px)}8%{transform:translate(1px,2px);filter:hue-rotate(45deg)}10%{transform:translate(0);filter:none}to{transform:translate(0);filter:none}}@keyframes glitch-text{0%{text-shadow:0 0 5px #00ff41,0 0 10px #00ff41;clip-path:inset(0 0 0 0)}5%{text-shadow:-2px 0 #ff0033,2px 0 #00ffff;clip-path:inset(20% 0 60% 0)}10%{text-shadow:2px 0 #ff0033,-2px 0 #00ffff;clip-path:inset(60% 0 10% 0)}15%{text-shadow:0 0 5px #00ff41,0 0 10px #00ff41;clip-path:inset(0 0 0 0)}to{text-shadow:0 0 5px #00ff41,0 0 10px #00ff41;clip-path:inset(0 0 0 0)}}@keyframes cursor-blink{0%,49%{opacity:1}50%,to{opacity:0}}@keyframes phosphor-pulse{0%,to{box-shadow:0 0 5px #00ff414d}50%{box-shadow:0 0 15px #00ff4199,0 0 30px #00ff4133}}@keyframes glow-pulse{0%,to{text-shadow:0 0 5px #00ff41,0 0 10px rgba(0,255,65,.5)}50%{text-shadow:0 0 10px #00ff41,0 0 20px #00ff41,0 0 40px rgba(0,255,65,.3)}}@keyframes crt-on{0%{opacity:0;transform:scaleY(.005) scaleX(.2);filter:brightness(30)}10%{opacity:1;transform:scaleY(.005) scaleX(.8);filter:brightness(10)}30%{transform:scaleY(1.1) scaleX(1);filter:brightness(2)}50%{transform:scaleY(.98) scaleX(1);filter:brightness(1.2)}70%{transform:scaleY(1.02) scaleX(1);filter:brightness(1)}to{transform:scaleY(1) scaleX(1);filter:brightness(1);opacity:1}}@keyframes scanline-crawl{0%{transform:translateY(0)}to{transform:translateY(4px)}}@keyframes beat-flash{0%{background:#00ff414d}50%{background:#00ff4126}to{background:#00ff410d}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;overflow:hidden;-webkit-font-smoothing:none;-moz-osx-font-smoothing:unset;text-rendering:optimizeSpeed}body{height:100%;overflow:hidden;background-color:#020502;color:var(--text-primary);font-family:var(--font-mono);font-size:var(--font-size-md);line-height:1.4;animation:crt-flicker 8s infinite}body:after{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.12) 2px,rgba(0,0,0,.12) 4px);pointer-events:none;z-index:var(--z-scanlines)}body:before{content:"";position:fixed;top:0;left:0;right:0;height:100%;background:linear-gradient(transparent 0%,rgba(0,255,65,.015) 50%,transparent 100%);background-size:100% 200%;animation:scanline-crawl 6s linear infinite;pointer-events:none;z-index:calc(var(--z-scanlines) - 1)}#app{display:grid;grid-template-columns:var(--sidebar-width) 1fr var(--effects-width);grid-template-rows:var(--transport-height) 1fr var(--mixer-height);grid-template-areas:"transport  transport   transport" "sidebar    main        right-panel" "sidebar    mixer       visualizer";height:100vh;width:100vw;overflow:hidden;gap:1px;background-color:#0a1f0a;border-radius:8px;box-shadow:inset 0 0 100px #00ff4108,inset 0 0 30px #00ff4105,0 0 20px #00ff4114,0 0 60px #00ff4108;animation:crt-on .8s cubic-bezier(.2,.8,.4,1) forwards;position:relative}#app:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:8px;background:radial-gradient(ellipse at center,transparent 60%,rgba(0,0,0,.3) 100%);pointer-events:none;z-index:calc(var(--z-scanlines) - 2)}#transport{grid-area:transport;z-index:var(--z-transport);background-color:var(--bg-dark);border-bottom:1px solid var(--border-color)}#sidebar{grid-area:sidebar;background-color:var(--bg-dark);overflow:hidden;display:flex;flex-direction:column;min-width:0;border-right:1px solid var(--border-color)}#sidebar #sample-browser,#sidebar #preset-library{flex:1;overflow:hidden;min-height:0}#main-area #pattern-builder,#main-area #code-panel{height:100%;overflow:hidden}#main-area{grid-area:main;background-color:var(--bg-darkest);overflow:hidden;position:relative;min-width:0;min-height:0}#right-panel{grid-area:right-panel;background-color:var(--bg-dark);overflow:hidden;display:flex;flex-direction:column;min-width:0;border-left:1px solid var(--border-color)}#right-panel #effect-rack{flex:1;overflow:hidden;min-height:0}#mixer{grid-area:mixer;background-color:var(--bg-dark);overflow:hidden;min-height:0;border-top:1px solid var(--border-color)}#visualizer{grid-area:visualizer;background-color:var(--bg-darkest);overflow:hidden;position:relative;min-width:0;min-height:0;border-top:1px solid var(--border-color);border-left:1px solid var(--border-color)}#app.sidebar-collapsed{grid-template-columns:0px 1fr var(--effects-width);grid-template-areas:"transport  transport   transport" "sidebar    main        right-panel" "sidebar    mixer       visualizer"}#app.sidebar-collapsed #sidebar{display:none}#app.right-collapsed{grid-template-columns:var(--sidebar-width) 1fr 0px;grid-template-areas:"transport  transport   transport" "sidebar    main        main" "sidebar    mixer       mixer"}#app.right-collapsed #right-panel,#app.right-collapsed #visualizer{display:none}#app.sidebar-collapsed.right-collapsed{grid-template-columns:0px 1fr 0px;grid-template-areas:"transport  transport   transport" "main       main        main" "mixer      mixer       mixer"}.resize-handle{position:absolute;z-index:var(--z-panel);background:transparent;transition:background var(--transition-fast)}.resize-handle:hover,.resize-handle.active{background:var(--accent-primary);opacity:.3;box-shadow:0 0 8px #00ff4166}.resize-handle-v{width:4px;height:100%;top:0;cursor:col-resize}.resize-handle-h{width:100%;height:4px;left:0;cursor:row-resize}.resize-handle-sidebar{right:-2px}.resize-handle-right{left:-2px}.resize-handle-mixer{top:-2px}::-webkit-scrollbar{width:var(--scrollbar-width);height:var(--scrollbar-width)}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:0}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover);box-shadow:0 0 4px #00ff414d}::-webkit-scrollbar-corner{background:var(--scrollbar-track)}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}.hidden{display:none!important}.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}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background-color:var(--bg-medium);border-bottom:1px solid var(--border-color);font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.12em;-webkit-user-select:none;user-select:none;font-family:var(--font-mono)}.panel-header h3{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.12em;font-family:var(--font-mono)}.panel-header h3:before{content:"> ";color:var(--text-muted)}.panel-body{flex:1;overflow-y:auto;overflow-x:hidden}::selection{background:#00ff4159;color:#000}:focus-visible{outline:1px dashed var(--accent-primary);outline-offset:1px}input,select,textarea,button{font-family:var(--font-mono)}::placeholder{color:var(--text-muted)!important;opacity:1}a{color:var(--accent-primary);text-decoration:none}a:hover{text-shadow:0 0 5px rgba(0,255,65,.5)}#transport{display:flex;align-items:center;padding:0 16px;height:var(--transport-height);border-bottom:1px solid var(--border-color);-webkit-user-select:none;user-select:none;gap:0;background:linear-gradient(180deg,var(--bg-dark) 0%,rgba(10,15,10,.98) 100%);box-shadow:inset 0 1px #00ff410d}.transport-logo{flex-shrink:0;margin-right:12px}.transport-logo .logo-text{font-family:var(--font-mono);font-weight:800;font-size:var(--font-size-lg);color:var(--accent-primary);letter-spacing:.2em;text-shadow:var(--glow-intense);cursor:default;text-transform:uppercase}.transport-logo .logo-text:hover{animation:glitch-text .5s ease-in-out;cursor:default}.transport-group{display:flex;align-items:center;gap:8px}.transport-divider{width:1px;height:24px;background:var(--border-color);margin:0 12px;flex-shrink:0;box-shadow:0 0 3px #00ff4114}.transport-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--bg-darkest);color:var(--text-primary);border:1px solid var(--border-color);border-radius:0;padding:5px 28px 5px 10px;font-family:var(--font-mono);font-size:var(--font-size-sm);cursor:pointer;outline:none;transition:border-color var(--transition-fast);min-width:140px;text-shadow:0 0 3px rgba(0,255,65,.2);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5' viewBox='0 0 8 5'%3E%3Cpath fill='%2300ff41' d='M0 0l4 5 4-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.transport-select:hover{border-color:var(--border-light)}.transport-select option{background:var(--bg-dark);color:var(--text-primary)}.transport-play-btn{display:flex;align-items:center;justify-content:center;width:40px;height:34px;background:var(--bg-medium);color:var(--accent-primary);font-size:var(--font-size-md);border:1px solid var(--accent-primary);border-radius:0;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 0 5px #00ff4126}.transport-play-btn:hover{background:#00ff411a;box-shadow:var(--glow-primary)}.transport-play-btn svg{fill:var(--accent-primary);filter:drop-shadow(0 0 3px rgba(0,255,65,.6))}.transport-play-btn.playing{background:#ff00331a;border-color:var(--accent-error);box-shadow:var(--glow-error);animation:phosphor-pulse 1.5s ease-in-out infinite}.transport-play-btn.playing svg{fill:var(--accent-error);filter:drop-shadow(0 0 3px rgba(255,0,51,.6))}@keyframes play-pulse{0%,to{box-shadow:0 0 6px #00ff414d}50%{box-shadow:0 0 14px #00ff4199,0 0 30px #00ff4126}}.transport-bpm-group{gap:6px}.transport-label{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;flex-shrink:0;font-family:var(--font-mono)}.transport-bpm-input{font-family:var(--font-mono);font-size:var(--font-size-lg);font-weight:700;color:var(--accent-primary);background:var(--bg-darkest);border:1px solid var(--border-color);border-radius:0;padding:3px 10px;min-width:64px;width:72px;text-align:center;text-shadow:0 0 8px rgba(0,255,65,.5);cursor:text;outline:none;-moz-appearance:textfield}.transport-bpm-input::-webkit-inner-spin-button,.transport-bpm-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.transport-tap-btn{font-size:var(--font-size-xs);padding:4px 8px;background:var(--bg-medium);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:0;cursor:pointer;font-family:var(--font-mono);font-weight:600;text-transform:uppercase;letter-spacing:.08em;transition:all var(--transition-fast)}.transport-tap-btn:active,.transport-tap-btn.tapped{background:var(--accent-primary);color:#000;border-color:var(--accent-primary);text-shadow:none;box-shadow:0 0 8px #00ff4166}.transport-vol-group{gap:6px}.transport-volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:80px;height:4px;background:var(--bg-light);border-radius:0;outline:none;cursor:pointer}.transport-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:10px;height:14px;background:var(--accent-primary);border-radius:0;cursor:pointer;box-shadow:0 0 6px #00ff4180}.transport-volume-slider::-webkit-slider-thumb:hover{background:#3f6;box-shadow:var(--glow-primary)}.transport-volume-slider::-moz-range-thumb{width:10px;height:14px;background:var(--accent-primary);border-radius:0;border:none;cursor:pointer}.transport-vol-value{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--text-secondary);min-width:32px;text-align:right;text-shadow:0 0 3px rgba(0,255,65,.2)}.transport-mode-group{gap:0;background:var(--bg-darkest);border:1px solid var(--border-color);border-radius:0;overflow:hidden;height:28px;padding:0}.transport-mode-btn{padding:0 14px;font-size:var(--font-size-xs);font-family:var(--font-mono);font-weight:700;text-transform:uppercase;letter-spacing:.1em;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);line-height:26px;height:100%}.transport-mode-btn:hover{color:var(--text-secondary);text-shadow:0 0 3px rgba(0,255,65,.2)}.transport-mode-btn.active{background:var(--accent-primary);color:#000;border-radius:0;text-shadow:none;box-shadow:inset 0 0 10px #00ff414d}#mixer{display:flex;flex-direction:column}.mixer-scroll{display:flex;flex:1;overflow-x:auto;overflow-y:hidden;padding:6px 4px;gap:2px;align-items:stretch}.mixer-add-btn{min-width:40px;width:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-medium);border:1px dashed var(--border-color);border-radius:0;color:var(--text-muted);font-size:var(--font-size-lg);font-family:var(--font-mono);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;align-self:stretch}.mixer-add-btn:hover{background:#00ff410d;color:var(--accent-primary);border-color:var(--accent-primary);border-style:solid;box-shadow:0 0 8px #00ff4133;text-shadow:0 0 5px rgba(0,255,65,.5)}.channel-strip{display:flex;flex-direction:column;align-items:center;min-width:72px;width:72px;background:var(--bg-medium);border:1px solid var(--border-color);border-radius:0;padding:0;position:relative;transition:opacity var(--transition-fast),filter var(--transition-fast);flex-shrink:0;height:100%}.channel-strip.muted{opacity:.3}.channel-strip.dimmed{opacity:.2;filter:grayscale(.8)}.channel-strip.soloed{opacity:1;filter:none;border-color:var(--accent-secondary);box-shadow:0 0 5px #ffb00033}.channel-color-bar{width:100%;height:3px;border-radius:0;flex-shrink:0;box-shadow:0 1px 4px currentColor}.channel-remove-btn{position:absolute;top:5px;right:4px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);font-size:14px;font-family:var(--font-mono);cursor:pointer;opacity:0;transition:all var(--transition-fast);z-index:2;padding:0;line-height:1}.channel-strip:hover .channel-remove-btn{opacity:.6}.channel-remove-btn:hover{opacity:1!important;color:var(--accent-error);text-shadow:0 0 5px rgba(255,0,51,.5)}.channel-name{font-size:var(--font-size-xs);font-family:var(--font-mono);color:var(--text-primary);text-align:center;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:6px 4px 2px;cursor:default;font-weight:600;text-transform:uppercase;letter-spacing:.05em;text-shadow:0 0 3px rgba(0,255,65,.2)}.channel-name-input{width:100%;background:var(--bg-darkest);color:var(--text-primary);border:1px solid var(--accent-primary);border-radius:0;font-size:var(--font-size-xs);font-family:var(--font-mono);text-align:center;text-transform:uppercase;padding:2px;outline:none;box-shadow:0 0 5px #00ff4133}.channel-sound-select{width:calc(100% - 8px);margin:2px 4px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--bg-darkest);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:0;padding:2px 4px;font-size:9px;font-family:var(--font-mono);cursor:pointer;outline:none;text-align:center;transition:border-color var(--transition-fast);text-transform:uppercase}.channel-sound-select:hover{border-color:var(--border-light)}.channel-sound-select:focus{border-color:var(--accent-primary);box-shadow:0 0 3px #00ff4133}.channel-fader-container{display:flex;flex-direction:column;align-items:center;flex:1;min-height:0;width:100%;padding:2px 8px;gap:2px}.channel-fader-label{font-size:8px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-mono)}.channel-fader-track{position:relative;width:var(--fader-width);flex:1;min-height:40px;background:var(--bg-darkest);border:1px solid var(--border-color);border-radius:0;cursor:pointer;overflow:visible}.channel-fader-fill{position:absolute;bottom:0;left:0;width:100%;border-radius:0;background:var(--accent-primary);opacity:.6;transition:height 50ms ease;box-shadow:0 0 4px #00ff4166}.channel-fader-thumb{position:absolute;left:50%;transform:translate(-50%);width:var(--fader-thumb-width);height:var(--fader-thumb-height);background:var(--accent-primary);border-radius:0;box-shadow:0 0 5px #00ff4180;cursor:grab;z-index:2;pointer-events:none;border:1px solid rgba(0,255,65,.7)}.channel-fader-thumb:after{content:"";position:absolute;top:50%;left:3px;right:3px;height:1px;background:#0009;transform:translateY(-50%)}.channel-fader-value{font-family:var(--font-mono);font-size:9px;color:var(--text-muted);text-align:center;text-shadow:0 0 2px rgba(0,255,65,.15)}.channel-knobs-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;width:100%;padding:0 2px}.channel-knob-container{display:flex;flex-direction:column;align-items:center;gap:0;padding:1px 0}.channel-knob-label{font-size:8px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-mono)}.channel-knob-svg{cursor:pointer;display:block;filter:drop-shadow(0 0 2px rgba(0,255,65,.15))}.channel-knob-svg:hover{filter:drop-shadow(0 0 4px rgba(0,255,65,.3)) brightness(1.1)}.channel-knob-svg.dragging{cursor:grabbing}.channel-knob-value{font-family:var(--font-mono);font-size:9px;color:var(--text-muted);text-align:center}.channel-btn-group{display:flex;gap:2px;margin:4px 4px 6px;width:calc(100% - 8px)}.channel-mute-btn,.channel-solo-btn{flex:1;height:20px;border:1px solid var(--border-color);border-radius:0;font-size:9px;font-family:var(--font-mono);font-weight:700;cursor:pointer;transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:.05em}.channel-mute-btn{background:var(--bg-darkest);color:var(--text-muted)}.channel-mute-btn:hover{background:var(--bg-hover);color:var(--text-secondary);border-color:var(--border-light)}.channel-mute-btn.active{background:var(--accent-secondary);color:#000;border-color:var(--accent-secondary);box-shadow:0 0 5px #ffb00066;text-shadow:none}.channel-solo-btn{background:var(--bg-darkest);color:var(--text-muted)}.channel-solo-btn:hover{background:var(--bg-hover);color:var(--text-secondary);border-color:var(--border-light)}.channel-solo-btn.active{background:var(--accent-primary);color:#000;border-color:var(--accent-primary);box-shadow:0 0 5px #00ff4166;text-shadow:none}#pattern-builder{display:flex;flex-direction:column;height:100%;overflow:hidden}.pattern-builder{display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative}.pattern-step-selector{display:flex;gap:4px}.pattern-step-btn{padding:2px 8px;font-size:var(--font-size-xs);font-family:var(--font-mono);font-weight:700;background:var(--bg-medium);color:var(--text-muted);border:1px solid var(--border-color);border-radius:0;cursor:pointer;transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:.05em}.pattern-step-btn:hover{background:var(--bg-hover);color:var(--text-secondary);border-color:var(--border-light)}.pattern-grid-wrapper{flex:1;overflow:auto;min-height:0}.pattern-grid{display:grid;min-width:100%}.pattern-cell{display:flex;align-items:center;justify-content:center;border-right:1px solid rgba(26,58,26,.25);border-bottom:1px solid rgba(26,58,26,.25);min-width:0;min-height:0}.pattern-corner{background:var(--bg-dark);border-right:1px solid var(--border-color)}.pattern-step-header{font-size:9px;font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-dark);padding:3px 0;text-align:center;-webkit-user-select:none;user-select:none}.pattern-step-header.beat-marker{color:var(--text-secondary);font-weight:700;text-shadow:0 0 3px rgba(0,255,65,.2);box-shadow:inset 0 -1px 0 var(--border-color)}.pattern-step-header.current-step{color:var(--accent-primary);text-shadow:0 0 8px rgba(0,255,65,.7);background:#00ff4114;box-shadow:inset 0 -2px 0 var(--accent-primary)}.pattern-row-label{background:var(--bg-dark);border-right:1px solid var(--border-color);padding:0 8px;font-size:var(--font-size-xs);font-weight:600;color:var(--text-secondary);-webkit-user-select:none;user-select:none;gap:5px;overflow:hidden;font-family:var(--font-mono)}.pattern-row-label.melodic-label{background:linear-gradient(90deg,rgba(0,255,255,.04) 0%,var(--bg-dark) 100%);border-right-color:#0ff3}.pattern-row-color{width:6px;height:6px;border-radius:0;flex-shrink:0;display:inline-block;box-shadow:0 0 3px currentColor}.pattern-row-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.03em;text-shadow:0 0 3px rgba(0,255,65,.12)}.pattern-row-type{font-size:7px;font-family:var(--font-mono);font-weight:700;letter-spacing:.08em;padding:1px 3px;border-radius:0;background:#00ff410f;color:var(--text-muted);flex-shrink:0;text-transform:uppercase;border:1px solid rgba(0,255,65,.08)}.pattern-row-type.melodic-badge{background:#00ffff14;color:#0ff9;border-color:#00ffff1f}.pattern-step{cursor:pointer;position:relative;transition:background 60ms ease;border-radius:0}.pattern-step.beat-start{border-left:1px solid rgba(42,90,42,.4)}.pattern-step:hover{background:var(--bg-hover)}.pattern-step.active{border-radius:0;box-shadow:0 0 4px #00ff414d,inset 0 0 4px #00ff4114}.pattern-step-drum.active:after{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;border-radius:0;background:inherit;opacity:.85;box-shadow:0 0 3px #00ff4133}.pattern-step.current-step{background:#00ff410f!important}.pattern-step.current-step:before{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:var(--accent-primary);box-shadow:0 0 8px #00ff4199;z-index:1}.pattern-step.active.current-step{filter:brightness(1.4);box-shadow:0 0 10px #00ff4180,0 0 20px #00ff4133}.pattern-step-melodic{background:#00ffff05;font-size:8px;font-family:var(--font-mono);font-weight:600;color:var(--text-muted);-webkit-user-select:none;user-select:none;overflow:hidden;padding:0 1px;border:1px solid rgba(0,255,255,.04);border-radius:0}.pattern-step-melodic:hover{background:#00ffff0f;border-color:#00ffff1f}.pattern-step-melodic.active{border-radius:0;font-weight:700;box-shadow:0 0 4px #00ffff4d}.pattern-step-melodic:not(.active) .melodic-note-label{color:var(--text-muted);opacity:.4}.note-picker{position:absolute;z-index:var(--z-overlay);background:var(--bg-dark);border:1px solid var(--border-light);border-radius:0;box-shadow:var(--shadow-lg),0 0 20px #00ff4114;padding:6px;min-width:180px;max-width:220px}.note-picker-rest{display:block;width:100%;padding:5px 8px;margin-bottom:6px;font-size:var(--font-size-xs);font-family:var(--font-mono);font-weight:600;background:var(--bg-medium);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:0;cursor:pointer;text-align:center;transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:.05em}.note-picker-label{font-size:9px;font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;margin-right:2px;flex-shrink:0;letter-spacing:.05em}.note-picker-note-btn:hover{background:var(--accent-tertiary);color:#000;border-color:var(--accent-tertiary);box-shadow:0 0 3px #00ffff4d}.note-picker-note-btn.active{background:var(--accent-primary);color:#000;border-color:var(--accent-primary);box-shadow:0 0 6px #00ff4166;text-shadow:none}.pattern-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:var(--font-size-sm);font-family:var(--font-mono);padding:20px;text-align:center;text-transform:uppercase;letter-spacing:.1em}.pattern-euclidean-area{border-top:1px solid var(--border-color);background:var(--bg-dark);padding:6px 10px;flex-shrink:0;max-height:180px;overflow-y:auto}.euclidean-header{font-size:var(--font-size-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px;font-family:var(--font-mono)}.euclidean-header:before{content:"// "}.euclidean-row{display:flex;align-items:center;gap:8px;padding:3px 0}.euclidean-label{font-size:var(--font-size-xs);font-weight:600;min-width:48px;font-family:var(--font-mono);color:var(--text-primary);text-transform:uppercase;text-shadow:0 0 2px rgba(0,255,65,.15)}.euclidean-param-label{font-size:9px;color:var(--text-muted);text-transform:uppercase;font-family:var(--font-mono);letter-spacing:.05em}.euclidean-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex:1;height:4px;background:var(--bg-light);border-radius:0;outline:none;cursor:pointer;max-width:120px}.euclidean-slider::-webkit-slider-thumb{-webkit-appearance:none;width:8px;height:12px;background:var(--accent-primary);border-radius:0;cursor:pointer;box-shadow:0 0 4px #00ff4166}.euclidean-slider::-moz-range-thumb{width:8px;height:12px;background:var(--accent-primary);border-radius:0;border:none;cursor:pointer}.euclidean-value{font-family:var(--font-mono);font-size:9px;color:var(--text-secondary);min-width:16px;text-align:right;text-shadow:0 0 2px rgba(0,255,65,.15)}.euclidean-apply-btn{padding:2px 8px;font-size:9px;font-family:var(--font-mono);font-weight:600;background:var(--bg-medium);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:0;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;transition:all var(--transition-fast)}.euclidean-apply-btn:hover{background:#00ff4126;color:var(--accent-primary);border-color:#00ff414d;box-shadow:0 0 5px #00ff4133}.gui-piano{position:absolute;z-index:100;background:var(--bg-darkest);border:1px solid var(--accent-primary);box-shadow:0 0 12px #00ff414d,0 4px 16px #0009;padding:6px;display:flex;flex-direction:column;gap:4px}.gui-piano-header{display:flex;justify-content:space-between;align-items:center;gap:6px}.gui-piano-rest-btn{padding:3px 8px;font-size:9px;font-family:var(--font-mono);font-weight:700;background:var(--bg-medium);color:var(--text-muted);border:1px solid var(--border-color);border-radius:0;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;transition:all var(--transition-fast)}.gui-piano-rest-btn:hover{background:#ff003326;color:var(--accent-error);border-color:var(--accent-error)}.gui-piano-octave{display:flex;align-items:center;gap:2px}.gui-piano-oct-btn{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:var(--bg-medium);color:var(--text-muted);border:1px solid var(--border-color);border-radius:0;cursor:pointer;font-size:8px;transition:all var(--transition-fast)}.gui-piano-oct-btn:hover{background:#00ff411a;color:var(--accent-primary);border-color:var(--accent-primary)}.gui-piano-oct-label{font-family:var(--font-mono);font-size:9px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;min-width:36px;text-align:center;text-shadow:0 0 2px rgba(0,255,65,.2)}.gui-piano-keys{user-select:none;-webkit-user-select:none}.gui-piano-white-key{position:absolute;top:0;background:linear-gradient(180deg,#e8e8e8,#d0d0d0 90%,#b0b0b0);border:1px solid rgba(0,0,0,.3);cursor:pointer;display:flex;align-items:flex-end;justify-content:center;padding-bottom:4px;transition:background .05s}.gui-piano-white-key:hover{background:linear-gradient(180deg,#fff,#e8e8e8 90%,#ccc);box-shadow:0 0 6px #00ff414d}.gui-piano-white-key:active{background:linear-gradient(180deg,#ccc,#b8b8b8 90%,#a0a0a0)}.gui-piano-white-key.active{background:linear-gradient(180deg,#00ff4166,#00ff4140 90%,#00c8324d);box-shadow:0 0 8px #00ff4166}.gui-piano-black-key{position:absolute;top:0;background:linear-gradient(180deg,#3a3a3a,#1a1a1a 90%,#0a0a0a);border:1px solid rgba(0,0,0,.5);cursor:pointer;z-index:2;display:flex;align-items:flex-end;justify-content:center;padding-bottom:3px;transition:background .05s}.gui-piano-black-key:hover{background:linear-gradient(180deg,#4a4a4a,#2a2a2a 90%,#1a1a1a);box-shadow:0 0 6px #00ff414d}.gui-piano-black-key:active{background:linear-gradient(180deg,#2a2a2a,#111 90%,#000)}.gui-piano-black-key.active{background:linear-gradient(180deg,#00c83280,#00962866 90%,#00641e80);box-shadow:0 0 8px #00ff4166}.gui-piano-key-label{font-family:var(--font-mono);font-size:7px;font-weight:600;color:#00000080;pointer-events:none}.gui-piano-black-key .gui-piano-key-label{color:#fff6}#effect-rack,.effect-rack{display:flex;flex-direction:column;height:100%;overflow:hidden}.effect-channel-tabs{display:flex;background:var(--bg-dark);border-bottom:1px solid var(--border-color);overflow-x:auto;overflow-y:hidden;flex-shrink:0;gap:0}.effect-channel-tab{padding:6px 10px;font-size:var(--font-size-xs);font-family:var(--font-mono);font-weight:600;color:var(--text-muted);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;flex-shrink:0;text-transform:uppercase;letter-spacing:.08em}.effect-channel-tab:hover{color:var(--text-secondary);background:var(--bg-hover);text-shadow:0 0 3px rgba(0,255,65,.15)}.effect-blocks{flex:1;overflow-y:auto;padding:6px;display:flex;flex-direction:column;gap:4px}.effect-block{background:var(--bg-medium);border:1px solid var(--border-color);border-radius:0;overflow:hidden;transition:border-color var(--transition-fast)}.effect-block-title{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:var(--bg-light);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:var(--font-size-sm);font-weight:700;color:var(--accent-secondary);font-family:var(--font-mono);border-bottom:1px solid var(--border-color)}.effect-block-title:hover{background:var(--bg-hover)}.effect-block-title span{font-size:var(--font-size-sm);font-weight:700;color:var(--accent-secondary);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.12em;text-shadow:0 0 5px rgba(255,176,0,.3)}.effect-collapse-btn{width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);font-size:10px;font-family:var(--font-mono);cursor:pointer;transition:transform var(--transition-fast),color var(--transition-fast);padding:0}.effect-collapse-btn:hover{color:var(--text-secondary)}.effect-knob-area{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;padding:10px;border-top:1px solid var(--border-color);transition:all var(--transition-normal)}.effect-knob-wrapper{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:52px}.effect-knob-wrapper.large{min-width:68px}.effect-knob-label{font-size:8px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;text-align:center;font-family:var(--font-mono)}.effect-knob-svg{cursor:pointer;display:block;filter:drop-shadow(0 0 2px rgba(0,255,65,.12))}.effect-knob-svg:hover{filter:drop-shadow(0 0 4px rgba(0,255,65,.25)) brightness(1.1)}.effect-knob-value{font-family:var(--font-mono);font-size:9px;color:var(--text-secondary);text-align:center;text-shadow:0 0 3px rgba(0,255,65,.15)}.effect-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:var(--font-size-sm);font-family:var(--font-mono);text-align:center;padding:20px;text-transform:uppercase;letter-spacing:.08em}.sidebar-tabs{display:flex;background:var(--bg-medium);border-bottom:1px solid var(--border-color);flex-shrink:0}.sidebar-tab{flex:1;padding:8px 0;font-size:var(--font-size-xs);font-family:var(--font-mono);font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.sidebar-tab:hover{color:var(--text-secondary);background:var(--bg-hover);text-shadow:0 0 3px rgba(0,255,65,.15)}.sidebar-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary);text-shadow:0 0 5px rgba(0,255,65,.3)}.sample-browser{flex:1;display:flex;flex-direction:column;overflow:hidden}.sample-search-wrap{position:relative;padding:8px;flex-shrink:0}.sample-search-input{width:100%;padding:6px 10px 6px 30px;background:var(--bg-darkest);border:1px solid var(--border-color);border-radius:0;color:var(--text-primary);font-family:var(--font-mono);font-size:var(--font-size-sm);outline:none;transition:border-color var(--transition-fast);text-shadow:0 0 2px rgba(0,255,65,.15)}.sample-search-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:var(--font-size-sm);pointer-events:none;display:flex;align-items:center}.sample-category{-webkit-user-select:none;user-select:none}.sample-category-header{display:flex;align-items:center;gap:6px;padding:6px 10px;cursor:pointer;transition:background var(--transition-fast);font-size:var(--font-size-sm);font-weight:700;font-family:var(--font-mono);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.sample-category-header:hover{background:var(--bg-hover);text-shadow:0 0 5px rgba(0,255,65,.2)}.sample-toggle-icon{font-size:8px;color:var(--text-muted);transition:transform var(--transition-fast);width:12px;text-align:center;flex-shrink:0}.sample-category-body{padding-left:8px;border-left:1px solid var(--border-color);margin-left:14px}.sample-sub-header{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:6px 10px 3px 16px;font-weight:700;font-family:var(--font-mono)}.sample-sub-header:before{content:"// ";color:var(--text-muted)}.sample-item{display:flex;align-items:center;gap:6px;padding:4px 10px 4px 20px;cursor:pointer;transition:background var(--transition-fast);font-size:var(--font-size-sm);color:var(--text-secondary);position:relative;border-left:2px solid transparent}.sample-item:hover{background:var(--bg-hover);color:var(--text-primary);border-left-color:var(--accent-primary)}.sample-item.selected{background:var(--bg-active);color:var(--text-primary);border-left-color:var(--accent-primary)}.sample-preview-btn{width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border-color);border-radius:0;color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:all var(--transition-fast);padding:0;font-family:var(--font-mono)}.sample-preview-btn:hover{color:var(--accent-primary);border-color:var(--accent-primary);background:#00ff4114}.sample-preview-btn.playing{color:var(--accent-primary);border-color:var(--accent-primary);box-shadow:0 0 5px #00ff414d;animation:preview-pulse .6s ease-in-out infinite}@keyframes preview-pulse{0%,to{opacity:1}50%{opacity:.4}}.sample-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-mono);font-size:var(--font-size-xs);text-shadow:0 0 2px rgba(0,255,65,.1)}.sample-drag-handle{color:var(--text-muted);font-size:10px;opacity:0;cursor:grab;transition:opacity var(--transition-fast);flex-shrink:0}.sample-item:hover .sample-drag-handle{opacity:.4}.sample-drag-handle:active{cursor:grabbing;opacity:.8}.sample-no-results{display:flex;align-items:center;justify-content:center;padding:20px;color:var(--text-muted);font-size:var(--font-size-sm);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em}.preset-library{flex:1;display:flex;flex-direction:column;overflow:hidden}.preset-save-area{display:flex;gap:4px;padding:8px;border-bottom:1px solid var(--border-color);flex-shrink:0}.preset-save-input{flex:1;padding:5px 8px;background:var(--bg-darkest);border:1px solid var(--border-color);border-radius:0;color:var(--text-primary);font-family:var(--font-mono);font-size:var(--font-size-sm);outline:none;transition:border-color var(--transition-fast)}.preset-save-btn{padding:5px 12px;font-size:var(--font-size-xs);font-family:var(--font-mono);font-weight:700;background:#00ff411a;color:var(--accent-primary);border:1px solid rgba(0,255,65,.3);border-radius:0;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;transition:all var(--transition-fast)}.preset-save-btn.success{background:var(--accent-primary);color:#000;border-color:var(--accent-primary);text-shadow:none}.preset-grid{flex:1;overflow-y:auto;padding:4px}.preset-section-header{font-size:var(--font-size-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;padding:8px 8px 4px;font-family:var(--font-mono)}.preset-section-header:before{content:"// "}.preset-card{display:flex;flex-direction:column;gap:4px;padding:8px 10px;margin:2px 4px;background:var(--bg-medium);border:1px solid var(--border-color);border-radius:0;cursor:pointer;transition:all var(--transition-fast)}.preset-card:hover{background:var(--bg-hover);border-color:var(--border-light);box-shadow:0 0 5px #00ff4114}.preset-card-name{font-size:var(--font-size-sm);font-weight:700;color:var(--text-primary);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;text-shadow:0 0 3px rgba(0,255,65,.15)}.preset-card-meta{display:flex;gap:8px;align-items:center}.preset-genre-tag{font-size:9px;font-family:var(--font-mono);color:var(--accent-tertiary);text-transform:uppercase;letter-spacing:.05em;background:#00ffff0f;padding:1px 6px;border:1px solid rgba(0,255,255,.12);border-radius:0}.preset-bpm-tag{font-size:9px;font-family:var(--font-mono);color:var(--text-muted)}.preset-card-actions{display:flex;gap:4px;margin-top:2px}.preset-load-btn,.preset-delete-btn{padding:2px 8px;font-size:9px;font-family:var(--font-mono);font-weight:600;border-radius:0;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;transition:all var(--transition-fast)}.preset-load-btn{background:var(--bg-light);color:var(--text-secondary);border:1px solid var(--border-color)}.preset-delete-btn{background:none;color:var(--text-muted);border:1px solid transparent}#code-panel,.code-panel{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--bg-darkest)}.code-panel-controls{display:flex;align-items:center;gap:8px}.code-sync-badge{font-size:9px;font-family:var(--font-mono);font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:2px 8px;border-radius:0;line-height:1.4}.code-sync-badge.synced{background:#00ff4114;color:var(--accent-primary);border:1px solid rgba(0,255,65,.2);text-shadow:0 0 3px rgba(0,255,65,.3)}.code-sync-badge.desynced{background:#ffb00014;color:var(--accent-secondary);border:1px solid rgba(255,176,0,.2);text-shadow:0 0 3px rgba(255,176,0,.3);animation:edited-pulse 2s ease-in-out infinite}.code-sync-badge.error{background:#ff003314;color:var(--accent-error);border:1px solid rgba(255,0,51,.2);text-shadow:0 0 3px rgba(255,0,51,.3)}@keyframes edited-pulse{0%,to{opacity:1}50%{opacity:.5}}.code-sync-btn{padding:3px 8px;font-size:var(--font-size-xs);font-family:var(--font-mono);font-weight:600;background:var(--bg-medium);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:0;cursor:pointer;text-transform:uppercase;letter-spacing:.06em;transition:all var(--transition-fast)}.code-sync-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-light)}.code-parse-btn{padding:3px 8px;font-size:var(--font-size-xs);font-family:var(--font-mono);font-weight:700;background:#00ffff14;color:var(--accent-tertiary);border:1px solid rgba(0,255,255,.2);border-radius:0;cursor:pointer;text-transform:uppercase;letter-spacing:.06em;transition:all var(--transition-fast)}.code-parse-btn:hover{background:#00ffff26;border-color:var(--accent-tertiary);box-shadow:0 0 5px #0ff3}.code-notification{padding:6px 12px;font-size:var(--font-size-xs);font-family:var(--font-mono);line-height:1.4;border-bottom:1px solid var(--border-color);letter-spacing:.03em}.code-notification--info{background:#00ffff0a;color:var(--accent-tertiary);border-bottom-color:#00ffff1a}.code-notification--warning{background:#ffb0000a;color:var(--accent-secondary);border-bottom-color:#ffb0001a}.code-notification--error{background:#ff00330a;color:var(--accent-error);border-bottom-color:#ff00331a}.code-eval-btn{padding:3px 10px;font-size:var(--font-size-xs);font-family:var(--font-mono);font-weight:700;background:#00ff4114;color:var(--accent-primary);border:1px solid rgba(0,255,65,.25);border-radius:0;cursor:pointer;text-transform:uppercase;letter-spacing:.06em;transition:all var(--transition-fast)}.code-eval-btn:hover{background:#00ff4126;border-color:var(--accent-primary);box-shadow:0 0 8px #00ff4133}.code-eval-btn:active,.code-eval-btn.success{background:var(--accent-primary);color:#000;border-color:var(--accent-primary);text-shadow:none;box-shadow:0 0 10px #00ff4166}.code-eval-btn.error{background:var(--accent-error);color:#000;border-color:var(--accent-error);box-shadow:0 0 10px #f036}.code-editor-area .CodeMirror{height:100%!important;font-family:var(--font-mono)!important;font-size:14px!important;line-height:1.6!important;background:var(--bg-darkest)!important;color:var(--text-primary)!important}.code-editor-area .CodeMirror-gutters{background:var(--bg-dark)!important;border-right:1px solid var(--border-color)!important;padding-right:4px}.code-editor-area .CodeMirror-linenumber{color:var(--text-muted)!important;font-size:var(--font-size-xs)!important}.code-editor-area .CodeMirror-cursor{border-left-color:var(--accent-primary)!important;border-left-width:2px!important;box-shadow:0 0 5px #00ff4180}.code-editor-area .CodeMirror-selected{background:#00ff411f!important}.code-editor-area .CodeMirror-activeline-background{background:#00ff4108!important}.code-editor-area .CodeMirror-matchingbracket{color:var(--accent-tertiary)!important;text-shadow:0 0 5px rgba(0,255,255,.5);border-bottom:1px solid var(--accent-tertiary)}.code-editor-area .cm-editor{height:100%;font-family:var(--font-mono);font-size:14px;line-height:1.6}.code-editor-area .cm-editor .cm-scroller{overflow:auto}.code-editor-area .cm-editor .cm-content{color:var(--text-primary)}.code-editor-area .cm-editor .cm-gutters{background:var(--bg-dark);border-right:1px solid var(--border-color)}.code-editor-area .cm-editor .cm-lineNumbers .cm-gutterElement{color:var(--text-muted)}.code-editor-area .cm-editor .cm-cursor{border-left-color:var(--accent-primary);box-shadow:0 0 5px #00ff4180}.code-editor-area .cm-editor .cm-selectionBackground{background:#00ff411f!important}.code-editor-area .cm-editor .cm-activeLine{background:#00ff4108}.inline-piano{position:fixed;z-index:10000;background:var(--bg-darkest, #050a05);border:1px solid var(--accent-primary, #00ff41);padding:8px;font-family:var(--font-mono, "JetBrains Mono", monospace);box-shadow:0 0 20px #00ff414d,0 0 40px #00ff411a,inset 0 0 30px #00000080;border-radius:0;-webkit-user-select:none;user-select:none;animation:piano-appear .15s ease-out}@keyframes piano-appear{0%{opacity:0;transform:scaleY(.3) scaleX(.8);filter:brightness(3)}50%{opacity:1;transform:scaleY(1.05) scaleX(1);filter:brightness(1.3)}to{transform:scaleY(1) scaleX(1);filter:brightness(1);opacity:1}}.piano-header{display:flex;align-items:center;gap:6px;margin-bottom:6px;color:var(--accent-primary, #00ff41);font-size:11px;font-weight:600;letter-spacing:.06em}.piano-oct-btn{background:var(--bg-medium, #0f1a0f);color:var(--accent-primary, #00ff41);border:1px solid var(--border-color, #1a3a1a);font-family:inherit;font-size:10px;width:22px;height:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:all 80ms ease}.piano-oct-btn:hover{background:var(--bg-hover, #1f3520);border-color:var(--accent-primary, #00ff41);box-shadow:0 0 6px #00ff414d}.piano-oct-btn:active{background:var(--accent-primary, #00ff41);color:#000}.piano-oct-display{font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--accent-primary, #00ff41);text-shadow:0 0 6px rgba(0,255,65,.4);min-width:42px;text-align:center}.piano-rest-btn{margin-left:auto;cursor:pointer;color:var(--accent-error, #ff0033);border:1px solid var(--accent-error, #ff0033);padding:2px 8px;font-family:inherit;font-size:10px;font-weight:700;letter-spacing:.06em;background:transparent;transition:all 80ms ease}.piano-rest-btn:hover{background:var(--accent-error, #ff0033);color:#000;box-shadow:0 0 8px #f036}.piano-keyboard{position:relative;height:80px}.piano-key-white{position:relative;display:inline-flex;align-items:flex-end;justify-content:center;width:28px;height:80px;background:#0a1a0a;border:1px solid #1a3a1a;border-right-color:#0f250f;cursor:pointer;padding-bottom:4px;box-sizing:border-box;vertical-align:top;transition:background 60ms ease,border-color 60ms ease,box-shadow 60ms ease}.piano-key-white .piano-key-label{font-size:9px;font-weight:500;color:#3a6a3a;pointer-events:none;transition:color 60ms ease}.piano-key-white:hover{background:#1a3a1a;border-color:var(--accent-secondary, #ffb000)}.piano-key-white:hover .piano-key-label{color:var(--accent-secondary, #ffb000)}.piano-key-white:active{background:#2a4a2a}.piano-key-white.active{background:var(--accent-primary, #00ff41);border-color:var(--accent-primary, #00ff41);box-shadow:0 0 12px #00ff4199,inset 0 0 8px #00ff414d}.piano-key-white.active .piano-key-label{color:#000;font-weight:700}.piano-key-black{position:absolute;top:0;width:20px;height:50px;background:var(--accent-primary, #00ff41);border:1px solid #00aa28;border-top:none;cursor:pointer;z-index:1;display:flex;align-items:flex-end;justify-content:center;padding-bottom:3px;box-sizing:border-box;transition:background 60ms ease,box-shadow 60ms ease;box-shadow:0 2px 4px #00000080}.piano-key-black .piano-key-label{font-size:7px;font-weight:700;color:#003310;pointer-events:none;transition:color 60ms ease}.piano-key-black:hover{background:var(--accent-secondary, #ffb000);border-color:#cc8c00;box-shadow:0 2px 8px #ffb00066}.piano-key-black:hover .piano-key-label{color:#320}.piano-key-black:active{background:#cc0}.piano-key-black.active{background:#fff;border-color:#fff;box-shadow:0 0 14px #fffc,0 0 30px #ffffff4d}.piano-key-black.active .piano-key-label{color:#000}.suggestion-toggle-btn{position:absolute;top:6px;right:6px;z-index:calc(var(--z-overlay) + 1);width:22px;height:22px;padding:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--text-muted);background:var(--bg-dark);border:1px solid var(--border-color);border-radius:0;cursor:pointer;transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:0;line-height:1}.suggestion-toggle-btn:hover{color:var(--accent-primary);border-color:var(--border-light);background:var(--bg-medium);box-shadow:0 0 4px #00ff4126}.suggestion-toggle-btn.active{color:var(--bg-darkest);background:var(--accent-primary);border-color:var(--accent-primary);box-shadow:0 0 8px #00ff4166}.suggestion-panel{position:absolute;right:0;top:0;bottom:0;width:280px;max-width:40%;z-index:var(--z-overlay);display:flex;flex-direction:column;background:#050a05f5;border-left:1px solid var(--border-color);box-shadow:-4px 0 16px #000a0099,inset 0 0 40px #00ff4103;font-family:var(--font-mono);font-size:var(--font-size-sm);overflow:hidden;animation:suggestion-panel-in .2s ease-out}@keyframes suggestion-panel-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.suggestion-panel-header{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;background:var(--bg-dark);border-bottom:1px solid var(--border-color);min-height:28px;flex-shrink:0}.suggestion-panel-title{font-size:9px;font-weight:700;color:var(--text-secondary);letter-spacing:.15em;text-transform:uppercase}.suggestion-panel-close{width:18px;height:18px;padding:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10px;font-weight:700;color:var(--text-muted);background:transparent;border:1px solid transparent;border-radius:0;cursor:pointer;transition:all var(--transition-fast)}.suggestion-panel-close:hover{color:var(--accent-error);border-color:#ff00334d;background:#ff00330f}.suggestion-panel-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px 0;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}.suggestion-panel-content::-webkit-scrollbar{width:var(--scrollbar-width)}.suggestion-panel-content::-webkit-scrollbar-track{background:var(--scrollbar-track)}.suggestion-panel-content::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb)}.suggestion-panel-content::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}.suggestion-category{padding:8px 10px 3px;font-size:8px;font-weight:700;color:var(--text-muted);letter-spacing:.2em;text-transform:uppercase;border-top:1px solid var(--border-color);margin-top:2px}.suggestion-divider{padding:6px 10px 3px;font-size:8px;font-weight:700;color:var(--text-amber);letter-spacing:.15em;text-transform:uppercase;border-top:1px solid rgba(255,176,0,.1);margin-top:4px}.suggestion-item{padding:5px 10px 6px;border-bottom:1px solid rgba(10,26,10,.6);transition:background var(--transition-fast)}.suggestion-item--clickable{cursor:pointer}.suggestion-item--clickable:hover{background:var(--bg-hover)}.suggestion-item--clickable:active{background:var(--bg-active)}.suggestion-label{display:block;font-size:11px;font-weight:700;line-height:1.4;letter-spacing:.04em}.suggestion-item--starter .suggestion-label,.suggestion-item--add .suggestion-label{color:var(--accent-primary);text-shadow:0 0 4px rgba(0,255,65,.2)}.suggestion-item--genre .suggestion-label{color:var(--accent-tertiary);text-shadow:0 0 4px rgba(0,255,255,.2)}.suggestion-item--effect .suggestion-label,.suggestion-item--melodic .suggestion-label{color:var(--accent-primary)}.suggestion-item--dj .suggestion-label{color:var(--accent-secondary);text-shadow:0 0 4px rgba(255,176,0,.2)}.suggestion-item--variation .suggestion-label{color:var(--accent-tertiary)}.suggestion-item--fix .suggestion-label{color:var(--accent-secondary)}.suggestion-item--warning .suggestion-label{color:var(--accent-error);text-shadow:0 0 4px rgba(255,0,51,.2)}.suggestion-item--default .suggestion-label{color:var(--accent-primary)}.suggestion-desc{display:block;font-size:10px;font-weight:400;color:var(--text-secondary);line-height:1.3;margin-top:1px}.suggestion-code{display:block;font-size:9px;font-weight:400;color:var(--text-muted);line-height:1.4;margin-top:3px;padding:2px 4px;background:#00ff4108;border:1px solid rgba(0,255,65,.06);border-radius:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggestion-item--clickable:hover .suggestion-code{color:var(--text-secondary);background:#00ff410f;border-color:#00ff411f}.suggestion-item--warning{background:#ff003305;border-left:2px solid rgba(255,0,51,.15);padding-left:8px}.suggestion-item--fix{border-left:2px solid rgba(255,176,0,.15);padding-left:8px}.suggestion-item--fix:hover{background:#ffb0000a}.suggestion-panel-content:empty:after{content:"NO SUGGESTIONS";display:block;padding:20px 10px;font-size:9px;color:var(--text-muted);letter-spacing:.15em;text-align:center}@media (max-width: 900px){.suggestion-panel{width:220px}}@media (max-width: 600px){.suggestion-panel{width:180px;font-size:10px}.suggestion-label{font-size:10px}.suggestion-desc{font-size:9px}.suggestion-code{display:none}}#visualizer{display:flex;flex-direction:column;background:var(--bg-darkest);position:relative;overflow:hidden}#visualizer:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 24px,rgba(0,255,65,.03) 24px,rgba(0,255,65,.03) 25px),repeating-linear-gradient(90deg,transparent,transparent 24px,rgba(0,255,65,.03) 24px,rgba(0,255,65,.03) 25px);pointer-events:none;z-index:1}.visualizer-tabs{display:flex;gap:2px;padding:4px 8px;background:var(--bg-dark);border-bottom:1px solid var(--border-color);flex-shrink:0;z-index:2;position:relative}.visualizer-tab{padding:3px 8px;font-size:9px;font-family:var(--font-mono);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--bg-medium);border:1px solid var(--border-color);border-radius:0;cursor:pointer;transition:all var(--transition-fast)}.visualizer-tab:hover{color:var(--text-secondary);background:var(--bg-hover);border-color:var(--border-light)}.visualizer-tab.active{color:var(--accent-primary);background:#00ff411a;border-color:#00ff414d;text-shadow:0 0 5px rgba(0,255,65,.3);box-shadow:0 0 5px #00ff4126}.visualizer-canvas{flex:1;display:block;width:100%;min-height:0;filter:drop-shadow(0 0 2px rgba(0,255,65,.2))}.transport-bar{display:flex;align-items:center;height:var(--transport-height);padding:0 12px;gap:8px;background:var(--bg-dark);border-bottom:1px solid var(--border-color);-webkit-user-select:none;user-select:none;overflow:hidden;font-family:var(--font-mono)}.transport-logo{flex-shrink:0}.transport-logo .logo-text{font-family:var(--font-mono);font-weight:700;font-size:var(--font-size-lg);color:var(--accent-primary);letter-spacing:.2em;text-shadow:var(--glow-intense);text-transform:uppercase;cursor:default}.transport-logo .logo-text:hover{animation:glitch-text .4s ease-in-out}.transport-group{display:flex;align-items:center;gap:6px;flex-shrink:0}.transport-divider{width:1px;height:28px;background:var(--border-color);flex-shrink:0;box-shadow:0 0 3px #00ff411a}.transport-select{background:var(--bg-darkest);color:var(--text-primary);border:1px solid var(--border-color);border-radius:0;padding:4px 8px;font-family:var(--font-mono);font-size:var(--font-size-sm);cursor:pointer;outline:none;max-width:140px;text-shadow:0 0 3px rgba(0,255,65,.3)}.transport-select:focus{border-color:var(--accent-primary);box-shadow:0 0 5px #00ff414d}.transport-play-btn{width:auto;min-width:38px;height:34px;border-radius:0;background:var(--bg-medium);color:var(--accent-primary);border:1px solid var(--accent-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);box-shadow:0 0 5px #00ff4133;flex-shrink:0;font-family:var(--font-mono);font-weight:700;font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em;padding:0 8px}.transport-play-btn:hover{background:#00ff411a;box-shadow:var(--glow-primary);text-shadow:0 0 5px #00ff41}.transport-play-btn svg{fill:var(--accent-primary);filter:drop-shadow(0 0 3px rgba(0,255,65,.5))}.transport-play-btn.playing{background:#ff003326;border-color:var(--accent-error);color:var(--accent-error);box-shadow:var(--glow-error);animation:phosphor-pulse 1.5s ease-in-out infinite}.transport-play-btn.playing svg{fill:var(--accent-error);filter:drop-shadow(0 0 3px rgba(255,0,51,.5))}.transport-bpm-group .transport-label{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-mono)}.transport-bpm-input{width:60px;background:var(--bg-darkest);color:var(--accent-primary);border:1px solid var(--border-color);border-radius:0;padding:4px 6px;font-family:var(--font-mono);font-size:var(--font-size-lg);font-weight:700;text-align:center;outline:none;-moz-appearance:textfield;text-shadow:0 0 8px rgba(0,255,65,.6)}.transport-bpm-input::-webkit-inner-spin-button,.transport-bpm-input::-webkit-outer-spin-button{-webkit-appearance:none}.transport-bpm-input:focus{border-color:var(--accent-primary);box-shadow:var(--glow-primary)}.transport-tap-btn{background:var(--bg-medium);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:0;padding:4px 10px;font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:700;cursor:pointer;transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:.05em}.transport-tap-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-light)}.transport-tap-btn.tapped{background:var(--accent-primary);color:var(--bg-darkest);text-shadow:none}.transport-vol-group .transport-label{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:600;text-transform:uppercase;font-family:var(--font-mono)}.transport-volume-slider{width:80px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-light);border-radius:0;outline:none;cursor:pointer}.transport-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:14px;border-radius:0;background:var(--accent-primary);cursor:pointer;box-shadow:0 0 6px #00ff4180}.transport-vol-value{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--text-secondary);min-width:30px;text-align:right;text-shadow:0 0 3px rgba(0,255,65,.3)}.transport-mode-group{margin-left:auto}.transport-mode-btn{background:var(--bg-medium);color:var(--text-muted);border:1px solid var(--border-color);padding:4px 12px;font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:700;cursor:pointer;transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:.08em;border-radius:0}.transport-mode-btn:first-child{border-radius:0;border-right:none}.transport-mode-btn:last-child{border-radius:0}.transport-mode-btn.active{background:var(--accent-primary);color:var(--bg-darkest);border-color:var(--accent-primary);text-shadow:none;box-shadow:0 0 8px #00ff414d}.sidebar-tabs{display:flex;border-bottom:1px solid var(--border-color);background:var(--bg-medium);flex-shrink:0}.sidebar-tab{flex:1;padding:8px 0;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-family:var(--font-mono);font-size:var(--font-size-sm);font-weight:600;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;transition:all var(--transition-fast)}.sidebar-tab:hover{color:var(--text-secondary);text-shadow:0 0 5px rgba(0,255,65,.2)}.sidebar-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary);text-shadow:0 0 5px rgba(0,255,65,.4)}.sample-browser{display:flex;flex-direction:column;height:100%;overflow:hidden}.sample-browser .panel-header{flex-shrink:0}.sample-search-wrap{display:flex;align-items:center;gap:6px;padding:8px;background:var(--bg-dark);border-bottom:1px solid var(--border-color);flex-shrink:0}.sample-search-icon{color:var(--text-muted);flex-shrink:0}.sample-search-input{flex:1;background:var(--bg-darkest);color:var(--text-primary);border:1px solid var(--border-color);border-radius:0;padding:5px 8px;font-family:var(--font-mono);font-size:var(--font-size-sm);outline:none;text-shadow:0 0 3px rgba(0,255,65,.2)}.sample-search-input:focus{border-color:var(--accent-primary);box-shadow:0 0 5px #00ff4133}.sample-search-input::placeholder{color:var(--text-muted)}.sample-tree{flex:1;overflow-y:auto;padding:4px 0}.sample-category{margin-bottom:0}.sample-category-header{display:flex;align-items:center;gap:6px;padding:6px 10px;cursor:pointer;color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:600;font-family:var(--font-mono);transition:background var(--transition-fast);text-transform:uppercase;letter-spacing:.05em}.sample-category-header:hover{background:var(--bg-hover);text-shadow:0 0 5px rgba(0,255,65,.3)}.sample-toggle-icon{font-size:8px;color:var(--text-muted);transition:transform var(--transition-fast);width:12px;text-align:center}.sample-category-body{overflow:hidden;transition:max-height var(--transition-normal)}.sample-category-body.collapsed{display:none}.sample-sub-header{padding:4px 10px 4px 28px;font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600;font-family:var(--font-mono)}.sample-item{display:flex;align-items:center;gap:6px;padding:3px 10px 3px 28px;cursor:pointer;transition:background var(--transition-fast);border-left:2px solid transparent}.sample-item:hover{background:var(--bg-hover);border-left-color:var(--accent-primary)}.sample-item.dragging{opacity:.5}.sample-preview-btn{width:20px;height:20px;background:var(--bg-medium);border:1px solid var(--border-color);border-radius:0;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0;padding:0;font-family:var(--font-mono)}.sample-preview-btn:hover{background:#00ff4126;color:var(--accent-primary);border-color:var(--accent-primary)}.sample-preview-btn.playing{background:#00ff4133;color:var(--accent-primary);border-color:var(--accent-primary);box-shadow:0 0 5px #00ff414d}.sample-name{flex:1;font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 0 3px rgba(0,255,65,.15)}.sample-drag-handle{color:var(--text-muted);font-size:var(--font-size-xs);cursor:grab;flex-shrink:0;opacity:0;transition:opacity var(--transition-fast)}.sample-item:hover .sample-drag-handle{opacity:1}.sample-no-results{padding:20px;text-align:center;color:var(--text-muted);font-size:var(--font-size-sm);font-family:var(--font-mono)}.mixer{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--bg-dark)}.mixer .panel-header{flex-shrink:0}.mixer-scroll{display:flex;flex:1;overflow-x:auto;overflow-y:hidden;gap:1px;padding:4px;background:var(--bg-dark);align-items:stretch}.mixer-strip-wrapper{flex-shrink:0}.mixer-add-btn{width:36px;min-height:100%;flex-shrink:0;background:var(--bg-medium);border:1px dashed var(--border-color);border-radius:0;color:var(--text-muted);font-size:var(--font-size-xl);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);font-family:var(--font-mono)}.mixer-add-btn:hover{background:#00ff410d;border-color:var(--accent-primary);border-style:solid;color:var(--accent-primary);box-shadow:0 0 8px #00ff4133}.channel-strip{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 8px;background:var(--bg-medium);border:1px solid var(--border-color);border-radius:0;width:80px;min-height:100%;position:relative;transition:opacity var(--transition-fast)}.channel-strip.muted{opacity:.35}.channel-strip.soloed{box-shadow:inset 0 0 0 1px var(--accent-secondary)}.channel-color-bar{width:100%;height:3px;border-radius:0}.channel-remove-btn{position:absolute;top:2px;right:2px;width:16px;height:16px;background:none;border:none;color:var(--text-muted);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast);padding:0;line-height:1;font-family:var(--font-mono)}.channel-strip:hover .channel-remove-btn{opacity:1}.channel-remove-btn:hover{color:var(--accent-error);text-shadow:0 0 5px rgba(255,0,51,.5)}.channel-name{font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:600;color:var(--text-primary);text-align:center;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:default;text-transform:uppercase;text-shadow:0 0 3px rgba(0,255,65,.2)}.channel-name-input{width:100%;background:var(--bg-darkest);color:var(--text-primary);border:1px solid var(--accent-primary);border-radius:0;padding:1px 3px;font-family:var(--font-mono);font-size:var(--font-size-xs);text-align:center;outline:none;text-transform:uppercase}.channel-sound-select{width:100%;background:var(--bg-darkest);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:0;padding:2px 3px;font-family:var(--font-mono);font-size:var(--font-size-xs);cursor:pointer;outline:none}.channel-sound-select:focus{border-color:var(--accent-primary);box-shadow:0 0 3px #00ff414d}.channel-fader-container{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1;width:100%}.channel-fader-label{font-size:8px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-family:var(--font-mono)}.channel-fader-track{position:relative;width:var(--fader-width);height:70px;background:var(--bg-darkest);border:1px solid var(--border-color);border-radius:0;cursor:pointer;touch-action:none}.channel-fader-fill{position:absolute;bottom:0;left:0;width:100%;background:var(--accent-primary);border-radius:0;opacity:.7;transition:background var(--transition-fast);box-shadow:0 0 5px #00ff414d}.channel-fader-thumb{position:absolute;left:50%;transform:translate(-50%);width:var(--fader-thumb-width);height:var(--fader-thumb-height);background:var(--accent-primary);border-radius:0;box-shadow:0 0 5px #00ff4166;pointer-events:none;border:1px solid rgba(0,255,65,.6)}.channel-fader-value{font-family:var(--font-mono);font-size:9px;color:var(--text-secondary);text-shadow:0 0 3px rgba(0,255,65,.2)}.channel-knob-container{display:flex;flex-direction:column;align-items:center;gap:1px}.channel-knob-label{font-size:8px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-family:var(--font-mono)}.channel-knob-svg{cursor:pointer;touch-action:none;filter:drop-shadow(0 0 2px rgba(0,255,65,.2))}.channel-knob-svg:hover circle:last-of-type{fill:var(--bg-hover)}.channel-knob-value{font-family:var(--font-mono);font-size:9px;color:var(--text-secondary)}.channel-btn-group{display:flex;gap:2px;width:100%}.channel-mute-btn,.channel-solo-btn{flex:1;padding:3px 0;background:var(--bg-darkest);border:1px solid var(--border-color);border-radius:0;font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:700;cursor:pointer;transition:all var(--transition-fast);text-transform:uppercase}.channel-mute-btn{color:var(--text-muted)}.channel-mute-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.channel-mute-btn.active{background:var(--accent-error);color:#000;border-color:var(--accent-error);box-shadow:0 0 5px #f036;text-shadow:none}.channel-solo-btn{color:var(--text-muted)}.channel-solo-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.channel-solo-btn.active{background:var(--accent-secondary);color:#000;border-color:var(--accent-secondary);box-shadow:0 0 5px #ffb00066;text-shadow:none}.pattern-builder{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--bg-darkest);position:relative}.pattern-builder .panel-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between}.pattern-step-selector{display:flex;gap:2px}.pattern-step-btn{background:var(--bg-medium);color:var(--text-muted);border:1px solid var(--border-color);border-radius:0;padding:2px 8px;font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:700;cursor:pointer;transition:all var(--transition-fast)}.pattern-step-btn:hover{background:var(--bg-hover);border-color:var(--border-light)}.pattern-step-btn.active{background:var(--accent-primary);color:#000;border-color:var(--accent-primary);box-shadow:0 0 5px #00ff414d;text-shadow:none}.pattern-grid-wrapper{flex:1;overflow:auto;padding:8px}.pattern-grid{display:grid;gap:2px;min-width:fit-content}.pattern-cell{display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);-webkit-user-select:none;user-select:none}.pattern-corner{background:transparent}.pattern-step-header{background:var(--bg-dark);color:var(--text-muted);border-radius:0;font-family:var(--font-mono);font-size:9px;font-weight:600}.pattern-step-header.beat-marker{color:var(--text-secondary);background:var(--bg-medium);text-shadow:0 0 3px rgba(0,255,65,.2)}.pattern-step-header.current-step{background:#00ff4126;color:var(--accent-primary);text-shadow:0 0 5px rgba(0,255,65,.6);box-shadow:inset 0 -2px 0 var(--accent-primary)}.pattern-row-label{display:flex;align-items:center;gap:6px;padding:0 8px;background:var(--bg-dark);border-radius:0;overflow:hidden;border-right:1px solid var(--border-color)}.pattern-row-label.muted{opacity:.3}.pattern-row-color{width:6px;height:6px;border-radius:0;flex-shrink:0;box-shadow:0 0 3px currentColor}.pattern-row-name{font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;text-transform:uppercase;text-shadow:0 0 3px rgba(0,255,65,.15)}.pattern-step{background:var(--bg-medium);border-radius:0;cursor:pointer;transition:all 50ms ease;min-height:28px;border:1px solid rgba(26,58,26,.3)}.pattern-step:hover{background:var(--bg-hover);border-color:#00ff4126}.pattern-step.beat-start{border-left:2px solid var(--border-color)}.pattern-step.active{border-radius:0;box-shadow:0 0 5px #00ff414d,inset 0 0 5px #00ff411a}.pattern-step.current-step{outline:1px solid rgba(0,255,65,.4);outline-offset:-1px;background:#00ff410d!important}.pattern-step.active.current-step{box-shadow:0 0 10px #00ff4180,0 0 20px #00ff4133;filter:brightness(1.3)}.pattern-empty{padding:40px 20px;text-align:center;color:var(--text-muted);font-size:var(--font-size-sm);font-family:var(--font-mono)}.pattern-euclidean-area{flex-shrink:0;border-top:1px solid var(--border-color);background:var(--bg-dark);padding:4px 8px;max-height:120px;overflow-y:auto}.euclidean-header{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:4px 0;font-weight:600;font-family:var(--font-mono)}.euclidean-row{display:flex;align-items:center;gap:8px;padding:2px 0}.euclidean-label{font-size:var(--font-size-xs);font-weight:600;min-width:50px;font-family:var(--font-mono);color:var(--text-primary)}.euclidean-param-label{font-size:var(--font-size-xs);color:var(--text-muted);font-family:var(--font-mono)}.euclidean-slider{width:80px;height:3px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-light);border-radius:0;outline:none;cursor:pointer}.euclidean-slider::-webkit-slider-thumb{-webkit-appearance:none;width:8px;height:12px;border-radius:0;background:var(--accent-primary);cursor:pointer;box-shadow:0 0 3px #00ff4166}.euclidean-value{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--text-secondary);min-width:16px;text-align:center}.euclidean-apply-btn{background:var(--bg-medium);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:0;padding:2px 8px;font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-mono);text-transform:uppercase}.euclidean-apply-btn:hover{background:var(--accent-primary);color:#000;border-color:var(--accent-primary);box-shadow:0 0 5px #00ff414d}.pattern-row-label.melodic-label{background:linear-gradient(90deg,rgba(0,255,255,.05) 0%,var(--bg-dark) 100%);border-right-color:#0ff3}.pattern-row-type{font-size:7px;font-family:var(--font-mono);font-weight:700;letter-spacing:.08em;padding:1px 3px;border-radius:0;background:#00ff4114;color:var(--text-muted);flex-shrink:0;text-transform:uppercase;border:1px solid rgba(0,255,65,.1)}.pattern-row-type.melodic-badge{background:#00ffff1a;color:var(--accent-tertiary);border-color:#00ffff26}.pattern-step-melodic{background:#00ffff05;font-size:8px;font-family:var(--font-mono);font-weight:600;color:var(--text-muted);-webkit-user-select:none;user-select:none;overflow:hidden;padding:0 1px;border:1px solid rgba(0,255,255,.05)}.pattern-step-melodic:hover{background:#00ffff14;border-color:#00ffff26}.pattern-step-melodic.active{border-radius:0;font-weight:700;box-shadow:0 0 5px #00ffff4d}.melodic-note-label{display:block;text-align:center;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2;pointer-events:none;z-index:1;position:relative}.pattern-step-melodic:not(.active) .melodic-note-label{color:var(--text-muted);opacity:.5}.pattern-step-melodic.active .melodic-note-label{color:#000;text-shadow:0 0 3px rgba(0,255,255,.5)}.note-picker{position:absolute;z-index:var(--z-overlay);background:var(--bg-dark);border:1px solid var(--border-light);border-radius:0;box-shadow:var(--shadow-lg),0 0 15px #00ff411a;padding:6px;min-width:180px;max-width:220px}.note-picker-rest{display:block;width:100%;padding:5px 8px;margin-bottom:6px;font-size:var(--font-size-xs);font-family:var(--font-mono);font-weight:500;background:var(--bg-medium);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:0;cursor:pointer;text-align:center;transition:all var(--transition-fast);text-transform:uppercase}.note-picker-rest:hover{background:var(--accent-error);color:#000;border-color:var(--accent-error);box-shadow:0 0 5px #ff00334d}.note-picker-octave-row{display:flex;align-items:center;gap:3px;margin-bottom:6px}.note-picker-label{font-size:9px;font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;margin-right:2px;flex-shrink:0}.note-picker-octave-btn{flex:1;padding:3px 0;font-size:9px;font-family:var(--font-mono);font-weight:600;background:var(--bg-medium);color:var(--text-muted);border:1px solid var(--border-color);border-radius:0;cursor:pointer;transition:all var(--transition-fast);text-align:center}.note-picker-octave-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.note-picker-octave-btn.active{background:var(--accent-tertiary);color:#000;border-color:var(--accent-tertiary);box-shadow:0 0 5px #00ffff4d}.note-picker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}.note-picker-note-btn{padding:5px 2px;font-size:9px;font-family:var(--font-mono);font-weight:600;background:var(--bg-medium);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:0;cursor:pointer;transition:all var(--transition-fast);text-align:center;white-space:nowrap}.note-picker-note-btn:hover{background:var(--accent-tertiary);color:#000;border-color:var(--accent-tertiary)}.note-picker-note-btn.sharp{background:var(--bg-darkest);color:var(--text-muted)}.note-picker-note-btn.sharp:hover{background:var(--accent-tertiary);color:#000}.note-picker-note-btn.active{background:var(--accent-primary);color:#000;border-color:var(--accent-primary);box-shadow:0 0 6px #00ff4166}.effect-rack{display:flex;flex-direction:column;height:100%;overflow:hidden}.effect-rack .panel-header{flex-shrink:0}.effect-channel-tabs{display:flex;overflow-x:auto;gap:0;background:var(--bg-dark);border-bottom:1px solid var(--border-color);flex-shrink:0}.effect-channel-tab{padding:6px 10px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:.05em}.effect-channel-tab:hover{color:var(--text-secondary);text-shadow:0 0 3px rgba(0,255,65,.2)}.effect-channel-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary);text-shadow:0 0 5px rgba(0,255,65,.3)}.effect-blocks{flex:1;overflow-y:auto;padding:4px}.effect-empty{padding:20px;text-align:center;color:var(--text-muted);font-size:var(--font-size-sm);font-family:var(--font-mono)}.effect-block{background:var(--bg-medium);border:1px solid var(--border-color);border-radius:0;margin-bottom:4px;overflow:hidden;transition:border-color var(--transition-fast)}.effect-block:hover{border-color:var(--border-light)}.effect-block-title{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:var(--bg-light);cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--border-color)}.effect-block-title span{font-size:var(--font-size-sm);font-weight:700;color:var(--accent-secondary);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;text-shadow:0 0 5px rgba(255,176,0,.3)}.effect-collapse-btn{background:none;border:none;color:var(--text-muted);font-size:10px;cursor:pointer;padding:0 2px;transition:transform var(--transition-fast);font-family:var(--font-mono)}.effect-knob-area{display:flex;flex-wrap:wrap;gap:8px;padding:8px 10px;justify-content:center}.effect-knob-area.collapsed{display:none}.effect-knob-wrapper{display:flex;flex-direction:column;align-items:center;gap:2px}.effect-knob-wrapper.large{width:100%}.effect-knob-wrapper.large .effect-knob-svg{display:block;margin:0 auto}.effect-knob-label{font-size:8px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-mono)}.effect-knob-svg{cursor:pointer;touch-action:none;filter:drop-shadow(0 0 2px rgba(0,255,65,.15))}.effect-knob-svg.dragging{cursor:grabbing}.effect-knob-value{font-family:var(--font-mono);font-size:9px;color:var(--text-secondary);text-shadow:0 0 3px rgba(0,255,65,.2)}.code-panel{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--bg-darkest)}.code-panel-header{display:flex;align-items:center;justify-content:space-between}.code-panel-controls{display:flex;align-items:center;gap:6px}.code-sync-badge{font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:700;padding:2px 6px;border-radius:0;text-transform:uppercase;letter-spacing:.05em}.code-sync-badge.synced{background:#00ff411a;color:var(--accent-primary);border:1px solid rgba(0,255,65,.25);text-shadow:0 0 3px rgba(0,255,65,.3)}.code-sync-badge.desynced{background:#ffb0001a;color:var(--accent-secondary);border:1px solid rgba(255,176,0,.25);text-shadow:0 0 3px rgba(255,176,0,.3)}.code-eval-btn{background:#00ff411a;color:var(--accent-primary);border:1px solid rgba(0,255,65,.3);border-radius:0;padding:4px 10px;font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:700;cursor:pointer;transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:.05em}.code-eval-btn:hover{background:#00ff4133;box-shadow:0 0 8px #00ff414d}.code-eval-btn.success{background:var(--accent-primary);color:#000}.code-eval-btn.error{background:var(--accent-error);color:#000;border-color:var(--accent-error)}.code-sync-btn{background:var(--bg-medium);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:0;padding:3px 8px;font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-mono);text-transform:uppercase}.code-sync-btn:hover{background:var(--bg-hover);border-color:var(--border-light)}.code-editor-area{flex:1;overflow:hidden;position:relative}.code-panel .CodeMirror{height:100%!important;font-family:var(--font-mono)!important;font-size:14px!important;background:var(--bg-darkest)!important;color:var(--text-primary)!important}.code-panel .CodeMirror-gutters{background:var(--bg-dark)!important;border-right:1px solid var(--border-color)!important}.code-panel .CodeMirror-linenumber{color:var(--text-muted)!important}.code-panel .CodeMirror-cursor,.code-editor-area .CodeMirror-cursor{border-left:2px solid var(--accent-primary)!important;box-shadow:0 0 5px #00ff4180}.code-panel .CodeMirror-selected,.code-editor-area .CodeMirror-selected{background:#00ff4126!important}.code-panel .CodeMirror-activeline-background,.code-editor-area .CodeMirror-activeline-background{background:#00ff4108!important}.visualizer-panel{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--bg-darkest)}.visualizer-tabs{display:flex;gap:1px;padding:4px;background:var(--bg-dark);border-bottom:1px solid var(--border-color);flex-shrink:0}.visualizer-tab{background:var(--bg-medium);color:var(--text-muted);border:1px solid var(--border-color);border-radius:0;padding:3px 10px;font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:.05em}.visualizer-tab:hover{background:var(--bg-hover);color:var(--text-secondary)}.visualizer-tab.active{background:#00ff4126;color:var(--accent-primary);border-color:#00ff414d;text-shadow:0 0 5px rgba(0,255,65,.3)}.visualizer-canvas{flex:1;width:100%;display:block;filter:drop-shadow(0 0 2px rgba(0,255,65,.15))}.preset-library{display:flex;flex-direction:column;height:100%;overflow:hidden}.preset-library .panel-header{flex-shrink:0}.preset-save-area{display:flex;gap:4px;padding:8px;background:var(--bg-dark);border-bottom:1px solid var(--border-color);flex-shrink:0}.preset-save-input{flex:1;background:var(--bg-darkest);color:var(--text-primary);border:1px solid var(--border-color);border-radius:0;padding:4px 8px;font-family:var(--font-mono);font-size:var(--font-size-sm);outline:none}.preset-save-input:focus{border-color:var(--accent-primary);box-shadow:0 0 5px #00ff4133}.preset-save-input::placeholder{color:var(--text-muted)}.preset-save-btn{background:#00ff411a;color:var(--accent-primary);border:1px solid rgba(0,255,65,.3);border-radius:0;padding:4px 12px;font-family:var(--font-mono);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;text-transform:uppercase}.preset-save-btn:hover{background:#00ff4133;box-shadow:0 0 5px #00ff414d}.preset-save-btn.success{background:var(--accent-primary);color:#000}.preset-grid{flex:1;overflow-y:auto;padding:8px}.preset-section-header{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600;padding:8px 0 4px;border-bottom:1px solid var(--border-color);margin-bottom:6px;font-family:var(--font-mono)}.preset-section-header:before{content:"// ";color:var(--text-muted)}.preset-card{background:var(--bg-medium);border:1px solid var(--border-color);border-radius:0;padding:8px 10px;margin-bottom:6px;cursor:pointer;transition:all var(--transition-fast)}.preset-card:hover{background:var(--bg-hover);border-color:var(--border-light);box-shadow:0 0 5px #00ff411a}.preset-card-name{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);margin-bottom:4px;font-family:var(--font-mono);text-transform:uppercase;text-shadow:0 0 3px rgba(0,255,65,.2)}.preset-card-meta{display:flex;gap:6px;margin-bottom:4px}.preset-genre-tag{font-size:var(--font-size-xs);color:var(--accent-tertiary);background:#00ffff14;padding:1px 6px;border-radius:0;border:1px solid rgba(0,255,255,.15);font-family:var(--font-mono);text-transform:uppercase}.preset-bpm-tag{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--text-muted)}.preset-card-actions{display:flex;gap:4px}.preset-load-btn{background:var(--bg-light);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:0;padding:2px 8px;font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-mono);text-transform:uppercase}.preset-load-btn:hover{background:#00ff4126;color:var(--accent-primary);border-color:#00ff414d}.preset-delete-btn{background:none;color:var(--text-muted);border:1px solid transparent;border-radius:0;padding:2px 8px;font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-mono);text-transform:uppercase}.preset-delete-btn:hover{color:var(--accent-error);border-color:var(--accent-error);text-shadow:0 0 5px rgba(255,0,51,.3)}#app.loading:after{content:"> INITIALIZING HEIMDALL...";position:fixed;top:0;left:0;right:0;bottom:0;background:#020502;color:var(--accent-primary);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:var(--font-size-lg);font-weight:700;letter-spacing:.15em;text-transform:uppercase;z-index:9999;text-shadow:var(--glow-intense);animation:glow-pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.channel-strip.drop-target{outline:2px solid var(--accent-primary);outline-offset:-2px;box-shadow:inset 0 0 15px #00ff4126,0 0 10px #00ff414d;background:#00ff410d}.pattern-row-label.drop-target{outline:2px solid var(--accent-primary);outline-offset:-2px;box-shadow:inset 0 0 10px #00ff411a,0 0 8px #00ff4140;background:#00ff410d}.mixer-add-btn.drop-target{border-color:var(--accent-primary);border-style:solid;background:#00ff4114;color:var(--accent-primary);box-shadow:0 0 15px #00ff414d}.mixer-scroll.drop-target{box-shadow:inset 0 0 20px #00ff4114;background:#00ff4105}#boot-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#000;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:10vh 12vw;overflow:hidden;box-shadow:inset 0 0 80px #00ff4108,inset 0 0 200px #000c}#boot-screen:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(to bottom,transparent 0px,transparent 2px,rgba(0,0,0,.15) 2px,rgba(0,0,0,.15) 3px);pointer-events:none;z-index:2}#boot-screen:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");background-size:256px 256px;pointer-events:none;z-index:1;opacity:.5}#boot-text{font-family:JetBrains Mono,Courier New,monospace;font-size:14px;line-height:1.7;color:#00ff41;white-space:pre;position:relative;z-index:3;text-shadow:0 0 4px rgba(0,255,65,.6),0 0 12px rgba(0,255,65,.3),0 0 30px rgba(0,255,65,.1);max-height:60vh;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}#boot-text::-webkit-scrollbar{display:none}.boot-progress{color:#0c3;text-shadow:0 0 4px rgba(0,204,51,.5),0 0 10px rgba(0,204,51,.2)}.boot-percent{color:#00ff41;font-weight:700}#boot-cursor{display:inline-block;font-family:JetBrains Mono,Courier New,monospace;font-size:14px;color:#00ff41;position:relative;z-index:3;text-shadow:0 0 4px rgba(0,255,65,.6),0 0 12px rgba(0,255,65,.3)}#boot-cursor.blink{animation:boot-cursor-blink .6s step-end infinite}@keyframes boot-cursor-blink{0%,50%{opacity:1}51%,to{opacity:0}}.boot-flash{animation:boot-flash-anim 80ms ease-out}@keyframes boot-flash-anim{0%{filter:brightness(1)}50%{filter:brightness(2.5);background:#00ff410a}to{filter:brightness(1)}}.boot-dismiss{animation:boot-powerdown .6s ease-in forwards}@keyframes boot-powerdown{0%{opacity:1;transform:scale(1) scaleY(1);filter:brightness(1)}30%{opacity:1;transform:scale(1) scaleY(1);filter:brightness(2)}60%{opacity:1;transform:scale(1.02) scaleY(.005);filter:brightness(3)}80%{opacity:.8;transform:scale(.5) scaleY(.002);filter:brightness(2)}to{opacity:0;transform:scale(0) scaleY(0);filter:brightness(0)}}.crt-power-on{animation:crt-power-on-anim .8s ease-out}@keyframes crt-power-on-anim{0%{opacity:0;filter:brightness(0);transform:scaleY(.005) scaleX(.8)}20%{opacity:1;filter:brightness(2);transform:scaleY(.005) scaleX(1)}40%{opacity:1;filter:brightness(1.5);transform:scaleY(.8) scaleX(1)}70%{filter:brightness(1.2);transform:scaleY(1.02) scaleX(1)}to{opacity:1;filter:brightness(1);transform:scaleY(1) scaleX(1)}}#crt-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;pointer-events:none;background:repeating-linear-gradient(to bottom,transparent 0px,transparent 2px,rgba(0,0,0,.06) 2px,rgba(0,0,0,.06) 4px);-webkit-mask-image:none;mask-image:none}#crt-overlay:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;box-shadow:inset 0 0 100px #00000059,inset 0 0 250px #00000026;pointer-events:none}#crt-overlay.crt-glitch-active{animation:crt-overlay-glitch .15s steps(4) forwards}@keyframes crt-overlay-glitch{0%{background-position:0 0;filter:none}25%{background-position:2px -3px;filter:hue-rotate(40deg) saturate(2)}50%{background-position:-1px 2px;filter:hue-rotate(-20deg) brightness(1.2)}75%{background-position:3px -1px;filter:hue-rotate(60deg) saturate(1.5)}to{background-position:0 0;filter:none}}.glitching{animation:glitch-anim .2s steps(3) forwards;position:relative}@keyframes glitch-anim{0%{transform:translate(0) skew(0);filter:none;clip-path:none}15%{transform:translate(var(--glitch-translate-x, 3px),-1px) skew(var(--glitch-skew-x, 2deg),var(--glitch-skew-y, 0deg));filter:hue-rotate(30deg) saturate(1.5);clip-path:inset(20% 0 30% 0)}30%{transform:translate(calc(var(--glitch-translate-x, 3px) * -.5),2px) skew(0);filter:hue-rotate(-20deg) brightness(1.3);clip-path:inset(60% 0 5% 0)}45%{transform:translate(var(--glitch-translate-x, 3px)) skew(calc(var(--glitch-skew-x, 2deg) * -1));filter:saturate(2) contrast(1.2);clip-path:inset(10% 0 50% 0)}60%{transform:translate(-1px,1px) skew(0);filter:hue-rotate(10deg);clip-path:inset(40% 0 20% 0)}80%{transform:translate(1px,-1px) skew(0);filter:brightness(1.1);clip-path:none}to{transform:translate(0) skew(0);filter:none;clip-path:none}}.glitching:before,.glitching:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9998}.glitching:before{background:#ff00000a;transform:translate(-2px);mix-blend-mode:screen;animation:glitch-chromatic-r .2s steps(2) forwards}.glitching:after{background:#00ffff0a;transform:translate(2px);mix-blend-mode:screen;animation:glitch-chromatic-c .2s steps(2) forwards}@keyframes glitch-chromatic-r{0%{transform:translate(0);opacity:0}20%{transform:translate(-3px,1px);opacity:1}60%{transform:translate(2px,-1px);opacity:.6}to{transform:translate(0);opacity:0}}@keyframes glitch-chromatic-c{0%{transform:translate(0);opacity:0}20%{transform:translate(3px,-1px);opacity:1}60%{transform:translate(-2px,1px);opacity:.6}to{transform:translate(0);opacity:0}}.glow-text{text-shadow:0 0 5px #00ff41,0 0 10px #00ff41,0 0 20px #00ff41,0 0 40px #00aa28}.glow-text-dim{text-shadow:0 0 3px rgba(0,255,65,.4),0 0 8px rgba(0,255,65,.2)}.glow-text-amber{text-shadow:0 0 5px #ffb000,0 0 10px #ffb000,0 0 20px rgba(255,176,0,.5)}.glow-text-cyan{text-shadow:0 0 5px #00ffff,0 0 10px #00ffff,0 0 20px rgba(0,255,255,.5)}.glow-text-red{text-shadow:0 0 5px #ff0033,0 0 10px #ff0033,0 0 20px rgba(255,0,51,.5)}.glitch-hover:hover{animation:glitch-anim .3s ease-in-out}.glitch-always{animation:glitch-anim 4s ease-in-out infinite}.chromatic-text{animation:chromatic-shift 8s ease-in-out infinite}@keyframes chromatic-shift{0%{text-shadow:0 0 5px #00ff41}25%{text-shadow:-1px 0 #ff0033,1px 0 #00ffff,0 0 5px #00ff41}50%{text-shadow:0 0 5px #00ff41}75%{text-shadow:1px 0 #ff0033,-1px 0 #00ffff,0 0 5px #00ff41}to{text-shadow:0 0 5px #00ff41}}.terminal-cursor:after{content:"_";animation:cursor-blink 1s step-end infinite;color:var(--accent-primary);text-shadow:0 0 5px rgba(0,255,65,.5);font-weight:700}.block-cursor:after{content:"█";animation:cursor-blink 1s step-end infinite;color:var(--accent-primary);text-shadow:0 0 5px rgba(0,255,65,.5)}.crt-hover-glow:hover{border-color:#00ff414d!important;box-shadow:0 0 10px #00ff411a,inset 0 0 10px #00ff4105}.crt-active-glow{border-color:#00ff4166!important;box-shadow:0 0 15px #00ff4126,inset 0 0 15px #00ff4108}.crt-amber-glow{border-color:#ffb0004d!important;box-shadow:0 0 10px #ffb0001a,inset 0 0 10px #ffb00005}@keyframes phosphor-fade-in{0%{opacity:0;filter:brightness(3) blur(2px);color:#fff}30%{opacity:.7;filter:brightness(1.5) blur(.5px);color:#8f8}to{opacity:1;filter:brightness(1) blur(0);color:var(--accent-primary)}}.phosphor-fade-in{animation:phosphor-fade-in .6s ease-out forwards}@keyframes step-flash{0%{box-shadow:0 0 8px #00ff4199,inset 0 0 8px #00ff4126}to{box-shadow:0 0 3px #00ff4133,inset 0 0 3px #00ff410d}}.step-active-flash{animation:step-flash .15s ease-out}.boot-text{font-family:var(--font-mono);font-size:var(--font-size-md);color:var(--accent-primary);text-shadow:0 0 5px rgba(0,255,65,.5);letter-spacing:.1em;text-transform:uppercase}.boot-text-dim{color:var(--text-muted);text-shadow:none}.boot-text-amber{color:var(--accent-secondary);text-shadow:0 0 5px rgba(255,176,0,.3)}.boot-text-error{color:var(--accent-error);text-shadow:0 0 5px rgba(255,0,51,.3)}.terminal-box-header{font-family:var(--font-mono);font-weight:700;font-size:var(--font-size-sm);color:var(--accent-secondary);text-transform:uppercase;letter-spacing:.12em;text-shadow:0 0 5px rgba(255,176,0,.3)}.terminal-prompt:before{content:"> ";color:var(--text-muted)}.visualizer-canvas-wrapper{flex:1;position:relative;overflow:hidden;min-height:0;background:#000}.visualizer-canvas-wrapper .visualizer-canvas{display:block;width:100%;height:100%}@media (max-width: 1200px){#crt-overlay{background:repeating-linear-gradient(to bottom,transparent 0px,transparent 3px,rgba(0,0,0,.04) 3px,rgba(0,0,0,.04) 6px)}}@media (prefers-reduced-motion: reduce){body{animation:none!important}body:before{animation:none!important}.transport-logo .logo-text:hover,.transport-play-btn.playing,.glitch-hover:hover,.glitch-always,.chromatic-text,.glitching,#boot-screen,.boot-dismiss,.crt-power-on{animation:none!important}.phosphor-fade-in{animation:none!important;opacity:1;filter:none}}.CodeMirror{font-family:monospace;height:300px;color:#000;direction:ltr}.CodeMirror-lines{padding:4px 0}.CodeMirror pre.CodeMirror-line,.CodeMirror pre.CodeMirror-line-like{padding:0 4px}.CodeMirror-scrollbar-filler,.CodeMirror-gutter-filler{background-color:#fff}.CodeMirror-gutters{border-right:1px solid #ddd;background-color:#f7f7f7;white-space:nowrap}.CodeMirror-linenumber{padding:0 3px 0 5px;min-width:20px;text-align:right;color:#999;white-space:nowrap}.CodeMirror-guttermarker{color:#000}.CodeMirror-guttermarker-subtle{color:#999}.CodeMirror-cursor{border-left:1px solid black;border-right:none;width:0}.CodeMirror div.CodeMirror-secondarycursor{border-left:1px solid silver}.cm-fat-cursor .CodeMirror-cursor{width:auto;border:0!important;background:#7e7}.cm-fat-cursor div.CodeMirror-cursors{z-index:1}.cm-fat-cursor .CodeMirror-line::selection,.cm-fat-cursor .CodeMirror-line>span::selection,.cm-fat-cursor .CodeMirror-line>span>span::selection{background:transparent}.cm-fat-cursor .CodeMirror-line::-moz-selection,.cm-fat-cursor .CodeMirror-line>span::-moz-selection,.cm-fat-cursor .CodeMirror-line>span>span::-moz-selection{background:transparent}.cm-fat-cursor{caret-color:transparent}@-moz-keyframes blink{50%{background-color:transparent}}@-webkit-keyframes blink{50%{background-color:transparent}}@keyframes blink{50%{background-color:transparent}}.cm-tab{display:inline-block;text-decoration:inherit}.CodeMirror-rulers{position:absolute;left:0;right:0;top:-50px;bottom:0;overflow:hidden}.CodeMirror-ruler{border-left:1px solid #ccc;top:0;bottom:0;position:absolute}.cm-s-default .cm-header{color:#00f}.cm-s-default .cm-quote{color:#090}.cm-negative{color:#d44}.cm-positive{color:#292}.cm-header,.cm-strong{font-weight:700}.cm-em{font-style:italic}.cm-link{text-decoration:underline}.cm-strikethrough{text-decoration:line-through}.cm-s-default .cm-keyword{color:#708}.cm-s-default .cm-atom{color:#219}.cm-s-default .cm-number{color:#164}.cm-s-default .cm-def{color:#00f}.cm-s-default .cm-variable-2{color:#05a}.cm-s-default .cm-variable-3,.cm-s-default .cm-type{color:#085}.cm-s-default .cm-comment{color:#a50}.cm-s-default .cm-string{color:#a11}.cm-s-default .cm-string-2{color:#f50}.cm-s-default .cm-meta,.cm-s-default .cm-qualifier{color:#555}.cm-s-default .cm-builtin{color:#30a}.cm-s-default .cm-bracket{color:#997}.cm-s-default .cm-tag{color:#170}.cm-s-default .cm-attribute{color:#00c}.cm-s-default .cm-hr{color:#999}.cm-s-default .cm-link{color:#00c}.cm-s-default .cm-error,.cm-invalidchar{color:red}.CodeMirror-composing{border-bottom:2px solid}div.CodeMirror span.CodeMirror-matchingbracket{color:#0b0}div.CodeMirror span.CodeMirror-nonmatchingbracket{color:#a22}.CodeMirror-matchingtag{background:#ff96004d}.CodeMirror-activeline-background{background:#e8f2ff}.CodeMirror{position:relative;overflow:hidden;background:#fff}.CodeMirror-scroll{overflow:scroll!important;margin-bottom:-50px;margin-right:-50px;padding-bottom:50px;height:100%;outline:none;position:relative;z-index:0}.CodeMirror-sizer{position:relative;border-right:50px solid transparent}.CodeMirror-vscrollbar,.CodeMirror-hscrollbar,.CodeMirror-scrollbar-filler,.CodeMirror-gutter-filler{position:absolute;z-index:6;display:none;outline:none}.CodeMirror-vscrollbar{right:0;top:0;overflow-x:hidden;overflow-y:scroll}.CodeMirror-hscrollbar{bottom:0;left:0;overflow-y:hidden;overflow-x:scroll}.CodeMirror-scrollbar-filler{right:0;bottom:0}.CodeMirror-gutter-filler{left:0;bottom:0}.CodeMirror-gutters{position:absolute;left:0;top:0;min-height:100%;z-index:3}.CodeMirror-gutter{white-space:normal;height:100%;display:inline-block;vertical-align:top;margin-bottom:-50px}.CodeMirror-gutter-wrapper{position:absolute;z-index:4;background:none!important;border:none!important}.CodeMirror-gutter-background{position:absolute;top:0;bottom:0;z-index:4}.CodeMirror-gutter-elt{position:absolute;cursor:default;z-index:4}.CodeMirror-gutter-wrapper ::selection{background-color:transparent}.CodeMirror-gutter-wrapper ::-moz-selection{background-color:transparent}.CodeMirror-lines{cursor:text;min-height:1px}.CodeMirror pre.CodeMirror-line,.CodeMirror pre.CodeMirror-line-like{-moz-border-radius:0;-webkit-border-radius:0;border-radius:0;border-width:0;background:transparent;font-family:inherit;font-size:inherit;margin:0;white-space:pre;word-wrap:normal;line-height:inherit;color:inherit;z-index:2;position:relative;overflow:visible;-webkit-tap-highlight-color:transparent;-webkit-font-variant-ligatures:contextual;font-variant-ligatures:contextual}.CodeMirror-wrap pre.CodeMirror-line,.CodeMirror-wrap pre.CodeMirror-line-like{word-wrap:break-word;white-space:pre-wrap;word-break:normal}.CodeMirror-linebackground{position:absolute;left:0;right:0;top:0;bottom:0;z-index:0}.CodeMirror-linewidget{position:relative;z-index:2;padding:.1px}.CodeMirror-rtl pre{direction:rtl}.CodeMirror-code{outline:none}.CodeMirror-scroll,.CodeMirror-sizer,.CodeMirror-gutter,.CodeMirror-gutters,.CodeMirror-linenumber{-moz-box-sizing:content-box;box-sizing:content-box}.CodeMirror-measure{position:absolute;width:100%;height:0;overflow:hidden;visibility:hidden}.CodeMirror-cursor{position:absolute;pointer-events:none}.CodeMirror-measure pre{position:static}div.CodeMirror-cursors{visibility:hidden;position:relative;z-index:3}div.CodeMirror-dragcursors,.CodeMirror-focused div.CodeMirror-cursors{visibility:visible}.CodeMirror-selected{background:#d9d9d9}.CodeMirror-focused .CodeMirror-selected{background:#d7d4f0}.CodeMirror-crosshair{cursor:crosshair}.CodeMirror-line::selection,.CodeMirror-line>span::selection,.CodeMirror-line>span>span::selection{background:#d7d4f0}.CodeMirror-line::-moz-selection,.CodeMirror-line>span::-moz-selection,.CodeMirror-line>span>span::-moz-selection{background:#d7d4f0}.cm-searching{background-color:#ffa;background-color:#ff06}.cm-force-border{padding-right:.1px}@media print{.CodeMirror div.CodeMirror-cursors{visibility:hidden}}.cm-tab-wrap-hack:after{content:""}span.CodeMirror-selectedtext{background:none}.cm-s-dracula.CodeMirror,.cm-s-dracula .CodeMirror-gutters{background-color:#282a36!important;color:#f8f8f2!important;border:none}.cm-s-dracula .CodeMirror-gutters{color:#282a36}.cm-s-dracula .CodeMirror-cursor{border-left:solid thin #f8f8f0}.cm-s-dracula .CodeMirror-linenumber{color:#6d8a88}.cm-s-dracula .CodeMirror-selected{background:#ffffff1a}.cm-s-dracula .CodeMirror-line::selection,.cm-s-dracula .CodeMirror-line>span::selection,.cm-s-dracula .CodeMirror-line>span>span::selection{background:#ffffff1a}.cm-s-dracula .CodeMirror-line::-moz-selection,.cm-s-dracula .CodeMirror-line>span::-moz-selection,.cm-s-dracula .CodeMirror-line>span>span::-moz-selection{background:#ffffff1a}.cm-s-dracula span.cm-comment{color:#6272a4}.cm-s-dracula span.cm-string,.cm-s-dracula span.cm-string-2{color:#f1fa8c}.cm-s-dracula span.cm-number{color:#bd93f9}.cm-s-dracula span.cm-variable{color:#50fa7b}.cm-s-dracula span.cm-variable-2{color:#fff}.cm-s-dracula span.cm-def{color:#50fa7b}.cm-s-dracula span.cm-operator,.cm-s-dracula span.cm-keyword{color:#ff79c6}.cm-s-dracula span.cm-atom{color:#bd93f9}.cm-s-dracula span.cm-meta{color:#f8f8f2}.cm-s-dracula span.cm-tag{color:#ff79c6}.cm-s-dracula span.cm-attribute,.cm-s-dracula span.cm-qualifier{color:#50fa7b}.cm-s-dracula span.cm-property{color:#66d9ef}.cm-s-dracula span.cm-builtin{color:#50fa7b}.cm-s-dracula span.cm-variable-3,.cm-s-dracula span.cm-type{color:#ffb86c}.cm-s-dracula .CodeMirror-activeline-background{background:#ffffff1a}.cm-s-dracula .CodeMirror-matchingbracket{text-decoration:underline;color:#fff!important}.CodeMirror-hints{position:absolute;z-index:10;overflow:hidden;list-style:none;margin:0;padding:2px;-webkit-box-shadow:2px 3px 5px rgba(0,0,0,.2);-moz-box-shadow:2px 3px 5px rgba(0,0,0,.2);box-shadow:2px 3px 5px #0003;border-radius:3px;border:1px solid silver;background:#fff;font-size:90%;font-family:monospace;max-height:20em;overflow-y:auto;box-sizing:border-box}.CodeMirror-hint{margin:0;padding:0 4px;border-radius:2px;white-space:pre;color:#000;cursor:pointer}li.CodeMirror-hint-active{background:#08f;color:#fff}
