*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}button{font:inherit;cursor:pointer;background:0 0;border:none}input,textarea{font:inherit}ul,ol{list-style:none}:root{--bg-base:#0c0e16;--bg-surface:#141729;--bg-elevated:#1e2240;--bg-groove:#090b12;--bg-input:#181b2e;--accent:#f5a623;--accent-dim:#f5a62333;--accent-hover:#f7b84e;--danger:#d64045;--danger-dim:#d6404526;--success:#22c55e;--text-primary:#e8eaf0;--text-secondary:#9198b5;--text-muted:#575e7e;--text-inverse:#0c0e16;--chip-chord-bg:#162848;--chip-chord-fg:#93c5fd;--chip-chord-border:#2c5090;--chip-lyric-bg:#1e1240;--chip-lyric-fg:#c4b5fd;--chip-lyric-border:#4a3080;--border-subtle:#181b2e;--border-measure:#404875;--border-beat:#2e3458;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--font-ui:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--metabar-h:48px;--sidebar-w:220px;--entry-h:200px;--col-width:18px;--row-h-chord:16px;--row-h-beat:10px;--row-h-lyric:28px;--chart-row-gap:16px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--ease:cubic-bezier(.4, 0, .2, 1);--dur-fast:.1s;--dur-mid:.16s}[data-theme=light]{--bg-base:#f4f5f8;--bg-surface:#fff;--bg-elevated:#eef0f5;--bg-groove:#e8eaf0;--bg-input:#fff;--accent:#f5a623;--accent-dim:#f5a62333;--accent-hover:#f7b84e;--danger:#d64045;--danger-dim:#d6404526;--success:#16a34a;--text-primary:#1a1d27;--text-secondary:#5a6080;--text-muted:#9098b0;--text-inverse:#fff;--chip-chord-bg:#def;--chip-chord-fg:#1a4a8a;--chip-chord-border:#ace;--chip-lyric-bg:#ede8ff;--chip-lyric-fg:#4a2090;--chip-lyric-border:#c0a8f0;--border-subtle:#dde0ea;--border-measure:#b0b8cc;--border-beat:#d0d5e5}body{font-family:var(--font-ui);color:var(--text-primary);background:var(--bg-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-measure);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--accent-dim)}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}@media print{*{-webkit-print-color-adjust:exact;print-color-adjust:exact}.sidebar,.entry-panel,.metabar__right,.drag-ghost,.metabar__btn--theme,.metabar__btn--orientation{display:none!important}.app-layout{display:block}.app-main{width:100%;display:block}:root,[data-theme=light]{--bg-base:#fff;--bg-surface:#fff;--bg-elevated:#fff;--bg-groove:#f5f5f5;--bg-input:#fff;--text-primary:#000;--text-secondary:#333;--text-muted:#888;--border-subtle:#ddd;--border-measure:#000;--border-beat:#666;--chip-chord-bg:#fff;--chip-chord-fg:#000;--chip-chord-border:#555;--chip-lyric-bg:transparent;--chip-lyric-fg:#000;--chip-lyric-border:#888;--accent:#000}.chart-area{background:#fff;padding:0;overflow:visible}.chart-area>.chart{width:100%}.metabar{background:#fff;border-bottom:1px solid #000;padding:4px 0}.chart-row{break-inside:avoid;page-break-inside:avoid}.beat-row svg{color:#000}}.auth-gate{background:var(--bg-base);z-index:100;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:8px;width:360px;max-width:calc(100vw - 2rem);padding:2rem}.auth-card__title{text-align:center;color:var(--text-primary);margin:0 0 1.5rem;font-size:1.25rem;font-weight:600}.auth-card__field{flex-direction:column;gap:.25rem;margin-bottom:1rem;display:flex}.auth-card__label{color:var(--text-muted);font-size:.8125rem}.auth-card__input{border:1px solid var(--border-subtle);background:var(--bg-base);color:var(--text-primary);border-radius:4px;outline:none;padding:.5rem .75rem;font-size:.9375rem}.auth-card__input:focus{border-color:var(--accent)}.auth-card__submit{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:4px;width:100%;margin-top:.5rem;padding:.625rem;font-size:.9375rem;font-weight:500}.auth-card__submit:disabled{opacity:.6;cursor:not-allowed}.auth-card__error{color:var(--danger);text-align:center;margin-top:.5rem;font-size:.8125rem}.auth-card__success{color:var(--success);text-align:center;padding:.5rem 0;font-size:.875rem}.auth-card__switch{text-align:center;color:var(--text-muted);margin-top:1.25rem;font-size:.8125rem}.auth-card__switch-btn{color:var(--accent);cursor:pointer;font-size:inherit;background:0 0;border:none;padding:0;text-decoration:underline}.sidebar{width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--border-subtle);transition:width var(--dur-mid) var(--ease);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar--collapsed{width:36px}.sidebar--collapsed .sidebar__header{justify-content:center;padding:0}.sidebar__toggle{border-radius:var(--radius-sm);width:24px;height:24px;color:var(--text-muted);transition:background var(--dur-fast), color var(--dur-fast);background:0 0;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.sidebar__toggle:hover{background:var(--bg-elevated);color:var(--text-secondary)}.sidebar__header{min-height:var(--metabar-h);padding:0 var(--sp-3);border-bottom:1px solid var(--border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.sidebar__brand{color:var(--text-secondary);letter-spacing:.03em;font-size:13px;font-weight:600}.sidebar__new-btn{border-radius:var(--radius-sm);background:var(--bg-elevated);width:24px;height:24px;color:var(--text-secondary);transition:background var(--dur-fast), color var(--dur-fast);justify-content:center;align-items:center;font-size:18px;line-height:1;display:flex}.sidebar__new-btn:hover{background:var(--accent-dim);color:var(--accent)}.sidebar__import-btn{border-radius:var(--radius-sm);background:var(--bg-elevated);width:24px;height:24px;color:var(--text-secondary);transition:background var(--dur-fast), color var(--dur-fast);justify-content:center;align-items:center;font-size:14px;line-height:1;display:flex}.sidebar__import-btn:hover{background:var(--accent-dim);color:var(--accent)}.sidebar__view-btn{border-radius:var(--radius-sm);background:var(--bg-elevated);width:24px;height:24px;color:var(--text-muted);transition:background var(--dur-fast), color var(--dur-fast);justify-content:center;align-items:center;font-size:12px;display:flex}.sidebar__view-btn:hover{background:var(--bg-elevated);color:var(--text-secondary)}.sidebar__view-btn--active{background:var(--accent-dim);color:var(--accent)}.sidebar__list{padding:var(--sp-2) 0;flex:1;overflow-y:auto}.sidebar__item-row{opacity:1;max-height:64px;transition:max-height .2s var(--ease), opacity .15s var(--ease);position:relative;overflow:hidden}.sidebar__item-row--removing{opacity:0;max-height:0}.sidebar__item-delete-bg{background:var(--danger);padding-right:var(--sp-4);pointer-events:none;justify-content:flex-end;align-items:center;display:flex;position:absolute;inset:0}.sidebar__item-delete-label{color:#fff;letter-spacing:.04em;text-transform:uppercase;font-size:12px;font-weight:600}.sidebar__item{z-index:1;width:100%;padding:var(--sp-2) var(--sp-3);text-align:left;transition:background var(--dur-fast);touch-action:pan-y;border-radius:0;display:block;position:relative}.sidebar__item--snapping{transition:background var(--dur-fast), transform .2s var(--ease)}.sidebar__item:hover{background:var(--bg-elevated)}.sidebar__item--active{background:var(--accent-dim)}.sidebar__item-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;padding-right:20px;font-size:13px;font-weight:500;display:block;overflow:hidden}.sidebar__item--active .sidebar__item-title{color:var(--accent)}.sidebar__item-meta{color:var(--text-muted);font-size:11px;font-family:var(--font-mono);margin-top:1px;display:block}.sidebar__item-del{z-index:2;border-radius:var(--radius-sm);width:20px;height:20px;color:var(--text-muted);opacity:0;pointer-events:none;transition:opacity var(--dur-fast), background var(--dur-fast), color var(--dur-fast);background:0 0;justify-content:center;align-items:center;font-size:13px;display:flex;position:absolute;top:50%;right:6px;transform:translateY(-50%)}@media (hover:hover){.sidebar__item-row:hover .sidebar__item-del{opacity:1;pointer-events:auto}.sidebar__item-del:hover{background:var(--danger-dim);color:var(--danger)}}.sidebar__undo-toast{align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:var(--bg-elevated);border-top:1px solid var(--border-subtle);animation:toast-slide-in .18s var(--ease);flex-shrink:0;display:flex}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.sidebar__undo-msg{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:11px;overflow:hidden}.sidebar__undo-btn{color:var(--accent);border-radius:var(--radius-sm);background:var(--accent-dim);transition:background var(--dur-fast);flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:600}.sidebar__undo-btn:hover{background:#f5a62347}.paste-jsl-overlay{z-index:200;background:#0009;justify-content:center;align-items:center;animation:.12s overlay-fade-in;display:flex;position:fixed;inset:0}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}.paste-jsl-dialog{background:var(--bg-surface);border:1px solid var(--border-subtle);width:min(560px,100vw - 32px);animation:dialog-slide-in .14s var(--ease);border-radius:8px;flex-direction:column;gap:0;display:flex;overflow:hidden}@keyframes dialog-slide-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.paste-jsl-header{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.paste-jsl-title{color:var(--text-secondary);letter-spacing:.03em;font-size:13px;font-weight:600}.paste-jsl-close{border-radius:var(--radius-sm);width:24px;height:24px;color:var(--text-muted);transition:background var(--dur-fast), color var(--dur-fast);background:0 0;justify-content:center;align-items:center;font-size:13px;display:flex}.paste-jsl-close:hover{background:var(--bg-elevated);color:var(--text-secondary)}.paste-jsl-textarea{font-family:var(--font-mono);color:var(--text-primary);background:var(--bg-input);border:none;border-bottom:1px solid var(--border-subtle);resize:none;padding:var(--sp-3) var(--sp-4);box-sizing:border-box;outline:none;width:100%;font-size:12px;line-height:1.6}.paste-jsl-textarea::placeholder{color:var(--text-muted);opacity:.7}.paste-jsl-error{color:var(--danger);background:var(--danger-dim);padding:var(--sp-2) var(--sp-4);border-bottom:1px solid var(--border-subtle);font-size:12px;font-family:var(--font-mono)}.paste-jsl-warnings{color:var(--accent);background:var(--accent-dim);padding:var(--sp-2) var(--sp-4);border-bottom:1px solid var(--border-subtle);flex-direction:column;gap:2px;font-size:11px;display:flex}.paste-jsl-footer{justify-content:flex-end;align-items:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);flex-shrink:0;display:flex}.paste-jsl-cancel{color:var(--text-muted);padding:4px var(--sp-3);border-radius:var(--radius-sm);transition:background var(--dur-fast), color var(--dur-fast);background:0 0;font-size:12px}.paste-jsl-cancel:hover{background:var(--bg-elevated);color:var(--text-secondary)}.paste-jsl-import{color:var(--text-inverse);background:var(--accent);padding:4px var(--sp-4);border-radius:var(--radius-sm);transition:background var(--dur-fast);font-size:12px;font-weight:600}.paste-jsl-import:hover{background:var(--accent-hover)}.paste-jsl-import:disabled{opacity:.35;cursor:default}.sidebar__tabs{border-bottom:1px solid var(--border-subtle);display:flex}.sidebar__tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:6px 0;font-size:12px}.sidebar__tab--active{color:var(--text-primary);border-bottom-color:var(--accent)}.sidebar__filters{gap:6px;padding:8px 10px 4px;display:flex}.sidebar__search{border:1px solid var(--border-subtle);background:var(--bg-base);min-width:0;color:var(--text-primary);border-radius:4px;flex:1;padding:3px 8px;font-size:12px}.sidebar__fav-filter{border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:4px;padding:0 8px;font-size:13px}.sidebar__fav-filter--on{color:var(--accent);border-color:var(--accent)}.sidebar__item-fav{z-index:1;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:13px;position:absolute;top:50%;right:28px;transform:translateY(-50%)}.sidebar__item-fav--on{color:var(--accent)}.sidebar__account{border-top:1px solid var(--border-subtle);align-items:center;gap:8px;margin-top:auto;padding:8px 10px;font-size:11px;display:flex}.sidebar__account-email{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.sidebar__account-logout{border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:4px;padding:2px 8px;font-size:11px}.sidebar__account-logout:hover{color:var(--text-primary)}.sidebar__buildmark{color:var(--text-muted);cursor:default;-webkit-user-select:none;user-select:none;flex-direction:column;gap:1px;padding:6px 10px 8px;font-size:10px;line-height:1.3;display:flex}.sidebar__buildmark-brand{color:var(--accent);letter-spacing:.02em;font-weight:600}.sidebar__buildmark-meta{opacity:.85;font-family:SFMono-Regular,ui-monospace,Menlo,monospace;font-size:9px}.sidebar__buildmark-love{opacity:.7}.sidebar__buildmark-love span{color:var(--accent)}.sets-panel{flex-direction:column;min-height:0;display:flex;overflow-y:auto}.sets-panel__actions{align-items:center;gap:6px;padding:8px 10px 4px;display:flex}.sets-panel__back,.sets-panel__archived-toggle,.sets-panel__tool{border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:4px;padding:2px 8px;font-size:11px}.sets-panel__tool:disabled{opacity:.35;cursor:default}.sets-panel__name{border:1px solid var(--border-subtle);background:var(--bg-base);color:var(--text-primary);border-radius:4px;margin:4px 10px;padding:3px 8px;font-size:13px}.sets-panel__add-active{border:1px dashed var(--border-subtle);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:4px;margin:0 10px 6px;padding:3px 8px;font-size:12px}.sets-panel__add-active:hover:not(:disabled){color:var(--text-primary);border-color:var(--accent)}.sets-panel__rows{margin:0;padding:0 10px;list-style:none}.sets-panel__row{border-bottom:1px solid var(--border-subtle);padding:6px 0}.sets-panel__row-head{align-items:center;gap:4px;display:flex}.sets-panel__row-title{text-align:left;min-width:0;color:var(--text-primary);cursor:pointer;text-overflow:ellipsis;white-space:nowrap;background:0 0;border:none;flex:1;font-size:12px;overflow:hidden}.sets-panel__row-duration{color:var(--text-secondary);font-size:11px}.sets-panel__note{border:1px solid var(--border-subtle);background:var(--bg-base);width:100%;color:var(--text-secondary);box-sizing:border-box;border-radius:4px;margin-top:4px;padding:2px 6px;font-size:11px}.sets-panel__note--transition{border-style:dashed}.sets-panel__total{color:var(--text-primary);padding:8px 10px;font-size:12px;font-weight:600}.sets-panel__pick-row{gap:6px;margin:0 10px 6px;display:flex}.sets-panel__pick{border:1px solid var(--border-subtle);background:var(--bg-base);min-width:0;color:var(--text-primary);border-radius:4px;flex:1;padding:3px 6px;font-size:12px}.sidebar__sync-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.sidebar__sync-dot--idle{background:#3fb950}.sidebar__sync-dot--syncing{background:var(--accent)}.sidebar__sync-dot--locked{background:var(--text-secondary)}.sidebar__sync-dot--error{background:var(--danger)}.performance-view{background:#faf9f4;flex-direction:column;flex:1;min-height:0;display:flex}.performance-toolbar{background:#1e1e20;border-bottom:2px solid #111;flex-shrink:0;align-items:center;gap:6px;padding:6px 12px;display:flex}.perf-toolbar-btn{color:#d0d0d0;cursor:pointer;white-space:nowrap;letter-spacing:.02em;background:#2e2e30;border:1px solid #444;border-radius:4px;padding:4px 10px;font-size:12px;transition:background .15s}.perf-toolbar-btn:hover{background:#3e3e42}.perf-toolbar-btn.active{color:#fff;background:#c0341e;border-color:#a02a18}.perf-toolbar-divider{background:#444;width:1px;height:18px;margin:0 4px}.perf-toolbar-label{color:#999;align-items:center;gap:6px;font-size:12px;display:flex}.perf-toolbar-slider{accent-color:#c0341e;width:80px}.perf-toolbar-value{color:#d0d0d0;text-align:right;min-width:20px}.performance-content{box-sizing:border-box;flex:1;width:100%;max-width:960px;margin:0 auto;padding:24px 64px 40px;overflow-y:auto}.performance-header{border-bottom:2px solid #1a1a1a;margin-bottom:20px;padding-bottom:12px}.performance-title{color:#111;letter-spacing:-.01em;margin:0 0 6px;font-family:Georgia,Times New Roman,serif;font-size:2em;font-weight:700}.performance-meta{color:#555;letter-spacing:.03em;margin:0;font-family:Helvetica Neue,Arial,sans-serif;font-size:.82em;font-weight:400;line-height:1.5}.performance-footer{color:#999;letter-spacing:.03em;margin:2.5em 0 0;font-family:Helvetica Neue,Arial,sans-serif;font-size:.72em;font-weight:400}.perf-chart{font-family:Georgia,Times New Roman,serif;line-height:1}.perf-section-header{align-items:center;gap:0;margin-top:2em;margin-bottom:.45em;display:flex}.perf-section-header .perf-notation{align-items:center;padding-right:.45em}.perf-section-bar{background:#c0341e;width:2px;height:.65em;display:block}.perf-chart>div:first-child .perf-section-header{margin-top:0}.perf-section-label{letter-spacing:.1em;text-transform:uppercase;color:#999;white-space:nowrap;margin-right:.75em;font-family:Helvetica Neue,Arial,sans-serif;font-size:.65em;font-weight:700}.perf-section-rule{display:none}.perf-staff-line{align-items:flex-end;gap:0;margin-bottom:.6em;display:flex}.perf-staff-line--section-end{margin-bottom:1.5em}.perf-staff{flex-wrap:wrap;align-items:flex-start;gap:0 3em;margin-bottom:1.5em;display:flex}.perf-repeat-block{flex-shrink:0}.perf-staff-row{align-items:flex-end;display:flex}.perf-staff-row--repeat{align-items:flex-start}.perf-staff-row--repeat .perf-notation--repeat-start,.perf-staff-row--repeat .perf-notation--repeat-end{align-self:flex-start}.perf-staff-row--repeat .perf-content{padding-left:0}.perf-notation{box-sizing:border-box;flex-shrink:0;justify-content:flex-end;align-items:center;width:2.5em;margin-left:-2.5em;padding-right:3px;display:flex}.perf-row-marker{color:#f5a623;pointer-events:none;-webkit-user-select:none;user-select:none;font-family:sans-serif;font-size:.45em;line-height:1}@media print{.perf-row-marker,.perf-beat-playhead{display:none}}.perf-content{flex-wrap:wrap;flex:1;align-items:flex-start;display:flex;position:relative}.perf-measure{flex-shrink:0;align-items:flex-start;display:inline-flex}.perf-measure--sep{border-right:1px solid #e0ddd6;margin-right:.6em;padding-right:.6em}.perf-beat-playhead{opacity:.55;pointer-events:none;z-index:10;background:#f5a623;width:1px;position:absolute;top:0;bottom:0;left:0}.perf-notation--repeat-start{justify-content:flex-end;align-self:flex-end;align-items:center;gap:.15em;padding-right:.45em;display:flex}.perf-notation--repeat-start>span{color:#aaa;font-family:Helvetica Neue,Arial,sans-serif;font-size:.75em;font-weight:500;line-height:1.6}.perf-notation--repeat-start>.perf-row-marker{color:#f5a623;font-family:sans-serif;font-size:.45em;font-weight:400;line-height:1}.perf-notation--repeat-end{color:#aaa;white-space:nowrap;align-self:flex-end;margin-left:auto;padding-left:.5em;font-family:Helvetica Neue,Arial,sans-serif;font-size:.75em;font-weight:500;line-height:1.6}.perf-notation--pass-label{box-sizing:border-box;border-top:1px solid #c8c8c8;border-left:1px solid #c8c8c8;align-self:flex-start;align-items:flex-end;padding:1px 3px 0;display:inline-flex}.perf-notation--pass-label>span{color:#aaa;white-space:nowrap;font-family:Helvetica Neue,Arial,sans-serif;font-size:.65em;font-weight:500;line-height:1.5}.perf-beat{flex-direction:column;align-items:flex-start;padding:0 .15em;display:inline-flex;position:relative}.perf-beat .perf-chord{align-self:flex-start}.perf-cue{color:#6a6a6a;white-space:nowrap;letter-spacing:.02em;align-self:flex-start;font-size:.62em;font-style:italic;line-height:1.2}.perf-beat--active{background:#f5a6231f;border-radius:3px}.perf-beat--active .perf-lyric{text-underline-offset:2px;-webkit-text-decoration:underline #f5a623cc;text-decoration:underline #f5a623cc;text-decoration-thickness:2px}.perf-chord{color:#b02010;white-space:nowrap;letter-spacing:.01em;align-items:center;gap:.2em;min-height:1.4em;font-family:Helvetica Neue,Arial,sans-serif;font-size:.85em;font-weight:300;line-height:1.4;display:inline-flex}.perf-lyric{white-space:nowrap;color:#111;font-weight:400;line-height:1.5}.perf-volta-row{margin-top:.25em}.perf-notation--volta-label{text-align:right;align-self:flex-start;padding-right:.3em}.perf-notation--volta-label>span{color:#aaa;white-space:nowrap;font-family:Helvetica Neue,Arial,sans-serif;font-size:.65em;font-weight:500;line-height:1.5}.perf-volta-lyric-block{flex-wrap:wrap;flex:1;align-items:flex-start;padding-top:2px;padding-left:0;display:flex;position:relative}.perf-volta-lyric-block:before{content:"";pointer-events:none;border-top:1px solid silver;border-left:1px solid silver;width:calc(.2em + 50px);height:50%;position:absolute;top:0;left:-.2em}@media print{.performance-toolbar{display:none}.performance-view{background:#fff}.performance-content{max-width:none;margin:0;padding:0;overflow:visible}.performance-title{color:#000}.perf-chord{color:#000;font-weight:900}.perf-lyric{color:#000}.perf-staff-line{page-break-inside:avoid}}.perf-scroll-spacer{height:70vh}@media print{.perf-scroll-spacer{display:none}}.builder{background:var(--bg-base);flex-direction:column;flex:1;min-width:0;min-height:0;display:flex}.builder__body{flex:1;min-height:0;display:flex}.builder__sections{border-right:1px solid var(--border-subtle);background:var(--bg-surface);flex-direction:column;flex-shrink:0;width:220px;display:flex;overflow-y:auto}.builder__sections-head{justify-content:space-between;align-items:center;padding:10px 12px 6px;display:flex}.builder__sections-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:600}.builder__add{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;background:0 0;padding:0 8px;font-size:14px}.builder__add:hover{border-color:var(--accent)}.builder__section-list{margin:0;padding:0 8px 8px;list-style:none}.builder__section{text-align:left;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-base);width:100%;color:var(--text-primary);cursor:pointer;flex-direction:column;margin-top:6px;padding:8px 10px;display:flex}.builder__section--selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.builder__section-name{font-size:13px}.builder__section-range{color:var(--text-secondary);margin-top:2px;font-size:11px}.builder__section-controls{align-items:center;gap:4px;padding:6px 2px;display:flex}.builder__rename{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-base);min-width:0;color:var(--text-primary);flex:1;padding:3px 6px;font-size:12px}.builder__ctl{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:0 0;padding:3px 6px;font-size:11px}.builder__ctl:hover:not(:disabled){color:var(--text-primary);border-color:var(--accent)}.builder__ctl:disabled{opacity:.35;cursor:default}.builder__ctl--danger:hover:not(:disabled){color:var(--danger);border-color:var(--danger)}.builder__canvas{--measure-w:168px;--subdivisions:4;-webkit-user-select:none;user-select:none;flex-wrap:wrap;flex:1;align-content:flex-start;gap:4px;min-width:0;padding:16px 20px 20px;display:flex;overflow-y:auto}.builder__canvas-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em;flex-basis:100%;align-items:baseline;gap:8px;padding:12px 0 4px;font-size:11px;font-weight:700;display:flex}.builder__canvas-label:first-child{padding-top:0}.builder__zoom-bar{z-index:2;background:var(--bg-base);flex-basis:100%;justify-content:flex-end;align-items:center;gap:8px;padding:2px 2px 6px;display:flex;position:sticky;top:0}.builder__zoom-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);font-size:10px}.builder__zoom-slider{width:120px;accent-color:var(--accent);cursor:pointer}.builder__zoom-value{color:var(--text-secondary);text-align:right;font-variant-numeric:tabular-nums;min-width:34px;font-size:11px}.builder__snap-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);margin-left:8px;font-size:10px}.builder__snap-group{gap:2px;display:inline-flex}.builder__snap-btn{font-variant-numeric:tabular-nums;border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:4px;padding:2px 7px;font-size:11px}.builder__snap-btn--active{background:var(--accent);border-color:var(--accent);color:var(--bg-base)}.builder__grid-toggle{margin-left:8px}.builder__canvas--grid .builder__beat:after{content:"";pointer-events:none;background-image:repeating-linear-gradient(to right, var(--border-beat) 0 1px, transparent 1px calc(100% / var(--subdivisions)));opacity:.45;position:absolute;inset:0}.builder__canvas-label-meta{text-transform:none;letter-spacing:0;color:var(--text-secondary);opacity:.6;font-size:10px;font-weight:400}.builder__ghost-measure{width:var(--measure-w,168px);border-radius:var(--radius-sm);cursor:pointer;border:1px dashed #ffffff1a;transition:border-color .15s,background .15s}.builder__ghost-measure:hover{background:#ffffff05;border-color:#ffffff38}.builder__measure{width:var(--measure-w,168px);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-surface);cursor:pointer;flex-direction:column;transition:border-color .2s;display:flex;position:relative}.builder__measure:hover{border-color:var(--border-measure)}.builder__measure--in-selection{border-color:var(--accent);opacity:1}.builder__measure-header{flex-shrink:0;justify-content:space-between;align-items:center;height:18px;padding:0 6px;display:flex}.builder__row-break{flex-basis:100%;height:0}.builder__measure--break-start{border-left:2px solid var(--accent)}.builder__break-btn{color:var(--text-secondary);cursor:pointer;opacity:0;background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:10px;line-height:1;transition:opacity .15s,color .15s}.builder__measure:hover .builder__break-btn{opacity:.35}.builder__break-btn--active,.builder__measure:hover .builder__break-btn--active{opacity:1;color:var(--accent)}.builder__measure-num{color:var(--text-secondary);font-size:10px;line-height:1}.builder__meter-control{flex-shrink:0;display:inline-flex;position:relative}.builder__measure-meter{letter-spacing:.02em;color:var(--text-secondary);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:3px;padding:2px 4px;font-size:9px;font-weight:600;line-height:1;transition:opacity .15s,color .15s,background .15s}.builder__measure:hover .builder__measure-meter{opacity:.5}.builder__measure-meter--changed,.builder__measure:hover .builder__measure-meter--changed{opacity:1;color:var(--accent);background:color-mix(in srgb, var(--accent) 14%, transparent)}.builder__meter-pop{z-index:5;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:5px;align-items:center;gap:2px;margin-top:3px;padding:3px;display:inline-flex;position:absolute;top:100%;left:0;box-shadow:0 4px 12px #00000059}.builder__meter-pop-value{color:var(--text-primary);text-align:center;min-width:26px;font-size:10px;font-weight:600}.builder__meter-step{border:1px solid var(--border-subtle);width:18px;height:18px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:4px;justify-content:center;align-items:center;font-size:13px;line-height:1;transition:color .15s,border-color .15s;display:inline-flex}.builder__meter-step:hover:not(:disabled){color:var(--accent);border-color:var(--accent)}.builder__meter-step:disabled{opacity:.3;cursor:default}.builder__beats{flex:1;align-items:stretch;gap:3px;padding:0 4px;display:flex;overflow:hidden}.builder__beat-col__chord{flex:1;justify-content:flex-start;align-items:center;min-height:0;padding:0 2px 0 5px;display:flex}.builder__beat-col__rhythm{flex-shrink:0;justify-content:center;align-items:center;height:18px;display:flex}.builder__beat-col__lyric{flex-shrink:0;justify-content:center;align-items:center;height:22px;padding:0 2px;display:flex;overflow:hidden}.builder__beat-rhythm-glyph{color:var(--accent);letter-spacing:.01em;font-family:Barlow Condensed,Arial Narrow,sans-serif;font-size:11px;font-weight:500;line-height:1}.builder__beat-rhythm-glyph--rest{color:var(--text-secondary);font-style:italic}.builder__beat-col__melody{flex-shrink:0;justify-content:center;align-items:center;height:20px;display:flex}.builder__subslots{width:100%;height:100%;display:flex}.builder__subslot{flex:1;justify-content:center;align-items:center;min-width:0;display:flex}.builder__subslot+.builder__subslot{border-left:1px solid color-mix(in srgb, var(--border-measure) 50%, transparent)}.builder__beat-melody-glyph{color:var(--accent);letter-spacing:.01em;font-family:Barlow Condensed,Arial Narrow,sans-serif;font-size:12px;font-weight:600;line-height:1}.builder__beat-melody-glyph sub{opacity:.7;font-size:8px;font-weight:400}.builder__palette{border-top:1px solid var(--border-subtle);background:var(--bg-surface);flex-shrink:0;justify-content:center;gap:10px;padding:10px;display:flex}.builder__tool{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-base);min-width:84px;color:var(--text-primary);cursor:pointer;padding:8px 14px;font-size:13px}.builder__tool--active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent);color:var(--accent)}.builder__tool:disabled{opacity:.4;cursor:default}.builder__beat{border-radius:var(--radius-sm);cursor:pointer;flex-direction:column;flex:1;min-width:0;transition:box-shadow .12s;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff0f}.builder__beat:hover{box-shadow:inset 0 0 0 1px var(--border-beat)}.builder__beat--selected,.builder__beat--selected:hover{box-shadow:inset 0 0 0 1px var(--accent);background:color-mix(in srgb, var(--accent) 10%, transparent)}.builder__beat--cursor,.builder__beat--cursor:hover{box-shadow:inset 0 0 0 2px var(--accent), 0 0 0 1px var(--accent);background:color-mix(in srgb, var(--accent) 14%, transparent)}.builder__beat--subcursor,.builder__beat--subcursor:hover{box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent);background:0 0}.builder__beat-subcursor{pointer-events:none;border-radius:var(--radius-sm);box-shadow:inset 0 0 0 1px var(--accent);background:color-mix(in srgb, var(--accent) 10%, transparent);position:absolute;top:0;bottom:0}.builder__beat-chord{letter-spacing:.01em;color:var(--accent);font-family:Barlow Condensed,Arial Narrow,sans-serif;font-size:12px;font-weight:500;line-height:1}.builder__beat-lyric{color:var(--text-primary);text-align:center;word-break:break-word;font-size:10px;line-height:1.1}.builder__toolbar{border-top:1px solid var(--border-subtle);background:var(--bg-surface);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:6px;padding:8px 12px;display:flex}.builder__toolbar--palette{flex-direction:column;align-items:stretch;gap:0;padding:0}.scale-palette{flex-direction:column;width:100%;display:flex}.scale-palette__degrees{gap:2px;padding:6px 8px 4px;display:flex}.scale-palette__degree{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-base);height:56px;color:var(--text-primary);cursor:pointer;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:0;transition:border-color .15s,background .15s;display:flex}.scale-palette__degree:hover{border-color:var(--accent);background:var(--accent-dim)}.scale-palette__degree--active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent);background:var(--accent-dim);color:var(--accent)}.scale-palette__degree--open{border-bottom-color:#0000;border-bottom-right-radius:0;border-bottom-left-radius:0}.scale-palette__degree-num{color:var(--text-secondary);letter-spacing:.04em;font-size:9px;font-weight:600}.scale-palette__degree--active .scale-palette__degree-num{color:var(--accent)}.scale-palette__degree-name{letter-spacing:.01em;font-family:Barlow Condensed,Arial Narrow,sans-serif;font-size:15px;font-weight:500;line-height:1}.scale-palette__footer{opacity:0;pointer-events:none;border-top:1px solid #ffffff0f;flex-wrap:wrap;align-items:center;gap:4px;max-height:0;padding:0 8px;transition:max-height .18s,opacity .15s,padding .18s;display:flex;overflow:hidden}.scale-palette__footer--open{opacity:1;pointer-events:auto;max-height:52px;padding:4px 8px 6px}.scale-palette__quality{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:0 0;padding:3px 8px;font-size:11px;transition:color .12s,border-color .12s}.scale-palette__quality:hover{color:var(--text-primary);border-color:var(--border-measure)}.scale-palette__quality--active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.scale-palette__quality--focused{outline:2px solid var(--accent);outline-offset:1px}.scale-palette__sep{background:var(--border-subtle);flex-shrink:0;width:1px;height:18px;margin:0 4px}.builder__toolbar-hint{color:var(--text-secondary);margin-right:8px;font-size:11px}.builder__lyrics-input{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-base);min-width:220px;color:var(--text-primary);flex:1;padding:6px 10px;font-size:13px}.builder__lyrics-input:focus{border-color:var(--accent);outline:none}.builder__chip{border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:var(--bg-base);color:var(--text-primary);cursor:pointer;padding:4px 10px;font-size:12px}.builder__chip--active{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.builder__chord-custom{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-base);width:90px;color:var(--text-primary);padding:4px 8px;font-size:12px}.builder__brush-label{color:var(--text-secondary);margin-left:6px;font-size:12px}.builder__brush-label--hint{opacity:.55;font-style:italic}.builder__goto-backdrop{z-index:1100;background:#0006;justify-content:center;align-items:flex-start;padding-top:18vh;display:flex;position:fixed;inset:0}.builder__goto{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);min-width:320px;max-width:480px;color:var(--text-primary);padding:14px;box-shadow:0 12px 40px #00000073}.builder__goto-row{align-items:center;gap:10px;display:flex}.builder__goto-label{white-space:nowrap;font-size:13px;font-weight:600}.builder__goto-input{background:var(--bg-base);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);min-width:0;color:var(--text-primary);flex:1;padding:6px 8px;font-size:15px}.builder__goto-input:focus{border-color:var(--accent);outline:none}.builder__goto-input--invalid{border-color:var(--danger,#e5484d)}.builder__goto-sections{flex-wrap:wrap;gap:6px;margin-top:12px;display:flex}.builder__goto-chip{background:var(--bg-base);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;padding:4px 10px;font-size:12px}.builder__goto-chip:hover{border-color:var(--accent);color:var(--accent)}.builder__beat-editor-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.builder__beat-editor{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);min-width:260px;color:var(--text-primary);padding:16px}.builder__beat-editor-title{margin-bottom:8px;font-size:13px;font-weight:600}.builder__beat-editor-list{margin:0 0 10px;padding:0;list-style:none}.builder__beat-editor-list li{justify-content:space-between;align-items:center;gap:8px;padding:4px 0;font-size:13px;display:flex}.builder__beat-editor-empty{color:var(--text-secondary);font-size:12px}.builder__beat-editor-add{gap:6px;margin-bottom:10px;display:flex}.builder__beat-editor-add input{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-base);color:var(--text-primary);flex:1;padding:4px 8px;font-size:12px}.builder__beat-editor-close{width:100%}.builder__measure--duplicate-target{border-color:var(--accent);background:var(--accent-dim);opacity:1;border-style:solid}.builder__measure--provisional{opacity:.75;border-style:dashed;border-color:#ffffff2e;animation:.15s ease-out prov-fade-in}@keyframes prov-fade-in{0%{opacity:0;transform:scale(.97)}to{opacity:.75;transform:scale(1)}}.builder__jsl{background:var(--bg-surface);border-left:1px solid var(--border-subtle);z-index:50;flex-direction:column;gap:8px;width:420px;max-width:60vw;padding:12px;display:flex;position:absolute;top:0;bottom:0;right:0;box-shadow:-8px 0 24px #00000040}.builder{position:relative}.builder__jsl-head{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;justify-content:space-between;align-items:center;font-size:12px;font-weight:600;display:flex}.builder__jsl-text{resize:none;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-base);min-height:0;color:var(--text-primary);flex:1;padding:10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;line-height:1.5}.builder__jsl-error{color:var(--danger);font-size:12px}.builder__jsl-apply{width:100%}.builder__cue-badge{color:var(--accent);pointer-events:auto;font-size:7px;line-height:1;position:absolute;top:2px;right:3px}.builder__cue-badge--private{color:var(--text-muted)}.builder__chip--cue{border-style:dashed;align-items:center;gap:4px;display:inline-flex}.builder__chip--private{border-color:var(--text-muted);color:var(--text-muted)}.builder__scopebar{border-bottom:1px solid var(--border-subtle);align-items:center;gap:12px;padding:5px 12px;display:flex}.builder__scope-seg{gap:2px;display:inline-flex}.builder__scope-opt{border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:4px;padding:3px 12px;font-size:11px}.builder__scope-opt.is-active{background:var(--accent);border-color:var(--accent);color:var(--bg-base)}.builder__scope-opt.is-active[data-testid=scope-private],.builder__scope-private.is-active{background:var(--text-muted);border-color:var(--text-muted)}.builder__scope-eye{border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:4px;padding:3px 10px;font-size:11px}.builder__scope-eye.is-on{color:var(--text-primary);border-color:var(--text-muted)}.builder__cue-x{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:10px}.builder__cue-x:hover{color:var(--danger)}.rhythm-palette{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.rhythm-palette__durations{gap:6px;display:flex}.rhythm-palette__dur{border:1px solid var(--border-measure);background:var(--bg-surface);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;font-family:Barlow Condensed,Arial Narrow,sans-serif;font-size:16px;font-weight:600;transition:background .12s,color .12s,border-color .12s;display:flex}.rhythm-palette__dur:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-measure)}.rhythm-palette__dur--armed{background:color-mix(in srgb, var(--accent) 15%, transparent);border-color:var(--accent);color:var(--accent)}.rhythm-palette__modifiers{border-left:1px solid var(--border-subtle);gap:6px;padding-left:8px;display:flex}.rhythm-palette__mod{border:1px solid var(--border-measure);background:var(--bg-surface);width:34px;height:34px;color:var(--text-secondary);cursor:pointer;border-radius:5px;justify-content:center;align-items:center;font-size:14px;font-weight:500;transition:background .12s,color .12s,border-color .12s;display:flex}.rhythm-palette__mod:hover{background:var(--bg-elevated);color:var(--text-primary)}.rhythm-palette__mod--active{background:color-mix(in srgb, var(--accent) 12%, transparent);border-color:var(--accent);color:var(--accent)}.rhythm-palette__hint{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:11px;overflow:hidden}.melody-palette{flex-wrap:wrap;flex:1;align-items:center;gap:8px 12px;min-width:0;display:flex}.melody-palette__degrees{flex-shrink:0;gap:4px;display:flex}.melody-palette__degree{border:1px solid var(--border-measure);background:var(--bg-surface);width:38px;height:40px;color:var(--text-secondary);cursor:pointer;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:1px;transition:background .12s,color .12s,border-color .12s;display:flex}.melody-palette__degree--armed{background:color-mix(in srgb, var(--accent) 15%, transparent);border-color:var(--accent);color:var(--accent)}.melody-palette__degree-num{font-family:Barlow Condensed,Arial Narrow,sans-serif;font-size:15px;font-weight:600;line-height:1}.melody-palette__degree-name{opacity:.75;font-size:9px;line-height:1}.melody-palette__durations{border-left:1px solid var(--border-subtle);gap:4px;padding-left:8px;display:flex}.melody-palette__dur,.melody-palette__mod{border:1px solid var(--border-measure);background:var(--bg-surface);width:34px;height:34px;color:var(--text-secondary);cursor:pointer;border-radius:5px;justify-content:center;align-items:center;font-family:Barlow Condensed,Arial Narrow,sans-serif;font-size:14px;font-weight:600;transition:background .12s,color .12s,border-color .12s;display:flex}.melody-palette__dur--armed,.melody-palette__mod--active{background:color-mix(in srgb, var(--accent) 12%, transparent);border-color:var(--accent);color:var(--accent)}.melody-palette__octave{border-left:1px solid var(--border-subtle);align-items:center;gap:4px;padding-left:8px;display:flex}.melody-palette__octave button{border:1px solid var(--border-measure);background:var(--bg-surface);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;border-radius:5px;justify-content:center;align-items:center;font-size:16px;display:flex}.melody-palette__octave-val{text-align:center;min-width:18px;color:var(--text-primary);font-family:Barlow Condensed,Arial Narrow,sans-serif;font-size:16px;font-weight:600}.builder__flow{flex-direction:column;flex:1;gap:12px;padding:12px;display:flex;overflow-y:auto}.builder__flow-readout{z-index:2;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);flex-wrap:wrap;align-items:center;gap:8px;padding:10px 12px;display:flex;position:sticky;top:0}.builder__flow-readout-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary);font-size:11px;font-weight:700}.builder__flow-readout-token{background:var(--bg-surface);border:1px solid var(--border-measure);border-radius:var(--radius-sm);color:var(--text-primary);white-space:nowrap;cursor:pointer;touch-action:manipulation;padding:3px 9px;font-size:14px;font-weight:600}.builder__flow-readout-token:hover{border-color:var(--accent)}.builder__flow-readout-token--active{background:var(--accent);border-color:var(--accent);color:var(--bg-base)}.builder__flow-readout-empty{color:var(--text-muted)}.builder__flow-blocks{flex-direction:column;gap:14px;display:flex;position:relative}.builder__flow-arcs{pointer-events:none;z-index:1;position:absolute;top:0;left:0;overflow:visible}.builder__flow-arc{fill:none;stroke:var(--accent);stroke-width:2px;opacity:.55;stroke-linecap:round}.builder__flow-arc--active{opacity:1;stroke-width:3px;filter:drop-shadow(0 0 5px color-mix(in srgb, var(--accent) 70%, transparent))}.builder__flow-arc--preview{opacity:.9;stroke-width:2.5px;stroke-dasharray:6 5;filter:drop-shadow(0 0 4px color-mix(in srgb, var(--accent) 55%, transparent));animation:.6s linear infinite flow-arc-crawl}@keyframes flow-arc-crawl{to{stroke-dashoffset:-11px}}@media (prefers-reduced-motion:reduce){.builder__flow-arc--preview{animation:none}}.builder__flow-section{flex-direction:column;gap:6px;display:flex}.builder__flow-section-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-size:11px;font-weight:700}.builder__flow-row{flex-wrap:wrap;align-items:stretch;gap:8px;display:flex}.builder__flow-ghost{border:1px dashed var(--border-measure);border-left:1px dashed var(--border-measure);border-radius:var(--radius-md);min-width:88px;min-height:64px;color:var(--text-muted);opacity:.7;cursor:pointer;touch-action:manipulation;background:0 0;flex-direction:column;justify-content:center;align-items:center;gap:2px;padding:8px 10px;display:flex}.builder__flow-ghost:hover{opacity:1;border-color:var(--accent);color:var(--text-secondary)}.builder__flow-ghost-plus{font-size:20px;font-weight:700;line-height:1}.builder__flow-ghost-text{font-size:11px;font-weight:700}.builder__flow-block{background:var(--bg-surface);border:1px solid var(--border-measure);border-left:4px solid hsl(var(--sec-hue,210) 45% 55%);border-radius:var(--radius-md);cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;flex-direction:column;justify-content:space-between;min-width:88px;min-height:64px;padding:8px 10px;display:flex;position:relative}.builder__flow-block--selected{background:color-mix(in srgb, var(--accent) 12%, var(--bg-surface));outline:2px solid var(--accent);outline-offset:1px;z-index:2}.builder__flow-block--played{border-color:hsl(var(--sec-hue,210) 45% 55%);background:color-mix(in srgb, var(--accent) 10%, var(--bg-surface))}.builder__flow-block--playing{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 28%, var(--bg-surface));box-shadow:0 0 0 2px var(--accent), 0 4px 16px color-mix(in srgb, var(--accent) 45%, transparent);z-index:1;transform:translateY(-2px)}.builder__flow-preview-btn{background:var(--accent);color:var(--bg-base);border-radius:var(--radius-sm);cursor:pointer;touch-action:manipulation;border:none;align-items:center;gap:5px;padding:4px 11px;font-size:13px;font-weight:700;display:inline-flex}.builder__flow-preview-btn--on{background:var(--danger)}.builder__flow-block-num{color:var(--text-secondary);font-size:12px;font-weight:700}.builder__flow-block-chords{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:600;overflow:hidden}.builder__flow-block--rep-start,.builder__flow-block--rep-mid,.builder__flow-block--rep-end,.builder__flow-block--rep-solo{border-top:3px solid var(--text-secondary)}.builder__flow-block--rep-start,.builder__flow-block--rep-solo{border-top-left-radius:var(--radius-md)}.builder__flow-block--rep-end,.builder__flow-block--rep-solo{border-top-right-radius:var(--radius-md)}.builder__flow-rep-badge{background:var(--bg-base);color:var(--text-secondary);border:1px solid var(--text-secondary);cursor:pointer;touch-action:manipulation;border-radius:9px;padding:1px 7px;font-size:11px;font-weight:700;position:absolute;top:-11px;left:6px}.builder__flow-block--volta{border-top:3px dashed var(--text-secondary);border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md)}.builder__flow-volta-badge{background:var(--bg-base);color:var(--text-secondary);border:1px solid var(--text-secondary);cursor:pointer;touch-action:manipulation;border-radius:9px;padding:1px 7px;font-size:11px;font-weight:700;position:absolute;top:-11px;right:6px}.builder__flow-palette{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);flex-wrap:wrap;align-items:center;gap:12px;padding:10px 12px;display:flex;position:sticky;bottom:0}.builder__flow-palette-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary);font-size:11px;font-weight:700}.builder__flow-palette-hint{color:var(--text-secondary);font-size:14px}.builder__flow-palette-hint--error{color:var(--danger);font-weight:600}.builder__flow-after-btn{background:var(--bg-surface);border:1px solid var(--border-measure);border-radius:var(--radius-sm);min-height:36px;color:var(--text-primary);cursor:pointer;touch-action:manipulation;padding:0 14px;font-size:14px;font-weight:600}.builder__flow-after-btn:hover{border-color:var(--accent)}.builder__flow-after-named{flex-direction:column;justify-content:center;align-items:center;gap:1px;padding-top:4px;padding-bottom:4px;line-height:1.15;display:inline-flex}.builder__flow-term{letter-spacing:.04em;color:var(--accent);font-size:11px;font-weight:700}.builder__flow-commit .builder__flow-term{color:color-mix(in srgb, var(--bg-base) 78%, transparent)}.builder__flow-stepper{align-items:center;gap:6px;display:flex}.builder__flow-step{background:var(--bg-surface);border:1px solid var(--border-measure);border-radius:var(--radius-sm);width:36px;height:36px;color:var(--text-primary);cursor:pointer;touch-action:manipulation;place-items:center;font-size:20px;display:grid}.builder__flow-step:disabled{opacity:.4;cursor:default}.builder__flow-count{text-align:center;min-width:34px;color:var(--text-primary);font-size:16px;font-weight:700}.builder__flow-commit,.builder__flow-remove{border-radius:var(--radius-sm);cursor:pointer;touch-action:manipulation;border:none;min-height:36px;padding:0 16px;font-size:14px;font-weight:700}.builder__flow-commit{background:var(--accent);color:var(--bg-base)}.builder__flow-remove{background:var(--bg-surface);color:var(--danger);border:1px solid var(--border-measure)}.builder__flow-marks{pointer-events:none;justify-content:space-between;gap:4px;padding:0 6px;display:flex;position:absolute;bottom:4px;left:0;right:0}.builder__flow-mark{pointer-events:auto;background:var(--bg-base);color:var(--text-secondary);border:1px solid var(--border-measure);border-radius:var(--radius-sm);white-space:nowrap;cursor:pointer;touch-action:manipulation;padding:0 5px;font-size:10px;font-weight:700}.builder__flow-mark--start{margin-right:auto}.builder__flow-mark--end{margin-left:auto}.builder__flow-draw-jump{background:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-sm);min-height:36px;color:var(--bg-base);cursor:pointer;touch-action:manipulation;margin-left:auto;padding:0 16px;font-size:14px;font-weight:700}.builder__flow-marks-toggle{background:var(--bg-surface);border:1px solid var(--border-measure);border-radius:var(--radius-sm);min-height:36px;color:var(--text-primary);cursor:pointer;touch-action:manipulation;padding:0 14px;font-size:14px;font-weight:600}.builder__flow-marks-toggle--open{border-color:var(--accent);color:var(--accent)}.builder__flow-marks-list{border-top:1px solid var(--border-subtle);flex-wrap:wrap;flex-basis:100%;gap:6px;margin-top:6px;padding-top:8px;display:flex}.builder__flow-mark-btn{background:var(--bg-surface);border:1px solid var(--border-measure);border-radius:var(--radius-sm);min-height:36px;color:var(--text-primary);white-space:nowrap;cursor:pointer;touch-action:manipulation;padding:0 12px;font-size:13px;font-weight:600}.builder__flow-mark-btn--active{background:var(--accent);color:var(--bg-base);border-color:var(--accent)}.builder__verb-bar{border-top:1px solid var(--border-subtle);background:var(--bg-surface);flex-shrink:0;justify-content:center;align-items:center;gap:8px;padding:8px 10px;display:flex}.builder__verb-label{color:var(--text-secondary);white-space:nowrap;margin-right:4px;font-size:12px}.builder__verb{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-base);min-width:72px;color:var(--text-primary);cursor:pointer;touch-action:manipulation;padding:7px 14px;font-size:13px}.builder__verb:hover:not(:disabled){border-color:var(--accent)}.builder__verb:disabled{opacity:.4;cursor:default}.builder__verb--primary{background:var(--accent);border-color:var(--accent);color:var(--bg-base)}.builder__verb--danger:hover:not(:disabled){border-color:var(--danger);color:var(--danger)}.builder__verb--toggle:before{content:"○ ";opacity:.7}.builder__verb--toggle.is-on{border-color:var(--accent);color:var(--accent)}.builder__verb--toggle.is-on:before{content:"● "}.builder__overlay-scrim{z-index:1100;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.builder__overlay{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);min-width:240px;color:var(--text-primary);padding:16px 18px;box-shadow:0 12px 40px #00000073}.builder__overlay-title{margin-bottom:10px;font-size:13px;font-weight:600}.builder__overlay-lanes{flex-direction:column;gap:8px;margin:0 0 14px;padding:0;list-style:none;display:flex}.builder__overlay-lanes label{cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.builder__overlay-lanes input{accent-color:var(--accent)}.builder__overlay-actions{justify-content:flex-end;gap:8px;display:flex}.session-bar{border-bottom:1px solid var(--border-subtle);background:var(--bg-surface);align-items:center;gap:10px;min-height:32px;padding:4px 12px;font-size:13px;display:flex}.session-bar--idle,.session-bar--disconnected{justify-content:flex-end}.session-bar__start-btn{border:1px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:4px;padding:4px 12px;font-size:12px}.session-bar__start-btn:hover{background:var(--accent);color:var(--text-inverse)}.session-bar--connected{gap:12px}.session-bar__role{color:var(--accent);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600}.session-bar__participants{color:var(--text-secondary);align-items:center;gap:5px;display:flex}.session-bar__dot{background:var(--success);border-radius:50%;width:7px;height:7px;display:inline-block}.session-bar__copy-link{color:var(--accent);margin-left:auto;font-size:12px;text-decoration:none}.session-bar__copy-link:hover{text-decoration:underline}.session-bar__end-btn{border:1px solid var(--danger);color:var(--danger);cursor:pointer;background:0 0;border-radius:4px;padding:2px 8px;font-size:11px}.session-bar__end-btn:hover{background:var(--danger);color:var(--text-inverse)}.session-bar--connecting{color:var(--text-secondary);font-style:italic}.session-bar--kicked,.session-bar--error{justify-content:space-between}.session-bar__notice{color:var(--danger);font-size:12px}.session-bar__participant-list{align-items:center;gap:8px;display:flex}.session-bar__participant{border:1px solid var(--border-subtle);color:var(--text-secondary);border-radius:10px;align-items:center;gap:4px;padding:1px 6px;font-size:11px;display:inline-flex}.session-bar__kick-btn{color:var(--danger);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:0 5px;font-size:10px}.session-bar__kick-btn:hover{background:var(--danger);color:var(--text-inverse)}.session-bar__invite{align-items:center;gap:4px;display:inline-flex}.session-bar__invite-input{border:1px solid var(--border-subtle);width:160px;color:inherit;background:0 0;border-radius:4px;padding:2px 6px;font-size:12px}.session-bar__invite-btn{border:1px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:4px;padding:2px 8px;font-size:11px}.session-bar__invite-btn:hover{background:var(--accent);color:var(--text-inverse)}.session-bar__follow{border:1px solid var(--accent);background:var(--accent);color:var(--text-inverse);cursor:pointer;white-space:nowrap;border-radius:999px;align-items:center;gap:6px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.session-bar__follow--on{color:var(--accent);cursor:default;background:0 0}.invitations-bar{border-bottom:1px solid var(--border-subtle);background:var(--bg-surface);flex-direction:column;gap:4px;padding:6px 12px;font-size:13px;display:flex}.invitations-bar__item{align-items:center;gap:10px;display:flex}.invitations-bar__text{color:var(--text-secondary)}.invitations-bar__join-btn{border:1px solid var(--accent);background:var(--accent);color:var(--text-inverse);cursor:pointer;border-radius:4px;padding:2px 12px;font-size:12px}.invitations-bar__join-btn:hover{opacity:.85}.metro-bar{align-items:center;gap:var(--sp-2);height:36px;padding:4px var(--sp-3);background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);flex-shrink:0;display:flex}.metro-play{background:var(--bg-elevated);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;transition:background var(--dur-fast), color var(--dur-fast);border:none;border-radius:4px;flex-shrink:0;font-size:10px;line-height:1}.metro-play:hover{background:var(--bg-elevated);color:var(--text-primary)}.metro-play--active{background:var(--accent-dim);color:var(--accent)}.metro-beats{flex:1;gap:4px;height:100%;display:flex}.metro-beat{background:var(--bg-elevated);border-radius:3px;flex:1}.metro-beat--one{border-top:2px solid var(--text-muted)}@keyframes metro-flash{0%{background:var(--accent);box-shadow:0 0 10px var(--accent)}20%{background:var(--accent)}to{background:var(--bg-elevated);box-shadow:none}}.metro-beat--active{animation:metro-flash var(--flash-dur,.4s) ease-out forwards}.metro-beat--one.metro-beat--active{border-top-color:var(--accent)}.metro-scroll-label{color:var(--text-muted);margin-left:var(--sp-2);flex-shrink:0;align-items:center;gap:5px;font-size:11px;display:flex}.metro-scroll-slider{width:72px;accent-color:var(--accent)}@media print{.metro-bar{display:none}}.song-meta-bar{align-items:center;gap:var(--sp-2) var(--sp-3);padding:var(--sp-2) var(--sp-4);background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;flex-shrink:0;display:flex}.song-meta-bar__title{color:var(--text-primary);font-family:var(--font-ui);min-width:100px;max-width:260px;transition:border-color var(--dur-fast);background:0 0;border:none;border-bottom:1px solid #0000;outline:none;padding-bottom:1px;font-size:15px;font-weight:600}.song-meta-bar__title:focus{border-bottom-color:var(--accent)}.song-meta-bar__title::placeholder{color:var(--text-muted)}.song-meta-bar__field{align-items:center;gap:var(--sp-1);flex-shrink:0;display:flex}.song-meta-bar__field--grow{flex:1;min-width:120px}.song-meta-bar__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:500}.song-meta-bar__input{background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);min-width:0;color:var(--text-primary);font-family:var(--font-mono);transition:border-color var(--dur-fast);outline:none;flex:1;padding:2px 6px;font-size:13px}.song-meta-bar__input:focus{border-color:var(--accent)}.song-meta-bar__input--short{text-align:center;flex:none;width:48px}.song-meta-bar__input--tiny{text-align:center;flex:none;width:30px}.song-meta-bar__input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.song-meta-bar__input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.song-meta-bar__input[type=number]{-moz-appearance:textfield}.song-meta-bar__time{align-items:center;gap:2px;display:flex}.song-meta-bar__sep{color:var(--text-muted);font-family:var(--font-mono);font-size:13px}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:.5rem;display:flex;position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%)}.toast{color:#fff;white-space:nowrap;pointer-events:auto;border-radius:6px;padding:.6rem 1.2rem;font-size:.875rem;font-weight:500;animation:.15s ease-out toast-in}.toast--error{background:#c0392b}.toast--info{background:#2c3e50}@keyframes toast-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.sync-paused{border-bottom:1px solid var(--border-subtle);background:var(--bg-surface)}.sync-paused__row{align-items:center;gap:10px;padding:3px 12px;font-size:12px;display:flex}.sync-paused__text{color:var(--text-secondary)}.sync-paused__expand{border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:10px;padding:1px 10px;font-size:11px}.sync-paused__expand:hover{color:var(--text-primary);border-color:var(--accent)}.sync-paused__dismiss{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;margin-left:auto;font-size:14px;line-height:1}.sync-paused__dismiss:hover{color:var(--text-primary)}.library-unlock-bar{border-bottom:1px solid var(--border-subtle);background:var(--bg-surface);align-items:center;gap:10px;padding:6px 12px;font-size:13px;display:flex}.library-unlock-bar__text{color:var(--text-secondary)}.library-unlock-bar__input{border:1px solid var(--border-subtle);background:var(--bg-base);color:var(--text-primary);border-radius:4px;padding:2px 8px;font-size:12px}.library-unlock-bar__btn{border:1px solid var(--accent);background:var(--accent);color:var(--text-inverse);cursor:pointer;border-radius:4px;padding:2px 12px;font-size:12px}.library-unlock-bar__btn:hover{opacity:.85}.library-unlock-bar__logout{border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:4px;padding:2px 10px;font-size:12px}.library-unlock-bar__logout:hover{color:var(--text-primary)}.library-unlock-bar__error{color:var(--danger);font-size:12px}.recovery-modal__backdrop{z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.recovery-modal{background:var(--bg-surface);border:1px solid var(--border-subtle);max-width:440px;color:var(--text-primary);border-radius:8px;padding:24px}.recovery-modal h2{margin-top:0;font-size:16px}.recovery-modal p{color:var(--text-secondary);font-size:13px}.recovery-modal__code{text-align:center;letter-spacing:1px;border:1px dashed var(--border-subtle);background:var(--bg-base);-webkit-user-select:all;user-select:all;border-radius:6px;margin:16px 0;padding:12px;font-family:monospace;font-size:18px;display:block}.recovery-modal__btn{border:1px solid var(--accent);background:var(--accent);width:100%;color:var(--text-inverse);cursor:pointer;border-radius:4px;padding:8px;font-size:13px}.recovery-modal__btn:hover{opacity:.85}.app-layout{height:100%;display:flex;overflow:hidden}.app-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.builder-shell{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.chart-area{padding:var(--sp-4);background:var(--bg-base);flex:1;overflow:auto}.chart-area>.chart{width:100%;min-width:0}
