*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0f0f1a;--bg-panel: #1a1a2e;--bg-input: #252540;--border: #333355;--text: #e0e0e8;--text-dim: #888899;--accent: #4fc3f7;--accent-hover: #81d4fa;--danger: #ef5350;--ok: #66bb6a;--pending: #ffa726}html,body{background:var(--bg);color:var(--text);font-family:Inter,-apple-system,system-ui,sans-serif;font-size:14px;height:100%;overflow:hidden}#app{display:grid;grid-template-columns:1fr;grid-template-rows:auto auto 1fr auto;gap:0;padding:0;height:100vh;min-width:600px}#app-header{grid-row:1;display:flex;align-items:center;gap:16px;padding:12px 16px}#app-header h1{color:var(--accent);font-size:22px;font-weight:700;letter-spacing:1px}#start-btn{margin-left:auto}#audio-status{color:var(--text-dim);font-size:13px}#top-bar{grid-row:2;position:relative;z-index:100}#col-center{grid-row:3;position:relative;overflow:hidden;padding:8px}#app-footer{grid-row:4;padding:0 12px 12px}.panel{background:var(--bg-panel);border:1px solid var(--border);border-radius:8px;padding:14px}.panel h2{font-size:13px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);margin-bottom:10px}.btn{border:none;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-primary{background:var(--accent);color:#111}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-input);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:#303050}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#e53935}.btn-small{padding:4px 10px;font-size:12px}.btn-mute{background:var(--bg-input);color:var(--text-dim);border:1px solid var(--border)}.btn-mute.active{background:var(--danger);color:#fff;border-color:var(--danger)}.hidden{display:none!important}.top-bar{display:flex;flex-direction:column;background:var(--bg-panel);border-bottom:1px solid var(--border)}.tb-row1{display:flex;align-items:center;height:34px;padding:0 16px;flex-shrink:0}.tb-row2{display:flex;align-items:center;gap:8px;height:38px;padding:0 16px;border-top:1px solid var(--border);flex-shrink:0}.tb-row3{display:flex;align-items:center;gap:10px;height:32px;padding:0 16px;border-top:1px solid var(--border);flex-shrink:0;background:#0f0f1a4d}.tb-brand{color:var(--accent);font-size:15px;font-weight:700;letter-spacing:1.5px;flex-shrink:0;margin:0}.tb-status{font-size:11px;font-weight:600;flex-shrink:0;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-left:10px}.tb-auth{margin-left:auto;display:flex;align-items:center;gap:8px;font-size:12px}.tb-auth-email{color:var(--text-dim);font-size:12px}.tb-auth-btn{background:none;border:none;color:var(--accent);font-size:12px;font-weight:600;cursor:pointer;padding:2px 6px;border-radius:4px;transition:background .15s}.tb-auth-btn:hover{background:#4fc3f71a}.tb-auth-input{width:200px;background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:3px 8px;font-size:12px;outline:none}.tb-auth-input:focus{border-color:var(--accent)}.tb-auth-input::placeholder{color:var(--text-dim)}.tb-auth-msg{font-size:11px;color:var(--text-dim)}.tb-auth-signed-in{display:flex;align-items:center;gap:6px}.tb-auth-display-name{color:var(--text);font-size:12px;font-weight:600;cursor:pointer}.tb-auth-display-name:hover{text-decoration:underline}.tb-avatar-dot{width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;flex-shrink:0;transition:transform .15s}.tb-avatar-dot:hover{transform:scale(1.2)}.tb-profile-editor{display:flex;align-items:center;gap:6px}.tb-name-input{width:140px;background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:3px 8px;font-size:12px;outline:none}.tb-name-input:focus{border-color:var(--accent)}.tb-name-input::placeholder{color:var(--text-dim)}.tb-color-picker{display:flex;gap:3px;align-items:center}.tb-color-swatch{width:16px;height:16px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:border-color .15s,transform .15s}.tb-color-swatch:hover{transform:scale(1.15)}.tb-color-swatch.selected{border-color:var(--text)}.tb-room-code-select{background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:4px 6px;font-size:12px;font-family:JetBrains Mono,Fira Code,monospace;letter-spacing:1px;outline:none;max-width:100px}.tb-room-code-select:focus{border-color:var(--accent)}.tb-friend-add-row{display:flex;gap:4px;align-items:center}.tb-friend-add-input{flex:1;background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:5px 8px;font-size:12px;outline:none}.tb-friend-add-input:focus{border-color:var(--accent)}.tb-friend-add-input::placeholder{color:var(--text-dim)}.tb-friend-add-msg{font-size:11px;margin-top:4px;display:block}.tb-friends-empty{font-size:12px;color:var(--text-dim);text-align:center;padding:12px 0}.tb-friends-list{max-height:240px;overflow-y:auto}.tb-friend-row{display:flex;align-items:center;gap:6px;padding:5px 0;border-bottom:1px solid var(--border)}.tb-friend-row:last-child{border-bottom:none}.tb-friend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;opacity:.4;transition:opacity .2s}.tb-friend-dot.online{opacity:1;box-shadow:0 0 4px currentColor}.tb-friend-name{font-size:12px;font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tb-friend-status{font-size:10px;color:var(--text-dim);white-space:nowrap;flex-shrink:0}.tb-friend-actions{display:flex;gap:3px;flex-shrink:0}.tb-friend-actions .btn{padding:2px 6px;font-size:10px}.tb-friend-remove{font-size:14px!important;line-height:1;opacity:.5}.tb-friend-remove:hover{opacity:1}.tb-invite-toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--bg-panel);border:1px solid var(--accent);border-radius:8px;padding:10px 16px;display:flex;align-items:center;gap:10px;z-index:200;box-shadow:0 8px 24px #00000080,0 0 12px #4fc3f733;animation:toast-slide-up .3s ease-out}.tb-invite-toast.hidden{display:none}.tb-invite-text{font-size:13px;color:var(--text)}@keyframes toast-slide-up{0%{transform:translate(-50%) translateY(20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.tb-peer-card{border-left:3px solid transparent}.tb-divider{width:1px;height:24px;background:var(--border);flex-shrink:0}.tb-section{display:flex;align-items:center;gap:4px;flex-shrink:0}.tb-code-input{width:60px;background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:4px 6px;font-size:13px;font-family:JetBrains Mono,Fira Code,monospace;letter-spacing:3px;text-transform:uppercase;text-align:center;outline:none}.tb-code-input:focus{border-color:var(--accent)}.tb-code-input::placeholder{letter-spacing:1px;font-size:11px;text-transform:none}.tb-room-code{font-family:JetBrains Mono,Fira Code,monospace;font-size:14px;font-weight:700;letter-spacing:3px;color:var(--accent)}.tb-status-dot{width:8px;height:8px;border-radius:50%;background:var(--ok);flex-shrink:0}.tb-midi{display:flex;align-items:center;gap:5px;flex-shrink:1;min-width:0}.tb-midi-icon{font-size:14px;flex-shrink:0}.tb-midi-name{font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.tb-midi-select{background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:3px 6px;font-size:12px;outline:none;max-width:180px;min-width:80px}.tb-midi-select:focus{border-color:var(--accent)}.tb-settings-section{margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border)}.tb-settings-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.tb-settings-section-label{font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}.tb-latency{display:flex;gap:4px}.tb-latency .latency-btn{flex:1;padding:5px 10px;font-size:11px}.tb-sync{display:flex;align-items:center;gap:6px}.tb-sync .sync-btn{padding:5px 10px;font-size:11px;min-width:40px}.tb-sync .sync-slider{flex:1;min-width:60px}.tb-sync .sync-delay-display{font-size:10px;min-width:70px;color:var(--text-dim);font-family:JetBrains Mono,Fira Code,monospace;white-space:nowrap}.tb-peer-list-inline{display:flex;align-items:center;gap:8px;margin-left:auto;overflow-x:auto;flex-shrink:1;min-width:0}.tb-peer-card{display:flex;align-items:center;gap:5px;font-size:11px;white-space:nowrap;flex-shrink:0;padding:2px 8px;background:#25254080;border-radius:4px;border:1px solid transparent}.tb-peer-card .activity-indicator{width:6px;height:6px}.tb-peer-card .activity-peer-label{font-size:11px;font-weight:600;max-width:80px;overflow:hidden;text-overflow:ellipsis}.tb-peer-card .activity-note{font-size:10px;min-width:24px;text-align:center}.tb-peer-card .quality-dot{width:6px;height:6px}.tb-peer-card .activity-status{font-size:9px;min-width:0}.tb-triggers{display:flex;align-items:center;gap:2px;margin-left:auto;flex-shrink:0}.tb-trigger{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--text-dim);border:1px solid transparent;border-radius:6px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.tb-trigger:hover{background:var(--bg-input);color:var(--text)}.tb-trigger.active{background:var(--bg-input);color:var(--accent);border-color:var(--accent)}.tb-dropdown{position:absolute;top:72px;right:12px;background:var(--bg-panel);border:1px solid var(--border);border-radius:8px;padding:12px;min-width:280px;max-width:400px;max-height:60vh;overflow-y:auto;box-shadow:0 8px 24px #0006;z-index:101}.tb-dropdown-section{margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border)}.tb-dropdown-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.tb-dd-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;display:block;margin-bottom:6px}.tb-mixer-peer{margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border)}.tb-mixer-peer:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.tb-mixer-peer-label{font-size:12px;font-weight:600;margin-bottom:4px}.tb-mixer-peer-controls{display:flex;flex-direction:column;gap:3px}.tb-mixer-peer-controls label{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-dim)}.tb-mixer-peer-controls label input{flex:1}.tb-master-row{display:flex;align-items:center;gap:8px}.tb-master-row input{flex:1}.tb-master-val{font-size:12px;color:var(--text-dim);min-width:32px}.conn-status{font-size:13px;font-weight:600;margin-bottom:10px}.status-ok{color:var(--ok)}.status-err{color:var(--danger)}.status-pending{color:var(--pending)}.conn-room-code{margin-bottom:10px}.room-code-value{font-size:24px;font-weight:700;letter-spacing:4px;color:var(--accent);font-family:JetBrains Mono,Fira Code,monospace}.conn-actions{display:flex;flex-direction:column;gap:8px}.conn-join-row{display:flex;gap:6px}.conn-join-row input{flex:1;background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:16px;font-family:JetBrains Mono,Fira Code,monospace;letter-spacing:4px;text-transform:uppercase;text-align:center;outline:none}.conn-join-row input:focus{border-color:var(--accent)}.conn-join-row input::placeholder{letter-spacing:1px;font-size:13px;text-transform:none}.midi-devices{margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.midi-devices-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;display:block;margin-bottom:6px}.midi-device-select{width:100%;background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:6px 8px;font-size:13px;outline:none;cursor:pointer}.midi-device-select:focus{border-color:var(--accent)}.midi-device-select:disabled{color:var(--text-dim);cursor:default}.midi-status{font-size:11px;margin-top:4px;min-height:16px}.peer-list{margin-top:10px}.peer-item{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:13px}.peer-dot{width:8px;height:8px;border-radius:50%;background:var(--ok);flex-shrink:0}.instrument-toolbar{display:flex;align-items:center;gap:6px;margin-bottom:8px;cursor:grab;flex-shrink:0}.instrument-toolbar h2{margin-bottom:0;flex-shrink:0}.instrument-toolbar .inst-preset{min-width:0;max-width:160px;background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:4px 8px;font-size:12px;outline:none}.instrument-toolbar .inst-preset:focus{border-color:var(--accent)}.save-preset-form{display:flex;align-items:center;gap:4px}.save-preset-input{width:120px;background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:4px 8px;font-size:11px;outline:none}.save-preset-input:focus{border-color:var(--accent)}.save-preset-input::placeholder{color:var(--text-dim)}.toolbar-spacer{flex:1}.toolbar-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-input);color:var(--text-dim);border:1px solid var(--border);border-radius:6px;cursor:pointer;flex-shrink:0;transition:transform .25s ease,background .15s,color .15s}.toolbar-btn:hover{background:#303050;color:var(--text)}.keyboard-panel,.drum-panel{position:absolute;overflow:hidden;display:flex;flex-direction:column;min-height:150px;min-width:150px}.corner-resize{position:absolute;right:0;bottom:0;width:16px;height:16px;cursor:nwse-resize;z-index:5}.corner-resize:after{content:"";position:absolute;right:3px;bottom:3px;width:8px;height:8px;border-right:2px solid var(--border);border-bottom:2px solid var(--border);transition:border-color .15s}.corner-resize:hover:after,.corner-resize:active:after{border-color:var(--accent)}.settings-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;flex-direction:column}.settings-overlay.hidden{display:none}.settings-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f0f1abf;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.settings-panel{position:relative;z-index:11;width:100%;height:100%;background:var(--bg-panel);border:1px solid var(--border);border-radius:6px;display:flex;flex-direction:column;overflow:hidden}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.settings-header h3{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text)}.settings-body{padding:10px 12px;overflow-y:auto;flex:1}.inst-sliders{display:flex;flex-direction:column;gap:6px}.slider-row{display:grid;grid-template-columns:72px 1fr 52px;align-items:center;gap:6px}.slider-label{font-size:11px;color:var(--text-dim);text-align:right;white-space:nowrap}.slider-val{font-size:10px;color:var(--text-dim);font-family:JetBrains Mono,Fira Code,monospace;text-align:right}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;background:var(--bg-input);border-radius:2px;outline:none;transition:background .1s}input[type=range]:hover{background:#303050}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg-panel);box-shadow:0 0 4px #4fc3f74d;transition:box-shadow .1s}input[type=range]::-webkit-slider-thumb:hover{box-shadow:0 0 8px #4fc3f780}.param-section{margin-bottom:6px;border:1px solid var(--border);border-radius:6px;overflow:hidden;background:#0f0f1a66}.param-section-header{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--bg-input);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.param-section-header:hover{background:#303050}.param-section-icon{font-size:14px;color:var(--accent);width:16px;text-align:center;flex-shrink:0}.param-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text)}.param-section-chevron{margin-left:auto;color:var(--text-dim);transition:transform .25s ease;flex-shrink:0}.param-section.collapsed .param-section-chevron{transform:rotate(-90deg)}.param-section-body{padding:8px 10px;display:flex;flex-direction:column;gap:5px;max-height:400px;transition:max-height .25s ease,padding .25s ease,opacity .2s ease;opacity:1}.param-section.collapsed .param-section-body{max-height:0;padding-top:0;padding-bottom:0;opacity:0;overflow:hidden}.segment-row{display:grid;grid-template-columns:72px 1fr;align-items:center;gap:6px}.segment-label{font-size:11px;color:var(--text-dim);text-align:right;white-space:nowrap}.segment-buttons{display:flex;gap:2px;background:var(--bg);border-radius:4px;padding:2px}.segment-btn{flex:1;padding:4px 2px;font-size:10px;font-weight:600;letter-spacing:.3px;border:none;border-radius:3px;background:transparent;color:var(--text-dim);cursor:pointer;transition:background .1s,color .1s;text-align:center}.segment-btn:hover{background:#303050;color:var(--text)}.segment-btn.active{background:var(--accent);color:#111}.drum-params-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.drum-pad-params{border:1px solid var(--border);border-radius:6px;padding:8px;background:#0f0f1a66}.drum-pad-params-header{font-size:10px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid var(--border)}.drum-pad-params .slider-row{grid-template-columns:42px 1fr 42px}.drum-pad-params .slider-label{font-size:10px}.drum-pad-params .slider-val{font-size:9px}.mixer-master{margin-bottom:10px}.mixer-master label{display:flex;align-items:center;gap:8px;font-size:13px}.mixer-master label input{flex:1}#mixer-master-val{font-size:12px;color:var(--text-dim);min-width:32px}.mixer-peer-row{margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border)}.mixer-peer-label{font-size:13px;font-weight:600;display:block;margin-bottom:4px}.mixer-peer-controls{display:flex;flex-direction:column;gap:4px}.mixer-peer-controls label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-dim)}.mixer-peer-controls label input{flex:1}.keyboard-body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.keyboard{position:relative;-webkit-user-select:none;user-select:none;overflow:hidden;flex:1;min-height:0}.keys-wrapper{position:relative;display:flex;height:100%}.key{display:flex;align-items:flex-end;justify-content:center;cursor:pointer;transition:background .05s}.white-key{flex:1;height:100%;min-width:0;background:#e8e8e8;border:1px solid #999;border-radius:0 0 4px 4px;z-index:1}.white-key:hover{background:#d0d0d0}.white-key.active{background:var(--accent)}.key-label{font-size:clamp(7px,1.5vw,10px);color:#666;margin-bottom:4px;pointer-events:none}.white-key.active .key-label{color:#111}.black-key{position:absolute;height:62%;background:#222;border:1px solid #111;border-radius:0 0 3px 3px;z-index:2;top:0}.black-key:hover{background:#444}.black-key.active{background:var(--accent)}.keyboard-hint{font-size:11px;color:var(--text-dim);padding:4px 0;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pads-body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.pads-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:1fr 1fr;gap:6px;flex:1;min-height:0}.drum-pad{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:0;overflow:hidden;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;padding:4px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .05s}.drum-pad:hover{background:#303050}.drum-pad.active{background:var(--accent);border-color:var(--accent)}.pad-label{display:block;font-size:12px;font-weight:600;pointer-events:none}.pad-key{display:block;font-size:10px;color:var(--text-dim);margin-top:2px;pointer-events:none}.drum-pad.active .pad-label,.drum-pad.active .pad-key{color:#111}.pads-compact .pad-key{display:none}.pads-compact .pad-label{font-size:10px}.pads-tiny .pad-label{font-size:8px}.pads-tiny .pad-key{display:none}.activity-peers{display:flex;flex-direction:column;gap:4px}.activity-peer-row{display:grid;grid-template-columns:10px 1fr 36px 8px auto;align-items:center;gap:6px;padding:3px 0;font-size:12px}.activity-indicator{width:8px;height:8px;border-radius:50%;background:var(--bg-input);transition:background .05s}.activity-indicator.midi-flash{background:var(--accent);box-shadow:0 0 6px var(--accent)}.activity-note{font-family:JetBrains Mono,Fira Code,monospace;font-size:11px;color:var(--text-dim);text-align:center}.activity-status{font-family:JetBrains Mono,Fira Code,monospace;font-size:10px;color:var(--text-dim);text-align:right;white-space:nowrap}.status-direct{color:var(--ok)}.status-buffered{color:var(--pending)}.activity-peer-label{font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quality-dot{width:8px;height:8px;border-radius:50%;background:var(--bg-input);flex-shrink:0}.quality-dot.quality-good{background:var(--ok);box-shadow:0 0 4px var(--ok)}.quality-dot.quality-ok{background:var(--pending);box-shadow:0 0 4px var(--pending)}.quality-dot.quality-poor{background:var(--danger);box-shadow:0 0 4px var(--danger)}.white-key.remote-active{background:#ab47bc}.white-key.remote-active .key-label{color:#fff}.black-key.remote-active{background:#ab47bc}.drum-pad.remote-active{background:#ab47bc;border-color:#ab47bc}.drum-pad.remote-active .pad-label,.drum-pad.remote-active .pad-key{color:#fff}.keyboard .white-key.active,.keyboard .black-key.active{background:var(--accent)}.debug-console{display:flex;flex-direction:column}.debug-header{display:flex;align-items:center;justify-content:space-between}.debug-header h2{margin-bottom:0}.debug-log{margin-top:8px;max-height:200px;overflow-y:auto;font-family:JetBrains Mono,Fira Code,monospace;font-size:11px;line-height:1.6;background:var(--bg);border-radius:4px;padding:6px 8px}.debug-line{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.debug-local{color:var(--accent)}.debug-hw-midi{color:#26c6da}.debug-peer{color:#ab47bc}.debug-state{color:var(--pending)}.debug-session{color:var(--ok)}.latency-mode{margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.latency-mode-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;display:block;margin-bottom:6px}.latency-mode-buttons{display:flex;gap:4px}.latency-btn{flex:1;text-align:center;background:var(--bg-input);color:var(--text-dim);border:1px solid var(--border);transition:background .15s,color .15s,border-color .15s}.latency-btn:hover{background:#303050}.latency-btn.active{background:var(--accent);color:#111;border-color:var(--accent)}.sync-mode{margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.sync-mode-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;display:block;margin-bottom:6px}.sync-mode-row{display:flex;align-items:center;gap:6px}.sync-slider{flex:1;min-width:0}.sync-slider:disabled{opacity:.3;cursor:not-allowed}.sync-btn{min-width:48px;text-align:center;background:var(--bg-input);color:var(--text-dim);border:1px solid var(--border);transition:background .15s,color .15s,border-color .15s}.sync-btn:hover{background:#303050}.sync-btn.active{background:var(--accent);color:#111;border-color:var(--accent)}.sync-btn:disabled{opacity:.4;cursor:not-allowed}.sync-btn:disabled:hover{background:var(--bg-input)}.sync-delay-display{font-family:JetBrains Mono,Fira Code,monospace;font-size:11px;color:var(--text-dim);white-space:nowrap;min-width:80px}#app.landing-root{display:block;overflow-y:auto;overflow-x:hidden;height:100vh;min-width:0}.landing{min-height:100vh;display:flex;flex-direction:column}.landing-nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#0f0f1ae6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}.landing-brand{color:var(--accent);font-size:18px;font-weight:700;letter-spacing:2px}.landing-hero{display:flex;align-items:center;justify-content:center;padding:80px 24px 60px;background:linear-gradient(180deg,rgba(79,195,247,.08) 0%,transparent 100%)}.landing-hero-content{text-align:center;max-width:600px}.landing-hero-icon{font-size:48px;margin-bottom:16px}.landing-hero-title{font-size:48px;font-weight:800;color:var(--accent);letter-spacing:3px;margin-bottom:12px}.landing-hero-subtitle{font-size:20px;color:var(--text);margin-bottom:8px}.landing-hero-tagline{font-size:16px;color:var(--text-dim);margin-bottom:32px}.btn-large{padding:14px 32px;font-size:16px;font-weight:700;border-radius:8px;letter-spacing:.5px}.landing-section{max-width:900px;margin:0 auto;padding:48px 24px;width:100%}.landing-section-title{font-size:24px;font-weight:700;color:var(--text);text-align:center;margin-bottom:32px;letter-spacing:1px}.landing-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.landing-step{text-align:center;padding:20px 12px;background:var(--bg-panel);border:1px solid var(--border);border-radius:10px}.landing-step-number{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#111;font-size:18px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;margin-bottom:12px}.landing-step h3{font-size:14px;font-weight:700;color:var(--text);margin-bottom:6px}.landing-step p{font-size:13px;color:var(--text-dim);line-height:1.4}.landing-features{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.landing-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:10px;padding:24px 16px;text-align:center}.landing-card-icon{font-size:32px;margin-bottom:12px}.landing-card h3{font-size:15px;font-weight:700;color:var(--text);margin-bottom:8px}.landing-card p{font-size:13px;color:var(--text-dim);line-height:1.4}.landing-cta{text-align:center;padding-top:40px;padding-bottom:40px;border-top:1px solid var(--border)}.landing-cta-description{font-size:15px;color:var(--text-dim);margin-bottom:24px;max-width:500px;margin-left:auto;margin-right:auto;line-height:1.5}.landing-signin-form{display:flex;align-items:center;justify-content:center;gap:8px;max-width:400px;margin:0 auto}.landing-email-input{flex:1;background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:10px 14px;font-size:14px;outline:none}.landing-email-input:focus{border-color:var(--accent)}.landing-email-input::placeholder{color:var(--text-dim)}.landing-auth-msg{font-size:13px;color:var(--text-dim);margin-top:12px;min-height:20px}.landing-footer{text-align:center;padding:32px 24px;color:var(--text-dim);font-size:13px;border-top:1px solid var(--border);margin-top:auto}@media (max-width: 768px){.landing-hero-title{font-size:32px}.landing-hero-subtitle{font-size:17px}.landing-steps,.landing-features{grid-template-columns:repeat(2,1fr)}.landing-signin-form{flex-direction:column}.landing-email-input{width:100%}}@media (max-width: 480px){.landing-hero{padding:48px 16px 32px}.landing-section{padding:32px 16px}.landing-hero-title{font-size:28px}.landing-steps,.landing-features{grid-template-columns:1fr}}
