*,: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:#0f1117;--bg-surface:#1a1d27;--bg-elevated:#252836;--bg-groove:#13151f;--bg-input:#1e2130;--accent:#f5a623;--accent-dim:#f5a6232e;--accent-hover:#f7b84e;--danger:#d64045;--danger-dim:#d6404526;--text-primary:#e8eaf0;--text-secondary:#8891a8;--text-muted:#454c66;--text-inverse:#0f1117;--chip-chord-bg:#1a2e50;--chip-chord-fg:#7db8f7;--chip-chord-border:#2a4a7a;--chip-lyric-bg:#251838;--chip-lyric-fg:#c4a8f5;--chip-lyric-border:#3d2660;--border-subtle:#252836;--border-measure:#3a4060;--border-beat:#2a2e3e;--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:20px;--radius-sm:3px;--radius-md:6px;--radius-lg:10px;--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;--text-primary:#1a1d27;--text-secondary:#5a6080;--text-muted:#b0b8cc;--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(--color-bg,#111);z-index:100;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-card{background:var(--color-surface,#1a1a1a);border:1px solid var(--color-border,#333);border-radius:8px;width:360px;max-width:calc(100vw - 2rem);padding:2rem}.auth-card__title{text-align:center;color:var(--color-text,#eee);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(--color-text-muted,#888);font-size:.8125rem}.auth-card__input{border:1px solid var(--color-border,#333);background:var(--color-bg,#111);color:var(--color-text,#eee);border-radius:4px;outline:none;padding:.5rem .75rem;font-size:.9375rem}.auth-card__input:focus{border-color:var(--color-accent,#5b8dee)}.auth-card__submit{background:var(--color-accent,#5b8dee);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(--color-error,#e55);text-align:center;margin-top:.5rem;font-size:.8125rem}.auth-card__success{color:var(--color-success,#5c5);text-align:center;padding:.5rem 0;font-size:.875rem}.auth-card__switch{text-align:center;color:var(--color-text-muted,#888);margin-top:1.25rem;font-size:.8125rem}.auth-card__switch-btn{color:var(--color-accent,#5b8dee);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}.metabar{min-height:var(--metabar-h);padding:0 var(--sp-4);background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;gap:var(--sp-2) var(--sp-3);flex-wrap:wrap;flex-shrink:0;display:flex;container-type:inline-size}.metabar__left{align-items:center;gap:var(--sp-2);flex:1;min-width:0;display:flex}.metabar__right{flex-shrink:0;align-items:center;gap:3px;display:flex}.metabar__title{color:var(--text-primary);font-size:15px;font-weight:600;font-family:var(--font-ui);min-width:80px;max-width:220px;transition:border-color var(--dur-fast);background:0 0;border:none;border-bottom:1px solid #0000;outline:none;padding-bottom:1px}.metabar__title:focus{border-bottom-color:var(--accent)}.metabar__title::placeholder{color:var(--text-muted)}.metabar__field{align-items:center;gap:var(--sp-1);flex-shrink:0;display:flex}.metabar__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:500}.metabar__input{background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);transition:border-color var(--dur-fast);text-align:center;outline:none;padding:2px 6px;font-size:13px}.metabar__input:focus{border-color:var(--accent)}.metabar__input--short{width:44px}.metabar__input--tiny{width:28px}.metabar__input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.metabar__input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.metabar__input[type=number]{-moz-appearance:textfield}.metabar__time{align-items:center;gap:2px;display:flex}.metabar__sep{color:var(--text-muted);font-family:var(--font-mono);font-size:13px}.metabar__pagecode{font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-elevated);border-radius:var(--radius-sm);padding:2px 6px;font-size:11px}.metabar__divider{background:var(--border-subtle);flex-shrink:0;width:1px;height:16px;margin:0 3px}.metabar__btn{border-radius:var(--radius-sm);color:var(--text-secondary);transition:background var(--dur-fast), color var(--dur-fast);white-space:nowrap;background:0 0;padding:2px 6px;font-size:12px;font-weight:500;position:relative}.metabar__btn--icon{padding:2px 5px;font-size:13px;line-height:1}.metabar__btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.metabar__btn:disabled{color:color-mix(in srgb, var(--text-secondary) 30%, transparent);cursor:default;pointer-events:all}.metabar__btn--theme,.metabar__btn--orientation{padding:2px 7px;font-size:14px}.metabar__btn--active{color:var(--accent);background:var(--accent-dim)}.metabar__scale-display{font-family:var(--font-mono);color:var(--text-secondary);text-align:center;-webkit-user-select:none;user-select:none;min-width:30px;font-size:11px}.metabar__ctrl-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;-webkit-user-select:none;user-select:none;font-size:10px;font-weight:600}.metabar__btn--text-size{font-size:10px;font-style:italic}.metabar__btn--text-size-up{font-size:14px;font-weight:700}.metabar__btn[title]:after{content:attr(title);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-subtle);font-family:var(--font-ui);white-space:nowrap;pointer-events:none;z-index:300;opacity:0;padding:4px 9px;font-size:11px;font-weight:500;line-height:1.4;transition:opacity 80ms,transform 80ms;position:absolute;top:calc(100% + 7px);left:50%;transform:translate(-50%)translateY(3px);box-shadow:0 2px 10px #0000002e}.metabar__btn[title]:hover:after{opacity:1;transition:opacity .12s .3s,transform .12s .3s;transform:translate(-50%)translateY(0)}@container (width<=780px){.metabar{padding:6px var(--sp-4);gap:4px var(--sp-3);align-content:center}.metabar__left{flex:100%}.metabar__right{flex:100%;justify-content:flex-start;gap:3px}}@container (width<=480px){.metabar__title{max-width:140px}.metabar__field:last-of-type{display:none}}.entry-panel{background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);flex-direction:column;flex-shrink:0;max-height:260px;display:flex}.entry-panel__tabs{border-bottom:1px solid var(--border-subtle);flex-shrink:0;gap:0;display:flex}.entry-panel__tab{color:var(--text-muted);transition:color var(--dur-fast), border-color var(--dur-fast);align-items:center;gap:var(--sp-1);border-bottom:2px solid #0000;margin-bottom:-1px;padding:6px 16px;font-size:12px;font-weight:500;display:flex}.entry-panel__tab:hover{color:var(--text-secondary)}.entry-panel__tab--active{color:var(--accent);border-bottom-color:var(--accent)}.entry-panel__note-value{align-items:center;gap:var(--sp-1);padding-right:var(--sp-2);margin-left:auto;display:flex}.entry-panel__note-label{color:var(--text-muted);font-size:11px;font-weight:500}.note-value-select{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);cursor:pointer;transition:border-color var(--dur-fast);outline:none;padding:1px 4px;font-size:13px}.note-value-select:focus{border-color:var(--accent)}.entry-panel__badge{background:var(--accent-dim);min-width:16px;height:16px;color:var(--accent);border-radius:8px;justify-content:center;align-items:center;padding:0 4px;font-size:10px;font-weight:600;display:inline-flex}.entry-panel__body{padding:var(--sp-3) var(--sp-4);gap:var(--sp-2);flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.entry-panel__section{gap:var(--sp-2);flex-direction:column;display:flex}.entry-panel__textarea{resize:vertical;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:100%;min-height:64px;color:var(--text-primary);font-family:var(--font-mono);padding:var(--sp-2) var(--sp-3);transition:border-color var(--dur-fast);outline:none;font-size:13px;line-height:1.5}.entry-panel__textarea:focus{border-color:var(--accent)}.entry-panel__palette-label{color:var(--text-muted);align-items:center;gap:var(--sp-2);flex-wrap:wrap;font-size:11px;display:flex}.entry-panel__flow-btn{color:var(--accent);border-radius:var(--radius-sm);background:var(--accent-dim);transition:background var(--dur-fast);padding:1px 6px;font-size:11px;font-weight:600}.entry-panel__flow-btn:hover{background:#f5a62347}.kb-help{gap:var(--sp-4);flex-wrap:wrap;column-gap:48px;display:flex}.kb-section{min-width:220px}.kb-heading{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:var(--sp-2);border-bottom:1px solid var(--border-subtle);padding-bottom:3px;font-size:10px;font-weight:600}.kb-row{align-items:baseline;gap:10px;padding:2px 0;display:flex}.kb-keys{flex-shrink:0;align-items:center;gap:2px;min-width:88px;display:flex}.kb-key{background:var(--bg-elevated);border:1px solid var(--border-subtle);min-width:20px;box-shadow:0 1px 0 var(--border-subtle);font-family:var(--font-mono);color:var(--text-secondary);white-space:nowrap;border-radius:3px;justify-content:center;align-items:center;padding:1px 5px;font-size:11px;display:inline-flex}.kb-desc{color:var(--text-muted);font-size:11px;line-height:1.4}.jsl-ref-section{min-width:280px}.jsl-ref-token{font-family:var(--font-mono);color:var(--text-secondary);white-space:nowrap;flex-shrink:0;min-width:160px;font-size:11px}.palette{flex-wrap:wrap;gap:4px;min-height:28px;display:flex}.palette-chip{border-radius:var(--radius-sm);height:22px;font-family:var(--font-mono);cursor:grab;-webkit-user-select:none;user-select:none;transition:background var(--dur-fast), transform var(--dur-fast);align-items:center;padding:0 7px;font-size:12px;display:flex}.palette-chip:active{transform:scale(.96)}.palette-chip--chord{background:var(--chip-chord-bg);color:var(--chip-chord-fg);border:1px solid var(--chip-chord-border)}.palette-chip--syllable{background:var(--chip-lyric-bg);color:var(--chip-lyric-fg);border:1px solid var(--chip-lyric-border)}.palette-chip--dragging{opacity:.3}.chart{gap:var(--chart-row-gap);flex-direction:column;display:flex}.chart-playhead{background:var(--accent);opacity:.55;pointer-events:none;z-index:20;width:1px;position:absolute;top:0;bottom:0}.chart-empty{height:200px;color:var(--text-muted);font-family:var(--font-mono);justify-content:center;align-items:center;font-size:13px;display:flex}.chart-row{flex-direction:column;gap:0;display:flex}.chord-row__line-break-hint{color:var(--accent);opacity:.7;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:7px;line-height:1;position:absolute;bottom:1px;left:3px}.chart-row-grid{display:grid;position:relative}.beat-row{height:var(--row-h-beat);color:var(--text-secondary);background:0 0;align-items:center;display:grid}.beat-cell{height:var(--row-h-beat);justify-content:center;align-items:center;display:flex;position:relative}.beat-cell--measure-start{border-left:1px solid var(--border-measure)}.beat-cell--row-end{border-right:1px solid var(--border-measure)}.beat-row--dragging .beat-cell{border-left:1px solid color-mix(in srgb, var(--border-beat) 25%, transparent)}.beat-row--dragging .beat-cell--on-beat{border-left:1px solid color-mix(in srgb, var(--border-beat) 45%, transparent)}.beat-row--dragging .beat-cell--measure-start{border-left:1px solid var(--border-measure)}.beat-mark{font-family:var(--font-mono);-webkit-user-select:none;user-select:none;pointer-events:none;font-size:8px}.beat-mark-default,.beat-mark-authored{opacity:.45}.beat-mark--on-beat{color:var(--text-secondary);font-size:10px;font-weight:500;line-height:1}.beat-mark--subdiv{background:var(--text-muted);opacity:.5;border-radius:1px;width:1px;height:4px;display:block}.beat-mark--measure{color:var(--border-measure);font-weight:500}.beat-cell--drop-target{background:var(--accent-dim)}.beat-cell__measure-number{font-family:var(--font-mono);color:var(--text-muted);opacity:.85;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:7px;line-height:1;position:absolute;top:1px;left:3px}.beat-row--syl-selected .beat-cell{border-left:1px solid color-mix(in srgb, var(--border-beat) 18%, transparent)}.beat-row--syl-selected .beat-cell--on-beat{border-left:1px solid color-mix(in srgb, var(--border-beat) 35%, transparent)}.beat-row--syl-selected .beat-cell--measure-start{border-left:1px solid var(--border-measure)}.chord-row{height:var(--row-h-chord);background:0 0;display:grid;position:relative}.chord-row__drop-cell{height:var(--row-h-chord);cursor:crosshair;position:relative}.chord-row__drop-cell--drop-target{background:var(--accent-dim)}.lyric-row{height:var(--row-h-lyric);background:var(--bg-base);display:grid;position:relative}.lyric-row__drop-cell{height:var(--row-h-lyric);cursor:crosshair;position:relative}.lyric-row__drop-cell--drop-target{background:var(--accent-dim)}.chord-chip{border-radius:var(--radius-sm);height:14px;color:var(--chip-chord-fg);font-family:var(--font-mono);white-space:nowrap;cursor:grab;-webkit-user-select:none;user-select:none;z-index:2;transition:background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease), outline var(--dur-fast) var(--ease);background:0 0;border:1px solid #0000;align-items:center;padding:0 6px;font-size:12px;font-weight:500;display:flex;position:absolute;bottom:0}.chord-chip:hover{background:color-mix(in srgb, var(--chip-chord-bg) 65%, transparent);border-color:var(--chip-chord-border)}.chord-chip--selected{background:var(--chip-chord-bg);border-color:var(--chip-chord-border);outline:2px solid var(--accent);outline-offset:1px}.chord-chip--dragging{opacity:.3}.syllable-chip{border-radius:var(--radius-sm);height:22px;color:var(--chip-lyric-fg);font-family:var(--font-mono);white-space:nowrap;cursor:grab;-webkit-user-select:none;user-select:none;z-index:2;transition:background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;padding:0 5px;font-size:12px;display:flex;position:absolute;top:2px}.syllable-chip:hover{background:color-mix(in srgb, var(--chip-lyric-bg) 65%, transparent);border-color:var(--chip-lyric-border)}.syllable-chip--selected{background:var(--chip-lyric-bg);border-color:var(--chip-lyric-border);outline:2px solid var(--accent);outline-offset:1px}.syllable-chip--dragging{opacity:.3}.syllable-chip--resizing{border-bottom:1.5px solid var(--chip-lyric-border)}.syllable-chip__hyphen{color:var(--text-muted);pointer-events:none;font-size:10px;position:absolute;right:-5px}.syllable-chip__resize-handle{cursor:ew-resize;border-radius:0 var(--radius-sm) var(--radius-sm) 0;width:5px;transition:background var(--dur-fast);background:0 0;position:absolute;top:0;bottom:0;right:0}.syllable-chip:hover .syllable-chip__resize-handle{background:var(--accent);opacity:.7}.goto-input-overlay{z-index:200;pointer-events:none;position:fixed;top:12px;left:50%;transform:translate(-50%)}.goto-input-pill{background:var(--bg-surface);border:1px solid var(--accent);pointer-events:all;border-radius:999px;align-items:center;gap:8px;padding:6px 12px;display:flex;box-shadow:0 4px 16px #0006}.goto-input-label{font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap;font-size:12px}.goto-input-field{border:none;border-bottom:1px solid var(--border-beat);color:var(--text-primary);font-family:var(--font-mono);width:80px;transition:border-color var(--dur-fast);background:0 0;outline:none;padding:2px 0;font-size:13px}.goto-input-field:focus{border-bottom-color:var(--accent)}.goto-input-field--invalid{border-bottom-color:var(--error,#e05c5c)}.drag-ghost{pointer-events:none;z-index:1000;opacity:.85;position:fixed}.drag-ghost__inner{border-radius:var(--radius-sm);height:22px;font-family:var(--font-mono);white-space:nowrap;align-items:center;padding:0 8px;font-size:12px;font-weight:500;display:flex;position:relative;box-shadow:0 4px 16px #0006}.drag-ghost__duplicate-badge{background:var(--accent);width:14px;height:14px;color:var(--text-inverse);font-size:11px;font-weight:700;font-family:var(--font-ui);pointer-events:none;border-radius:50%;justify-content:center;align-items:center;line-height:1;display:flex;position:absolute;top:-7px;right:-7px}.drag-ghost__inner--chord{background:var(--chip-chord-bg);color:var(--chip-chord-fg);border:1px solid var(--chip-chord-border)}.drag-ghost__inner--syllable,.drag-ghost__inner--syllable-resize{background:var(--chip-lyric-bg);color:var(--chip-lyric-fg);border:1px solid var(--chip-lyric-border)}.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}}.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-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}}.session-bar{border-bottom:1px solid var(--border,#e0e0e0);background:var(--surface,#fafafa);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,#5a5af0);color:var(--accent,#5a5af0);cursor:pointer;background:0 0;border-radius:4px;padding:4px 12px;font-size:12px}.session-bar__start-btn:hover{background:var(--accent,#5a5af0);color:#fff}.session-bar--connected{gap:12px}.session-bar__role{color:var(--accent,#5a5af0);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600}.session-bar__participants{color:var(--text-secondary,#666);align-items:center;gap:5px;display:flex}.session-bar__dot{background:#22c55e;border-radius:50%;width:7px;height:7px;display:inline-block}.session-bar__copy-link{color:var(--accent,#5a5af0);margin-left:auto;font-size:12px;text-decoration:none}.session-bar__copy-link:hover{text-decoration:underline}.session-bar__end-btn{color:#f87171;cursor:pointer;background:0 0;border:1px solid #f87171;border-radius:4px;padding:2px 8px;font-size:11px}.session-bar__end-btn:hover{color:#fff;background:#f87171}.session-bar--connecting{color:var(--text-secondary,#888);font-style:italic}.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)}}.app-layout{height:100%;display:flex;overflow:hidden}.app-main{flex-direction:column;flex:1;min-width: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}
