: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-border: #3a3a3a;--color-border-light: #4a4a4a;--color-accent: #e85a30;--color-accent-light: #f07048;--color-accent-glow: rgba(232, 90, 48, .6);--color-playhead: #ffffff;--color-playhead-glow: rgba(255, 255, 255, .4);--color-secondary: #d4a054;--color-info: #4a9ece;--color-success: #4abb8b;--color-purple: #9b59b6;--color-text: rgba(255, 255, 255, .87);--color-text-muted: rgba(255, 255, 255, .5)}*{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:#3a3a3a;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}.step-cell.active.selected{border-color:var(--color-info)}.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-secondary)}.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.dimmed{opacity:.2;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}.chromatic-grid{display:flex;gap:4px;padding:8px 0 12px;margin-top:4px;background:#0003;border-radius:6px;overflow-x:auto}.chromatic-grid::-webkit-scrollbar{height:8px}.chromatic-grid::-webkit-scrollbar-track{background:#252525;border-radius:4px}.chromatic-grid::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.chromatic-grid::-webkit-scrollbar-thumb:hover{background:#555}.chromatic-pitch-labels{display:flex;flex-direction:column;gap:2px;min-width:50px;padding-left:8px;flex-shrink:0}.pitch-label{height:18px;display:flex;align-items:center;justify-content:space-between;gap:4px;font-size:9px;color:#666;padding-right:4px}.pitch-label.root{color:#3498db;font-weight:600}.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:#3498db1a;border-radius:2px;margin:0 -2px;padding:0 2px}.chromatic-cell{width:24px;height:18px;border:1px solid #333;border-radius:2px;background:#1a1a1a;cursor:pointer;transition:all .1s ease;padding:0}.chromatic-cell:disabled{background:transparent;border-color:#222;cursor:not-allowed;opacity:.3}.chromatic-cell.step-active{background:#252525;border-color:#444}.chromatic-cell.step-active:hover{background:#333;border-color:#666}.chromatic-cell.note{background:var(--color-orange, #f39c12);border-color:var(--color-orange, #f39c12)}.chromatic-cell.note:hover{background:#f5ab35;border-color:#f5ab35}.chromatic-cell.playing{box-shadow:0 0 8px var(--color-orange, #f39c12);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:#3498db;r:4}.expand-toggle{width:24px;height:24px;border:1px solid #444;border-radius:3px;background:#252525;color:#888;font-size:12px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.expand-toggle:hover{background:#333;border-color:#666;color:#fff}.expand-toggle.expanded{background:#3498db;border-color:#3498db;color:#fff}.expand-toggle.expanded:hover{background:#2980b9}.steps-with-contour{position:relative}.inline-drawer{background:#1a1a1a;border-radius:0 0 8px 8px;border:1px solid #333;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:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.drawer-row{display:flex;align-items:center;gap:12px}.drawer-row+.drawer-row{margin-top:8px}.drawer-label{font-size:13px;color:#aaa;min-width:70px}.drawer-stepper{display:flex;align-items:center;gap:4px}.drawer-stepper-btn{width:32px;height:32px;border:1px solid #444;border-radius:6px;background:#252525;color:#fff;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:#333;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:#fff;font-family:monospace}.drawer-stepper-value.active{color:var(--color-info, #3498db)}.drawer-segment{display:flex;gap:2px;background:#1a1a1a;border-radius:6px;padding:2px;border:1px solid #333}.drawer-segment-btn{padding:8px 14px;border:none;border-radius:4px;background:transparent;color:#888;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, #9b59b6);color:#fff}.drawer-select{height:36px;padding:0 32px 0 12px;border:1px solid #444;border-radius:6px;background:#252525;color:#fff;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, #9b59b6)}.drawer-select option{background:#1a1a1a;color:#fff}.drawer-actions{display:flex;gap:8px;flex-wrap:wrap}.drawer-action-btn{flex:1;min-width:70px;padding:10px 12px;border:1px solid #444;border-radius:6px;background:#252525;color:#ddd;font-size:12px;font-weight:500;cursor:pointer;transition:all .1s ease}.drawer-action-btn:active{background:#333;transform:scale(.98)}.drawer-action-btn:disabled{opacity:.4;cursor:not-allowed}.drawer-action-btn.destructive{color:#e74c3c;border-color:#e74c3c4d}.drawer-action-btn.destructive:active{background:#e74c3c33}.drawer-action-btn.primary{background:var(--color-accent, #ff6b35);border-color:var(--color-accent, #ff6b35);color:#fff}.drawer-divider{height:1px;background:#333;margin:12px 0}.drawer-toggle-group{display:flex;gap:8px}.drawer-toggle-btn{width:40px;height:36px;border:2px solid #555;border-radius:6px;background:transparent;color:#888;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:#e74c3c;border-color:#e74c3c;color:#fff}.drawer-toggle-btn.active.soloed{background:#f1c40f;border-color:#f1c40f;color:#1a1a1a}.drawer-mode-btn{padding:8px 14px;border:2px solid #555;border-radius:6px;background:#252525;color:#aaa;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:#666;color:#888}.drawer-mode-btn.gate{border-color:#00bcd4;background:#00bcd426;color:#00bcd4}.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,#333 0% 100%);border-radius:3px;cursor:pointer}.drawer-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#3498db;cursor:pointer;border:2px solid #fff;box-shadow:0 2px 4px #0000004d}.drawer-volume-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#3498db;cursor:pointer;border:2px solid #fff;box-shadow:0 2px 4px #0000004d}.drawer-slider-value{min-width:40px;text-align:right;font-size:13px;font-weight:600;color:#aaa;font-family:monospace}.track-row-wrapper{display:flex;flex-direction:column}.track-header-mobile,.mobile-edit-panel{display:none}.track-row{display:grid;grid-template-columns:[mute] 32px [solo] 32px [volume] 50px [name] 70px [transpose] 76px [step-count] 72px [playback-mode] 32px [expand] 32px [steps] 1fr [actions] auto;align-items:center;gap:8px;padding:6px 0;border-radius:4px;transition:background .15s ease;min-width:0}@media(max-width:768px){.track-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 0;border-bottom:1px solid #2a2a2a}.track-volume-control,.transpose-control,.step-count-select,.playback-mode-btn,.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:#333}.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 #444;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:#ddd;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:#f1c40f}.track-type-badge{font-size:12px;color:#9b59b6}.track-status-badge{font-size:10px;font-weight:700;padding:2px 5px;border-radius:3px;margin-left:4px}.track-status-badge.muted{background:#e74c3c;color:#fff}.track-status-badge.soloed{background:#f1c40f;color:#1a1a1a}.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 #2a2a2a;cursor:pointer;transition:background .1s ease}.mobile-edit-panel:active{background:#ffffff0d}.mobile-edit-hint{font-size:11px;color:#666;letter-spacing:.5px}.mobile-edit-panel.expanded .mobile-edit-hint{color:#888}}.track-row.muted{opacity:.5}.track-row.soloed{background:#f1c40f14}.track-row.copy-source{background:#2ecc7126}.track-row.copy-target{background:#3498db1a}.track-row.copy-target:hover{background:#3498db33}.mute-button{grid-column:mute}.solo-button{grid-column:solo}.track-name{grid-column:name;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transpose-control{grid-column:transpose}.step-count-control{grid-column:step-count}.expand-toggle{grid-column:expand;width:24px;height:24px;border:1px solid #444;border-radius:4px;background:#252525;color:#888;font-size:12px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;padding:0}.expand-toggle:hover{background:#333;border-color:#666}.expand-toggle.expanded{background:var(--color-purple, #9b59b6);border-color:var(--color-purple, #9b59b6);color:#fff}.expand-toggle svg{display:block}.expand-placeholder{grid-column:expand;width:24px;height:24px}.steps{grid-column:steps}.track-actions{grid-column:actions}.track-name{font-size:13px;font-weight:500;color:#ddd;text-transform:capitalize;min-width:50px}.mute-button{width:26px;height:26px;border:2px solid #555;border-radius:4px;background:transparent;color:#666;font-size:11px;font-weight:700;cursor:pointer;transition:all .15s ease}.mute-button:hover{border-color:#777;color:#888}.mute-button.active{background:#e74c3c;border-color:#e74c3c;color:#fff}.solo-button{width:26px;height:26px;border:2px solid #555;border-radius:4px;background:transparent;color:#666;font-size:11px;font-weight:700;cursor:pointer;transition:all .15s ease}.solo-button:hover{border-color:#777;color:#888}.solo-button.active{background:#f1c40f;border-color:#f1c40f;color:#1a1a1a}.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,#444,#666);border-radius:2px;outline:none;cursor:pointer}.track-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:#3498db;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 #3498db80}.track-volume-slider::-moz-range-thumb{width:12px;height:12px;border:none;border-radius:50%;background:#3498db;cursor:pointer}.transpose-control{display:flex;align-items:center;gap:2px}.transpose-btn{width:20px;height:20px;border:1px solid #444;border-radius:3px;background:#252525;color:#888;font-size:14px;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:#333;border-color:#666;color:#fff}.transpose-btn:disabled{opacity:.3;cursor:not-allowed}.transpose-value{min-width:28px;text-align:center;font-size:11px;font-family:monospace;color:#666}.transpose-value.active{color:#3498db;font-weight:600}.step-count-select{grid-column:step-count;width:54px;height:24px;padding:0 18px 0 4px;border:1px solid #444;border-radius:4px;background:#252525;color:#aaa;font-size:11px;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 6px center}.step-count-select:hover{background-color:#333;border-color:#666;color:#ddd}.step-count-select:focus{outline:none;border-color:var(--color-purple, #9b59b6)}.step-count-select option{background:#1a1a1a;color:#ddd}.steps{display:flex;gap:3px;flex-shrink:0}.track-actions{display:flex;gap:4px;margin-left:auto;min-width:170px;width:170px;flex-shrink:0;justify-content:flex-end}@media(max-width:768px){.track-actions{display:none}}.action-btn{padding:4px 8px;border:1px solid #444;border-radius:3px;background:#252525;color:#666;font-size:10px;font-weight:600;font-family:monospace;cursor:pointer;transition:all .15s ease}.action-btn:hover:not(:disabled){background:#333;border-color:#666;color:#999}.action-btn:disabled{opacity:.3;cursor:not-allowed}.action-btn.delete:hover:not(:disabled){background:#c0392b;border-color:#c0392b;color:#fff}.action-btn.paste{background:#27ae60;border-color:#27ae60;color:#fff}.action-btn.paste:hover{background:#2ecc71;border-color:#2ecc71}.plock-inline{display:flex;align-items:center;gap:16px;padding:8px 12px;background:#252525;border-radius:6px;margin-top:6px;width:100%}.plock-step{font-size:12px;color:#888;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:#3498db;color:#fff}.plock-label.volume{background:#e67e22;color:#fff}.plock-slider-row{display:flex;align-items:center;gap:6px}.plock-slider{width:80px;height:4px;-webkit-appearance:none;appearance:none;background:#444;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:#3498db}.plock-slider.volume::-webkit-slider-thumb{background:#e67e22}.plock-value{font-size:12px;color:#aaa;min-width:35px;text-align:right;font-family:monospace}.plock-clear{padding:4px 8px;border:1px solid #e74c3c;border-radius:4px;background:transparent;color:#e74c3c;font-size:12px;cursor:pointer;transition:all .15s ease;margin-left:auto}.plock-clear:hover{background:#e74c3c;color:#fff}.playback-mode-btn{width:26px;height:26px;border:2px solid #555;border-radius:4px;background:transparent;color:#888;font-size:12px;font-weight:700;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.playback-mode-btn:hover{border-color:#777;color:#aaa;background:#ffffff0d}.playback-mode-btn.oneshot{color:#888}.playback-mode-btn.gate{border-color:#00bcd4;color:#00bcd4;background:#00bcd41a}.playback-mode-btn.gate:hover{border-color:#26c6da;background:#00bcd433}.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}}.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:#1a1a1a;border:2px solid #333;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, #00bcd4);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:#333}.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, #00bcd4);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, #00bcd4);border:2px solid #fff;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 0 8px #00000080,0 0 12px var(--accent-color, #00bcd4);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, #00bcd4)}.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:#666}.xy-pad.dragging~.xy-pad-bottom-labels .xy-pad-values-external{color:var(--accent-color, #00bcd4)}.transport{display:flex;flex-direction:column;padding:16px 0;border-bottom:1px solid #333;margin-bottom:16px}.transport-controls{display:flex;align-items:center;gap:24px}.fx-combined-btn{display:flex;align-items:stretch;margin-left:auto;border-radius:8px;overflow:hidden;border:2px solid #555;background:#252525;transition:all .15s ease}.fx-combined-btn:hover{border-color:#666}.fx-combined-btn.expanded{border-color:#00bcd4}.fx-combined-btn.has-effects{border-color:#4caf50}.fx-combined-btn.has-effects.bypassed{border-color:#ff5722}.fx-main-area{display:grid;grid-auto-flow:column;place-items:center;gap:8px;height:36px;padding:0 12px;border:none;background:transparent;color:#888;font-size:12px;font-weight:700;cursor:pointer;transition:background .15s ease}.fx-state-group{display:grid;place-items:center}.fx-state-group[data-has-effects=false]{visibility:hidden}.fx-state{grid-area:1 / 1;display:grid;grid-auto-flow:column;place-items:center;gap:6px;opacity:0;transition:opacity .15s ease;pointer-events:none}.fx-state.visible{opacity:1}.fx-state .fx-state-icon{font-size:12px;line-height:1}.fx-state-active .fx-state-icon{color:#4caf50}.fx-state-bypassed .fx-state-icon{color:#ff5722}.fx-state .fx-state-text{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;line-height:1}.fx-state-active .fx-state-text{color:#4caf50}.fx-state-bypassed .fx-state-text{color:#ff5722}.fx-main-area:hover:not(:disabled){background:#ffffff0d}.fx-main-area:disabled{opacity:.5;cursor:not-allowed}.fx-main-area .fx-label{font-size:12px;font-weight:800;letter-spacing:.5px;line-height:1;margin:0;color:#aaa}.fx-combined-btn.has-effects .fx-main-area .fx-label{color:#fff}.fx-combined-btn:before{content:none}.fx-panel-toggle{display:grid;place-items:center;height:36px;padding:0 10px;border:none;border-left:1px solid #444;background:transparent;color:#666;cursor:pointer;transition:all .15s ease}.fx-panel-toggle:hover:not(:disabled){background:#ffffff14;color:#aaa}.fx-panel-toggle:disabled{opacity:.5;cursor:not-allowed}.fx-chevron{font-size:10px;line-height:1;transition:transform .2s ease}.fx-combined-btn.expanded .fx-panel-toggle{background:#00bcd41a;color:#00bcd4}.fx-combined-btn.expanded .fx-chevron{color:#00bcd4}.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:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding-top:0;transition:padding .25s ease-out}.transport-fx-panel.expanded .fx-panel-content{padding-top: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:#1a1a1a;border-radius:8px;border:1px solid #333}.fx-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}.fx-panel-content>.fx-group:nth-child(1) .fx-label{color:#9c27b0}.fx-panel-content>.fx-group:nth-child(2) .fx-label{color:#2196f3}.fx-panel-content>.fx-group:nth-child(3) .fx-label{color:#4caf50}.fx-panel-content>.fx-group:nth-child(4) .fx-label{color:#ff5722}.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:#666;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:#333;border-radius:2px;cursor:pointer}.fx-param input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;background:#00bcd4;border-radius:50%;cursor:pointer;transition:transform .1s ease}.fx-param input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}.fx-panel-content>.fx-group:nth-child(1) input[type=range]::-webkit-slider-thumb{background:#9c27b0}.fx-panel-content>.fx-group:nth-child(2) input[type=range]::-webkit-slider-thumb{background:#2196f3}.fx-panel-content>.fx-group:nth-child(3) input[type=range]::-webkit-slider-thumb{background:#4caf50}.fx-panel-content>.fx-group:nth-child(4) input[type=range]::-webkit-slider-thumb{background:#ff5722}.fx-param select{flex:1;background:#333;border:1px solid #444;border-radius:4px;color:#ddd;font-size:11px;padding:4px 8px;cursor:pointer}.fx-param select:focus{outline:none;border-color:#00bcd4}.fx-value{font-size:11px;color:#888;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:#1db954;color:#fff;font-size:24px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.play-button:hover{background:#1ed760;transform:scale(1.05)}.play-button.playing{background:#e74c3c}.play-button.playing:hover{background:#ff6b5a}.tempo-control{display:flex;align-items:center;gap:12px}.tempo-control label{font-size:14px;color:#888;font-weight:500}.tempo-control input[type=range]{width:150px;accent-color:#1db954}.tempo-value{font-size:18px;font-weight:700;color:#fff;min-width:40px}.swing-control{display:flex;align-items:center;gap:12px}.swing-control label{font-size:14px;color:#888;font-weight:500}.swing-control input[type=range]{width:100px;accent-color:#f39c12}.swing-value{font-size:14px;font-weight:700;color:#f39c12;min-width:40px}.transport-bar{display:none;align-items:center;gap:16px;padding:12px 16px;background:#1a1a1a;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-accent, #ff6b35);border-radius:50%;background:transparent;color:var(--color-accent, #ff6b35);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-accent, #ff6b35);color:#fff}.transport-value{display:flex;flex-direction:column;align-items:center;padding:8px 16px;background:#252525;border-radius:8px;cursor:ns-resize;user-select:none;-webkit-user-select:none;touch-action:none;transition:background .1s ease}.transport-value:active{background:#333}.transport-label{font-size:10px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.transport-number{font-size:20px;font-weight:700;color:#fff;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:#444;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}}.step-sequencer{background:#1a1a1a;border-radius:12px;padding:24px;width:100%;max-width:calc(100vw - 48px);position:relative;box-sizing:border-box}.tracks{display:flex;flex-direction:column;gap:2px;overflow-x:auto;padding-bottom:8px}.tracks::-webkit-scrollbar{height:8px}.tracks::-webkit-scrollbar-track{background:#252525;border-radius:4px}.tracks::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.tracks::-webkit-scrollbar-thumb:hover{background:#555}.step-sequencer.published{box-shadow:inset 0 0 0 1px #9b59b64d,0 0 20px #9b59b61a}.step-sequencer.published .tracks{position:relative;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}.sample-picker{display:flex;flex-direction:column;gap:12px;padding:16px;background:#1a1a1a;border-radius:12px;margin-top:16px;width:100%;box-sizing:border-box}.sample-picker.disabled{opacity:.5;pointer-events:none}.picker-header{display:flex;align-items:center;gap:12px}.picker-label{font-size:14px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:1px}.picker-hint{font-size:11px;color:#666;font-style:italic}.sample-picker.previews-unavailable .instrument-btn{opacity:.7}.sample-picker.previews-unavailable .instrument-btn:hover:not(:disabled){opacity:1}.picker-categories{display:flex;flex-direction:column;gap:8px}.picker-category{background:#222;border-radius:8px;overflow:hidden;border:1px solid #333;transition:border-color .2s ease}.picker-category:hover{border-color:#444}.picker-category.expanded{border-color:var(--category-color, #444)}.category-header{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:transparent;border:none;cursor:pointer;transition:background .15s ease}.category-header:hover{background:#2a2a2a}.category-label{font-size:13px;font-weight:600;color:var(--category-color, #888);text-transform:uppercase;letter-spacing:.5px;flex:1;text-align:left}.category-chevron{font-size:10px;color:#555;transition:color .15s ease}.picker-category.expanded .category-chevron{color:var(--category-color, #888)}.category-instruments{display:flex;flex-wrap:wrap;gap:6px;padding:0 12px 12px}.instrument-btn{min-width:56px;min-height:32px;padding:6px 10px;border:1px solid #444;border-radius:6px;background:#2a2a2a;color:#aaa;font-size:11px;font-weight:500;cursor:pointer;transition:all .15s ease;display:inline-flex;align-items:center;justify-content:center}.instrument-btn:hover:not(:disabled){background:#333;border-color:var(--category-color, #666);color:#fff;transform:translateY(-1px)}.instrument-btn:active:not(:disabled){transform:translateY(0);background:var(--category-color, #444);border-color:var(--category-color, #444);color:#fff}.instrument-btn:disabled{opacity:.4;cursor:not-allowed}.instrument-btn.advanced{font-weight:600}.instrument-btn.sampled{position:relative}.instrument-btn.sampled:before{content:"★";font-size:8px;position:absolute;top:2px;right:3px;color:var(--category-color, #fff);opacity:.6}@media(min-width:769px){.picker-categories{flex-direction:row;flex-wrap:wrap;gap:12px;align-items:flex-start}.picker-category{flex:1 1 auto;min-width:180px;max-width:280px}.category-chevron{display:none}.category-header{cursor:default;padding:8px 12px}.category-header:hover{background:transparent}.category-instruments{padding-top:4px}}@media(max-width:768px){.sample-picker{padding:12px;gap:8px}.picker-header{flex-direction:column;align-items:flex-start;gap:4px}.picker-label{font-size:13px}.picker-categories{gap:6px}.category-header{padding:12px}.category-label{font-size:14px}.category-instruments{padding:8px 12px 12px}.instrument-btn{min-width:64px;min-height:44px;padding:8px 12px;font-size:12px}}@media(max-width:480px){.sample-picker{padding:10px;margin-top:12px;border-radius:8px}.category-header{padding:10px}.category-label{font-size:13px}.instrument-btn{min-width:60px;min-height:44px;padding:7px 10px;font-size:11px;border-radius:4px}}.waveform-container{position:relative;width:100%;border-radius:6px;overflow:hidden;cursor:pointer;background:#1a1a1a}.waveform-canvas{display:block;width:100%}.slice-count{position:absolute;top:4px;right:4px;font-size:10px;color:#f39c12;background:#0009;padding:2px 6px;border-radius:3px}.recorder{background:#1a1a1a;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 #666;border-radius:8px;background:#2a2a2a;color:#ddd;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none}.mic-button:hover{background:#3a3a3a;border-color:#888}.mic-button.recording{background:#e74c3c;border-color:#e74c3c;color:#fff}.mic-button.request{background:#1db954;border-color:#1db954;color:#fff}.mic-button.request:hover{background:#1ed760;border-color:#1ed760}.mic-button.disabled{opacity:.5;cursor:not-allowed;background:#333;border-color:#444}.recording-bar{height:4px;background:#333;border-radius:2px;overflow:hidden}.recording-progress{height:100%;background:#e74c3c;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:#666;text-align:center}.slice-controls{display:flex;align-items:center;gap:16px}.slice-toggle{padding:8px 16px;border:2px solid #f39c12;border-radius:6px;background:transparent;color:#f39c12;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.slice-toggle:hover{background:#f39c121a}.slice-toggle.active{background:#f39c12;color:#fff}.sensitivity-control{display:flex;align-items:center;gap:8px}.sensitivity-label{font-size:12px;color:#888}.sensitivity-slider{width:100px;height:4px;-webkit-appearance:none;appearance:none;background:#444;border-radius:2px;outline:none}.sensitivity-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#f39c12;cursor:pointer}.sensitivity-value{font-size:12px;color:#f39c12;min-width:24px;font-family:monospace}.recorder-actions{display:flex;gap:8px}.action-button{padding:10px 16px;border:2px solid #666;border-radius:6px;background:#2a2a2a;color:#ddd;font-size:13px;cursor:pointer;transition:all .15s ease}.action-button:hover{background:#3a3a3a}.action-button.add{border-color:#1db954;color:#1db954}.action-button.add:hover{background:#1db954;color:#fff}.action-button.discard{border-color:#e74c3c;color:#e74c3c}.action-button.discard:hover{background:#e74c3c;color:#fff}.action-button:disabled{opacity:.5;cursor:not-allowed}.track-count{color:#666;font-size:13px;align-self:flex-end}.effects-panel{position:relative;display:flex;flex-direction:column}.effects-panel.disabled{opacity:.5;pointer-events:none}.transport-right .effects-panel{position:static}.transport-right .effects-container{position:absolute;top:100%;right:0;margin-top:8px;min-width:700px;max-width:calc(100vw - 32px)}.effects-toggle{display:flex;align-items:center;justify-content:center;gap:4px;padding:8px 12px;border:2px solid #555;border-radius:6px;background:#252525;color:#888;font-size:12px;font-weight:700;cursor:pointer;transition:all .15s ease;position:relative}.effects-toggle:hover:not(:disabled){border-color:#777;color:#aaa;background:#333}.effects-toggle.expanded{border-color:#00bcd4;color:#00bcd4;background:#00bcd41a}.effects-toggle.active .effects-icon{color:#00bcd4}.effects-indicator{position:absolute;top:4px;right:4px;width:6px;height:6px;background:#00bcd4;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.effects-container{position:relative;background:#1a1a1a;border:1px solid #333;border-radius:12px;padding:16px;margin-top:8px;width:100%;box-shadow:0 8px 32px #00000080;z-index:100}@media(min-width:769px){.effects-container{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:none}.effect-group{margin-bottom:0;padding-bottom:0;border-bottom:none;border-right:1px solid #333;padding-right:16px}.effect-group:last-child{border-right:none;padding-right:0}}.effect-group{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #333}.effect-group:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.effect-label{display:block;font-size:11px;font-weight:700;color:#00bcd4;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}.effect-controls{display:flex;flex-direction:column;gap:8px}@media(min-width:769px){.effect-controls{flex-direction:column;gap:10px}}.effect-param{display:flex;align-items:center;gap:8px}@media(min-width:769px){.effect-param{display:flex;flex-direction:row;align-items:center;gap:8px}.effect-param label{min-width:50px;flex-shrink:0}.effect-param input[type=range]{flex:1;min-width:60px}.effect-param .param-value{min-width:40px;text-align:right}}.effect-param label{font-size:10px;color:#666;text-transform:uppercase;letter-spacing:.5px}.effect-param input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:4px;background:#333;border-radius:2px;cursor:pointer}.effect-param input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:#00bcd4;border-radius:50%;cursor:pointer;transition:transform .1s ease}.effect-param input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}.effect-param input[type=range]::-moz-range-thumb{width:14px;height:14px;background:#00bcd4;border:none;border-radius:50%;cursor:pointer}.effect-param select{background:#333;border:1px solid #444;border-radius:4px;color:#ddd;font-size:11px;padding:4px 8px;cursor:pointer}.effect-param select:focus{outline:none;border-color:#00bcd4}.param-value{font-size:11px;color:#888;font-family:monospace;text-align:right}@media(max-width:768px){.effects-container{position:fixed;inset:auto 0 0;max-width:none;min-width:auto;border-radius:12px 12px 0 0;padding:20px;max-height:80vh;overflow-y:auto;z-index:1000}.effect-controls{gap:16px}.effect-param{min-width:100px}}.effect-group:nth-child(1) .effect-label{color:#9c27b0}.effect-group:nth-child(1) input[type=range]::-webkit-slider-thumb{background:#9c27b0}.effect-group:nth-child(1) input[type=range]::-moz-range-thumb{background:#9c27b0}.effect-group:nth-child(2) .effect-label{color:#2196f3}.effect-group:nth-child(2) input[type=range]::-webkit-slider-thumb{background:#2196f3}.effect-group:nth-child(2) input[type=range]::-moz-range-thumb{background:#2196f3}.effect-group:nth-child(3) .effect-label{color:#4caf50}.effect-group:nth-child(3) input[type=range]::-webkit-slider-thumb{background:#4caf50}.effect-group:nth-child(3) input[type=range]::-moz-range-thumb{background:#4caf50}.effect-group:nth-child(4) .effect-label{color:#ff5722}.effect-group:nth-child(4) input[type=range]::-webkit-slider-thumb{background:#ff5722}.effect-group:nth-child(4) input[type=range]::-moz-range-thumb{background:#ff5722}.effects-master-controls{grid-column:1 / -1;display:flex;align-items:center;gap:12px;padding-bottom:12px;margin-bottom:8px;border-bottom:1px solid #333}.effects-bypass-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:2px solid #4caf50;border-radius:6px;background:#4caf501a;color:#4caf50;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .15s ease}.effects-bypass-btn:hover:not(:disabled){background:#4caf5033;border-color:#66bb6a}.effects-bypass-btn.bypassed{border-color:#ff5722;background:#ff572226;color:#ff5722}.effects-bypass-btn.bypassed:hover:not(:disabled){background:#ff572240;border-color:#ff7043}.effects-bypass-btn:disabled{opacity:.4;cursor:not-allowed;border-color:#555;color:#555;background:transparent}.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:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);border:2px solid var(--bg-primary, #1a1a1a);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(--accent-color, #4ecdc4)}.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(--accent-color, #4ecdc4),0 0 0 4px #4ecdc466}50%{box-shadow:0 0 0 2px var(--accent-color, #4ecdc4),0 0 0 8px #4ecdc433}}.avatar-play-indicator{position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;background-color:var(--accent-color, #4ecdc4);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:6px;color:#fff;border:1px solid var(--bg-primary, #1a1a1a);pointer-events:none}.avatar-letter{-webkit-user-select:none;user-select:none;pointer-events:none}.avatar-overflow{background-color:#666;font-size:11px}.avatar-count{-webkit-user-select:none;user-select:none;pointer-events:none}@media(prefers-color-scheme:light){.avatar{border-color:#fff}}@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, #666);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, #666);font-weight:700}.toast-message{font-size:14px;color:#fff;white-space:nowrap}.toast.join .toast-icon{color:var(--toast-color, #4caf50)}.toast.leave .toast-icon{color:var(--toast-color, #f44336)}.toast-url{flex-direction:column;align-items:stretch;gap:6px;padding:12px 16px;background:#ff6b3526;border:1px solid rgba(255,107,53,.3);border-left:3px solid #ff6b35;cursor:pointer;max-width:320px}.toast-url-header{display:flex;justify-content:space-between;align-items:center}.toast-url-header .toast-message{color:#ff8a5c;font-weight:500}.toast-dismiss{background:none;border:none;color:#ff8a5c;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:#ccc;font-family:monospace;word-break:break-all;display:block}.toast-url-hint{font-size:11px;color:#888;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:#aaa}.connection-status__queue{color:#888;font-size:.7rem}.connection-status--connected .connection-status__dot{background:#4caf50;box-shadow:0 0 4px #4caf50}.connection-status--connected .connection-status__text{color:#4caf50}.connection-status--connecting .connection-status__dot{background:#ffc107;animation:pulse 1.5s ease-in-out infinite}.connection-status--connecting .connection-status__text{color:#ffc107}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 4px #ffc107}50%{opacity:.5;box-shadow:0 0 8px #ffc107}}.connection-status--disconnected .connection-status__dot{background:#f44336;box-shadow:0 0 4px #f44336}.connection-status--disconnected .connection-status__text{color:#f44336}.connection-status--disconnected .connection-status__queue,.connection-status--connecting .connection-status__queue{color:#ff9800}.connection-status--single_player .connection-status__dot{background:#888;box-shadow:0 0 4px #888}.connection-status--single_player .connection-status__text{color:#888}.connection-status__retry{background:none;border:1px solid #666;border-radius:4px;color:#aaa;cursor:pointer;font-size:.7rem;padding:2px 6px;margin-left:4px;transition:all .15s ease}.connection-status__retry:hover{background:#ffffff1a;border-color:#888;color:#fff}.connection-status__retry:active{background:#fff3}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:var(--bg-dark, #1a1a1a);color:var(--text-primary, #fff)}.error-boundary-content{max-width:500px;text-align:center}.error-boundary h1{font-size:1.5rem;margin-bottom:.5rem;color:#ff6b6b}.error-message{color:var(--text-secondary, #888);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:#4a9eff;color:#fff}.error-btn.secondary{background:#333;color:#ccc;border:1px solid #444}.error-details{margin-top:2rem;text-align:left;font-size:.75rem}.error-details summary{cursor:pointer;color:var(--text-secondary, #888);margin-bottom:.5rem}.error-stack,.component-stack{background:#0d0d0d;padding:1rem;border-radius:4px;overflow-x:auto;white-space:pre-wrap;word-break:break-word;color:#ff6b6b;font-size:.7rem;max-height:200px;overflow-y:auto}.component-stack{color:#888;margin-top:.5rem}.orientation-hint{display:flex;align-items:center;justify-content:center;gap:8px;background:#ff6b3526;border:1px solid rgba(255,107,53,.3);color:#ff8a5c;padding:8px 16px;border-radius:8px;font-size:13px;margin-bottom:12px;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:16px;animation:rotate-hint 2s ease-in-out infinite}@keyframes rotate-hint{0%,to{transform:rotate(0)}25%{transform:rotate(-15deg)}75%{transform:rotate(15deg)}}.orientation-hint-text{font-weight:500}.orientation-hint-dismiss{background:none;border:none;color:#ff8a5c;cursor:pointer;font-size:14px;padding:2px 6px;margin-left:4px;opacity:.7;transition:opacity .15s}.orientation-hint-dismiss:hover{opacity:1}@media(orientation:landscape),(min-width:769px){.orientation-hint{display:none}}.qr-overlay{--qr-bg: #121212;--qr-surface: #1a1a1a;--qr-border: #2a2a2a;--qr-code-light: #FFFFFF;--qr-code-dark: #1a1a1a;--qr-accent: #e85a30;--qr-text-primary: rgba(255, 255, 255, .9);--qr-text-secondary: #888888;--qr-player-count: #4ade80;--qr-backdrop: rgba(18, 18, 18, .92);--qr-enter-duration: .25s;--qr-exit-duration: .15s;--qr-ease: cubic-bezier(.16, 1, .3, 1)}@keyframes qr-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes qr-fade-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes qr-code-enter{0%{transform:scale(1.02);opacity:0}to{transform:scale(1);opacity:1}}@keyframes qr-accent-pulse{0%,to{opacity:.6}50%{opacity:1}}@keyframes qr-backdrop-fade{0%{opacity:0}to{opacity:1}}.qr-panel{display:flex;flex-direction:column;align-items:center;padding:24px;position:relative}.qr-panel-content{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%}.qr-code-container{animation:qr-code-enter var(--qr-enter-duration) var(--qr-ease)}.qr-code{border-radius:8px;overflow:hidden;background:var(--qr-code-light);display:flex;align-items:center;justify-content:center}.qr-code svg{display:block;width:100%;height:100%}.qr-code-loading{background:var(--qr-surface);animation:pulse 1.5s ease-in-out infinite}.qr-code-error{background:var(--qr-surface);color:var(--qr-accent);font-size:2rem;display:flex;align-items:center;justify-content:center}.qr-accent-line{width:100%;height:2px;background:var(--qr-accent);animation:qr-accent-pulse 2s ease-in-out infinite;margin:8px 0}.qr-panel-text{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}.qr-panel-text>*{opacity:0;animation:qr-fade-up var(--qr-enter-duration) var(--qr-ease) forwards}.qr-panel-text>:nth-child(1){animation-delay:0ms}.qr-panel-text>:nth-child(2){animation-delay:50ms}.qr-panel-text>:nth-child(3){animation-delay:.1s}.qr-action-text{font-family:system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-size:1.125rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--qr-text-primary)}.qr-session-name{font-family:system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-size:1rem;font-weight:400;color:var(--qr-text-secondary);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qr-player-count{font-size:.75rem;font-weight:500;color:var(--qr-player-count);background:#4ade8026;padding:4px 12px;border-radius:12px}.qr-panel-divider{width:100%;height:1px;background:var(--qr-border);margin:8px 0}.qr-panel-actions{display:flex;flex-direction:column;gap:8px;width:100%}.qr-btn{font-family:system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-size:.875rem;font-weight:500;padding:10px 16px;border-radius:6px;border:1px solid var(--qr-border);background:var(--qr-surface);color:var(--qr-text-primary);cursor:pointer;transition:all .15s ease;width:100%}.qr-btn:hover{background:var(--qr-border);border-color:#3a3a3a}.qr-btn:active{transform:scale(.98)}.qr-btn-copy{background:var(--qr-accent);border-color:var(--qr-accent);color:#fff}.qr-btn-copy:hover{background:#d14d26;border-color:#d14d26}.qr-btn-exit{background:transparent;border-color:var(--qr-border);color:var(--qr-text-secondary)}.qr-btn-exit:hover{color:var(--qr-text-primary)}.qr-close-btn{position:absolute;width:44px;height:44px;min-width:44px;min-height:44px;border:none;background:#ffffff26;color:var(--qr-text-primary);font-size:1.5rem;cursor:pointer;border-radius:22px;display:flex;align-items:center;justify-content:center;transition:all .15s ease;top:12px;right:12px;z-index:10}.qr-close-btn:hover{background:#fff3;color:#fff}.qr-close-btn:active{background:#ffffff40;transform:scale(.95)}.qr-dismiss-hint{font-size:.875rem;color:var(--qr-text-secondary);opacity:0;animation:qr-fade-up var(--qr-enter-duration) var(--qr-ease) .2s forwards;margin-top:24px;text-align:center;padding-bottom:env(safe-area-inset-bottom,0px)}.qr-overlay-large{position:fixed;right:0;top:0;bottom:0;width:280px;background:var(--qr-bg);border-left:1px solid var(--qr-border);z-index:1000;animation:qr-slide-in var(--qr-enter-duration) var(--qr-ease);display:flex;align-items:center;justify-content:center}.qr-overlay-large .qr-panel{width:100%}.qr-overlay-medium{position:fixed;right:16px;bottom:16px;width:240px;background:var(--qr-surface);border:1px solid var(--qr-border);border-radius:12px;box-shadow:0 8px 32px #0006;z-index:1000;animation:qr-fade-up var(--qr-enter-duration) var(--qr-ease)}.qr-overlay-medium .qr-panel{padding:16px}.qr-overlay-medium .qr-action-text{font-size:1rem}.qr-overlay-medium .qr-session-name{font-size:.875rem;max-width:160px}.qr-overlay-small{position:fixed;inset:0;min-height:100dvh;min-height:-webkit-fill-available;background:var(--qr-backdrop);z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;animation:qr-backdrop-fade var(--qr-enter-duration) var(--qr-ease);padding:env(safe-area-inset-top,16px) env(safe-area-inset-right,16px) env(safe-area-inset-bottom,16px) env(safe-area-inset-left,16px);box-sizing:border-box;overflow:hidden;overscroll-behavior:none}.qr-overlay-small .qr-panel{background:transparent;animation:qr-fade-up var(--qr-enter-duration) var(--qr-ease);max-height:calc(100dvh - env(safe-area-inset-top,32px) - env(safe-area-inset-bottom,32px) - 80px);max-height:calc(100vh - 120px);overflow-y:auto}.qr-overlay-small .qr-action-text{font-size:1.25rem}.qr-overlay-small .qr-panel-actions{max-width:240px}.qr-overlay-small .qr-btn-exit{display:none}.qr-overlay-small .qr-close-btn{position:fixed;top:max(16px,env(safe-area-inset-top,16px));right:max(16px,env(safe-area-inset-right,16px));background:#fff3;border:1px solid rgba(255,255,255,.1)}@media(max-width:767px)and (orientation:landscape){.qr-overlay-small{overflow-y:auto;justify-content:flex-start;padding-top:16px;padding-bottom:16px}.qr-overlay-small .qr-panel{margin:auto}.qr-overlay-small .qr-code{width:140px!important;height:140px!important}.qr-overlay-small .qr-accent-line,.qr-overlay-small .qr-panel-divider,.qr-overlay-small .qr-panel-actions,.qr-overlay-small .qr-dismiss-hint{display:none}}.qr-overlay:focus{outline:none}.qr-btn:focus-visible{outline:2px solid var(--qr-accent);outline-offset:2px}.qr-close-btn:focus-visible{outline:2px solid var(--qr-accent);outline-offset:2px}.app.qr-mode-large{margin-right:280px;transition:margin-right var(--qr-enter-duration) var(--qr-ease)}@keyframes pulse{0%,to{opacity:.4}50%{opacity:.6}}.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:2.5rem;font-weight:700;margin:0;background:linear-gradient(135deg,#ff6b35,#f7931e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:#888;font-size:1rem;margin-top:8px}.subtitle.published{color:#b794c4}.header-title-group{display:flex;align-items:baseline;gap:8px}.title-separator{color:#555;font-size:1.5rem;font-weight:300;margin:0 4px}.session-name{background:none;border:none;font-size:1.5rem;font-weight:500;color:#aaa;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:#ccc}.session-name:focus{outline:none;box-shadow:0 0 0 2px #ff6b354d}.session-name-disabled{cursor:default}.session-name-disabled:hover{background:none;color:#aaa}.session-name-saving{color:#666;font-size:.9em;margin-left:4px}.session-name-input{font-size:1.5rem;font-weight:500;color:#fff;background:#ffffff14;border:1px solid rgba(255,107,53,.5);border-radius:4px;padding:2px 8px;outline:none;max-width:300px;width:auto;min-width:150px}.session-name-input:focus{border-color:#ff6b35;box-shadow:0 0 0 2px #ff6b3533}.session-name-input::placeholder{color:#666}@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}}.session-controls{display:flex;align-items:center;gap:8px}.session-controls.session-loading,.session-controls.session-error{font-size:.85rem;color:#888}.session-controls.session-error{color:#ff6b6b}.session-controls.session-not-found{flex-wrap:wrap;justify-content:center}.not-found-text{font-size:.85rem;color:#ff6b6b}.orphan-banner{display:flex;align-items:center;gap:12px;background:#ffc10726;border:1px solid rgba(255,193,7,.3);color:#ffc107;padding:8px 16px;border-radius:6px;font-size:.85rem;margin-bottom:12px;max-width:600px}.orphan-dismiss{background:none;border:none;color:#ffc107;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:#888;margin-right:8px}.lineage-arrow{color:#666}.lineage-text{color:#888}.remix-count,.remix-count-standalone{color:#666;font-size:.75rem}.remix-count-standalone{margin-right:8px}.player-count{color:#4ade80;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 #444;border-radius:6px;background:#2a2a2a;color:#fff;cursor:pointer;transition:all .15s ease}.session-btn:hover:not(:disabled){background:#3a3a3a;border-color:#555}.session-btn:disabled{opacity:.5;cursor:not-allowed}.publish-btn{background:linear-gradient(135deg,#9b59b6,#8e44ad);border-color:#9b59b6;color:#fff}.publish-btn:hover:not(:disabled){background:linear-gradient(135deg,#a569c0,#9b59b6);border-color:#a569c0;color:#fff}.remix-btn:hover:not(:disabled){border-color:#f7931e;color:#f7931e}.new-btn:hover:not(:disabled){border-color:#4ecdc4;color:#4ecdc4}.download-btn:hover:not(:disabled){border-color:#3498db;color:#3498db}.invite-btn{background:transparent;border-color:#555;color:#aaa}.invite-btn:hover:not(:disabled){border-color:#ff6b35;color:#ff6b35;background:#ff6b3514}.published-badge{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600;color:#9b59b6;background:#9b59b626;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:#2a2a2a;border:1px solid #444;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:#fff;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:#3a3a3a}.share-dropdown-item:active{background:#444}.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%}}
