:root{--bg: #0a0a0a;--panel: #131313;--panel-2: #1a1a1a;--line: #262626;--ink: #f5f5f4;--ink-dim: #a3a3a3;--ink-mute: #525252;--accent: #ff5b1f;--accent-hot: #ff7a3a;--gold: #d4a44e;--green: #3ddc84;--tone: #4dc3ff;--beat: #2a2a2a;--beat-down: #353535;color-scheme:dark}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:Space Grotesk,system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}body{min-height:100dvh;background:radial-gradient(1200px 600px at 20% -10%,rgba(255,91,31,.08),transparent 60%),radial-gradient(900px 500px at 90% 110%,rgba(212,164,78,.05),transparent 70%),var(--bg)}#app{width:100%;margin:0 auto;padding:clamp(6px,1.2vw,18px) clamp(12px,2.5vw,40px)}.brand{display:flex;align-items:baseline;gap:14px;margin-bottom:22px;flex-wrap:wrap}.brand h1{margin:0;font-size:38px;font-weight:700;letter-spacing:-.02em}.brand h1 a{color:inherit;text-decoration:none;cursor:pointer}.brand h1 a:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}.brand h1 .accent{color:var(--accent)}.brand .tag{font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);border:1px solid var(--line);padding:4px 8px;border-radius:4px}.inspire-btn{font-family:inherit;font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;display:inline-flex;align-items:center;gap:7px;padding:8px 17px;border-radius:20px;border:1px solid var(--gold);background:linear-gradient(135deg,#d4a44e24,#ff5b1f24);color:var(--gold);cursor:pointer;transition:transform 80ms ease,background .12s ease,color .12s ease,box-shadow .12s ease}.inspire-btn:hover{background:linear-gradient(135deg,#d4a44e47,#ff5b1f3d);color:var(--ink);box-shadow:0 0 14px #d4a44e73}.inspire-btn:active{transform:translateY(1px)}.inspire-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px}.inspire-icon svg{width:16px;height:16px;display:block}@keyframes inspireShake{0%,to{transform:translate(0) rotate(0)}15%{transform:translate(-3px) rotate(-2deg)}30%{transform:translate(3px) rotate(2deg)}45%{transform:translate(-2px) rotate(-1deg)}60%{transform:translate(2px) rotate(1deg)}75%{transform:translate(-1px) rotate(0)}}@keyframes inspireGlow{0%{box-shadow:0 0 #d4a44eb3}60%{box-shadow:0 0 26px 6px #d4a44e8c}to{box-shadow:0 0 #d4a44e00}}@keyframes inspireSpin{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.4)}to{transform:rotate(360deg) scale(1)}}.inspire-btn.sparking{animation:inspireShake .6s ease-out,inspireGlow .6s ease-out;background:linear-gradient(135deg,#d4a44e73,#ff5b1f66);color:var(--ink)}.inspire-btn.sparking .inspire-icon{animation:inspireSpin .6s cubic-bezier(.34,1.56,.64,1);color:var(--accent-hot)}@media (max-width: 720px) and (orientation: portrait){.inspire-btn{width:36px;height:36px;padding:0;gap:0;border-radius:50%;justify-content:center}.inspire-btn .inspire-label{display:none}}.btn.icon-btn{width:44px;min-width:44px;height:44px;padding:0;display:inline-flex;align-items:center;justify-content:center;letter-spacing:0;position:relative}.btn.icon-btn svg{width:22px;height:22px;display:block}.btn.icon-btn:disabled{opacity:.32;cursor:not-allowed;pointer-events:none}.btn.icon-btn.play-btn{width:88px;min-width:88px;border-radius:10px}@media (hover: none){.btn.icon-btn[data-tip]:after,.chip-btn[data-tip]:after,.saved-clear[data-tip]:after,.inspire-btn[data-tip]:after,.bars-btn[data-tip]:after,.bars-chip[data-tip]:after,.mix-toggle-btn[data-tip]:after,.presence-room-link[data-tip]:after,.row .label[data-tip]:after{display:none!important}}.btn.icon-btn[data-tip],.chip-btn[data-tip],.saved-clear[data-tip],.inspire-btn[data-tip],.bars-btn[data-tip],.bars-chip[data-tip],.mix-toggle-btn[data-tip],.presence-room-link[data-tip]{position:relative}@keyframes tooltip-show{0%{opacity:0;transform:translate(-50%) translateY(4px)}8%{opacity:1;transform:translate(-50%) translateY(0)}80%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(0)}}.btn.icon-btn[data-tip]:after,.chip-btn[data-tip]:after,.saved-clear[data-tip]:after,.inspire-btn[data-tip]:after,.bars-btn[data-tip]:after,.bars-chip[data-tip]:after,.mix-toggle-btn[data-tip]:after,.presence-room-link[data-tip]:after,.row .label[data-tip]:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(4px);background:#1e1e1e;color:var(--ink);font-family:JetBrains Mono,monospace;font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;padding:4px 8px;border-radius:6px;border:1px solid var(--line);pointer-events:none;opacity:0;z-index:100}.row .label[data-tip]:after{white-space:pre-line;text-align:left;line-height:1.5;min-width:110px;bottom:auto;top:50%;left:50%;transform:translate(-8px) translateY(-50%)}@keyframes tooltip-show-label{0%{opacity:0;transform:translate(-8px) translateY(-50%)}8%{opacity:1;transform:translate(0) translateY(-50%)}80%{opacity:1;transform:translate(0) translateY(-50%)}to{opacity:0;transform:translate(0) translateY(-50%)}}.btn.icon-btn[data-tip]:not(:disabled):hover:after,.chip-btn[data-tip]:not(:disabled):hover:after,.saved-clear[data-tip]:not(:disabled):hover:after,.inspire-btn[data-tip]:not(:disabled):hover:after,.bars-btn[data-tip]:not(:disabled):hover:after,.bars-chip[data-tip]:not(:disabled):hover:after,.mix-toggle-btn[data-tip]:not(:disabled):hover:after,.presence-room-link[data-tip]:hover:after{animation:tooltip-show 2.8s ease forwards}.row .label[data-tip]:hover:after{animation:tooltip-show-label 2.8s ease forwards}.saved-chip:has(.chip-btn:hover){position:relative;z-index:100}.btn.save{background:var(--panel-2);color:var(--green);border-color:var(--green)}.btn.save:hover{background:#3ddc841f}.btn.save.btn-saved{color:var(--green);border-color:var(--green);background:#3ddc8438}.btn.share{background:var(--panel-2);color:var(--accent);border-color:var(--accent)}.btn.share:hover{background:#ff5b1f1f}.btn.collab{background:transparent;color:var(--tone);border-color:var(--tone);box-shadow:none}.btn.collab:hover{background:#4dc3ff1f;color:var(--tone)}.btn.collab.active{background:var(--tone);color:#04222e;border-color:transparent;--pulse-color: var(--tone);animation:livePulse 1.1s ease-out infinite}.btn.collab.active:hover{background:#6fd0ff}.btn.share.copied{color:var(--green);border-color:var(--green);background:#3ddc8424;box-shadow:none;animation:none}@keyframes livePulse{0%{box-shadow:0 0 color-mix(in srgb,var(--pulse-color, var(--accent)) 55%,transparent),0 0 14px color-mix(in srgb,var(--pulse-color, var(--accent)) 32%,transparent)}70%{box-shadow:0 0 0 9px color-mix(in srgb,var(--pulse-color, var(--accent)) 0%,transparent),0 0 14px color-mix(in srgb,var(--pulse-color, var(--accent)) 32%,transparent)}to{box-shadow:0 0 color-mix(in srgb,var(--pulse-color, var(--accent)) 0%,transparent),0 0 14px color-mix(in srgb,var(--pulse-color, var(--accent)) 32%,transparent)}}.transport{display:flex;align-items:center;gap:10px 14px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 18px;margin-bottom:22px;flex-wrap:wrap}.transport-zone{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.transport-playback{flex:1 1 240px;min-width:200px;gap:12px}.transport-divider{align-self:stretch;width:1px;background:var(--line);margin:2px;flex-shrink:0}.transport-danger{margin-left:auto}@media (hover: hover){.btn.icon-btn.danger:hover{color:#ff4d8d;border-color:#e056;background:#ee00551f}}.btn.icon-btn.danger:focus-visible,.btn.icon-btn.danger:active{color:#ff4d8d;border-color:#e056;background:#ee00551f}@media (max-width: 900px){.transport{gap:10px}.transport-divider{display:none}.transport-playback{flex-basis:100%;min-width:0}}.btn{font-family:inherit;font-weight:700;font-size:14px;letter-spacing:.06em;text-transform:uppercase;border:none;padding:12px 22px;border-radius:8px;cursor:pointer;transition:transform 80ms ease,background .12s ease,box-shadow .12s ease;background:var(--panel-2);color:var(--ink);border:1px solid var(--line)}.btn:hover{background:#222}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--accent);color:#1a0a00;border-color:transparent;box-shadow:0 0 #ff5b1f66}.btn.primary.playing{background:var(--green);color:#042311;--pulse-color: var(--green);animation:livePulse 1.1s ease-out infinite}.btn.ghost{background:transparent}.bpm{display:flex;align-items:center;gap:10px;flex:1 1 auto;min-width:160px}.bpm label{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim)}.bpm input[type=range]{flex:1;accent-color:var(--accent);height:4px}.bpm .value{font-family:JetBrains Mono,monospace;font-weight:700;font-size:22px;width:56px;text-align:right;color:var(--accent-hot)}.grid-wrap{display:flex;align-items:stretch;gap:10px;position:relative}.grid{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:9px 12px;display:flex;flex-direction:column;gap:8px;flex:1;min-width:0;--step-count: 16}.rows-scroll{display:grid;gap:14px;overflow-x:auto;overflow-y:hidden;padding-block:6px;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch;--step-count: 16}.rows-scroll-drums{scrollbar-width:none}.rows-scroll-drums::-webkit-scrollbar{display:none}.rows-scroll-tone::-webkit-scrollbar{height:6px}.rows-scroll-tone::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}.row{display:grid;grid-template-columns:76px 52px max-content;align-items:center;gap:10px}.row .label{display:flex;align-items:center;gap:7px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;font-size:13px;position:sticky;left:0;background-color:var(--panel);background-image:linear-gradient(#ffffff29,#ffffff29);background-repeat:no-repeat;background-position:left center;background-size:0% 100%;transition:background-size .18s ease-out;border-radius:4px;z-index:2;padding-right:4px;cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:none;overflow:visible;white-space:nowrap;min-width:0}.row .label .label-text{overflow:hidden;white-space:nowrap;min-width:0;display:inline-block}.row .label.holding{background-size:100% 100%;transition:background-size .5s linear}@keyframes label-cleared{0%{transform:scale(1)}35%{transform:scale(1.08);color:var(--green)}to{transform:scale(1)}}.row .label.cleared{animation:label-cleared .4s ease}.row.muted .steps .step,.row.muted .vol{opacity:.4}.row.muted .label{opacity:1}.row.muted .label .label-text{opacity:.65;text-decoration:line-through;text-decoration-thickness:1px}.row.muted .label .swatch{opacity:.5}.row .label .label-full,.row .label .label-short{white-space:nowrap}.row .label .swatch{flex:none;width:12px;height:12px;border-radius:3px}.row .label .label-short{display:none;font-weight:700;font-size:13px}.row .label .label-full{display:inline}@media (max-width: 720px){.row .label .label-full{display:none}.row .label .label-short{display:inline}}.vol{display:flex;align-items:center;justify-content:center;height:100%;width:22px}.vol input[type=range]{appearance:none;-webkit-appearance:none;background:transparent;width:56px;height:16px;transform:rotate(-90deg);margin:0;cursor:ns-resize;accent-color:var(--track-color, var(--accent))}.vol input[type=range]::-webkit-slider-runnable-track{height:3px;background:var(--line);border-radius:2px}.vol input[type=range]::-moz-range-track{height:3px;background:var(--line);border-radius:2px}.vol input[type=range]::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--track-color, var(--ink));border:1px solid var(--bg);margin-top:-8px;cursor:ns-resize;box-shadow:0 0 6px var(--track-color, transparent)}.vol input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--track-color, var(--ink));border:1px solid var(--bg);cursor:ns-resize;box-shadow:0 0 6px var(--track-color, transparent)}.vol.vol-dual{width:52px;gap:14px}.vol-slot{display:flex;align-items:center;justify-content:center;width:16px}.glide-slot input[type=range],.decay-slot input[type=range],.drum-decay-slot input[type=range],.octave-slot input[type=range]{opacity:.85}.grid:not(.src-808) .decay-slot{display:none}.grid:not(.src-808) .row.kick-row .vol{width:22px;gap:0}.grid:not(.src-808) .only808-row{display:none}.grid.src-organic .drum-decay-slot{display:none}.grid.src-organic .row.has-drum-decay .vol{width:24px;gap:0}.steps{display:grid;grid-template-columns:repeat(var(--step-count),minmax(clamp(32px,4.2vw,64px),1fr));gap:clamp(4px,.6vw,8px)}.step{aspect-ratio:1;border-radius:8px;background:var(--beat);border:1px solid transparent;cursor:pointer;position:relative;touch-action:manipulation;transition:background 80ms ease,transform 60ms ease,box-shadow .12s ease}.step.downbeat{background:var(--beat-down)}.step.barline{border-left:2px solid var(--ink-mute)}.step:hover{background:#3a3a3a}.step:active{transform:scale(.94)}.step.on{background:var(--track-color, var(--accent));box-shadow:0 0 12px var(--track-color, var(--accent))}.step.on.owned{background:color-mix(in srgb,var(--owner-color) 72%,var(--beat));box-shadow:0 0 12px color-mix(in srgb,var(--owner-color) 60%,transparent)}.step.playhead{outline:2px solid var(--ink);outline-offset:-2px}.step.on.playhead{filter:brightness(1.3) saturate(1.2)}.tone-row .step{aspect-ratio:auto;height:clamp(44px,5.5vw,72px);cursor:ns-resize;touch-action:none}.tone-row .step.on{box-shadow:0 0 10px var(--track-color);background:linear-gradient(180deg,#4dc3ff8c,#4dc3ff59)}.tone-row .step.on.owned{box-shadow:0 0 10px var(--owner-color);background:linear-gradient(180deg,color-mix(in srgb,var(--owner-color) 55%,transparent),color-mix(in srgb,var(--owner-color) 32%,transparent))}.pitch-dot{position:absolute;left:50%;width:12px;height:12px;border-radius:50%;background:var(--ink);transform:translate(-50%,-50%);pointer-events:none;opacity:0;transition:opacity .12s ease,top .1s ease;box-shadow:0 0 6px #f5f5f4b3}.tone-row .step.on .pitch-dot{opacity:1}.source-bar{display:flex;align-items:center;gap:10px;padding:0 2px 5px;border-bottom:1px dashed var(--line)}.source-bar .tone-voice-btn.active{background:#ffaf502e;color:#ffaf50;border-color:#ffaf50;box-shadow:0 0 10px #ffaf504d}.source-bar .tone-voice-btn.loading{opacity:.6;cursor:progress}.source-bar .inspire-btn{margin-left:auto}.tone-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:6px 2px 4px;border-top:1px dashed var(--line);border-bottom:1px dashed var(--line)}.tt-group{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.tt-right{display:flex;align-items:center;gap:12px;margin-left:auto}.tt-group-scale{justify-content:flex-end}.tt-pills{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.tone-toolbar-label{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);margin-right:6px}.tt-label-scale{display:inline-flex;align-items:baseline;gap:6px}.tt-scale-name{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--tone)}.tone-voice-btn{font-family:inherit;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:7px 14px;border-radius:16px;border:1px solid var(--line);background:var(--panel-2);color:var(--ink-dim);cursor:pointer;transition:background .1s ease,color .1s ease,border-color .1s ease,box-shadow .12s ease}.tone-voice-btn:hover{border-color:var(--tone);color:var(--ink)}.tone-voice-btn.active{background:#4dc3ff26;color:var(--tone);border-color:var(--tone);box-shadow:0 0 10px #4dc3ff4d}.tt-select{display:none;font-family:inherit;font-size:12px;font-weight:600;padding:7px 14px;border-radius:16px;border:1px solid var(--line);background:var(--panel-2);color:var(--ink);cursor:pointer}.tt-select.tt-select-always{display:inline-block}.tt-select:focus{outline:1px solid var(--tone)}.loupe{position:fixed;z-index:200;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:3px;background:var(--ink);color:var(--bg);font-family:JetBrains Mono,monospace;font-weight:700;line-height:1;padding:8px 14px;border-radius:10px;white-space:nowrap;opacity:0;transform:translate(-50%,-100%) scale(.85);transform-origin:50% 110%;transition:opacity .1s ease,transform .14s cubic-bezier(.34,1.56,.64,1);box-shadow:0 8px 24px #0000008c,0 0 0 2px var(--tone)}.loupe .loupe-label{font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;opacity:.55;line-height:1}.loupe .loupe-value{font-size:18px;font-weight:700;line-height:1}.loupe:after{content:"";position:absolute;bottom:-7px;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid var(--ink);filter:drop-shadow(0 1px 0 var(--tone))}.loupe.visible{opacity:1;transform:translate(-50%,-100%) scale(1)}@media (max-width: 900px){.loupe{padding:10px 16px;gap:4px}.loupe .loupe-value{font-size:20px}.loupe .loupe-label{font-size:10px}.tone-toolbar{gap:6px;padding:6px 0 4px}.tone-toolbar-label{margin-right:2px}.tt-pills{display:none}.tt-select{display:inline-block}}@media (max-width: 720px) and (orientation: portrait){.tt-right .tone-toolbar-label{display:none}}.bars-btn{font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;background:var(--panel);color:var(--accent);border:1px solid var(--accent);border-radius:12px;padding:0 8px;min-width:44px;cursor:pointer;writing-mode:vertical-rl;transform:rotate(180deg);transition:background .12s ease;white-space:nowrap}.bars-btn:hover{background:#ff5b1f1f}.bars-chip{display:none;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700;letter-spacing:.04em;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border-radius:50%;border:1px solid var(--accent);background:var(--panel);color:var(--accent);cursor:pointer;transition:background .12s ease}.bars-chip:hover{background:#ff5b1f1f}.mix-toggle-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border-radius:50%;border:1px solid var(--line);background:var(--panel-2);color:var(--ink-dim);cursor:pointer;transition:background .1s ease,color .1s ease,border-color .1s ease,box-shadow .12s ease}.mix-toggle-btn svg{width:19px;height:19px;display:block}.mix-toggle-btn:hover{border-color:var(--accent);color:var(--ink)}.mix-toggle-btn.active{background:#ff5b1f26;color:var(--accent);border-color:var(--accent);box-shadow:0 0 10px #ff5b1f40}.grid.mixers-off .vol{display:none}.grid.mixers-off .row{grid-template-columns:76px max-content}@media (max-width: 1024px){.vol input[type=range]{height:22px}.vol input[type=range]::-webkit-slider-runnable-track{height:5px}.vol input[type=range]::-moz-range-track{height:5px}.vol input[type=range]::-webkit-slider-thumb{margin-top:-7px}}@media (max-width: 720px){.grid-wrap{gap:0}.rows-scroll{padding-inline:2px}.row{grid-template-columns:40px 50px max-content;gap:4px}.vol{width:26px}.vol input[type=range]{width:56px;height:22px}.vol input[type=range]::-webkit-slider-runnable-track{height:6px}.vol input[type=range]::-moz-range-track{height:6px}.vol input[type=range]::-webkit-slider-thumb{margin-top:-6px}.vol.vol-dual{width:50px;gap:12px}.vol-slot{width:18px}.grid:not(.src-808) .row.kick-row .vol{width:26px}.row .label{font-size:10px;gap:4px;padding-right:2px}.steps{gap:4px;grid-template-columns:repeat(var(--step-count),minmax(50px,1fr));padding-left:4px}.step{border-radius:8px}.tone-row .step{height:50px}.brand h1{font-size:30px}.grid{padding:8px}.bars-btn{display:none}.bars-chip{display:inline-flex}.grid.mixers-off .row{grid-template-columns:36px max-content}}@media (max-width: 420px){#app{padding:8px}.grid{padding:7px 12px}.row{grid-template-columns:36px 46px max-content;gap:3px}.vol{width:24px}.vol.vol-dual{width:46px;gap:10px}.grid:not(.src-808) .row.kick-row .vol{width:24px}.bars-chip{padding:0;font-size:11px}.steps{gap:3px;grid-template-columns:repeat(var(--step-count),minmax(48px,1fr));padding-left:4px}.tone-row .step{height:48px}.grid.mixers-off .row{grid-template-columns:30px max-content}}.saved{margin-top:22px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:10px 12px}.saved.empty .saved-head .saved-label{display:none}.saved.empty .saved-head .saved-clear:not(.saved-import){display:none}.saved.empty .saved-head{justify-content:flex-end}.saved.empty .saved-strip:before{content:"No saved beats yet";font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.12em;color:var(--ink-mute);opacity:.45;padding:4px 2px}.saved-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:0}.saved-label{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute)}.saved-clear{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);background:transparent;border:none;cursor:pointer;padding:2px 6px;border-radius:4px}.saved-clear:hover{color:var(--ink-dim);background:var(--panel-2)}.saved-actions{display:flex;align-items:center;gap:2px}.saved-footer{text-align:center;font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.08em;color:var(--ink-dim);opacity:.85;margin-top:8px}.saved-strip{overflow:visible}.saved-scroller{display:flex;gap:8px;overflow-x:auto;padding-top:20px;padding-bottom:4px}.saved-scroller::-webkit-scrollbar{height:6px}.saved-scroller::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}.saved-chip{flex:0 0 auto;display:inline-flex;flex-direction:row;align-items:center;gap:6px;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:6px 8px 6px 12px;cursor:pointer;text-decoration:none;color:var(--ink-dim);box-shadow:inset 0 0 0 1px #ffffff05;transition:border-color .12s ease,color .12s ease,background .12s ease,transform 80ms ease}.saved-chip:hover{border-color:var(--accent);color:var(--ink);background:#ff5b1f14}.saved-chip:active{transform:translateY(1px)}.saved-chip .ts{font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600;color:var(--ink);white-space:nowrap}.saved-chip .chip-label{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--ink-dim);white-space:nowrap;max-width:140px;overflow:hidden;text-overflow:ellipsis}.chip-btn{background:transparent;border:1px solid transparent;cursor:pointer;position:relative;padding:0;min-width:36px;min-height:36px;width:36px;height:36px;line-height:1;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-dim);font-size:16px;opacity:.5;transition:opacity .1s ease,color .1s ease,background .1s ease,border-color .1s ease;flex-shrink:0;border-radius:8px}.saved-chip .chip-btn:hover{opacity:1}.chip-btn:focus-visible{opacity:1;outline:1px solid var(--tone);outline-offset:1px}.chip-rename:hover{color:var(--accent);background:#ff5b1f1f;border-color:#ff5b1f59}.chip-delete:hover{color:#ff4d8d;background:#ee005524;border-color:#e056}.chip-download:hover{color:var(--tone);background:#4dc3ff24;border-color:#4dc3ff66}.chip-download.busy{color:var(--tone);opacity:1;pointer-events:none}.chip-rename svg,.chip-delete svg,.chip-download svg{width:18px;height:18px}.chip-error{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:6px;padding:0 10px;border-radius:14px;background:#ee0055eb;color:#fff;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;box-shadow:0 0 0 1px #ff4d8d,0 8px 18px #00000059;z-index:2;pointer-events:none}.chip-error svg{width:14px;height:14px;flex-shrink:0}.saved-chip.has-error{box-shadow:0 0 0 1px #ff4d8d}.saved-chip{position:relative}.chip-label-input{font-family:JetBrains Mono,monospace;font-size:11px;background:var(--panel-2);border:1px solid var(--accent);border-radius:4px;color:var(--ink);padding:3px 6px;width:100px;outline:none}.hint{margin-top:20px;font-size:12px;color:var(--ink-mute);font-family:JetBrains Mono,monospace;letter-spacing:.05em;text-align:center}.hint kbd{background:var(--panel-2);border:1px solid var(--line);padding:2px 6px;border-radius:4px;font-family:inherit;color:var(--ink-dim)}@media (pointer: coarse){.hint{display:none}}.toast{position:fixed;top:24px;left:50%;z-index:250;transform:translate(-50%,-16px);background:var(--ink);color:var(--bg);font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700;letter-spacing:.06em;padding:10px 16px;border-radius:999px;box-shadow:0 10px 32px #00000080,0 0 0 1px var(--accent);opacity:0;pointer-events:none;white-space:nowrap;transition:opacity .16s ease,transform .22s cubic-bezier(.34,1.56,.64,1)}.toast.visible{opacity:1;transform:translate(-50%)}.toast.error{box-shadow:0 10px 32px #00000080,0 0 0 1px #ff4d8d}@media (max-width: 720px){.toast{font-size:11px;padding:9px 14px;max-width:88vw;white-space:normal;text-align:center}}.entry-burst{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center;pointer-events:none}.entry-burst-card{position:relative;padding:16px 30px;background:#0c0c0ef0;border:1px solid var(--peer, var(--accent));border-radius:14px;box-shadow:0 0 48px -8px var(--peer, var(--accent)),0 16px 48px #000000a6;color:#f4f4f6;font-family:JetBrains Mono,monospace;font-weight:800;font-size:clamp(15px,3.6vw,24px);letter-spacing:.04em;white-space:nowrap;text-align:center;transform:scale(.3);opacity:0;animation:entry-pop 2.6s cubic-bezier(.18,1.5,.4,1) forwards}.entry-burst-card .entry-name{color:var(--peer, var(--accent));text-shadow:0 0 14px var(--peer, var(--accent))}@keyframes entry-pop{0%{transform:scale(.25) rotate(-7deg);opacity:0}10%{transform:scale(1.14) rotate(2.5deg);opacity:1}20%{transform:scale(.98) rotate(0)}26%{transform:scale(1.02)}32%{transform:scale(1)}80%{transform:scale(1) translateY(0);opacity:1}to{transform:scale(.95) translateY(-14px);opacity:0}}.entry-spark{position:absolute;left:50%;top:50%;width:9px;height:9px;border-radius:2px;background:var(--c, var(--accent));box-shadow:0 0 8px var(--c, var(--accent));transform:translate(-50%,-50%);opacity:0;animation:entry-spark-fly .95s ease-out forwards}@keyframes entry-spark-fly{0%{transform:translate(-50%,-50%) rotate(0) scale(1);opacity:1}to{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) rotate(var(--rot)) scale(.2);opacity:0}}@media (prefers-reduced-motion: reduce){.entry-burst-card{animation:entry-fade 2.2s ease forwards;transform:none}.entry-spark{display:none}}@keyframes entry-fade{0%{opacity:0}12%{opacity:1}82%{opacity:1}to{opacity:0}}.link-busy{pointer-events:none;opacity:.6;position:relative}.link-busy.icon-btn>svg{opacity:0}.link-busy.icon-btn:after{content:"";position:absolute;inset:0;margin:auto;width:14px;height:14px;border-radius:50%;border:2px solid currentColor;border-top-color:transparent;animation:link-spin .6s linear infinite}@keyframes link-spin{to{transform:rotate(360deg)}}.splash{position:fixed;inset:0;background:#0a0a0aeb;display:flex;align-items:center;justify-content:center;z-index:100;cursor:pointer;backdrop-filter:blur(4px);overflow-y:auto;padding:24px 0}.splash .inner{text-align:center;padding:32px}.splash h2{font-size:56px;margin:0 0 8px;letter-spacing:-.03em;font-weight:700}.splash h2 .accent{color:var(--accent)}.splash p{margin:0;color:var(--ink-dim);font-family:JetBrains Mono,monospace;font-size:13px;letter-spacing:.12em;text-transform:uppercase}.splash p.tagline{font-family:inherit;font-size:18px;letter-spacing:0;text-transform:none;color:var(--ink);margin:4px auto 20px;opacity:.78;max-width:360px}.splash p.splash-cta{font-size:14px;letter-spacing:.18em;color:var(--accent);font-weight:700;margin:0 auto 4px}.splash-steps{display:flex;flex-direction:row;justify-content:center;align-items:flex-start;gap:28px;margin:28px auto 0;padding-top:24px;border-top:1px solid var(--line);max-width:480px}.splash-step{display:flex;flex-direction:column;align-items:center;gap:10px;flex:1 1 0;min-width:0}.splash-step-icon{flex-shrink:0;width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:11px;background:#ff5b1f1a;border:1px solid rgba(255,91,31,.32);color:var(--accent)}.splash-step-icon svg{width:20px;height:20px;display:block}.splash-step-body{display:flex;flex-direction:column;align-items:center}.splash-step-title{font-family:inherit;font-size:13px;font-weight:600;letter-spacing:.01em;color:var(--ink);text-align:center;line-height:1.3}@media (max-height: 640px),(max-width: 480px){.splash h2{font-size:42px}.splash p.tagline{font-size:15px;margin-bottom:14px}.splash-steps{gap:16px;margin-top:20px;padding-top:18px}.splash-step-title{font-size:12px}.splash-step-icon{width:36px;height:36px}}.modal-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;background:#000000b3;backdrop-filter:blur(3px);opacity:0;transition:opacity .18s ease}.modal-overlay.visible{opacity:1}.modal-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:24px 22px;width:100%;max-width:340px;box-shadow:0 18px 48px #0009;transform:translateY(10px) scale(.97);transition:transform .2s cubic-bezier(.22,1,.36,1)}.modal-overlay.visible .modal-card{transform:translateY(0) scale(1)}.modal-title{margin:0 0 6px;font-size:18px;font-weight:700;letter-spacing:-.01em;color:var(--ink)}.modal-sub{margin:0 0 16px;font-size:13px;line-height:1.45;color:var(--ink-dim)}.name-modal-input{width:100%;font-family:inherit;font-size:15px;padding:10px 12px;border-radius:8px;background:var(--panel-2);border:1px solid var(--line);color:var(--ink);outline:none;transition:border-color .12s ease,box-shadow .12s ease}.name-modal-input:focus{border-color:var(--tone);box-shadow:0 0 0 3px #4dc3ff2e}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.modal-actions .btn{padding:9px 16px;font-size:12px}.btn.modal-danger{background:#e05;color:#fff;border-color:transparent}.btn.modal-danger:hover{background:#ff1f6e}.presence-row{display:none;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px;padding:8px 12px;background:#4dc3ff0f;border:1px solid rgba(77,195,255,.28);border-radius:12px}.presence-row.visible{display:flex}.presence-room-link{display:inline-flex;align-items:center;gap:6px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--tone);background:#4dc3ff1a;border:1px solid rgba(77,195,255,.35);border-radius:8px;padding:5px 10px 5px 8px;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease;flex-shrink:0}.presence-room-link:hover{background:#4dc3ff33;color:var(--ink)}.presence-room-link.copied{color:var(--green);border-color:var(--green);background:#3ddc8429}.presence-room-icon{display:inline-flex;width:13px;height:13px}.presence-room-icon svg{width:13px;height:13px;display:block}.presence-dots{display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-width:0}.presence-peer{display:inline-flex;align-items:center;gap:6px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600;letter-spacing:.06em;color:var(--ink-dim);transition:opacity .24s ease,transform .24s ease}.presence-peer.you{color:var(--ink)}.presence-peer .presence-name{white-space:nowrap}.presence-peer.joining{opacity:0;transform:translate(-8px)}.presence-peer.leaving{opacity:0;transform:scale(.6)}.presence-dot{width:11px;height:11px;border-radius:50%;display:inline-block;flex-shrink:0;background:var(--dot-color, currentColor);box-shadow:0 0 6px var(--dot-color, currentColor);transform-origin:center}.presence-peer.you .presence-dot{outline:1.5px solid var(--ink);outline-offset:1.5px}@keyframes presencePulse{0%{box-shadow:0 0 color-mix(in srgb,var(--dot-color, var(--accent)) 60%,transparent),0 0 6px var(--dot-color, var(--accent))}70%{box-shadow:0 0 0 6px color-mix(in srgb,var(--dot-color, var(--accent)) 0%,transparent),0 0 8px var(--dot-color, var(--accent))}to{box-shadow:0 0 color-mix(in srgb,var(--dot-color, var(--accent)) 0%,transparent),0 0 6px var(--dot-color, var(--accent))}}.presence-peer.playing .presence-dot{animation:presencePulse 1.1s ease-out infinite}.presence-peer.editable-name{position:relative;cursor:pointer}.name-hint{position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background:var(--ink);color:var(--bg);font-size:11px;font-weight:600;padding:4px 9px;border-radius:6px;white-space:nowrap;pointer-events:none;z-index:80;opacity:1;transition:opacity .35s ease}.name-hint:before{content:"";position:absolute;right:100%;top:50%;transform:translateY(-50%);border:5px solid transparent;border-right-color:var(--ink)}.name-hint.fade{opacity:0}.presence-peer.editable-name:hover .presence-name,.presence-peer.editable-name:focus-visible .presence-name{text-decoration:underline dotted;text-underline-offset:3px}.presence-peer.editable-name:focus-visible{outline:none}.presence-emoji-bar{display:flex;align-items:center;gap:4px;margin-left:auto;flex-shrink:0}.emoji-react-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;font-size:18px;line-height:1;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:9px;cursor:pointer;transition:background .12s ease,transform .12s ease,border-color .12s ease;-webkit-tap-highlight-color:transparent}.emoji-react-btn:hover{background:#ffffff1a;border-color:#ffffff38}.emoji-react-btn:active{transform:scale(.88)}.emoji-react-btn:focus-visible{outline:2px solid var(--tone);outline-offset:1px}@media (max-width: 720px){.presence-row{flex-wrap:wrap}.presence-dots{order:2;flex-basis:100%}.presence-emoji-bar{order:1;margin-left:auto}}.emoji-float{position:fixed;z-index:420;font-size:26px;line-height:1;pointer-events:none;transform:translate(-50%,-50%);filter:drop-shadow(0 2px 6px rgba(0,0,0,.5));animation:emoji-float-up 2.4s ease-out forwards}@keyframes emoji-float-up{0%{transform:translate(-50%,-50%) scale(.4);opacity:0}10%{transform:translate(-50%,-65%) scale(1.15);opacity:1}28%{transform:translate(calc(-50% + var(--drift, 8px)),-82%) scale(1);opacity:1}50%{transform:translate(calc(-50% - var(--drift, 8px) * .6),-95%) scale(1);opacity:1}72%{transform:translate(calc(-50% + var(--drift, 8px) * .4),-106%) scale(.95);opacity:.75}to{transform:translate(-50%,-115%) scale(.9);opacity:0}}@media (prefers-reduced-motion: reduce){.emoji-float{animation:emoji-float-fade 1.8s ease forwards}}@keyframes emoji-float-fade{0%{transform:translate(-50%,-50%) scale(1);opacity:0}18%{opacity:1}70%{opacity:1}to{transform:translate(-50%,-70px) scale(1);opacity:0}}@keyframes remoteRipple{0%{box-shadow:0 0 0 0 var(--remote-color),0 0 12px 0 var(--remote-color);background-image:radial-gradient(circle at center,color-mix(in srgb,var(--remote-color) 70%,transparent),transparent 70%)}35%{box-shadow:0 0 0 4px color-mix(in srgb,var(--remote-color) 50%,transparent),0 0 20px 4px color-mix(in srgb,var(--remote-color) 80%,transparent)}to{box-shadow:0 0 0 0 transparent,0 0 0 0 transparent;background-image:none}}.step.remote-edit,.tone-voice-btn.remote-edit,.bpm.remote-edit,.vol.remote-edit{animation:remoteRipple .65s cubic-bezier(.22,1,.36,1);position:relative;z-index:2}.tone-voice-btn.remote-edit{outline:1.5px solid var(--remote-color);outline-offset:1px;transition:outline-color .2s ease}@media (pointer: coarse){.vol input[type=range]{height:36px}}
