: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}.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}}.step-sequencer-skeleton{display:flex;flex-direction:column;gap:8px;padding:16px;min-height:300px}.skeleton-transport{height:48px;border-radius:8px;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}.skeleton-grid{display:flex;flex-direction:column;gap:4px}.skeleton-track-row{display:flex;gap:8px;align-items:center}.skeleton-track-label{width:80px;height:36px;border-radius:4px;flex-shrink:0;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}.skeleton-steps{display:flex;gap:4px;flex:1}.skeleton-step-cell{flex:1;height:36px;border-radius:4px;background:var(--color-surface);border:1px solid var(--color-border)}.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,.skeleton-transport,.skeleton-track-label{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}
