:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#121212;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-bg: #121212;--color-surface: #1e1e1e;--color-surface-elevated: #2a2a2a;--color-surface-hover: #333333;--color-surface-active: #444444;--color-border: #3a3a3a;--color-border-light: #4a4a4a;--color-border-hover: #555555;--color-text: rgba(255, 255, 255, .87);--color-text-muted: rgba(255, 255, 255, .6);--color-text-dimmed: rgba(255, 255, 255, .38);--color-accent: #e85a30;--color-accent-hover: #f07048;--color-accent-muted: rgba(232, 90, 48, .2);--color-accent-glow: rgba(232, 90, 48, .6);--color-brand: var(--color-accent);--color-accent-light: var(--color-accent-hover);--color-success: #1db954;--color-warning: #ffc107;--color-error: #e74c3c;--color-secondary: #d4a054;--color-danger: var(--color-error);--color-blue: #3498db;--color-blue-muted: rgba(52, 152, 219, .15);--color-info: var(--color-blue);--color-purple: #9b59b6;--color-purple-muted: rgba(155, 89, 182, .15);--color-purple-dark: #8e44ad;--color-teal: #4ecdc4;--color-teal-muted: rgba(78, 205, 196, .15);--color-cyan: #00bcd4;--color-cyan-muted: rgba(0, 188, 212, .15);--color-pink: #e91e63;--color-pink-muted: rgba(233, 30, 99, .15);--color-green: #2ecc71;--color-green-muted: rgba(46, 204, 113, .15);--color-orange: #e67e22;--color-orange-muted: rgba(230, 126, 34, .15);--color-yellow: #f1c40f;--color-yellow-muted: rgba(241, 196, 15, .15);--color-red: #e74c3c;--color-red-muted: rgba(231, 76, 60, .15);--color-drums: var(--color-orange);--color-bass: var(--color-purple);--color-keys: var(--color-blue);--color-leads: var(--color-pink);--color-pads: var(--color-green);--color-fx: var(--color-cyan);--color-playhead: #ffffff;--color-playhead-glow: rgba(255, 255, 255, .4);--track-left-width: 512px;--flex-gap: 8px}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%}button{font-family:inherit}.step-cell{width:36px;height:36px;border:2px solid var(--color-border);border-radius:4px;background:var(--color-surface-elevated);cursor:pointer;position:relative;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}@media(max-width:768px){.step-cell{width:44px;height:44px;border-radius:6px}}@media(max-width:480px)and (orientation:portrait){.step-cell{width:48px;height:48px;border-radius:8px;border-width:2px;scroll-snap-align:start}.step-cell.beat-start{border-left-width:4px}.step-cell.playing,.step-cell.active.playing{border-width:4px}}.step-cell:hover{background:var(--color-surface-hover);border-color:var(--color-border-light)}.step-cell.beat-start{border-left-color:var(--color-border-light);border-left-width:3px}.step-cell.active{background:var(--color-accent);border-color:var(--color-accent-light)}.step-cell.active:hover{background:var(--color-accent-light);box-shadow:0 0 4px #ffffff4d}.step-cell.playing,.step-cell.active.playing{border-color:var(--color-playhead);border-width:3px}.playing-indicator{position:absolute;inset:4px;background:#fff6;border-radius:2px}.step-cell.selected{border-color:var(--color-info);box-shadow:0 0 0 2px #4a9ece66;background:#4a9ece26}.step-cell.active.selected{border-color:var(--color-info);background:var(--color-accent);box-shadow:0 0 0 2px #4a9ece80}.step-cell.anchor:after{content:"▲";position:absolute;bottom:1px;left:50%;transform:translate(-50%);font-size:8px;color:var(--color-info);line-height:1}.step-cell.anchor{border-width:3px}.step-cell.has-lock,.step-cell.active.has-lock{border-color:var(--color-purple)}.lock-badges{position:absolute;top:1px;right:1px;display:flex;gap:1px}.lock-badge{width:12px;height:12px;border-radius:2px;font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center;color:#fff}.lock-badge.pitch{background:var(--color-info)}.lock-badge.volume{background:var(--color-accent)}.lock-badge.tie{background:var(--color-blue)}.step-cell.has-tie{border-left-style:double;border-left-width:4px;border-left-color:var(--color-blue)}.step-cell.active.has-tie{border-left-color:var(--color-blue)}.step-cell .velocity-fill{position:absolute;bottom:0;left:0;right:0;background:#ffffff26;border-radius:0 0 2px 2px;pointer-events:none}.step-cell.active .velocity-fill{background:#ffffff40}.step-cell:not(.active):not(.dimmed){opacity:.65}.step-cell:not(.active):not(.dimmed):hover{opacity:1}.step-cell.dimmed{opacity:.35;pointer-events:none}.step-cell.dimmed.active{background:#4a3a32;border-color:#3a2a22}.step-cell.page-end{margin-right:8px}@keyframes remote-flash{0%{box-shadow:0 0 0 4px var(--flash-color, transparent),0 0 12px var(--flash-color, transparent);transform:scale(1.1)}to{box-shadow:0 0 0 0 transparent,0 0 0 transparent;transform:scale(1)}}.step-cell.remote-flash{animation:remote-flash .6s ease-out;z-index:10}.step-cell.out-of-range{border-color:var(--color-error)!important;background:#ee555526}.step-cell.active.out-of-range{background:linear-gradient(135deg,var(--color-accent) 50%,rgba(238,85,85,.4) 50%);border-color:var(--color-error)!important}.step-cell.out-of-range:before{content:"⚠";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:14px;color:var(--color-error);opacity:.7;pointer-events:none}.step-cell.active.out-of-range:before{font-size:10px;top:2px;left:2px;transform:none}.step-cell.suboptimal-range{border-color:var(--color-warning)!important}.step-cell.active.suboptimal-range{border-color:var(--color-warning)!important;background:linear-gradient(135deg,var(--color-accent) 85%,rgba(255,193,7,.4) 85%)}.step-cell.playing{will-change:transform,box-shadow}@keyframes step-pulse{0%{transform:scale(1.08);box-shadow:0 0 #4ecdc466}50%{transform:scale(1.04);box-shadow:0 0 12px 2px #4ecdc44d}to{transform:scale(1);box-shadow:0 0 #4ecdc400}}.step-cell.active.playing{animation:step-pulse .2s ease-out}.step-cell.playing:not(.active){box-shadow:inset 0 0 8px #4ecdc44d}@media(max-width:768px)and (orientation:portrait){.step-cell.active.playing{animation:step-pulse-portrait .25s ease-out}@keyframes step-pulse-portrait{0%{transform:scale(1.12);box-shadow:0 0 #4ecdc480}50%{transform:scale(1.06);box-shadow:0 0 16px 4px #4ecdc466}to{transform:scale(1);box-shadow:0 0 8px #4ecdc433}}}@media(prefers-reduced-motion:reduce){.step-cell.playing,.step-cell.active.playing{animation:none!important;will-change:auto}.step-cell.playing:not(.active){box-shadow:none}}.chromatic-grid{display:flex;gap:8px;padding:8px 0 12px;margin-top:4px;background:#0003;border-radius:6px;min-width:max-content}.chromatic-grid::-webkit-scrollbar{height:8px}.chromatic-grid::-webkit-scrollbar-track{background:var(--color-surface-elevated);border-radius:4px}.chromatic-grid::-webkit-scrollbar-thumb{background:var(--color-surface-active);border-radius:4px}.chromatic-grid::-webkit-scrollbar-thumb:hover{background:var(--color-border-hover)}.chromatic-pitch-labels{display:flex;flex-direction:column;gap:2px;width:var(--track-left-width);min-width:var(--track-left-width);padding-left:8px;flex-shrink:0;position:sticky;left:0;z-index:2;background:#0003;justify-content:flex-end;align-items:flex-end}.pitch-label{height:20px;width:100%;display:flex;align-items:center;justify-content:flex-end;gap:4px;font-size:9px;color:var(--color-text-muted);padding-right:8px}.pitch-label.root{color:var(--color-blue);font-weight:600}.pitch-label.fifth{color:var(--color-purple);font-weight:500}.pitch-note{font-weight:500}.pitch-value{font-family:monospace;font-size:8px;opacity:.7}.chromatic-steps{display:flex;flex-direction:column;gap:2px}.chromatic-row{display:flex;gap:3px}.chromatic-row.root{background:var(--color-blue-muted);border-radius:2px;margin:0 -2px;padding:0 2px}.chromatic-row.fifth{background:var(--color-purple-muted);border-radius:2px;margin:0 -2px;padding:0 2px}.chromatic-grid.scale-locked{box-shadow:inset 0 0 0 1px #9c27b04d}.pitch-label.out-of-range{opacity:.35}.pitch-label.out-of-range .pitch-note{text-decoration:line-through;color:var(--color-error)}.chromatic-row.out-of-range{opacity:.35;background:#ee555514}.chromatic-row.out-of-range .chromatic-cell{cursor:not-allowed;border-color:#ee55554d}.chromatic-row.out-of-range .chromatic-cell:hover{background:#ee555526}.pitch-label.suboptimal-range{opacity:.65}.chromatic-row.suboptimal-range{opacity:.75}.chromatic-row.pitch-shift-fair{background:#f1c40f14}.chromatic-cell.note.pitch-shift-fair{background:var(--color-yellow);border-color:var(--color-yellow)}.chromatic-row.pitch-shift-poor{background:#e67e221a}.chromatic-cell.note.pitch-shift-poor{background:var(--color-orange);border-color:#e67e22;box-shadow:0 0 0 1px #e67e2280}.chromatic-row.pitch-shift-bad{background:#ee55551a}.chromatic-cell.note.pitch-shift-bad{background:#c0392b;border-color:#a93226;box-shadow:0 0 0 1px #c0392b99}.chromatic-cell{width:36px;height:20px;border:1px solid var(--color-border);border-radius:2px;background:var(--color-surface);cursor:pointer;transition:all .1s ease;padding:0}.chromatic-cell:disabled{background:transparent;border-color:var(--color-surface-elevated);cursor:not-allowed;opacity:.3}.chromatic-cell.step-active{background:var(--color-surface-elevated);border-color:var(--color-surface-active)}.chromatic-cell.step-active:hover{background:var(--color-surface-hover);border-color:var(--color-text-muted)}.chromatic-cell.note{background:var(--color-orange);border-color:var(--color-orange)}.chromatic-cell.note:hover{filter:brightness(1.1)}.chromatic-cell.playing{box-shadow:0 0 8px var(--color-orange);animation:chromatic-pulse .15s ease-out}@keyframes chromatic-pulse{0%{transform:scale(1.2)}to{transform:scale(1)}}.chromatic-cell.page-end{margin-right:6px}.pitch-contour{position:absolute;top:50%;left:0;transform:translateY(-50%);pointer-events:none;z-index:1}.contour-line{fill:none;stroke:#3498db99;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.contour-dot{fill:#3498dbcc}.contour-dot.playing{fill:var(--color-blue);r:4}.expand-toggle{width:24px;height:24px;border:1px solid var(--color-surface-active);border-radius:3px;background:var(--color-surface-elevated);color:var(--color-text-muted);font-size:12px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.expand-toggle:hover{background:var(--color-surface-hover);border-color:var(--color-text-muted);color:var(--color-text)}.expand-toggle.expanded:hover{background:var(--color-cyan-muted);filter:brightness(1.1)}.steps-with-contour{position:relative}.chromatic-grid{flex-direction:column}.chromatic-grid-header{display:flex;align-items:center;gap:12px;padding:8px 8px 4px;position:sticky;left:0;z-index:3}.chromatic-view-mode-control{display:flex;gap:0;border-radius:3px;background:var(--color-surface-elevated);padding:2px}.chromatic-view-mode-control__button{padding:4px 10px;font-size:11px;font-weight:500;color:var(--color-text-muted);background:transparent;border:1px solid transparent;border-radius:2px;cursor:pointer;transition:background-color .15s ease,color .15s ease}.chromatic-view-mode-control__button:hover{background:var(--color-surface-hover);color:var(--color-text)}.chromatic-view-mode-control__button--active{background:var(--color-cyan-muted);border-color:var(--color-cyan);color:var(--color-cyan)}.chromatic-out-of-scale-warning{font-size:10px;color:var(--color-yellow);background:var(--color-yellow-muted);padding:2px 8px;border-radius:3px;border:1px solid var(--color-yellow)}.chromatic-grid-content{display:flex;gap:8px;min-width:max-content}.pitch-label.fourth{color:var(--color-purple);font-weight:500;opacity:.85}.chromatic-row.fourth{background:var(--color-purple-muted);border-radius:2px;margin:0 -2px;padding:0 2px;opacity:.85}.pitch-label.octave{font-weight:600}.chromatic-row.octave{opacity:1}.view-mode-all .chromatic-row.chromatic,.view-mode-all .pitch-label.chromatic{opacity:.5}.chromatic-row.chromatic:not(.root):not(.fifth):not(.fourth):not(.octave){background:transparent}.chromatic-row.out-of-scale{background:var(--color-yellow-muted);border-left:3px solid var(--color-yellow);margin-left:-3px}.pitch-label.out-of-scale,.pitch-label.out-of-scale .pitch-note{color:var(--color-yellow)}.piano-roll{display:flex;gap:8px;background:var(--color-surface);border-radius:8px;border:1px solid var(--color-border);overflow-y:auto;overflow-x:visible;max-height:400px;min-width:max-content}.piano-keyboard{display:flex;flex-direction:column;width:var(--track-left-width);min-width:var(--track-left-width);flex-shrink:0;background:linear-gradient(90deg,#1a1512,#2a2320 70%,#1a1815);border-right:2px solid #0a0908;position:sticky;left:0;z-index:2;align-items:flex-end;box-shadow:inset -4px 0 8px #0000004d}.piano-keyboard::-webkit-scrollbar{display:none}.piano-key{display:flex;align-items:center;justify-content:flex-end;height:20px;min-height:20px;padding-right:12px;transition:all .1s ease;position:relative}.piano-key.white-key{width:100%;background:linear-gradient(180deg,#f8f8f0,#eeede5,#e8e7df);border-bottom:1px solid #d0cfc5;box-shadow:inset 0 -2px 3px #00000014,inset -2px 0 3px #0000000d}.piano-key.white-key:hover{background:linear-gradient(180deg,#fff,#f5f5ed,#efefe7)}.piano-key.black-key{width:70%;margin-left:30%;background:linear-gradient(180deg,#3a3a3a,#1a1a1a 40%,#0d0d0d);border-bottom:1px solid #000;box-shadow:inset 0 -2px 4px #ffffff1a,inset 2px 0 3px #ffffff0d,-3px 0 8px #0006;border-radius:0 0 3px 3px;z-index:1}.piano-key.black-key:hover{background:linear-gradient(180deg,#4a4a4a,#2a2a2a 40%,#1d1d1d)}.piano-key.octave-c{border-top:2px solid #b0b0a0}.piano-key.octave-c .key-label{font-weight:700}.key-label{font-size:10px;font-family:var(--font-mono, "SF Mono", "Consolas", monospace);text-shadow:0 1px 1px rgba(255,255,255,.3);z-index:2}.piano-key.white-key .key-label{color:#444}.piano-key.black-key .key-label{color:#aaa;text-shadow:0 1px 2px rgba(0,0,0,.5);font-size:9px}.piano-key.root .key-label{font-weight:700}.piano-key.fifth .key-label{font-weight:600}.piano-key.out-of-range{opacity:.3}.piano-key.out-of-range .key-label{text-decoration:line-through}.piano-key.suboptimal-range{opacity:.7}.piano-grid-scroll{flex:1;overflow:visible;min-width:max-content}.piano-grid{display:flex;flex-direction:column;min-width:fit-content}.piano-row{display:flex;height:20px;min-height:20px;border-bottom:1px solid rgba(255,255,255,.03)}.piano-row.white-key{background:#ffffff05}.piano-row.black-key{background:#00000026}.piano-row.octave-c{border-top:1px solid rgba(255,255,255,.15)}.piano-row.root{background:#4ecdc414}.piano-row.fifth{background:#9b59b60f}.piano-row.out-of-range{background:#ee55550d;opacity:.5}.piano-row.suboptimal-range{opacity:.85}.piano-cell{width:36px;min-width:36px;height:100%;border:none;background:transparent;cursor:pointer;transition:background .1s ease;border-right:1px solid rgba(255,255,255,.03);padding:0;margin-right:2px}.piano-cell:hover{background:#ffffff1a}.piano-cell.beat-start{border-left:1px solid rgba(255,255,255,.1)}.piano-cell.page-end{border-right:2px solid rgba(255,255,255,.2)}.piano-cell.step-active{background:#ffffff0d}.piano-cell.note{background:var(--color-accent);border-radius:2px;margin:2px 1px;height:calc(100% - 4px);box-shadow:0 0 4px #4ecdc466}.piano-cell.note:hover{background:var(--color-accent-light, #5ed9cf);transform:scale(1.05)}.piano-cell.playing{background:var(--color-yellow);box-shadow:0 0 8px #ffd93d99;animation:note-pulse .15s ease-out}@keyframes note-pulse{0%{transform:scale(1.1)}to{transform:scale(1)}}.piano-grid-scroll::-webkit-scrollbar{width:8px;height:8px}.piano-grid-scroll::-webkit-scrollbar-track{background:var(--color-surface)}.piano-grid-scroll::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.piano-grid-scroll::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.piano-grid-scroll::-webkit-scrollbar-corner{background:var(--color-surface)}@media(max-width:768px){.piano-roll{max-height:300px}.piano-keyboard{width:40px}.key-label{font-size:8px}.piano-cell{width:44px;min-width:44px}}@media(prefers-reduced-motion:reduce){.piano-cell.playing{animation:none}.piano-cell,.piano-key{transition:none}}.velocity-lane{display:flex;gap:8px;padding:4px 0;background:#00000026;border-radius:4px;margin-top:2px;min-width:max-content;cursor:ns-resize;-webkit-user-select:none;user-select:none;touch-action:none}.velocity-lane-spacer{width:var(--track-left-width);min-width:var(--track-left-width);flex-shrink:0;position:sticky;left:0;z-index:2;background:#00000026}.velocity-bars{display:flex;gap:3px;height:40px;align-items:flex-end}.velocity-step{width:36px;min-width:36px;height:100%;display:flex;align-items:flex-end;justify-content:center;position:relative}.velocity-step.inactive{background:#ffffff05;border-radius:2px}.velocity-step.active{background:#ffffff08;border-radius:2px}.velocity-bar{width:100%;background:var(--color-accent);border-radius:2px 2px 0 0;min-height:2px;transition:height .05s ease-out,background .1s ease}.velocity-bar:hover{filter:brightness(1.2)}.velocity-bar.extreme-low{background:var(--color-purple);box-shadow:0 0 4px #9b59b666}.velocity-bar.normal{background:var(--color-accent)}.velocity-bar.extreme-high{background:var(--color-red);box-shadow:0 0 4px #e74c3c66}.velocity-toggle{width:36px;height:36px;border:1px solid var(--color-border-hover);border-radius:4px;background:transparent;color:var(--color-text-muted);font-size:11px;font-weight:700;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.velocity-toggle:hover{border-color:var(--color-text-muted);color:var(--color-text-muted)}.velocity-toggle.expanded{background:var(--color-surface-active);border-color:var(--color-text-muted);color:var(--color-text)}.velocity-toggle.expanded:hover{background:var(--color-surface-active);filter:brightness(1.1)}@media(max-width:768px){.velocity-lane{display:none}}@media(prefers-reduced-motion:reduce){.velocity-bar{transition:none}}.inline-drawer{background:var(--color-bg);border-radius:0 0 8px 8px;border:1px solid var(--color-border);border-top:none;margin-top:-4px;animation:slideDown .15s ease;overflow:hidden}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:300px}}.inline-drawer-content{padding:12px 16px}.drawer-section{margin-bottom:16px}.drawer-section:last-child{margin-bottom:0}.drawer-section-title{font-size:10px;font-weight:600;color:var(--color-text-dimmed);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.drawer-row{display:grid;grid-template-columns:[label] 70px [control] 1fr [value] auto;align-items:center;gap:12px}.drawer-row+.drawer-row{margin-top:8px}.drawer-label{grid-column:label;font-size:13px;color:var(--color-text-muted)}.drawer-toggle-group,.drawer-stepper,.drawer-select,.drawer-pattern-tools{grid-column:control}.drawer-slider-group{grid-column:control / span 2}.drawer-stepper{display:flex;align-items:center;gap:4px}.drawer-stepper-btn{width:32px;height:32px;border:1px solid var(--color-surface-active);border-radius:6px;background:var(--color-surface-elevated);color:var(--color-text);font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s ease}.drawer-stepper-btn:active{background:var(--color-surface-hover);transform:scale(.95)}.drawer-stepper-btn:disabled{opacity:.3;cursor:not-allowed}.drawer-stepper-value{min-width:36px;text-align:center;font-size:14px;font-weight:600;color:var(--color-text);font-family:monospace}.drawer-stepper-value.active{color:var(--color-info)}.drawer-segment{display:flex;gap:2px;background:var(--color-bg);border-radius:6px;padding:2px;border:1px solid var(--color-border)}.drawer-segment-btn{padding:8px 14px;border:none;border-radius:4px;background:transparent;color:var(--color-text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:all .1s ease}.drawer-segment-btn:active{transform:scale(.95)}.drawer-segment-btn.active{background:var(--color-purple);color:var(--color-text)}.drawer-select{height:36px;padding:0 32px 0 12px;border:1px solid var(--color-surface-active);border-radius:6px;background:var(--color-surface-elevated);color:var(--color-text);font-size:14px;font-weight:600;font-family:monospace;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath fill='%23888' d='M0 3l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;min-width:70px}.drawer-select:focus{outline:none;border-color:var(--color-purple)}.drawer-select option{background:var(--color-bg);color:var(--color-text)}.drawer-actions{display:flex;gap:8px;flex-wrap:wrap}.drawer-action-btn{flex:1;min-width:70px;padding:10px 12px;border:1px solid var(--color-surface-active);border-radius:6px;background:var(--color-surface-elevated);color:var(--color-text);font-size:12px;font-weight:500;cursor:pointer;transition:all .1s ease}.drawer-action-btn:active{background:var(--color-surface-hover);transform:scale(.98)}.drawer-action-btn:disabled{opacity:.4;cursor:not-allowed}.drawer-action-btn.destructive{color:var(--color-error);border-color:#e74c3c4d}.drawer-action-btn.destructive:active{background:#e74c3c33}.drawer-action-btn.primary{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-text)}.drawer-divider{height:1px;background:var(--color-border);margin:12px 0}.drawer-toggle-group{display:flex;gap:8px}.drawer-toggle-btn{width:40px;height:36px;border:2px solid var(--color-border-hover);border-radius:6px;background:transparent;color:var(--color-text-muted);font-size:14px;font-weight:700;cursor:pointer;transition:all .1s ease}.drawer-toggle-btn:active{transform:scale(.95)}.drawer-toggle-btn.active.muted{background:var(--color-error);border-color:var(--color-error);color:var(--color-text)}.drawer-toggle-btn.active.soloed{background:var(--color-yellow);border-color:var(--color-yellow);color:var(--color-bg)}.drawer-mode-btn{padding:8px 14px;border:2px solid var(--color-border-hover);border-radius:6px;background:var(--color-surface-elevated);color:var(--color-text-muted);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease}.drawer-mode-btn:active{transform:scale(.95)}.drawer-mode-btn:not(.gate){border-color:var(--color-text-dimmed);color:var(--color-text-muted)}.drawer-mode-btn.gate{border-color:var(--color-cyan);background:var(--color-cyan-muted);color:var(--color-cyan)}.drawer-slider-group{display:flex;align-items:center;gap:8px;flex:1}.drawer-volume-slider{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:linear-gradient(to right,var(--color-border) 0%,var(--color-border) 100%);border-radius:3px;cursor:pointer}.drawer-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--color-blue);cursor:pointer;border:2px solid var(--color-text);box-shadow:0 2px 4px #0000004d}.drawer-volume-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--color-blue);cursor:pointer;border:2px solid var(--color-text);box-shadow:0 2px 4px #0000004d}.drawer-swing-slider{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:linear-gradient(to right,var(--color-border) 0%,var(--color-border) 100%);border-radius:3px;cursor:pointer}.drawer-swing-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--color-orange);cursor:pointer;border:2px solid var(--color-text);box-shadow:0 2px 4px #0000004d}.drawer-swing-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--color-orange);cursor:pointer;border:2px solid var(--color-text);box-shadow:0 2px 4px #0000004d}.drawer-slider-value{min-width:40px;text-align:right;font-size:13px;font-weight:600;color:var(--color-text-muted);font-family:monospace}.step-count-dropdown{position:relative;display:inline-block}.step-count-trigger{display:flex;align-items:center;gap:4px;height:36px;padding:0 8px;background:var(--color-surface-elevated, #2a2a2a);border:1px solid var(--color-border, #444);border-radius:4px;color:var(--color-text, #fff);font-size:13px;cursor:pointer;transition:border-color .15s,background .15s;min-width:50px;box-sizing:border-box}.step-count-trigger:hover:not(:disabled){border-color:var(--color-accent, #ff6b35);background:var(--color-surface-hover, #333)}.step-count-trigger:disabled{opacity:.5;cursor:not-allowed}.step-count-trigger.open{border-color:var(--color-cyan);background:var(--color-cyan-muted);color:var(--color-cyan)}.step-count-value{font-weight:500;min-width:24px;text-align:right}.step-count-chevron{font-size:10px;opacity:.7}.step-count-menu{background:var(--color-surface-elevated, #2a2a2a);border:1px solid var(--color-border, #444);border-radius:8px;box-shadow:0 8px 24px #0006;min-width:160px;max-height:320px;overflow-y:auto;z-index:10000;animation:dropdown-appear .15s ease-out}@keyframes dropdown-appear{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.category-header{display:flex;align-items:center;padding:8px 12px 4px;color:var(--color-text-muted, #888);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.category-label{flex:1}.category-options{padding-bottom:4px}.step-option{display:flex;align-items:center;gap:8px;width:100%;padding:6px 12px;background:transparent;border:none;color:var(--color-text, #fff);font-size:13px;cursor:pointer;transition:background .1s;text-align:left}.step-option:hover{background:var(--color-surface-hover, #333)}.step-option.selected{background:var(--color-accent-muted, rgba(255, 107, 53, .15))}.option-value{font-weight:600;min-width:24px;text-align:right}.option-label{flex:1;color:var(--color-text-muted, #888);font-size:12px}.option-check{color:var(--color-accent, #ff6b35);font-size:12px}.step-count-menu::-webkit-scrollbar{width:6px}.step-count-menu::-webkit-scrollbar-track{background:transparent}.step-count-menu::-webkit-scrollbar-thumb{background:var(--color-border, #444);border-radius:3px}.step-count-menu::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted, #666)}@media(prefers-reduced-motion:reduce){.step-count-menu{animation:none}}.transpose-dropdown{position:relative;display:inline-block}.transpose-trigger{display:flex;align-items:center;gap:4px;height:36px;padding:0 8px;background:var(--color-surface-elevated, #2a2a2a);border:1px solid var(--color-border, #444);border-radius:4px;color:var(--color-text-muted, #888);font-size:13px;font-family:monospace;cursor:pointer;transition:border-color .15s,background .15s,color .15s;min-width:50px;box-sizing:border-box}.transpose-trigger:hover:not(:disabled){border-color:var(--color-accent, #ff6b35);background:var(--color-surface-hover, #333)}.transpose-trigger:disabled{opacity:.5;cursor:not-allowed}.transpose-trigger.open{border-color:var(--color-cyan);background:var(--color-cyan-muted);color:var(--color-cyan)}.transpose-trigger.active:not(.open){color:var(--color-blue)}.transpose-value{font-weight:600;min-width:28px;text-align:right}.transpose-chevron{font-size:10px;opacity:.7}.transpose-menu{background:var(--color-surface-elevated, #2a2a2a);border:1px solid var(--color-border, #444);border-radius:8px;box-shadow:0 8px 24px #0006;min-width:140px;max-height:320px;overflow-y:auto;z-index:10000;animation:transpose-dropdown-appear .15s ease-out}@keyframes transpose-dropdown-appear{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.transpose-menu .category-header{display:flex;align-items:center;padding:8px 12px 4px;color:var(--color-text-muted, #888);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.transpose-menu .category-label{flex:1}.transpose-menu .category-options{padding-bottom:4px}.transpose-option{display:flex;align-items:center;gap:8px;width:100%;padding:6px 12px;background:transparent;border:none;color:var(--color-text, #fff);font-size:13px;cursor:pointer;transition:background .1s;text-align:left}.transpose-option:hover{background:var(--color-surface-hover, #333)}.transpose-option.selected{background:var(--color-accent-muted, rgba(255, 107, 53, .15))}.transpose-option .option-value{font-weight:600;font-family:monospace;min-width:32px;text-align:right}.transpose-option .option-label{flex:1;color:var(--color-text-muted, #888);font-size:12px}.transpose-option .option-check{color:var(--color-accent, #ff6b35);font-size:12px}.transpose-menu::-webkit-scrollbar{width:6px}.transpose-menu::-webkit-scrollbar-track{background:transparent}.transpose-menu::-webkit-scrollbar-thumb{background:var(--color-border, #444);border-radius:3px}.transpose-menu::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted, #666)}@media(prefers-reduced-motion:reduce){.transpose-menu{animation:none}}.track-row-wrapper{display:flex;flex-direction:column;transition:transform .15s ease-out,opacity .15s ease-out}.track-row-wrapper.drag-target{background:var(--color-accent-muted);border:2px solid var(--color-accent);border-radius:4px}.track-row-wrapper.dragging{opacity:.5;transform:scale(.98);background:var(--color-surface-elevated);border-radius:4px}.track-header-mobile,.mobile-edit-panel{display:none}.track-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-radius:4px;transition:background .15s ease;min-width:max-content}.track-left{display:grid;grid-template-columns:[drag] 20px [name] 100px [mute] 36px [solo] 36px [transpose] 60px [badge] 36px [step-count] 60px [pitch-view] 36px [velocity] 36px [tools] 36px;column-gap:4px;align-items:center;padding-left:8px;padding-right:8px;position:sticky;left:0;z-index:3;background:var(--color-surface);box-shadow:4px 0 8px -4px #0003}.track-drag-handle{grid-column:drag}.track-name,.track-name-input{grid-column:name}.mute-button{grid-column:mute}.solo-button{grid-column:solo}.expand-toggle{grid-column:pitch-view}.velocity-toggle{grid-column:velocity}.pattern-tools-toggle{grid-column:tools}.track-pitch-step-group{grid-column:transpose / span 3}.track-drag-handle{display:flex;align-items:center;justify-content:center;width:20px;height:36px;color:var(--color-text-muted);opacity:.4;cursor:grab;transition:opacity .15s ease,color .15s ease;-webkit-user-select:none;user-select:none;font-size:12px;letter-spacing:-1px}.track-drag-handle:hover{opacity:.8;color:var(--color-text)}.track-drag-handle:active{cursor:grabbing;opacity:1;color:var(--color-accent)}.track-right{display:flex;align-items:center;padding-left:8px;padding-right:12px;position:sticky;right:0;z-index:3;background:var(--color-surface);box-shadow:-4px 0 8px -4px #0003}@media(max-width:768px){.track-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 0;border-bottom:1px solid var(--color-surface-elevated)}.transpose-control,.step-count-select,.track-actions{display:none}.mute-button,.solo-button{width:36px;height:36px;font-size:13px;flex-shrink:0}.track-name{flex:0 0 auto;min-width:60px;max-width:80px;padding:8px 4px;border-radius:4px;cursor:pointer;transition:background .1s ease}.track-name:active{background:var(--color-surface-hover)}.expand-toggle{flex-shrink:0;order:3}.expand-placeholder{display:none}.steps{flex:1;min-width:0;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px 0}.steps::-webkit-scrollbar{display:none}.track-row:after{content:"";position:absolute;right:8px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--color-surface-active);opacity:0;transition:opacity .15s;pointer-events:none}.track-row-wrapper:not(:has(.inline-drawer)) .track-row:after{opacity:1}}@media(max-width:480px)and (orientation:portrait){.track-header-mobile{display:flex;align-items:center;padding:8px 0 4px}.track-name-mobile{font-size:14px;font-weight:600;color:var(--color-text);text-transform:capitalize;display:flex;align-items:center;gap:6px}.track-header-mobile.muted .track-name-mobile{opacity:.5}.track-header-mobile.soloed .track-name-mobile{color:var(--color-yellow)}.track-type-badge{font-size:12px;color:var(--color-purple)}.track-status-badge{font-size:10px;font-weight:700;padding:2px 5px;border-radius:3px;margin-left:4px}.track-status-badge.muted{background:var(--color-error);color:#fff}.track-status-badge.soloed{background:var(--color-yellow);color:var(--color-bg)}.track-row{display:block;padding:0;border-bottom:none}.track-row .mute-button,.track-row .solo-button,.track-row .track-name,.track-row .transpose-control,.track-row .step-count-select,.track-row .expand-toggle,.track-row .expand-placeholder,.track-row .track-actions{display:none!important}.track-row .steps{display:flex;width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px 24px 4px 0;margin-right:-12px;scroll-snap-type:x proximity}.track-row .steps::-webkit-scrollbar{display:none}.track-row:after{display:none}.mobile-edit-panel{display:flex;justify-content:center;align-items:center;padding:8px 0;border-bottom:1px solid var(--color-surface-elevated);cursor:pointer;transition:background .1s ease}.mobile-edit-panel:active{background:#ffffff0d}.mobile-edit-hint{font-size:11px;color:var(--color-text-muted);letter-spacing:.5px}.mobile-edit-panel.expanded .mobile-edit-hint{color:var(--color-text-muted)}}.track-row.muted{opacity:.5}.track-row.soloed{background:var(--color-yellow-muted)}.track-row.copy-source{background:var(--color-green-muted)}.track-row.copy-target{background:var(--color-blue-muted)}.track-row.copy-target:hover{background:#3498db33}.expand-toggle{width:36px;height:36px;border:1px solid var(--color-surface-active);border-radius:4px;background:var(--color-surface-elevated);color:var(--color-text-muted);font-size:14px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0}.expand-toggle:hover{background:var(--color-surface-hover);border-color:var(--color-text-muted)}.expand-toggle.expanded{background:var(--color-cyan-muted);border-color:var(--color-cyan);color:var(--color-cyan)}.expand-toggle svg{display:block}.steps{flex:1;min-width:0}.track-name{height:36px;width:80px;flex-shrink:0;display:flex;align-items:center;font-size:13px;font-weight:500;color:var(--color-text);text-transform:capitalize;padding:0 4px;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-name:hover{color:var(--color-text-bright)}.track-name-input{height:36px;width:80px;flex-shrink:0;font-size:13px;font-weight:500;color:var(--color-text);background:var(--color-surface-elevated);border:1px solid var(--color-accent);border-radius:4px;padding:0 8px;outline:none;box-sizing:border-box}.track-name-input:focus{border-color:var(--color-accent-light);box-shadow:0 0 0 2px rgba(var(--color-accent-rgb, 255, 160, 100),.2)}.track-pitch-step-group{display:flex;align-items:center;gap:2px;height:36px}.track-key-badge{font-family:var(--font-mono, "SF Mono", "Consolas", monospace);font-size:13px;font-weight:600;min-width:28px;text-align:center;height:36px;line-height:36px;padding:0 6px;background:var(--color-surface-elevated, #2a2a2a);border:1px solid var(--color-border, #444);border-left:none;border-radius:0 4px 4px 0;box-sizing:border-box;flex-shrink:0;transition:background .15s,color .15s,border-color .15s}.track-key-badge.active{color:var(--color-blue, #6eb5ff);background:var(--color-surface-elevated, #2a2a2a)}.track-key-badge.placeholder{color:var(--color-text-muted, #666);opacity:.5}.track-key-badge.placeholder-empty{visibility:hidden}.track-key-badge:hover:not(.placeholder){background:var(--color-surface-hover, #333);border-color:var(--color-accent, #ff6b35)}.track-pitch-step-group .transpose-trigger{border-radius:4px 0 0 4px}.track-pitch-step-group:not(:has(.track-key-badge)) .transpose-trigger{border-radius:4px 0 0 4px}.track-pitch-step-group .step-count-dropdown .step-count-trigger{border-radius:0 4px 4px 0}.mute-button{width:36px;height:36px;border:1px solid var(--color-border-hover);border-radius:4px;background:transparent;flex-shrink:0;color:var(--color-text-muted);font-size:11px;font-weight:700;cursor:pointer;transition:all .15s ease}.mute-button:hover{border-color:var(--color-text-muted);color:var(--color-text-muted)}.mute-button.active{background:var(--color-error);border-color:var(--color-error);color:#fff}.solo-button{width:36px;height:36px;border:1px solid var(--color-border-hover);border-radius:4px;background:transparent;flex-shrink:0;color:var(--color-text-muted);font-size:11px;font-weight:700;cursor:pointer;transition:all .15s ease}.solo-button:hover{border-color:var(--color-text-muted);color:var(--color-text-muted)}.solo-button.active{background:var(--color-yellow);border-color:var(--color-yellow);color:var(--color-bg)}.track-volume-control{grid-column:volume;display:flex;align-items:center;height:26px}.track-volume-slider{width:100%;height:4px;-webkit-appearance:none;appearance:none;background:linear-gradient(90deg,var(--color-surface-active) 0%,var(--color-text-muted) 100%);border-radius:2px;outline:none;cursor:pointer}.track-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--color-blue);cursor:pointer;transition:transform .1s ease,box-shadow .1s ease}.track-volume-slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 0 6px var(--color-blue-muted)}.track-volume-slider::-moz-range-thumb{width:12px;height:12px;border:none;border-radius:50%;background:var(--color-blue);cursor:pointer}.transpose-control{display:flex;align-items:center;gap:2px;height:36px}.transpose-btn{width:36px;height:36px;border:1px solid var(--color-surface-active);border-radius:4px;background:var(--color-surface-elevated);color:var(--color-text-muted);font-size:18px;font-weight:700;line-height:1;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.transpose-btn:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-text-muted);color:var(--color-text)}.transpose-btn:disabled{opacity:.3;cursor:not-allowed}.step-count-select{grid-column:step-count;width:60px;height:36px;padding:0 20px 0 6px;border:1px solid var(--color-surface-active);border-radius:4px;background:var(--color-surface-elevated);color:var(--color-text-muted);font-size:12px;font-weight:600;font-family:monospace;cursor:pointer;transition:all .15s ease;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8'%3E%3Cpath fill='%23888' d='M0 2l4 4 4-4z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.step-count-select:hover{background-color:var(--color-surface-hover);border-color:var(--color-text-muted);color:var(--color-text)}.step-count-select:focus{outline:none;border-color:var(--color-purple)}.step-count-select option{background:var(--color-surface);color:var(--color-text)}.steps{display:flex;gap:3px;flex-shrink:0}.track-actions{display:flex;gap:4px;flex-shrink:0;justify-content:flex-end;padding-right:12px}@media(max-width:768px){.track-actions{display:none}}.action-btn{height:36px;padding:0 10px;border:1px solid var(--color-surface-active);border-radius:4px;background:var(--color-surface-elevated);color:var(--color-text-muted);font-size:11px;font-weight:600;font-family:monospace;cursor:pointer;transition:all .15s ease;display:flex;align-items:center}.action-btn:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-text-muted);color:var(--color-text-muted)}.action-btn:disabled{opacity:.3;cursor:not-allowed}.action-btn.delete:hover:not(:disabled){background:var(--color-error);border-color:var(--color-error);color:#fff}.action-btn.paste{background:var(--color-success);border-color:var(--color-success);color:#fff}.action-btn.paste:hover{filter:brightness(1.1)}.plock-inline{display:flex;align-items:center;gap:16px;padding:8px 12px;background:var(--color-surface-elevated);border-radius:6px;margin-top:6px;width:100%}.plock-step{font-size:12px;color:var(--color-text-muted);font-weight:500;min-width:50px}.plock-control,.plock-param{display:flex;align-items:center;gap:8px}.plock-label{font-size:11px;font-weight:600;padding:2px 6px;border-radius:3px;text-transform:uppercase}.plock-label.pitch{background:var(--color-blue);color:#fff}.plock-label.volume{background:var(--color-accent);color:#fff}.plock-slider-row{display:flex;align-items:center;gap:6px}.plock-slider{width:80px;height:4px;-webkit-appearance:none;appearance:none;background:var(--color-surface-active);border-radius:2px;outline:none}.plock-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;cursor:pointer}.plock-slider.pitch::-webkit-slider-thumb{background:var(--color-blue)}.plock-slider.volume::-webkit-slider-thumb{background:var(--color-accent)}.plock-value{font-size:12px;color:var(--color-text-muted);min-width:35px;text-align:right;font-family:monospace}.plock-clear{padding:4px 8px;border:1px solid var(--color-error);border-radius:4px;background:transparent;color:var(--color-error);font-size:12px;cursor:pointer;transition:all .15s ease;margin-left:auto}.plock-clear:hover{background:var(--color-error);color:#fff}.plock-tie{padding:4px 8px;border:1px solid var(--color-text-muted);border-radius:4px;background:transparent;color:var(--color-text-muted);font-size:14px;cursor:pointer;transition:all .15s ease;margin-left:8px}.plock-tie:hover{border-color:var(--color-blue);color:var(--color-blue)}.plock-tie.active{border-color:var(--color-blue);background:var(--color-blue);color:#fff}.plock-label.out-of-range,.plock-value.out-of-range{color:var(--color-error)}.plock-label.pitch.out-of-range{background:var(--color-error);color:#fff}.plock-slider.pitch.out-of-range{opacity:.7}.plock-slider.pitch.out-of-range::-webkit-slider-thumb{background:var(--color-error)}.fm-controls-panel{display:flex;align-items:center;gap:24px;padding:10px 16px;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:6px;margin-top:6px;border:1px solid #2a2a4a}.fm-control{display:flex;align-items:center;gap:10px}.fm-label{font-size:11px;font-weight:600;color:#8a8aff;text-transform:uppercase;letter-spacing:.5px;min-width:85px}.fm-slider{width:120px;height:4px;-webkit-appearance:none;appearance:none;background:linear-gradient(90deg,#3a3a6a,#5a5aaa);border-radius:2px;outline:none;cursor:pointer}.fm-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#8a8aff;cursor:pointer;box-shadow:0 0 6px #8a8aff80;transition:transform .1s ease,box-shadow .1s ease}.fm-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 0 10px #8a8affb3}.fm-slider::-moz-range-thumb{width:14px;height:14px;border:none;border-radius:50%;background:#8a8aff;cursor:pointer;box-shadow:0 0 6px #8a8aff80}.fm-value{font-size:12px;color:#aaf;min-width:40px;text-align:right;font-family:monospace;font-weight:500}@media(max-width:768px){.fm-controls-panel{flex-direction:column;align-items:stretch;gap:12px;padding:12px}.fm-control{justify-content:space-between}.fm-slider{flex:1;max-width:150px}}.panel-animation-container{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease-out;overflow:hidden}.panel-animation-container.expanded{grid-template-rows:1fr;overflow:visible}.panel-animation-content{min-height:0;overflow:hidden}.panel-animation-container.expanded>.panel-animation-content{overflow:visible}.pattern-tools-toggle{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;font-size:14px;border:1px solid var(--color-surface-active);border-radius:4px;background:var(--color-surface-elevated);color:var(--color-text-muted);cursor:pointer;transition:all .15s ease;flex-shrink:0}.pattern-tools-toggle:hover{background:var(--color-surface-hover);border-color:var(--color-text-muted)}.pattern-tools-toggle.active{background:var(--color-cyan-muted);border-color:var(--color-cyan);color:var(--color-cyan)}.pattern-tools-panel{display:flex;align-items:center;gap:16px;padding:8px 12px;background:var(--color-surface-elevated);border-radius:6px;margin-top:4px;margin-bottom:4px;flex-wrap:wrap;max-width:calc(100vw - 170px);position:sticky;left:0;z-index:2}.pattern-tools-group{display:flex;align-items:center;gap:4px}.pattern-tools-label{font-size:10px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-right:4px}.pattern-tool-btn{width:28px;height:28px;border:1px solid var(--color-surface-active);border-radius:4px;background:var(--color-surface);color:var(--color-text-muted);font-size:14px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.pattern-tool-btn:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-purple);color:var(--color-purple)}.pattern-tool-btn:active:not(:disabled){transform:scale(.95)}.pattern-tool-btn:disabled{opacity:.3;cursor:not-allowed}.euclidean-group,.swing-group{display:grid;grid-template-columns:[label] auto [slider] 1fr [value] auto;align-items:center;gap:8px;flex:1;min-width:100px}.euclidean-group .pattern-tools-label,.swing-group .pattern-tools-label{grid-column:label}.euclidean-slider,.track-swing-slider{grid-column:slider}.euclidean-value,.swing-value{grid-column:value}.euclidean-slider{height:4px;-webkit-appearance:none;appearance:none;background:linear-gradient(90deg,var(--color-surface-active) 0%,var(--color-teal) 100%);border-radius:2px;outline:none;cursor:pointer}.euclidean-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--color-teal);cursor:pointer;transition:transform .1s ease,box-shadow .1s ease}.euclidean-slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 0 6px var(--color-teal-muted)}.euclidean-slider::-moz-range-thumb{width:14px;height:14px;border:none;border-radius:50%;background:var(--color-teal);cursor:pointer}.euclidean-value{font-size:11px;font-weight:600;color:var(--color-teal);font-family:monospace;min-width:35px}.track-swing-slider{height:4px;-webkit-appearance:none;appearance:none;background:linear-gradient(90deg,var(--color-surface-active) 0%,var(--color-cyan) 100%);border-radius:2px;outline:none;cursor:pointer}.track-swing-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--color-cyan);cursor:pointer;transition:transform .1s ease,box-shadow .1s ease}.track-swing-slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 0 6px var(--color-cyan-muted)}.track-swing-slider::-moz-range-thumb{width:14px;height:14px;border:none;border-radius:50%;background:var(--color-cyan);cursor:pointer}.swing-value{font-size:11px;font-weight:600;color:var(--color-cyan);font-family:monospace;min-width:32px}.drawer-pattern-tools{display:flex;gap:6px}.drawer-pattern-btn{width:36px;height:36px;border:1px solid var(--color-surface-active);border-radius:6px;background:var(--color-surface);color:var(--color-text-muted);font-size:16px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.drawer-pattern-btn:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-purple);color:var(--color-purple)}.drawer-pattern-btn:active:not(:disabled){transform:scale(.95)}.drawer-pattern-btn:disabled{opacity:.3;cursor:not-allowed}.drawer-euclidean-slider{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:linear-gradient(90deg,var(--color-surface-active) 0%,var(--color-teal) 100%);border-radius:3px;outline:none;cursor:pointer}.drawer-euclidean-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--color-teal);cursor:pointer}.drawer-euclidean-slider::-moz-range-thumb{width:18px;height:18px;border:none;border-radius:50%;background:var(--color-teal);cursor:pointer}@media(max-width:768px){.pattern-tools-panel{display:none}}.track-row{border-left:4px solid transparent}.track-row[data-category=drums]{border-left-color:var(--color-drums, var(--color-orange))}.track-row[data-category=bass]{border-left-color:var(--color-bass, var(--color-purple))}.track-row[data-category=keys]{border-left-color:var(--color-keys, var(--color-blue))}.track-row[data-category=leads]{border-left-color:var(--color-leads, var(--color-pink))}.track-row[data-category=pads]{border-left-color:var(--color-pads, var(--color-green))}.track-row[data-category=fx]{border-left-color:var(--color-fx, var(--color-cyan))}.pitch-view-header{display:flex;align-items:center;padding:8px 12px 4px;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.pitch-view-tabs{display:flex;gap:2px;background:var(--color-surface-elevated);border-radius:6px;padding:2px}.pitch-view-tab{padding:6px 12px;border:none;border-radius:4px;background:transparent;color:var(--color-text-muted);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease}.pitch-view-tab:hover{color:var(--color-text);background:#ffffff0d}.pitch-view-tab.active{background:var(--color-accent);color:var(--color-bg)}@media(max-width:768px){.pitch-view-header{display:none}}@media(prefers-reduced-motion:reduce){.panel-animation-container,.pitch-view-tab{transition:none}}@media(max-width:768px)and (orientation:landscape){.track-row-wrapper{margin-bottom:2px}.track-header-mobile,.mobile-edit-panel{display:none!important}.track-row{display:flex;align-items:center;gap:4px;padding:4px 0;min-width:unset}.track-left{display:grid;grid-template-columns:[mute] 36px [solo] 36px [name] minmax(60px,80px);column-gap:4px;align-items:center;padding:0 4px;position:sticky;left:0;z-index:3;background:var(--color-surface);box-shadow:2px 0 4px -2px #0003}.track-left .track-drag-handle,.track-left .track-pitch-step-group,.track-left .expand-toggle,.track-left .velocity-toggle,.track-left .pattern-tools-toggle{display:none!important}.track-left .mute-button{grid-column:1;grid-row:1;width:36px;height:36px;font-size:11px;border-radius:4px}.track-left .solo-button{grid-column:2;grid-row:1;width:36px;height:36px;font-size:11px;border-radius:4px}.track-left .track-name{grid-column:3;grid-row:1;width:auto;min-width:60px;max-width:80px;height:36px;padding:0 8px;font-size:12px;cursor:pointer;position:relative;background:var(--color-surface-elevated);border-radius:4px;transition:background .1s ease}.track-left .track-name:active{background:var(--color-surface-hover)}.track-left .track-name:after{content:"▾";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:10px;color:var(--color-text-muted);transition:transform .2s ease}.track-row-wrapper:has(.track-drawer) .track-name:after{transform:translateY(-50%) rotate(180deg)}.track-right{display:none}.track-row .steps{flex:1;min-width:0;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:0;gap:2px}.track-row .steps::-webkit-scrollbar{display:none}.track-row .step-cell{width:36px;height:36px;min-width:36px;border-radius:4px;border-width:2px}.track-row .step-cell.beat-start{border-left-width:2px}.track-row .step-cell.playing{border-width:2px}.panel-animation-container,.fm-controls-panel,.inline-drawer{display:none!important}}.track-skeleton{display:flex;align-items:center;gap:8px;padding:6px 0;min-height:44px;animation:skeleton-fade-in .3s ease-out forwards;animation-delay:var(--skeleton-delay, 0s);opacity:0}@keyframes skeleton-fade-in{0%{opacity:0}to{opacity:1}}@keyframes skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-left,.skeleton-drag,.skeleton-name,.skeleton-btn,.skeleton-steps,.skeleton-step{background:linear-gradient(90deg,var(--color-surface-elevated) 25%,var(--color-surface-hover) 50%,var(--color-surface-elevated) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:4px}.skeleton-left{display:flex;align-items:center;gap:4px;flex-shrink:0;position:sticky;left:0;background:var(--color-surface);z-index:1;padding-right:8px}.skeleton-drag{width:20px;height:20px}.skeleton-name{width:80px;height:24px}.skeleton-btn{width:32px;height:28px}.skeleton-steps{display:flex;gap:4px;flex:1;min-width:0}.skeleton-step{width:40px;height:32px;flex-shrink:0}@media(max-width:768px){.skeleton-left{display:none}.skeleton-step{width:36px;height:36px}.track-skeleton{min-height:48px}}@media(prefers-reduced-motion:reduce){.track-skeleton{animation:none;opacity:1}.skeleton-left,.skeleton-drag,.skeleton-name,.skeleton-btn,.skeleton-steps,.skeleton-step{animation:none;background:var(--color-surface-elevated)}}.xy-pad-container{display:flex;flex-direction:column;align-items:center;gap:4px}.xy-pad-label-y-external{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;align-self:flex-start;margin-left:2px}.xy-pad{position:relative;background:var(--color-bg);border:2px solid var(--color-border);border-radius:8px;cursor:crosshair;touch-action:none;-webkit-user-select:none;user-select:none;overflow:hidden}.xy-pad.dragging{border-color:var(--accent-color, var(--color-cyan));box-shadow:0 0 12px #00bcd44d}.xy-pad.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.xy-pad-grid{position:absolute;inset:0;pointer-events:none}.xy-pad-line{position:absolute;background:var(--color-border)}.xy-pad-line.horizontal{left:0;right:0;top:50%;height:1px}.xy-pad-line.vertical{top:0;bottom:0;left:50%;width:1px}.xy-pad-crosshair{position:absolute;pointer-events:none;transform:translate(-50%,-50%)}.xy-pad-crosshair-h,.xy-pad-crosshair-v{position:absolute;background:var(--accent-color, var(--color-cyan));opacity:.3}.xy-pad-crosshair-h{left:-200%;right:-200%;top:50%;height:1px;transform:translateY(-50%)}.xy-pad-crosshair-v{top:-200%;bottom:-200%;left:50%;width:1px;transform:translate(-50%)}.xy-pad.dragging .xy-pad-crosshair-h,.xy-pad.dragging .xy-pad-crosshair-v{opacity:.5}.xy-pad-puck{position:absolute;width:14px;height:14px;background:var(--accent-color, var(--color-cyan));border:2px solid var(--color-text);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 0 8px #00000080,0 0 12px var(--accent-color, var(--color-cyan));transition:transform .05s ease}.xy-pad.dragging .xy-pad-puck{transform:translate(-50%,-50%) scale(1.2);box-shadow:0 0 12px #00000080,0 0 20px var(--accent-color, var(--color-cyan))}.xy-pad-bottom-labels{display:flex;justify-content:space-between;width:100%;padding:0 2px}.xy-pad-label-x-external{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.xy-pad-values-external{font-size:9px;font-family:monospace;color:var(--color-text-dimmed)}.xy-pad.dragging~.xy-pad-bottom-labels .xy-pad-values-external{color:var(--accent-color, var(--color-cyan))}.scale-selector{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem;background:var(--color-surface-elevated);border-radius:4px;transition:background-color .2s ease}.scale-selector.locked{background:var(--color-surface-hover);box-shadow:0 0 0 1px var(--color-purple)}.scale-controls{display:flex;align-items:center;gap:.25rem}.scale-root-select,.scale-type-select{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-surface-active);border-radius:3px;padding:.25rem .5rem;font-size:.75rem;cursor:pointer;transition:border-color .2s ease}.scale-root-select:hover,.scale-type-select:hover{border-color:var(--color-purple)}.scale-root-select:focus,.scale-type-select:focus{outline:none;border-color:var(--color-purple);box-shadow:0 0 0 2px var(--color-purple-muted)}.scale-root-select{width:3rem}.scale-type-select{width:8rem}.scale-lock-btn{background:transparent;border:1px solid var(--color-surface-active);border-radius:3px;padding:.25rem .5rem;font-size:.875rem;cursor:pointer;transition:all .2s ease;line-height:1}.scale-lock-btn:hover{background:var(--color-surface-hover);border-color:var(--color-purple)}.scale-lock-btn.locked{background:var(--color-purple);border-color:var(--color-purple)}.scale-lock-btn:focus{outline:none;box-shadow:0 0 0 2px var(--color-purple-muted)}.scale-lock-btn:disabled{opacity:.5;cursor:not-allowed}.scale-display{font-size:.7rem;color:var(--color-text-muted);white-space:nowrap;display:none}@media(max-width:768px){.scale-type-select{width:6rem}.scale-display{display:inline}}@media(max-width:480px){.scale-selector{flex-direction:column;align-items:flex-start;gap:.25rem}.scale-type-select,.scale-root-select{width:100%}}.transport{display:flex;flex-direction:column;padding:16px 0;border-bottom:1px solid var(--color-border);margin-bottom:16px}.transport-controls{display:flex;align-items:center;gap:24px}.transport-control-group{display:flex;align-items:stretch;gap:1px;margin-left:auto;background:var(--color-border-hover);border-radius:8px;overflow:hidden}.control-group-btn{display:flex;align-items:center;justify-content:center;gap:6px;height:36px;padding:0 14px;border:none;background:var(--color-surface-elevated);color:var(--color-text-muted);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease}.control-group-btn:hover:not(:disabled){background:var(--color-surface-active);color:var(--color-text)}.control-group-btn:disabled{opacity:.4;cursor:not-allowed}.control-group-btn .btn-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.control-group-btn .btn-badge{display:flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--color-error);color:#fff;font-size:10px;font-weight:700}.unmute-btn{border-radius:8px 0 0 8px}.unmute-btn.has-muted{color:var(--color-text)}.unmute-btn.has-muted:hover{background:var(--color-error-muted, rgba(239, 83, 80, .15))}.fx-btn .btn-badge{min-width:auto;width:18px;height:18px;padding:0;font-size:11px;background:var(--color-success)}.fx-btn .btn-badge.bypassed{background:var(--color-warning)}.fx-btn.has-effects{color:var(--color-text)}.fx-btn.expanded,.mixer-btn.active{background:var(--color-surface-active);color:var(--color-text)}.mixer-btn.has-adjustments{color:var(--color-text)}.pitch-btn{border-radius:0 8px 8px 0}.pitch-btn.active{background:var(--color-surface-active);color:var(--color-text)}.transport-control-group:has(.pitch-btn) .mixer-btn{border-radius:0}.transport-fx-panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease-out;overflow:hidden}.transport-fx-panel.expanded{grid-template-rows:1fr}.fx-panel-content{min-height:0;overflow:hidden;display:flex;flex-direction:column;gap:16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:0;margin-top:0;transition:padding .25s ease-out,margin-top .25s ease-out}.transport-fx-panel.expanded .fx-panel-content{padding:16px;margin-top:16px}.fx-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:12px;border-bottom:1px solid var(--color-border)}.fx-title{font-size:14px;font-weight:600;color:var(--color-text);margin:0}.fx-master-toggle{display:flex;align-items:center;gap:8px;padding:8px 14px;border:2px solid var(--color-success);border-radius:6px;background:var(--color-success-muted, rgba(78, 205, 196, .15));color:var(--color-success);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease}.fx-master-toggle:hover:not(:disabled){background:var(--color-success-muted, rgba(78, 205, 196, .25));filter:brightness(1.1)}.fx-master-toggle:disabled{opacity:.4;cursor:not-allowed;border-color:var(--color-border);background:transparent;color:var(--color-text-muted)}.fx-master-toggle.bypassed{border-color:var(--color-warning);background:var(--color-warning-muted, rgba(255, 152, 0, .15));color:var(--color-warning)}.fx-master-toggle.bypassed:hover:not(:disabled){background:var(--color-warning-muted, rgba(255, 152, 0, .25))}.master-indicator{font-size:14px;line-height:1}.master-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.fx-groups{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.fx-controls-with-xy{display:flex;gap:12px;align-items:flex-start}.fx-sliders{flex:1;display:flex;flex-direction:column;gap:8px}.fx-group{padding:12px;background:var(--color-surface);border-radius:8px;border:1px solid var(--color-border)}.fx-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}.fx-groups>.fx-group:nth-child(1) .fx-label{color:var(--color-purple)}.fx-groups>.fx-group:nth-child(2) .fx-label{color:var(--color-blue)}.fx-groups>.fx-group:nth-child(3) .fx-label{color:var(--color-green)}.fx-groups>.fx-group:nth-child(4) .fx-label{color:var(--color-warning)}.fx-controls{display:flex;flex-direction:column;gap:8px}.fx-param{display:flex;align-items:center;gap:8px}.fx-param label{font-size:10px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;min-width:50px}.fx-param input[type=range]{flex:1;min-width:60px;height:4px;-webkit-appearance:none;appearance:none;background:var(--color-surface-hover);border-radius:2px;cursor:pointer}.fx-param input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;background:var(--color-cyan);border-radius:50%;cursor:pointer;transition:transform .1s ease}.fx-param input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}.fx-groups>.fx-group:nth-child(1) input[type=range]::-webkit-slider-thumb{background:var(--color-purple)}.fx-groups>.fx-group:nth-child(2) input[type=range]::-webkit-slider-thumb{background:var(--color-blue)}.fx-groups>.fx-group:nth-child(3) input[type=range]::-webkit-slider-thumb{background:var(--color-green)}.fx-groups>.fx-group:nth-child(4) input[type=range]::-webkit-slider-thumb{background:var(--color-warning)}.fx-param select{flex:1;background:var(--color-surface-hover);border:1px solid var(--color-surface-active);border-radius:4px;color:var(--color-text);font-size:11px;padding:4px 8px;cursor:pointer}.fx-param select:focus{outline:none;border-color:var(--color-cyan)}.fx-value{font-size:11px;color:var(--color-text-muted);font-family:monospace;min-width:40px;text-align:right}@media(max-width:768px){.transport{display:none}}.play-button{width:56px;height:56px;border:none;border-radius:50%;background:var(--color-success);color:#fff;font-size:24px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.play-button:before{content:"";position:absolute;inset:0;background:#ffffff26;border-radius:50%;transform:scaleX(0);transform-origin:left center;transition:transform .25s ease-out}.play-button:hover:before{transform:scaleX(1)}.play-button:active:before{transform:scaleX(1);transition:transform 0ms}.play-button:hover{filter:brightness(1.1);transform:scale(1.05)}.play-button.playing{background:var(--color-error)}.play-button.playing:hover{filter:brightness(1.15)}.play-button.primary-action{box-shadow:0 0 0 3px var(--color-accent),0 4px 12px #e85a304d;transform:scale(1.05)}.play-button.primary-action:hover{box-shadow:0 0 0 3px var(--color-accent-light),0 4px 16px #e85a3066;transform:scale(1.1)}.play-button.beat-pulse{animation:beat-pulse var(--beat-pulse-duration, .1s) ease-out}@keyframes beat-pulse{0%{box-shadow:0 0 #4ecdc480}to{box-shadow:0 0 0 8px #4ecdc400}}@media(prefers-reduced-motion:reduce){.play-button.beat-pulse{animation:none}.play-button:before{transition:none}}.tempo-control{display:flex;align-items:center;gap:12px}.tempo-control label{font-size:14px;color:var(--color-text-muted);font-weight:500}.tempo-control input[type=range]{width:150px;accent-color:var(--color-success)}.tempo-value{font-size:18px;font-weight:700;color:var(--color-text);min-width:40px}.swing-control{display:flex;align-items:center;gap:12px}.swing-control label{font-size:14px;color:var(--color-text-muted);font-weight:500}.swing-control input[type=range]{width:100px;accent-color:var(--color-yellow)}.swing-value{font-size:14px;font-weight:700;color:var(--color-yellow);min-width:40px}@media(max-width:768px)and (orientation:landscape){.transport{display:flex;padding:8px 0;margin-bottom:8px}.transport-controls{gap:12px}.play-button{width:44px;height:44px;font-size:18px}.tempo-control{gap:8px}.tempo-control input[type=range]{width:100px}.tempo-value{font-size:14px;min-width:32px}.swing-control{gap:8px}.swing-control input[type=range]{width:80px}.scale-selector,.transport-control-group,.transport-fx-panel{display:none!important}}.transport-bar{display:none;align-items:center;gap:16px;padding:12px 16px;background:var(--color-bg);border-radius:12px;margin-bottom:12px}@media(max-width:768px){.transport-bar{display:flex}}.transport-play{width:48px;height:48px;border:2px solid var(--color-success);border-radius:50%;background:transparent;color:var(--color-success);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0}.transport-play:active{transform:scale(.95)}.transport-play.playing{background:var(--color-error);border-color:var(--color-error);color:#fff}.transport-value{display:flex;flex-direction:column;align-items:center;padding:8px 16px;background:var(--color-surface-elevated);border-radius:8px;cursor:ns-resize;user-select:none;-webkit-user-select:none;touch-action:none;transition:background .1s ease}.transport-value:active{background:var(--color-surface-hover)}.transport-label{font-size:10px;font-weight:600;color:var(--color-text-dimmed);text-transform:uppercase;letter-spacing:.5px}.transport-number{font-size:20px;font-weight:700;color:var(--color-text);font-family:monospace;min-width:50px;text-align:center}@keyframes dragHint{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.transport-value:after{content:"↕";font-size:10px;color:var(--color-surface-active);margin-top:2px}.cursor-overlay{position:absolute;inset:0;pointer-events:none;z-index:100;overflow:hidden}.remote-cursor{position:absolute;transform:translate(-2px,-2px);transition:left .1s ease-out,top .1s ease-out,opacity .5s ease-out;display:flex;flex-direction:column;align-items:flex-start;gap:2px}.cursor-pointer{filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.cursor-label{font-size:11px;font-weight:500;color:#fff;padding:2px 6px;border-radius:3px;white-space:nowrap;transform:translate(12px);box-shadow:0 1px 3px #0000004d}@media(max-width:768px){.cursor-overlay{display:none}}.mixer-panel-container{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease-out;overflow:hidden}.mixer-panel-container.expanded{grid-template-rows:1fr}.mixer-panel-content{min-height:0;overflow:hidden}.mixer-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:16px;margin-bottom:16px}.mixer-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--color-border)}.mixer-title{font-size:14px;font-weight:600;color:var(--color-text);margin:0}.mixer-tracks{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px}.mixer-channel{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:80px;padding:12px 8px;background:var(--color-surface-elevated);border-radius:8px;border:1px solid var(--color-border);transition:opacity .2s}.mixer-channel.muted{opacity:.5}.mixer-channel .channel-category-bar{width:100%;height:3px;border-radius:2px;background:var(--color-text-muted)}.mixer-channel[data-category=drums] .channel-category-bar{background:var(--color-accent)}.mixer-channel[data-category=bass] .channel-category-bar{background:var(--color-purple)}.mixer-channel[data-category=keys] .channel-category-bar{background:var(--color-cyan)}.mixer-channel[data-category=melodic] .channel-category-bar{background:var(--color-teal)}.mixer-channel[data-category=strings] .channel-category-bar,.mixer-channel[data-category=brass] .channel-category-bar{background:var(--color-info)}.mixer-channel[data-category=fx] .channel-category-bar{background:var(--color-text-muted)}.channel-name{font-size:11px;font-weight:500;color:var(--color-text);text-align:center;max-width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.channel-steps{font-size:10px;color:var(--color-text-muted)}.channel-buttons{display:flex;gap:4px}.channel-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-muted);font-size:10px;font-weight:600;cursor:pointer;transition:all .15s}.channel-btn:hover{background:var(--color-surface-hover)}.channel-btn.mute.active{background:var(--color-warning);border-color:var(--color-warning);color:#000}.channel-btn.solo.active{background:var(--color-yellow);border-color:var(--color-yellow);color:var(--color-bg)}.channel-fader-container{position:relative;width:24px;height:120px}.channel-fader-track{position:absolute;left:50%;transform:translate(-50%);width:8px;height:100%;background:var(--color-surface);border-radius:4px;overflow:hidden}.channel-fader-fill{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,var(--color-accent),var(--color-accent-light, #ff8f65));border-radius:4px;transition:height .05s}.channel-fader{position:absolute;width:120px;height:24px;left:50%;top:50%;transform:translate(-50%) translateY(-50%) rotate(-90deg);transform-origin:center;appearance:none;-webkit-appearance:none;background:transparent;cursor:pointer;opacity:0}.channel-fader::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:var(--color-accent);border-radius:50%;cursor:grab}.channel-fader::-moz-range-thumb{width:20px;height:20px;background:var(--color-accent);border-radius:50%;border:none;cursor:grab}.channel-fader:active::-webkit-slider-thumb{cursor:grabbing}.channel-fader:active::-moz-range-thumb{cursor:grabbing}.channel-volume-value{font-size:11px;font-weight:500;color:var(--color-text);min-width:36px;text-align:center}.channel-swing{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%;padding-top:8px;border-top:1px solid var(--color-border)}.channel-swing .swing-label{font-size:9px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.channel-swing .swing-slider{width:60px;height:4px;appearance:none;-webkit-appearance:none;background:var(--color-surface);border-radius:2px;cursor:pointer}.channel-swing .swing-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:var(--color-text);border-radius:50%;cursor:grab}.channel-swing .swing-slider::-moz-range-thumb{width:12px;height:12px;background:var(--color-text);border-radius:50%;border:none;cursor:grab}.channel-swing .swing-value{font-size:10px;color:var(--color-text-muted)}.mixer-tracks::-webkit-scrollbar{height:6px}.mixer-tracks::-webkit-scrollbar-track{background:var(--color-surface);border-radius:3px}.mixer-tracks::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.mixer-tracks::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@media(max-width:768px){.mixer-tracks{flex-direction:column;gap:8px}.mixer-channel{flex-direction:row;align-items:center;min-width:100%;padding:8px 12px;gap:12px}.mixer-channel .channel-category-bar{width:4px;height:40px;order:-1}.channel-name{flex:1;text-align:left;max-width:none}.channel-steps{display:none}.channel-fader-container{width:100px;height:24px}.channel-fader-track{width:100%;height:8px;left:0;transform:none}.channel-fader-fill{width:auto;height:100%;left:0;bottom:0;right:auto;background:linear-gradient(to right,var(--color-accent),var(--color-accent-light, #ff8f65))}.channel-fader{width:100%;height:24px;left:0;top:0;transform:none}.channel-swing{flex-direction:row;padding-top:0;padding-left:12px;border-top:none;border-left:1px solid var(--color-border);gap:8px}}@media(prefers-reduced-motion:reduce){.channel-fader-fill,.mixer-panel-container{transition:none}}.loop-ruler{height:24px;background:var(--color-surface-elevated);border-radius:4px;margin-bottom:8px;position:relative;cursor:crosshair;user-select:none;-webkit-user-select:none}.loop-ruler.dragging{cursor:ew-resize}.ruler-markers{position:absolute;inset:0;pointer-events:none}.ruler-marker{position:absolute;top:0;height:100%;pointer-events:none}.ruler-marker.beat{width:1px;background:var(--color-border);opacity:.3}.ruler-marker.page{width:2px;background:var(--color-border-light);opacity:.6}.ruler-marker.page .marker-label{position:absolute;top:2px;left:4px;font-size:10px;color:var(--color-text-muted);font-weight:500}.loop-region{position:absolute;top:2px;bottom:2px;background:#4a9ece4d;border-radius:2px;pointer-events:none}.loop-region.preview{background:#4a9ece33;border:1px dashed var(--color-info)}.loop-bracket{position:absolute;top:0;bottom:0;width:4px;background:var(--color-info)}.loop-bracket.start{left:0;border-radius:2px 0 0 2px}.loop-bracket.end{right:0;border-radius:0 2px 2px 0}.shift-click-marker{position:absolute;top:0;bottom:0;width:2px;background:var(--color-warning);animation:marker-pulse 1s ease-in-out infinite}@keyframes marker-pulse{0%,to{opacity:1}50%{opacity:.4}}.ruler-playhead{position:absolute;top:0;bottom:0;width:2px;background:var(--color-playhead);pointer-events:none;z-index:10}.loop-ruler.has-loop,.loop-ruler:hover{background:var(--color-surface-hover)}@media(prefers-reduced-motion:reduce){.shift-click-marker{animation:none}}@media(max-width:768px){.loop-ruler{height:32px}.ruler-marker.page .marker-label{font-size:11px;top:6px}}.pitch-overview{display:flex;flex-direction:column;gap:8px;padding:16px;background:var(--color-surface);border-radius:8px;border:1px solid var(--color-border);margin-bottom:16px}.pitch-overview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding-bottom:12px;border-bottom:1px solid var(--color-border)}.pitch-overview-title{font-size:14px;font-weight:600;color:var(--color-text);margin:0}.pitch-overview-info{font-size:11px;color:var(--color-text-muted)}.pitch-overview-content{display:flex;gap:12px;align-items:stretch}.pitch-overview-y-axis{display:flex;flex-direction:column;justify-content:space-between;width:32px;flex-shrink:0;padding:12px 0}.pitch-overview-y-axis .range-label{font-size:10px;font-family:var(--font-mono, "SF Mono", "Consolas", monospace);color:var(--color-text-muted);text-align:right}.pitch-overview-grid{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.pitch-overview-chords{display:flex;height:12px;gap:1px}.chord-cell{flex:1;min-width:0;height:12px;background:var(--color-surface-elevated);border-radius:2px;transition:background .1s ease}.chord-cell.has-chord{background:var(--color-info);opacity:.6}.chord-cell.playing{background:var(--color-yellow);opacity:.8}.chord-cell.has-chord.playing{background:var(--color-yellow);opacity:1}.pitch-overview-bars{display:flex;height:100px;gap:1px;position:relative;background:var(--color-surface-elevated);border-radius:6px;padding:4px}.pitch-bar-cell{flex:1;min-width:0;height:100%;position:relative;border-radius:3px;transition:background .1s ease}.pitch-bar-cell.beat-start{background:#ffffff08}.pitch-bar-cell.page-end{border-right:2px solid rgba(255,255,255,.15);margin-right:2px}.pitch-bar-cell.playing{background:#ffc8644d}.pitch-bar-cell.out-of-scale{background:#e553}.pitch-dot{position:absolute;left:50%;transform:translate(-50%,-50%);width:6px;height:6px;border-radius:50%;background:var(--color-accent);box-shadow:0 0 4px #4ecdc480;transition:all .1s ease}.pitch-dot.out-of-scale{background:var(--color-error);box-shadow:0 0 4px #ee555580}.pitch-bar-cell.playing .pitch-dot{transform:translate(-50%,-50%) scale(1.4);background:var(--color-yellow);box-shadow:0 0 8px #ffd93db3}.pitch-bar-cell:hover{background:#ffffff14}.pitch-bar-cell:hover .pitch-dot{transform:translate(-50%,-50%) scale(1.3)}@media(max-width:768px){.pitch-overview{display:none}}.shortcuts-backdrop{position:fixed;inset:0;background:#000000bf;backdrop-filter:blur(8px) saturate(150%);-webkit-backdrop-filter:blur(8px) saturate(150%);z-index:1050;display:flex;align-items:center;justify-content:center;animation:shortcuts-backdrop-fade .2s ease-out}@keyframes shortcuts-backdrop-fade{0%{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}to{opacity:1;-webkit-backdrop-filter:blur(8px) saturate(150%);backdrop-filter:blur(8px) saturate(150%)}}.shortcuts-panel{--panel-bg: rgba(22, 22, 24, .97);--panel-border: rgba(255, 255, 255, .08);--panel-glow: rgba(232, 90, 48, .15);background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:16px;box-shadow:0 0 0 1px #0000004d,0 24px 80px #00000080,0 0 120px var(--panel-glow),inset 0 1px #ffffff0d;max-width:420px;width:calc(100% - 48px);max-height:80vh;overflow:hidden;display:flex;flex-direction:column;animation:shortcuts-panel-enter .3s cubic-bezier(.16,1,.3,1);transform-origin:center center}@keyframes shortcuts-panel-enter{0%{transform:scale(.95) translateY(10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.shortcuts-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 16px;border-bottom:1px solid rgba(255,255,255,.06);background:linear-gradient(180deg,rgba(255,255,255,.03) 0%,transparent 100%)}.shortcuts-title{font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:15px;font-weight:600;letter-spacing:-.01em;color:#fffffff2;margin:0;display:flex;align-items:center;gap:10px}.shortcuts-title:before{content:"";display:inline-block;width:3px;height:14px;background:linear-gradient(180deg,#e85a30,#ff7a50);border-radius:2px}.shortcuts-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:8px;color:#fff6;cursor:pointer;transition:all .15s ease}.shortcuts-close:hover{background:#ffffff14;border-color:#ffffff1a;color:#ffffffe6}.shortcuts-close:focus-visible{outline:none;box-shadow:0 0 0 2px #e85a3080}.shortcuts-close svg{width:14px;height:14px}.shortcuts-content{padding:6px 20px 20px;overflow-y:auto;flex:1}.shortcuts-section{margin-top:18px}.shortcuts-section:first-child{margin-top:12px}.shortcuts-section-title{font-family:SF Pro Text,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#ffffff59;margin:0 0 10px;padding-left:1px}.shortcuts-list{display:flex;flex-direction:column;gap:6px}.shortcut-row{display:grid;grid-template-columns:160px 1fr;align-items:center;gap:16px;padding:8px 0;border-radius:6px;transition:background .15s ease;animation:shortcut-row-fade .3s ease-out backwards}.shortcuts-section:nth-child(1) .shortcut-row:nth-child(1){animation-delay:50ms}.shortcuts-section:nth-child(1) .shortcut-row:nth-child(2){animation-delay:80ms}.shortcuts-section:nth-child(2) .shortcut-row:nth-child(1){animation-delay:.11s}.shortcuts-section:nth-child(2) .shortcut-row:nth-child(2){animation-delay:.14s}.shortcuts-section:nth-child(3) .shortcut-row:nth-child(1){animation-delay:.17s}.shortcuts-section:nth-child(4) .shortcut-row:nth-child(1){animation-delay:.2s}@keyframes shortcut-row-fade{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.shortcut-keys{display:flex;align-items:center;gap:5px;justify-content:flex-start}.shortcut-key{display:inline-flex;align-items:center;justify-content:center;height:26px;min-width:26px;padding:0 8px;background:linear-gradient(180deg,#ffffff1a,#ffffff0d);border:1px solid rgba(255,255,255,.12);border-radius:6px;font-family:SF Mono,JetBrains Mono,Fira Code,Consolas,monospace;font-size:11px;font-weight:500;letter-spacing:.02em;color:#e85a30;white-space:nowrap;box-shadow:0 1px 2px #0003,inset 0 1px #ffffff0d;text-shadow:0 0 12px rgba(232,90,48,.4)}.shortcut-alt-separator{font-family:SF Pro Text,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:11px;font-weight:400;color:#ffffff40;padding:0 2px}.shortcut-separator{font-family:SF Pro Text,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:10px;font-weight:500;color:#ffffff4d}.shortcut-action{font-family:SF Pro Text,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:13px;font-weight:400;color:#ffffffbf;letter-spacing:-.01em}.shortcuts-footer{padding:14px 20px;border-top:1px solid rgba(255,255,255,.06);background:#0003}.shortcuts-hint{font-family:SF Pro Text,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:11px;font-weight:400;color:#ffffff59;text-align:center;margin:0;letter-spacing:.01em}.shortcuts-hint kbd{display:inline-flex;align-items:center;justify-content:center;height:18px;min-width:18px;padding:0 5px;margin:0 3px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:4px;font-family:SF Mono,JetBrains Mono,Fira Code,Consolas,monospace;font-size:10px;font-weight:500;color:#fff9;vertical-align:middle}.shortcuts-content::-webkit-scrollbar{width:6px}.shortcuts-content::-webkit-scrollbar-track{background:transparent}.shortcuts-content::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.shortcuts-content::-webkit-scrollbar-thumb:hover{background:#ffffff40}.portrait-header{display:none;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--color-surface);border-bottom:1px solid var(--color-border);gap:12px}.portrait-play-btn{width:48px;height:48px;border:none;border-radius:50%;background:var(--color-success);color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0;position:relative;overflow:hidden}.portrait-play-btn:hover{filter:brightness(1.1);transform:scale(1.05)}.portrait-play-btn.playing{background:var(--color-error)}.portrait-play-btn.beat-pulse{animation:portrait-beat-pulse var(--beat-pulse-duration, .1s) ease-out}@keyframes portrait-beat-pulse{0%{box-shadow:0 0 #4ecdc480}to{box-shadow:0 0 0 8px #4ecdc400}}.portrait-title{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;min-width:0;overflow:hidden}.portrait-app-name{font-size:16px;font-weight:700;color:var(--color-brand);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portrait-session-name{font-size:12px;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.portrait-bpm{display:flex;flex-direction:column;align-items:center;gap:0;min-width:48px;flex-shrink:0}.portrait-bpm-value{font-size:18px;font-weight:700;color:var(--color-text);font-variant-numeric:tabular-nums}.portrait-bpm-label{font-size:9px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.portrait-header-actions{display:flex;gap:8px;flex-shrink:0}.portrait-qr-btn{width:44px;height:44px;border:none;border-radius:8px;background:var(--color-surface-elevated);color:var(--color-text);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.portrait-qr-btn:hover{filter:brightness(1.1);transform:scale(1.05)}.portrait-qr-btn:active{transform:scale(.95)}.portrait-share-btn{width:44px;height:44px;border:none;border-radius:8px;background:var(--color-accent);color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.portrait-share-btn:hover{filter:brightness(1.1);transform:scale(1.05)}.portrait-share-btn:active{transform:scale(.95)}.portrait-share-btn.copied{background:var(--color-success)}@media(max-width:768px)and (orientation:portrait){.portrait-header{display:flex}}@media(prefers-reduced-motion:reduce){.portrait-play-btn.beat-pulse{animation:none}}.portrait-grid{display:none;flex-direction:column;gap:2px;padding:8px;background:var(--color-surface);border-radius:12px;position:relative;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;will-change:transform;transform:translateZ(0)}.portrait-grid-header{display:grid;grid-template-columns:28px repeat(8,1fr);gap:2px;padding-bottom:4px;border-bottom:1px solid var(--color-border);margin-bottom:4px}.portrait-grid-label-spacer{width:28px}.portrait-step-number{font-size:10px;font-weight:600;color:var(--color-text-muted);text-align:center;padding:2px 0;font-variant-numeric:tabular-nums;transition:color .1s ease}.portrait-step-number.active{color:var(--color-playhead)}.portrait-grid-body{display:flex;flex-direction:column;gap:2px}.portrait-track-row{display:grid;grid-template-columns:28px repeat(8,1fr);gap:2px;align-items:center;transition:opacity .15s ease}.portrait-track-row.muted{opacity:.4}.portrait-track-row.soloed{background:#f7ce461a;border-radius:4px}.portrait-track-label{width:28px;height:32px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;flex-shrink:0}.portrait-step-cell{height:32px;background:var(--color-surface-elevated);border:2px solid var(--color-border);border-radius:6px;position:relative;pointer-events:none;will-change:transform,opacity;transform:translateZ(0)}.portrait-step-cell.beat-start{border-left-color:var(--color-border-light);border-left-width:3px}.portrait-step-cell.active{background:var(--color-accent);border-color:var(--color-accent-light)}.portrait-step-cell.playing{border-color:var(--color-playhead);border-width:3px;animation:portrait-cell-pulse .15s ease-out}.portrait-step-cell.active.playing{border-color:var(--color-playhead);box-shadow:0 0 8px var(--color-playhead)}@keyframes portrait-cell-pulse{0%{transform:scale(1.1);opacity:1}to{transform:scale(1);opacity:1}}.portrait-playing-indicator{position:absolute;inset:3px;background:#ffffff4d;border-radius:3px;animation:portrait-indicator-flash .1s ease-out}@keyframes portrait-indicator-flash{0%{opacity:.8}to{opacity:.3}}.portrait-page-indicator{display:flex;justify-content:center;gap:8px;padding-top:12px;margin-top:8px;border-top:1px solid var(--color-border)}.portrait-page-dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--color-surface-active);cursor:pointer;padding:0;transition:all .2s ease;pointer-events:auto}.portrait-page-dot:hover{background:var(--color-text-muted);transform:scale(1.2)}.portrait-page-dot.active{background:var(--color-accent);transform:scale(1.3)}.portrait-playhead-glow{position:absolute;top:0;bottom:0;left:calc(28px + (var(--playhead-column) - 1) * (100% - 28px - 14px) / 8 + 2px);width:calc((100% - 42px)/8 - 2px);background:linear-gradient(180deg,#4ecdc426,#4ecdc440,#4ecdc426);border-radius:4px;pointer-events:none;z-index:1;transition:left .05s linear;will-change:left}.portrait-grid .progress-bar-container{height:6px;margin-bottom:16px}.portrait-grid .progress-bar-fill{opacity:.9;box-shadow:0 0 8px var(--color-playhead)}@media(max-width:768px)and (orientation:portrait){.portrait-grid{display:flex}}@media(prefers-reduced-motion:reduce){.portrait-step-cell.playing,.portrait-playing-indicator{animation:none}.portrait-playhead-glow,.portrait-page-dot{transition:none}}.orientation-hint{display:flex;align-items:center;justify-content:center;gap:6px;background:#ff6b351a;border:1px solid rgba(255,107,53,.2);color:#ff8a5c;padding:6px 12px;border-radius:6px;font-size:11px;margin:0 8px 6px;animation:hint-fade-in .3s ease-out}@keyframes hint-fade-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.orientation-hint-icon{font-size:14px;animation:rotate-hint 2.5s ease-in-out infinite;opacity:.9}@keyframes rotate-hint{0%,to{transform:rotate(0)}25%{transform:rotate(-15deg)}75%{transform:rotate(15deg)}}.orientation-hint-text{font-weight:600;letter-spacing:.3px}.orientation-hint-dismiss{background:none;border:none;color:#ff8a5c;cursor:pointer;font-size:12px;padding:4px 8px;margin-left:2px;opacity:.6;transition:opacity .15s}.orientation-hint-dismiss:hover{opacity:1}@media(orientation:landscape),(min-width:769px){.orientation-hint{display:none}}.orientation-hint.prominent{background:#ff6b3526;border-color:#ff6b3559;padding:8px 14px;font-size:12px}.orientation-hint.prominent .orientation-hint-icon{font-size:16px}.orientation-hint-dismiss:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.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}@media(prefers-reduced-motion:reduce){.orientation-hint-icon{animation:none}}.step-sequencer{background:var(--color-surface);border-radius:12px;padding:24px;width:100%;max-width:calc(100vw - 48px);position:relative;box-sizing:border-box}.step-sequencer.portrait-mode,.step-sequencer.landscape-mode{animation:orientation-fade-in .3s ease-out}@keyframes orientation-fade-in{0%{opacity:.7;transform:scale(.98)}to{opacity:1;transform:scale(1)}}@media(prefers-reduced-motion:reduce){.step-sequencer.portrait-mode,.step-sequencer.landscape-mode{animation:none}}.progress-bar-container{height:3px;width:100%;background:var(--color-surface-elevated);border-radius:2px;margin-bottom:12px;overflow:hidden;opacity:0;transition:opacity .2s ease}.progress-bar-container.visible{opacity:1}.progress-bar-fill{height:100%;width:var(--progress-position, 0%);background:var(--color-text-muted);border-radius:2px;transition:width .05s cubic-bezier(.4,0,.2,1);opacity:.6}@media(prefers-reduced-motion:reduce){.progress-bar-fill{transition:none}}.pitch-panel-container{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease-out;overflow:hidden}.pitch-panel-container.expanded{grid-template-rows:1fr}.pitch-panel-content{min-height:0;overflow:hidden;padding:8px 0 16px}@media(max-width:768px){.pitch-panel-container{display:none}}.sequencer-content{display:flex;gap:0}.tracks{flex:1;min-width:0;overflow-x:auto;padding-bottom:8px}.tracks-inner{display:inline-flex;flex-direction:column;gap:2px;min-width:100%;min-height:182px}@media(max-width:768px){.tracks-inner{min-height:198px}}.tracks::-webkit-scrollbar{height:8px}.tracks::-webkit-scrollbar-track{background:var(--color-surface-elevated);border-radius:4px}.tracks::-webkit-scrollbar-thumb{background:var(--color-surface-active);border-radius:4px}.tracks::-webkit-scrollbar-thumb:hover{background:var(--color-border-hover)}.step-sequencer.published{box-shadow:inset 0 0 0 1px var(--color-purple-muted),0 0 20px #9b59b61a}.step-sequencer.published .sequencer-content{pointer-events:none}.step-sequencer.published .tracks{position:relative;pointer-events:auto}.step-sequencer.published .track-row{pointer-events:none}.step-sequencer.published .tracks:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#9b59b608,#9b59b60f,#9b59b608);pointer-events:none;z-index:10;border-radius:4px}.step-sequencer.published .tracks:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(155,89,182,.02) 2px,rgba(155,89,182,.02) 4px);pointer-events:none;z-index:11;border-radius:4px}.step-sequencer.published .track-row{filter:saturate(.85)}.step-sequencer.published .step-cell.playing:before{filter:saturate(1.3)}.step-sequencer.published .transport{pointer-events:auto}.step-sequencer.published .transport .tempo-control,.step-sequencer.published .transport .swing-control{pointer-events:none;opacity:.5;cursor:default}.step-sequencer.published .transport .tempo-control input,.step-sequencer.published .transport .swing-control input{cursor:default}.step-sequencer.published .transport-bar .transport-value{pointer-events:none;opacity:.5;cursor:default}.step-sequencer.published .transport-bar .transport-value:after{display:none}.selection-badge{position:fixed;bottom:80px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--color-info);color:#fff;border-radius:20px;font-size:13px;font-weight:500;box-shadow:0 2px 8px #0000004d;z-index:100;animation:slide-up .15s ease-out}@keyframes slide-up{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.selection-badge .selection-count{font-weight:700;font-size:14px}.selection-badge .selection-label{opacity:.9}.selection-badge .selection-clear{background:#fff3;border:none;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:14px;line-height:1;margin-left:4px;padding:0;transition:background .15s ease}.selection-badge .selection-clear:hover{background:#ffffff59}@media(prefers-reduced-motion:reduce){.selection-badge{animation:none}}@media(max-width:768px)and (orientation:portrait){.step-sequencer.portrait-mode{padding:0;border-radius:0;max-width:100vw;min-height:100vh;display:flex;flex-direction:column}.step-sequencer.portrait-mode .transport,.step-sequencer.portrait-mode .transport-bar,.step-sequencer.portrait-mode .mixer-panel-container,.step-sequencer.portrait-mode .pitch-panel-container,.step-sequencer.portrait-mode .loop-ruler,.step-sequencer.portrait-mode .selection-badge,.step-sequencer.portrait-mode .sequencer-content,.step-sequencer.portrait-mode .keyboard-shortcuts-panel{display:none!important}.step-sequencer.portrait-mode .progress-bar-container{height:6px;margin:0 16px 8px;border-radius:3px}.step-sequencer.portrait-mode .progress-bar-fill{opacity:.9;box-shadow:0 0 8px var(--color-playhead)}}.step-sequencer{transition:padding .2s ease-out,max-width .2s ease-out}.step-sequencer .sequencer-content,.step-sequencer .portrait-grid,.step-sequencer .portrait-header{transition:opacity .15s ease-out}.step-sequencer[data-orientation]{will-change:padding}.step-sequencer[data-orientation] .sequencer-content,.step-sequencer[data-orientation] .portrait-grid{will-change:opacity}@media(max-width:768px)and (orientation:landscape){.step-sequencer{padding:8px;max-width:100vw}.mixer-panel-container,.pitch-panel-container{display:none!important}.progress-bar-container{height:4px;margin-bottom:8px}.loop-ruler{display:none}}.waveform-container{position:relative;width:100%;border-radius:6px;overflow:hidden;cursor:pointer;background:var(--color-bg)}.waveform-canvas{display:block;width:100%}.slice-count{position:absolute;top:4px;right:4px;font-size:10px;color:var(--color-orange);background:#0009;padding:2px 6px;border-radius:3px}.recorder{background:var(--color-surface);border-radius:12px;padding:16px 24px;margin-top:16px;display:flex;flex-direction:column;gap:12px;width:100%;box-sizing:border-box}.recorder-main{display:flex;flex-direction:column;gap:8px}.mic-button{padding:12px 24px;border:2px solid var(--color-text-muted);border-radius:8px;background:var(--color-surface-elevated);color:var(--color-text);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none}.mic-button:hover{background:var(--color-surface-hover);border-color:var(--color-text-muted)}.mic-button.recording{background:var(--color-error);border-color:var(--color-error);color:#fff}.mic-button.request{background:var(--color-success);border-color:var(--color-success);color:#fff}.mic-button.request:hover{filter:brightness(1.1)}.mic-button.disabled{opacity:.5;cursor:not-allowed;background:var(--color-surface-hover);border-color:var(--color-surface-active)}.recording-bar{height:4px;background:var(--color-surface-hover);border-radius:2px;overflow:hidden}.recording-progress{height:100%;background:var(--color-error);transition:width .1s linear}.recorder-edit{display:flex;flex-direction:column;gap:12px}.waveform-section{display:flex;flex-direction:column;gap:4px}.waveform-hint{font-size:11px;color:var(--color-text-muted);text-align:center}.slice-controls{display:flex;align-items:center;gap:16px}.slice-toggle{padding:8px 16px;border:2px solid var(--color-yellow);border-radius:6px;background:transparent;color:var(--color-yellow);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.slice-toggle:hover{background:var(--color-yellow-muted)}.slice-toggle.active{background:var(--color-yellow);color:var(--color-bg)}.sensitivity-control{display:flex;align-items:center;gap:8px}.sensitivity-label{font-size:12px;color:var(--color-text-muted)}.sensitivity-slider{width:100px;height:4px;-webkit-appearance:none;appearance:none;background:var(--color-surface-active);border-radius:2px;outline:none}.sensitivity-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--color-yellow);cursor:pointer}.sensitivity-value{font-size:12px;color:var(--color-yellow);min-width:24px;font-family:monospace}.recorder-actions{display:flex;gap:8px}.action-button{padding:10px 16px;border:2px solid var(--color-text-muted);border-radius:6px;background:var(--color-surface-elevated);color:var(--color-text);font-size:13px;cursor:pointer;transition:all .15s ease}.action-button:hover{background:var(--color-surface-hover)}.action-button.add{border-color:var(--color-success);color:var(--color-success)}.action-button.add:hover{background:var(--color-success);color:#fff}.action-button.discard{border-color:var(--color-error);color:var(--color-error)}.action-button.discard:hover{background:var(--color-error);color:#fff}.action-button:disabled{opacity:.5;cursor:not-allowed}.track-count{color:var(--color-text-muted);font-size:13px;align-self:flex-end}@keyframes landing-enter{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.landing{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:24px;max-width:100vw;overflow-x:hidden;box-sizing:border-box}.landing-header{width:100%;max-width:900px;display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.landing-header-left{display:flex;align-items:center;gap:16px}.landing-header h1{font-size:1.5rem;font-weight:700;margin:0;color:var(--color-brand);opacity:0;animation:landing-enter .4s ease-out .1s forwards}.landing-tagline{font-size:1rem;color:var(--color-text-muted);opacity:0;animation:landing-enter .4s ease-out .25s forwards}.landing-tagline .c{color:var(--color-brand)}.landing-tagline .r{color:var(--color-purple)}.landing-tagline .s{color:var(--color-teal)}.landing-btn{font-size:.85rem;padding:6px 12px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-surface-elevated);color:#fff;cursor:pointer;transition:all .15s ease;font-family:inherit}.landing-btn:hover:not(:disabled){background:var(--color-border);border-color:var(--color-border-light)}.landing-btn.primary{background:var(--color-accent);border-color:var(--color-accent);opacity:0;animation:landing-enter .4s ease-out .4s forwards}.landing-btn.primary:hover{background:var(--color-accent-light);border-color:var(--color-accent-light)}.landing-features{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;width:100%;max-width:900px;margin-bottom:24px;opacity:0;animation:landing-enter .4s ease-out .55s forwards}.landing-feature-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;padding:20px}.landing-feature-title{font-size:1rem;font-weight:600;color:var(--color-text);margin:0 0 8px}.landing-feature-desc{font-size:.85rem;color:var(--color-text-muted);margin:0;line-height:1.5}.landing-panel{background:var(--color-surface);border-radius:12px;padding:24px;width:100%;max-width:900px;opacity:0;animation:landing-enter .4s ease-out .7s forwards}.landing-sequencer{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--color-border)}.landing-grid{display:flex;flex-direction:column;gap:5px}.landing-grid-row{display:flex;gap:5px}.landing-cell{width:40px;height:40px;background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:5px;transition:all .1s ease}.landing-cell.active{background:var(--color-accent);border-color:var(--color-accent-light)}.landing-cell.playing{border-color:var(--color-playhead);border-width:2px}.landing-cell.active.playing{box-shadow:0 0 14px var(--color-accent-glow)}.landing-examples{padding-top:0}.landing-examples-header{font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:12px}.landing-carousel-wrapper{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px}.landing-carousel-btn{width:36px;height:36px;border-radius:50%;background:var(--color-surface-elevated);border:1px solid var(--color-border);color:var(--color-text-muted);font-size:1.1rem;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.landing-carousel-btn:hover:not(:disabled){border-color:var(--color-brand);color:var(--color-brand)}.landing-carousel-btn:disabled{opacity:.3;cursor:not-allowed}.landing-carousel-track{flex:1;overflow:hidden;min-width:0}.landing-carousel-slides{display:flex;gap:12px;transition:transform .3s ease}.landing-example-card{flex:0 0 340px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:10px;padding:14px;cursor:pointer;transition:all .15s ease}.landing-example-card:hover{border-color:var(--color-brand);transform:translateY(-2px)}.landing-example-thumb{display:grid;grid-template-columns:repeat(16,1fr);gap:3px;margin-bottom:12px}.landing-thumb-row{display:contents}.landing-thumb-cell{aspect-ratio:1;background:var(--color-surface-elevated);border-radius:2px}.landing-thumb-cell.active{background:var(--color-accent)}.landing-example-meta{display:flex;justify-content:space-between;align-items:center}.landing-example-name{font-size:.95rem;font-weight:500;color:var(--color-text)}.landing-example-bpm{font-size:.8rem;color:var(--color-text-muted)}@media(max-width:768px){.landing{padding:12px}.landing-header{flex-direction:column;gap:16px;text-align:center;margin-bottom:16px}.landing-header h1{font-size:1.75rem}.landing-tagline{font-size:.85rem}.landing-header-left{flex-direction:column;gap:8px}.landing-features{grid-template-columns:1fr;gap:12px}.landing-feature-card{padding:16px}.landing-cell{width:18px;height:18px}.landing-example-card{flex:0 0 260px}}.avatar-stack{display:flex;flex-direction:row-reverse;align-items:center;margin-right:8px}.avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--color-text);text-shadow:0 1px 2px rgba(0,0,0,.3);border:2px solid var(--color-bg);margin-left:-8px;cursor:default;transition:transform .15s ease,margin-left .15s ease}.avatar:last-child{margin-left:0}.avatar:hover{transform:scale(1.1);z-index:100!important}.avatar-stack:hover .avatar{margin-left:-4px}.avatar-stack:hover .avatar:last-child{margin-left:0}.avatar-current{box-shadow:0 0 0 2px var(--color-teal)}.avatar-playing{position:relative;animation:avatar-pulse 1.5s ease-in-out infinite}@keyframes avatar-pulse{0%,to{box-shadow:0 0 #4ecdc466}50%{box-shadow:0 0 0 4px #4ecdc433}}.avatar-current.avatar-playing{animation:avatar-pulse-current 1.5s ease-in-out infinite}@keyframes avatar-pulse-current{0%,to{box-shadow:0 0 0 2px var(--color-teal),0 0 0 4px #4ecdc466}50%{box-shadow:0 0 0 2px var(--color-teal),0 0 0 8px #4ecdc433}}.avatar-play-indicator{position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;background-color:var(--color-teal);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:6px;color:var(--color-text);border:1px solid var(--color-bg);pointer-events:none}.avatar-letter{-webkit-user-select:none;user-select:none;pointer-events:none}.avatar-overflow{background-color:var(--color-text-dimmed);font-size:11px}.avatar-count{-webkit-user-select:none;user-select:none;pointer-events:none}@media(prefers-color-scheme:light){.avatar{border-color:var(--color-text)}}@media(max-width:600px){.avatar{width:24px;height:24px;font-size:12px;margin-left:-6px}.avatar-stack:hover .avatar{margin-left:-3px}.avatar-overflow{font-size:10px}.avatar-play-indicator{width:10px;height:10px;font-size:5px;bottom:-1px;right:-1px}}.toast-container{position:fixed;bottom:80px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:1000;pointer-events:none}.toast{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#1e1e1ef2;border-radius:20px;border-left:3px solid var(--toast-color, var(--color-text-muted));box-shadow:0 4px 12px #0000004d;animation:toast-enter .3s ease-out;pointer-events:auto}.toast.exiting{animation:toast-exit .3s ease-in forwards}@keyframes toast-enter{0%{opacity:0;transform:translateY(20px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toast-exit{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-20px) scale(.9)}}.toast-icon{font-size:14px;color:var(--toast-color, var(--color-text-muted));font-weight:700}.toast-message{font-size:14px;color:var(--color-text);white-space:nowrap}.toast.join .toast-icon{color:var(--toast-color, var(--color-success))}.toast.leave .toast-icon{color:var(--toast-color, var(--color-error))}.toast.warning .toast-icon{color:var(--toast-color, #f39c12)}.toast-url{flex-direction:column;align-items:stretch;gap:6px;padding:12px 16px;background:var(--color-accent-muted);border:1px solid rgba(255,107,53,.3);border-left:3px solid var(--color-accent);cursor:pointer;max-width:320px}.toast-url-header{display:flex;justify-content:space-between;align-items:center}.toast-url-header .toast-message{color:var(--color-accent-hover);font-weight:500}.toast-dismiss{background:none;border:none;color:var(--color-accent-hover);font-size:18px;cursor:pointer;padding:0 4px;opacity:.7;line-height:1}.toast-dismiss:hover{opacity:1}.toast-url-content{background:#0000004d;padding:8px 10px;border-radius:4px;overflow:hidden}.toast-url-text{font-size:12px;color:var(--color-text);font-family:monospace;word-break:break-all;display:block}.toast-url-hint{font-size:11px;color:var(--color-text-muted);text-align:center}@media(max-width:600px){.toast-container{bottom:100px;width:90%;left:5%;transform:none}.toast{width:100%;justify-content:center}.toast-url{max-width:none}}.connection-status{display:flex;align-items:center;gap:6px;font-size:.75rem;padding:4px 8px;border-radius:12px;background:#ffffff0d;cursor:default;-webkit-user-select:none;user-select:none}.connection-status__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.connection-status__text{color:var(--color-text-muted)}.connection-status__queue{color:var(--color-text-muted);font-size:.7rem}.connection-status--connected .connection-status__dot{background:var(--color-success);box-shadow:0 0 4px var(--color-success)}.connection-status--connected .connection-status__text{color:var(--color-success)}.connection-status--connecting .connection-status__dot{background:var(--color-warning);animation:pulse 1.5s ease-in-out infinite}.connection-status--connecting .connection-status__text{color:var(--color-warning)}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 4px var(--color-warning)}50%{opacity:.5;box-shadow:0 0 8px var(--color-warning)}}.connection-status--disconnected .connection-status__dot{background:var(--color-error);box-shadow:0 0 4px var(--color-error)}.connection-status--disconnected .connection-status__text{color:var(--color-error)}.connection-status--disconnected .connection-status__queue,.connection-status--connecting .connection-status__queue{color:var(--color-warning)}.connection-status--single_player .connection-status__dot{background:var(--color-text-muted);box-shadow:0 0 4px var(--color-text-muted)}.connection-status--single_player .connection-status__text{color:var(--color-text-muted)}.connection-status__retry{background:none;border:1px solid var(--color-text-muted);border-radius:4px;color:var(--color-text-muted);cursor:pointer;font-size:.7rem;padding:2px 6px;margin-left:4px;transition:all .15s ease}.connection-status__retry:hover{background:#ffffff1a;border-color:var(--color-text-muted);color:var(--color-text)}.connection-status__retry:active{background:#fff3}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:var(--color-surface);color:var(--color-text)}.error-boundary-content{max-width:500px;text-align:center}.error-boundary h1{font-size:1.5rem;margin-bottom:.5rem;color:var(--color-error)}.error-message{color:var(--color-text-muted);margin-bottom:1.5rem;font-size:.9rem}.error-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.error-btn{padding:.5rem 1rem;border-radius:4px;border:none;cursor:pointer;font-size:.875rem;transition:opacity .2s}.error-btn:hover{opacity:.9}.error-btn.primary{background:var(--color-blue);color:#fff}.error-btn.secondary{background:var(--color-surface-hover);color:var(--color-text);border:1px solid var(--color-surface-active)}.error-details{margin-top:2rem;text-align:left;font-size:.75rem}.error-details summary{cursor:pointer;color:var(--color-text-muted);margin-bottom:.5rem}.error-stack,.component-stack{background:var(--color-bg);padding:1rem;border-radius:4px;overflow-x:auto;white-space:pre-wrap;word-break:break-word;color:var(--color-error);font-size:.7rem;max-height:200px;overflow-y:auto}.component-stack{color:var(--color-text-muted);margin-top:.5rem}.feature-error-boundary{display:flex;align-items:center;justify-content:center;padding:1rem;min-height:100px;background:var(--surface-secondary, #1a1a2e);border-radius:8px;border:1px solid var(--error-color, #ff6b6b)}.feature-error-content{text-align:center;max-width:300px}.feature-error-content h3{margin:0 0 .5rem;font-size:1rem;color:var(--error-color, #ff6b6b)}.feature-error-content p{margin:0 0 1rem;font-size:.875rem;color:var(--text-secondary, #a0a0a0)}.feature-error-retry{padding:.5rem 1rem;background:var(--primary-color, #6366f1);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;transition:background .2s}.feature-error-retry:hover{background:var(--primary-hover, #5558e3)}.feature-error-details{margin-top:1rem;text-align:left;font-size:.75rem}.feature-error-details summary{cursor:pointer;color:var(--text-secondary, #a0a0a0)}.feature-error-details pre{margin:.5rem 0;padding:.5rem;background:var(--surface-primary, #0f0f1a);border-radius:4px;overflow-x:auto;font-size:.7rem;color:var(--text-primary, #ffffff)}.feature-error-sequencer{grid-column:1 / -1}.feature-error-audio{width:100%}.feature-error-multiplayer{position:absolute;top:0;left:0;right:0;z-index:100}@keyframes suspense-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-label,.skeleton-category,.skeleton-fx-toggle{background:linear-gradient(90deg,var(--color-surface-elevated) 25%,var(--color-surface-hover) 50%,var(--color-surface-elevated) 75%);background-size:200% 100%;animation:suspense-shimmer 1.5s ease-in-out infinite;border-radius:4px}.sample-picker-skeleton{display:flex;flex-direction:column;gap:12px;padding:16px;background:var(--color-surface);border-radius:12px;margin-top:16px;width:100%;box-sizing:border-box;min-height:280px}.skeleton-header{display:flex;align-items:center}.skeleton-label{width:80px;height:16px}.skeleton-categories{display:flex;flex-direction:column;gap:8px}.skeleton-category{height:42px;border-radius:8px;border:1px solid var(--color-border)}@media(min-width:769px){.skeleton-categories{flex-direction:row;flex-wrap:wrap;gap:12px}.skeleton-category{flex:1 1 auto;min-width:180px;max-width:280px;height:120px}.sample-picker-skeleton{min-height:180px}}@media(max-width:768px){.sample-picker-skeleton{padding:12px;gap:8px;min-height:320px}}.effects-panel-skeleton{display:flex}.skeleton-fx-toggle{width:60px;height:36px;border-radius:6px;border:2px solid var(--color-border-hover)}@media(prefers-reduced-motion:reduce){.skeleton-label,.skeleton-category,.skeleton-fx-toggle{animation:none;background:var(--color-surface-elevated)}}.debug-overlay{position:fixed;bottom:16px;right:16px;z-index:9999;font-family:SF Mono,Monaco,Menlo,monospace;font-size:11px}.debug-overlay.collapsed{width:auto}.debug-overlay.expanded{width:360px;max-height:80vh;background:#121212f2;border:1px solid #333;border-radius:8px;overflow:hidden;display:flex;flex-direction:column}.debug-toggle{background:#ff6b00;color:#000;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-weight:700;font-size:11px;font-family:inherit}.debug-overlay.expanded .debug-toggle{width:100%;border-radius:0;text-align:left;padding:8px 12px}.debug-toggle:hover{background:#ff8533}.debug-content{padding:12px;overflow-y:auto;flex:1}.debug-section{margin-bottom:16px}.debug-section:last-child{margin-bottom:0}.debug-section h4{margin:0 0 8px;color:#888;font-size:10px;text-transform:uppercase;letter-spacing:.5px}.debug-info{display:flex;gap:8px;margin-bottom:4px}.debug-label{color:#666}.debug-value{color:#fff}code.debug-value{background:#222;padding:1px 4px;border-radius:2px;font-size:10px;word-break:break-all}.debug-logs{max-height:200px;overflow-y:auto;background:#1a1a1a;border-radius:4px;padding:4px}.debug-log{display:flex;flex-wrap:wrap;gap:4px;padding:4px;border-bottom:1px solid #222}.debug-log:last-child{border-bottom:none}.debug-log-time{color:#555}.debug-log-type{color:#666;text-transform:uppercase;font-size:9px;background:#222;padding:1px 4px;border-radius:2px}.debug-log-request .debug-log-type{background:#1a3a1a;color:#4a9}.debug-log-response .debug-log-type{background:#1a1a3a;color:#49a}.debug-log-state .debug-log-type{background:#3a3a1a;color:#aa9}.debug-log-error .debug-log-type{background:#3a1a1a;color:#a44}.debug-log-method{color:#4a9;font-weight:700}.debug-log-path{color:#aaa;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.debug-log-status{color:#4a9}.debug-log-duration{color:#666}.debug-log-error{color:#f44;flex-basis:100%}.debug-log-empty{color:#555;text-align:center;padding:8px}.debug-endpoints{display:flex;flex-direction:column;gap:4px}.debug-endpoints a{color:#49a;text-decoration:none;padding:4px 8px;background:#1a1a1a;border-radius:4px;font-size:10px}.debug-endpoints a:hover{background:#222;color:#6bc}.debug-status-disconnected{color:#666}.debug-status-connecting{color:#f1c40f}.debug-status-connected,.debug-quality-good{color:#4a9}.debug-quality-fair{color:#f1c40f}.debug-quality-poor{color:#f44}.debug-log-ws .debug-log-type{background:#2a1a3a;color:#a4a}.debug-log-ws-type{color:#a4a;font-weight:700}.debug-log-player{color:#6bc;font-size:10px;background:#1a2a3a;padding:1px 4px;border-radius:2px}.debug-log-msg-type{color:#aaa;font-style:italic}.debug-warning{margin-top:8px;padding:8px;background:#f4433633;border:1px solid #f44;border-radius:4px;color:#f88;font-size:10px;line-height:1.4}.debug-warning strong{color:#f44;display:block;margin-bottom:4px}.debug-warning-text{color:#f1c40f}.debug-success-text{color:#4a9}.debug-error-text{color:#f44}.debug-age{color:#888;font-size:10px}.app{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:24px;max-width:100vw;overflow-x:hidden;box-sizing:border-box}@media(max-width:768px){.app{padding:12px}}.app-header{text-align:center;margin-bottom:32px}@media(max-width:768px){.app-header{margin-bottom:16px}.app-header h1{font-size:1.75rem}.subtitle{font-size:.85rem}}.header-top{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}.app-header h1{font-size:1.5rem;font-weight:700;margin:0;color:var(--color-brand)}.subtitle{color:var(--color-text-muted);font-size:1rem;margin-top:8px}.subtitle.published{color:var(--color-purple)}.header-title-group{display:flex;align-items:baseline;gap:8px}.title-separator{color:var(--color-border-hover);font-size:1.5rem;font-weight:300;margin:0 4px}.session-name{background:none;border:none;font-size:1.5rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;padding:2px 8px;border-radius:4px;transition:all .15s ease;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-name:hover{background:#ffffff0d;color:var(--color-text)}.session-name:focus{outline:none;box-shadow:0 0 0 2px var(--color-accent-muted)}.session-name-disabled{cursor:default}.session-name-disabled:hover{background:none;color:var(--color-text-muted)}.session-name-saving{color:var(--color-text-dimmed);font-size:.9em;margin-left:4px}.session-name-input{font-size:1.5rem;font-weight:500;color:var(--color-text);background:#ffffff14;border:1px solid var(--color-accent-muted);border-radius:4px;padding:2px 8px;outline:none;max-width:300px;width:auto;min-width:150px}.session-name-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-muted)}.session-name-input::placeholder{color:var(--color-text-dimmed)}@media(max-width:768px){.header-title-group{flex-direction:column;align-items:center;gap:4px}.title-separator{display:none}.session-name,.session-name-input{font-size:1rem;max-width:200px}}@media(max-width:768px)and (orientation:portrait){.app-header,.cloudflare-footer,.controls-row{display:none}}.session-controls{display:flex;align-items:center;gap:8px}.session-controls.session-loading,.session-controls.session-error{font-size:.85rem;color:var(--color-text-muted)}.session-controls.session-error{color:var(--color-error)}.session-controls.session-not-found{flex-wrap:wrap;justify-content:center}.not-found-text{font-size:.85rem;color:var(--color-error)}.orphan-banner{display:flex;align-items:center;gap:12px;background:var(--color-yellow-muted);border:1px solid rgba(255,193,7,.3);color:var(--color-warning);padding:8px 16px;border-radius:6px;font-size:.85rem;margin-bottom:12px;max-width:600px}.orphan-dismiss{background:none;border:none;color:var(--color-warning);cursor:pointer;font-size:1rem;padding:2px 6px;opacity:.7;transition:opacity .15s}.orphan-dismiss:hover{opacity:1}.remix-lineage{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--color-text-muted);margin-right:8px}.lineage-arrow{color:var(--color-text-dimmed)}.lineage-text{color:var(--color-text-muted)}.remix-count,.remix-count-standalone{color:var(--color-text-dimmed);font-size:.75rem}.remix-count-standalone{margin-right:8px}.player-count{color:var(--color-success);font-size:.75rem;font-weight:500;margin-right:12px;padding:2px 8px;background:#4ade8026;border-radius:4px}.session-btn{font-size:.85rem;padding:6px 12px;border:1px solid var(--color-surface-active);border-radius:6px;background:var(--color-surface-elevated);color:var(--color-text);cursor:pointer;transition:all .15s ease}.session-btn:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-hover)}.session-btn:disabled{opacity:.5;cursor:not-allowed}.publish-btn{background:linear-gradient(135deg,var(--color-purple),var(--color-purple-dark));border-color:var(--color-purple);color:var(--color-text)}.publish-btn:hover:not(:disabled){background:linear-gradient(135deg,#a569c0,var(--color-purple));border-color:#a569c0;color:var(--color-text)}.remix-btn:hover:not(:disabled){border-color:var(--color-orange);color:var(--color-orange)}.session-btn.remix-btn.primary-action{border:2px solid var(--color-accent);box-shadow:0 2px 8px #e85a3026;transform:scale(1.02);font-weight:500;color:var(--color-accent)}.session-btn.remix-btn.primary-action:hover:not(:disabled){border-color:var(--color-accent-light);box-shadow:0 2px 12px #e85a3040;color:var(--color-accent-light)}.new-btn:hover:not(:disabled){border-color:var(--color-teal);color:var(--color-teal)}.download-btn:hover:not(:disabled){border-color:var(--color-info);color:var(--color-info)}.invite-btn{background:transparent;border-color:var(--color-border-light);color:var(--color-text-muted)}.invite-btn:hover:not(:disabled){border-color:var(--color-brand);color:var(--color-brand);background:var(--color-accent-muted)}.published-badge{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600;color:var(--color-purple);background:var(--color-purple-muted);border:1px solid rgba(155,89,182,.3);padding:3px 10px;border-radius:12px;margin-right:8px}.share-dropdown-container{position:relative}.share-dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:var(--color-surface-elevated);border:1px solid var(--color-surface-active);border-radius:6px;min-width:140px;z-index:100;box-shadow:0 4px 12px #0000004d;animation:dropdown-fade-in .15s ease-out}@keyframes dropdown-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.share-dropdown-item{display:block;width:100%;padding:10px 14px;border:none;background:transparent;color:var(--color-text);font-size:.85rem;text-align:left;cursor:pointer;transition:background .15s ease}.share-dropdown-item:first-child{border-radius:5px 5px 0 0}.share-dropdown-item:last-child{border-radius:0 0 5px 5px}.share-dropdown-item:hover{background:var(--color-surface-hover)}.share-dropdown-item:active{background:var(--color-surface-active)}.app.qr-mode-large{margin-right:280px;transition:margin-right .25s cubic-bezier(.16,1,.3,1)}main{display:flex;flex-direction:column;align-items:center;width:100%;max-width:100vw;overflow-x:hidden}.controls-row{display:flex;align-items:flex-start;gap:16px;width:100%;flex-wrap:wrap}@media(max-width:768px){.controls-row{flex-direction:column;gap:12px}}.mobile-effects-wrapper{display:none}@media(max-width:768px){.mobile-effects-wrapper{display:block;width:100%}}.cloudflare-footer{margin-top:auto;padding:24px 0 12px;text-align:center;font-size:10px;color:var(--color-text-dimmed, #555);letter-spacing:.3px}.cloudflare-footer a{color:var(--color-text-muted, #888);text-decoration:none;transition:color .15s ease}.cloudflare-footer a:hover{color:var(--color-text, #fff)}.qr-loading,.sample-picker-loading,.effects-loading{display:flex;align-items:center;justify-content:center;padding:1rem;color:var(--color-text-muted, #888);font-size:.875rem}.sample-picker-loading{min-height:100px;background:var(--surface-secondary, #1a1a2e);border-radius:8px}.effects-loading{min-height:60px}
