:root{--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--font-ui: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;--font-lyric: Georgia, "Times New Roman", "Palatino Linotype", serif;--font-mono: "SF Mono", "Fira Code", "Cascadia Code", Consolas, monospace;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-md: 17px;--text-lg: 20px;--text-xl: 24px;--text-2xl: 30px;--weight-normal: 400;--weight-medium: 500;--weight-semibold: 600;--leading-tight: 1.25;--leading-normal: 1.5;--leading-lyric: 1.9;--leading-chord: 2.6;--radius-sm: 3px;--radius-md: 6px;--radius-lg: 10px;--radius-full: 9999px;--sidebar-width: 220px;--right-panel-width: 280px;--header-height: 44px;--mobile-tab-height: 56px;--z-base: 0;--z-raised: 10;--z-tooltip: 50;--z-overlay: 100;--z-modal: 200;--z-toast: 300;--transition-fast: .1s ease;--transition-base: .18s ease;--transition-slow: .32s ease;--opacity-chrome: .4;--opacity-chrome-hover: 1;--opacity-dimmed: .3}[data-theme=light]{--color-bg: #f7f6f3;--color-surface: #ffffff;--color-surface-2: #f1f0ec;--color-surface-3: #e8e7e2;--color-border: #dddbd5;--color-border-subtle: #e8e7e2;--color-text-primary: #1c1b18;--color-text-secondary: #6b6964;--color-text-tertiary: #9b9894;--color-accent: #7a8c6d;--color-accent-hover: #697a5d;--color-accent-subtle: #edf0e9;--color-accent-text: #ffffff;--color-chord: #5e7054;--color-chord-bg: transparent;--color-danger: #b85450;--color-danger-hover: #a04844;--color-danger-subtle: #fdf0f0;--color-danger-text: #ffffff;--color-success: #22c55e;--color-error: #ef4444;--color-overlay-bg: rgba(247, 246, 243, .85);--color-scrim: rgba(0, 0, 0, .18);--color-diff-added-bg: #e6f4ea;--color-diff-added-border: #a8d5b0;--color-diff-added-text: #1e6b32;--color-diff-removed-bg: #fce8e8;--color-diff-removed-border: #e4a5a5;--color-diff-removed-text: #9b2626}[data-theme=dark]{--color-bg: #1a1916;--color-surface: #222120;--color-surface-2: #2a2927;--color-surface-3: #333230;--color-border: #3a3936;--color-border-subtle: #2e2d2b;--color-text-primary: #f0efe9;--color-text-secondary: #9b9894;--color-text-tertiary: #6b6964;--color-accent: #8fa37e;--color-accent-hover: #a0b48f;--color-accent-subtle: #252e21;--color-accent-text: #1c1b18;--color-chord: #8fa37e;--color-chord-bg: transparent;--color-danger: #d07070;--color-danger-hover: #e08080;--color-danger-subtle: #2e1f1f;--color-danger-text: #1c1b18;--color-success: #22c55e;--color-error: #ef4444;--color-overlay-bg: rgba(26, 25, 22, .88);--color-scrim: rgba(0, 0, 0, .45);--color-diff-added-bg: #1a2e1e;--color-diff-added-border: #3d6e47;--color-diff-added-text: #72c487;--color-diff-removed-bg: #2e1a1a;--color-diff-removed-border: #6e3d3d;--color-diff-removed-text: #c47272}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-ui);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text-primary);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.text-ui{font-family:var(--font-ui);font-size:var(--text-base);line-height:var(--leading-normal)}.text-ui-sm{font-family:var(--font-ui);font-size:var(--text-sm);line-height:var(--leading-normal)}.text-ui-xs{font-family:var(--font-ui);font-size:var(--text-xs);line-height:var(--leading-normal);letter-spacing:.02em}.text-lyric{font-family:var(--font-lyric);font-size:var(--text-md);line-height:var(--leading-lyric);color:var(--color-text-primary)}.text-lyric-chorded{font-family:var(--font-lyric);font-size:var(--text-md);line-height:var(--leading-chord)}.text-chord{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-chord);line-height:1}.heading-lg{font-family:var(--font-ui);font-size:var(--text-xl);font-weight:var(--weight-semibold);line-height:var(--leading-tight);color:var(--color-text-primary)}.heading-md{font-family:var(--font-ui);font-size:var(--text-lg);font-weight:var(--weight-semibold);line-height:var(--leading-tight);color:var(--color-text-primary)}.heading-sm{font-family:var(--font-ui);font-size:var(--text-base);font-weight:var(--weight-semibold);line-height:var(--leading-tight);color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}.app-shell{display:flex;flex-direction:column;height:100dvh;background-color:var(--color-bg);position:relative;overflow:hidden}.app-header{display:flex;align-items:center;gap:var(--space-4);height:var(--header-height);padding:0 var(--space-5);border-bottom:1px solid var(--color-border-subtle);background-color:var(--color-surface);flex-shrink:0;z-index:var(--z-raised)}.app-header__logo{font-family:var(--font-ui);font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--color-text-primary);letter-spacing:-.01em;flex-shrink:0;text-decoration:none}.app-header__logo:hover{color:var(--color-text-secondary);text-decoration:none}.app-header__song-title{font-family:var(--font-ui);font-size:var(--text-base);color:var(--color-text-secondary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-header__project-link{color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast)}.app-header__project-link:hover{color:var(--color-text-primary)}.app-header__actions{display:flex;align-items:center;gap:var(--space-2);margin-left:auto}.app-header__updated-by{font-size:var(--text-xs);color:var(--color-text-tertiary);white-space:nowrap}.app-body{display:flex;flex:1;min-height:0;overflow:hidden}.app-sidebar{width:var(--sidebar-width);flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--color-border-subtle);background-color:var(--color-surface);overflow-y:auto;padding:var(--space-4) 0}.app-sidebar__heading-row{display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-3) var(--space-2) var(--space-4)}.app-sidebar__heading{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em}.app-sidebar__add-section{background:transparent;border:none;color:var(--color-text-tertiary);font-size:var(--text-sm);cursor:pointer;padding:0 var(--space-1);line-height:1;opacity:var(--opacity-chrome);transition:opacity var(--transition-fast),color var(--transition-fast)}.app-sidebar__add-section:hover{opacity:1;color:var(--color-text-primary)}.app-sidebar__section-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-4);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;border-radius:0;transition:background-color var(--transition-fast),color var(--transition-fast)}.app-sidebar__section-item:hover,.app-sidebar__section-item--active{background-color:var(--color-surface-2);color:var(--color-text-primary)}.app-sidebar__add-section{margin:var(--space-2) var(--space-3) 0;font-size:var(--text-sm);color:var(--color-text-tertiary);opacity:var(--opacity-chrome);transition:opacity var(--transition-fast)}.app-sidebar__add-section:hover{opacity:var(--opacity-chrome-hover)}.app-editor{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden;background-color:var(--color-bg);transition:filter var(--transition-slow)}.app-editor__banner{flex-shrink:0}.app-editor__scroll{flex:1;overflow-y:auto}.app-right-panel{width:var(--right-panel-width);flex-shrink:0;display:flex;flex-direction:column;border-left:1px solid var(--color-border-subtle);background-color:var(--color-surface);overflow-y:auto;transition:width var(--transition-base),opacity var(--transition-base)}.app-right-panel[data-open=false]{width:0;opacity:0;overflow:hidden;pointer-events:none}.app-right-panel__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0}.app-right-panel__title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--color-text-secondary)}.history-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-overlay);background-color:var(--color-overlay-bg);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);align-items:stretch;justify-content:center}[data-slot=history-panel]{flex:1;max-width:860px;margin:0 auto;display:flex;flex-direction:column}.history-overlay__close{align-self:flex-end;margin:var(--space-4)}.auth-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg);padding:var(--space-6)}.auth-card{width:100%;max-width:380px;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-8);display:flex;flex-direction:column;gap:var(--space-5)}.auth-title{font-family:var(--font-ui);font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--color-text-primary);letter-spacing:-.02em}.auth-heading{font-size:var(--text-base);font-weight:var(--weight-medium);color:var(--color-text-secondary);margin-top:calc(-1 * var(--space-3))}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-label{display:flex;flex-direction:column;gap:var(--space-1);font-size:var(--text-sm);color:var(--color-text-secondary)}.auth-input{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-2);color:var(--color-text-primary);font-family:var(--font-ui);font-size:var(--text-base);outline:none;transition:border-color var(--transition-fast)}.auth-input:focus{border-color:var(--color-accent)}.auth-button{width:100%;padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-family:var(--font-ui);font-size:var(--text-base);font-weight:var(--weight-medium);cursor:pointer;border:1px solid transparent;transition:background-color var(--transition-fast),color var(--transition-fast)}.auth-button--primary{background-color:var(--color-accent);color:var(--color-accent-text)}.auth-button--primary:hover:not(:disabled){background-color:var(--color-accent-hover)}.auth-button--primary:disabled{opacity:.5;cursor:not-allowed}.auth-button--oauth{background-color:var(--color-surface-2);color:var(--color-text-primary);border-color:var(--color-border)}.auth-button--oauth:hover{background-color:var(--color-surface-3)}.auth-error{font-size:var(--text-sm);color:var(--color-danger)}.auth-message{font-size:var(--text-sm);color:var(--color-text-secondary)}.auth-footer{font-size:var(--text-sm);color:var(--color-text-tertiary);text-align:center}.auth-link{color:var(--color-accent);text-decoration:none;background:none;border:none;cursor:pointer;font-size:inherit;font-family:inherit;padding:0}.auth-link:hover{text-decoration:underline}.dashboard{min-height:100dvh;background-color:var(--color-bg);display:flex;flex-direction:column}.dashboard__header{display:flex;align-items:center;gap:var(--space-4);height:var(--header-height);padding:0 var(--space-6);border-bottom:1px solid var(--color-border-subtle);background-color:var(--color-surface)}.dashboard__logo{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--color-text-primary);letter-spacing:-.01em}.dashboard__user{display:flex;align-items:center;gap:var(--space-2);margin-left:auto}.dashboard__display-name{font-size:var(--text-sm);color:var(--color-text-secondary)}.dashboard__signout{font-size:var(--text-sm);color:var(--color-text-tertiary);background:none;border:none;cursor:pointer;padding:0;font-family:var(--font-ui);transition:color var(--transition-fast)}.dashboard__signout:hover{color:var(--color-text-primary)}.dashboard__main{flex:1;max-width:880px;margin:0 auto;width:100%;padding:var(--space-10) var(--space-6)}.dashboard__toolbar{display:flex;align-items:center;margin-bottom:var(--space-6);gap:var(--space-4)}.dashboard__heading{font-size:var(--text-xl);font-weight:700;color:var(--color-text-primary);flex:1}.dashboard__new-song-form{display:flex;gap:var(--space-2);align-items:center}.dashboard__new-song-input{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface);color:var(--color-text-primary);font-family:var(--font-ui);font-size:var(--text-base);outline:none;transition:border-color var(--transition-fast)}.dashboard__new-song-input:focus{border-color:var(--color-accent)}.dashboard__btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-family:var(--font-ui);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;border:1px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text-secondary);white-space:nowrap;transition:background-color var(--transition-fast),color var(--transition-fast)}.dashboard__btn:hover{background-color:var(--color-surface-2);color:var(--color-text-primary)}.dashboard__btn--primary{background-color:var(--color-accent);color:var(--color-accent-text);border-color:var(--color-accent)}.dashboard__btn--primary:hover{background-color:var(--color-accent-hover);border-color:var(--color-accent-hover);color:var(--color-accent-text)}.dashboard__status{font-size:var(--text-sm);color:var(--color-text-tertiary);padding:var(--space-4) 0}.dashboard__status--error{color:var(--color-danger)}.dashboard__empty{font-size:var(--text-base);color:var(--color-text-tertiary);padding:var(--space-12) 0;text-align:center}.dashboard__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-4)}.song-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);cursor:pointer;display:flex;flex-direction:column;gap:var(--space-3);transition:border-color var(--transition-fast),background-color var(--transition-fast)}.song-card:hover{border-color:var(--color-border);background-color:var(--color-surface-2)}.song-card__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.song-card__title-group{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.song-card__title{font-size:var(--text-base);font-weight:var(--weight-medium);color:var(--color-text-primary);line-height:var(--leading-tight);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-card__menu{background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-secondary);font-size:var(--text-base);padding:0 var(--space-1);line-height:1;opacity:0;transition:opacity var(--transition-fast),color var(--transition-fast);flex-shrink:0}.song-card:hover .song-card__menu{opacity:1}.song-card__menu:hover,.song-card__menu:focus-visible{opacity:1;color:var(--color-text-primary);outline:2px solid var(--color-border);outline-offset:1px}.song-card__meta{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.song-card__avatars{display:flex}.song-card__avatars>.avatar+.avatar{margin-left:-5px}.song-card:hover .avatar{background-color:var(--color-surface-3)}[data-theme=dark] .song-card:hover .avatar{background-color:var(--color-surface-2)}.song-card__updated{font-size:var(--text-xs);color:var(--color-text-secondary)}.song-card__actions{display:flex;gap:var(--space-2);opacity:0;transition:opacity var(--transition-fast);margin-top:auto}.song-card:hover .song-card__actions{opacity:1}.song-card__action{background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);color:var(--color-text-secondary);font-family:var(--font-ui);padding:0;transition:color var(--transition-fast)}.song-card__action:hover{color:var(--color-text-primary)}.song-card__action:focus-visible{outline:2px solid var(--color-border);outline-offset:2px;color:var(--color-text-primary)}.song-card__action--danger:hover,.song-card__action--danger:focus-visible{color:var(--color-danger)}.song-card__clip-play{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--color-surface-2);border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast);padding:0;flex-shrink:0}.song-card__clip-play:hover{color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 10%,var(--color-surface-2));border-color:var(--color-accent)}.song-card__clip-play--active{color:var(--color-accent);border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 15%,var(--color-surface-2))}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);background-color:var(--color-scrim);display:flex;align-items:center;justify-content:center;padding:var(--space-6)}.modal{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:440px;display:flex;flex-direction:column;max-height:80vh;overflow:hidden}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0}.modal__title{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.modal__close{background:none;border:none;cursor:pointer;color:var(--color-text-tertiary);font-size:var(--text-base);padding:var(--space-1);line-height:1;transition:color var(--transition-fast)}.modal__close:hover{color:var(--color-text-primary)}.settings-section{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-subtle);display:flex;flex-direction:column;gap:var(--space-3);overflow-y:auto}.settings-section:last-child{border-bottom:none}.settings-section__heading{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em}.settings-section__description{font-size:var(--text-sm);color:var(--color-text-secondary)}.settings-section__status{font-size:var(--text-sm);color:var(--color-text-tertiary)}.settings-section__btn{align-self:flex-start;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-family:var(--font-ui);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;border:1px solid var(--color-border);background-color:var(--color-surface-2);color:var(--color-text-secondary);transition:background-color var(--transition-fast),color var(--transition-fast)}.settings-section__btn:hover:not(:disabled){background-color:var(--color-surface-3);color:var(--color-text-primary)}.settings-section__btn:disabled{opacity:.5;cursor:not-allowed}.settings-section__btn--primary{background-color:var(--color-accent);color:var(--color-accent-text);border-color:var(--color-accent)}.settings-section__btn--primary:hover:not(:disabled){background-color:var(--color-accent-hover);border-color:var(--color-accent-hover)}.settings-section__btn--danger:hover:not(:disabled){background-color:var(--color-danger-subtle);color:var(--color-danger);border-color:var(--color-danger)}.settings-section__input,.settings-section__role-select{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-2);color:var(--color-text-primary);font-family:var(--font-ui);font-size:var(--text-sm);outline:none;transition:border-color var(--transition-fast)}.settings-section__input:focus,.settings-section__role-select:focus{border-color:var(--color-accent)}.settings-section__input{flex:1;min-width:0}.settings-section__inline-form,.settings-section__invite-form{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.settings-section__member{display:flex;align-items:center;gap:var(--space-2)}.settings-section__member-name{flex:1;font-size:var(--text-sm);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-section__member-role{font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:capitalize;flex-shrink:0}.settings-section__member-remove{background:none;border:none;cursor:pointer;font-size:var(--text-sm);color:var(--color-text-secondary);font-family:var(--font-ui);padding:0 var(--space-1);line-height:1;flex-shrink:0;transition:color var(--transition-fast)}.settings-section__member-remove:hover{color:var(--color-danger)}.settings-section__remove{background:none;border:none;cursor:pointer;font-size:var(--text-base);color:var(--color-text-tertiary);font-family:var(--font-ui);padding:0 var(--space-1);line-height:1;flex-shrink:0;transition:color var(--transition-fast)}.settings-section__remove:hover{color:var(--color-danger)}.settings-section__error{font-size:var(--text-xs);color:var(--color-danger)}.settings-section__hint{font-size:var(--text-xs);color:var(--color-text-tertiary)}.settings-section--danger{background-color:var(--color-danger-subtle)}.collaborator-row{display:flex;align-items:center;gap:var(--space-3)}.collaborator-row__name{flex:1;font-size:var(--text-sm);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.collaborator-row__role{font-size:var(--text-xs);color:var(--color-text-tertiary);text-transform:capitalize}.collaborator-row__remove{background:none;border:none;cursor:pointer;font-size:var(--text-xs);color:var(--color-text-tertiary);font-family:var(--font-ui);padding:0;transition:color var(--transition-fast);flex-shrink:0}.collaborator-row__remove:hover:not(:disabled){color:var(--color-danger)}.join-link{display:flex;gap:var(--space-2);align-items:center}.join-link__input{flex:1;min-width:0;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-2);color:var(--color-text-secondary);font-family:var(--font-mono);font-size:var(--text-xs);outline:none}.join-link__btn{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-family:var(--font-ui);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;border:1px solid var(--color-border);background-color:var(--color-surface-2);color:var(--color-text-secondary);white-space:nowrap;flex-shrink:0;transition:background-color var(--transition-fast),color var(--transition-fast)}.join-link__btn:hover:not(:disabled){background-color:var(--color-surface-3);color:var(--color-text-primary)}.join-link__btn--danger:hover:not(:disabled){color:var(--color-danger)}@media(max-width:768px){.app-header__actions,.app-header__updated-by{display:none}.app-header__song-title{flex:1;text-align:center}.app-sidebar{display:none;width:100%;border-right:none}.app-right-panel{display:none;width:100%;border-left:none}[data-mobile-tab=discussion] .app-right-panel[data-open=false]{width:100%;opacity:1;overflow-y:auto;pointer-events:auto}.app-editor,.app-editor__banner{display:none}[data-mobile-tab=sections] .app-sidebar,[data-mobile-tab=edit] .app-editor{display:flex}[data-mobile-tab=edit] .app-editor__scroll{padding-bottom:var(--mobile-tab-height)}[data-mobile-tab=discussion] .app-right-panel,[data-mobile-tab=tune] .app-editor{display:flex}[data-mobile-tab=tune] .app-editor__banner{display:block;flex:1;overflow-y:auto;border-bottom:none;padding-bottom:var(--mobile-tab-height)}[data-mobile-tab=tune] .app-editor__scroll,[data-mobile-tab=tune] .app-editor__footer{display:none}.mobile-tab-bar{position:fixed;bottom:0;left:0;right:0;height:var(--mobile-tab-height);padding-bottom:env(safe-area-inset-bottom);display:flex;align-items:center;justify-content:space-around;background-color:var(--color-surface);border-top:1px solid var(--color-border-subtle);z-index:var(--z-raised);-webkit-tap-highlight-color:transparent}.mobile-tab-bar__tab{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1;padding:var(--space-1) 0;background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color var(--transition-fast)}.mobile-tab-bar__tab--active{color:var(--color-accent)}.mobile-tab-bar__icon-wrap{position:relative;display:flex;align-items:center;justify-content:center}.mobile-tab-bar__unread{position:absolute;top:-2px;right:-6px}.mobile-tab-bar__label{font-family:var(--font-ui);font-size:var(--text-xs);line-height:1}.mobile-menu__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-overlay);background-color:var(--color-scrim)}.mobile-menu{position:fixed;bottom:var(--mobile-tab-height);left:0;right:0;z-index:var(--z-modal);background-color:var(--color-surface);border-top:1px solid var(--color-border-subtle);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:var(--space-4);padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:var(--space-3);max-height:60vh;overflow-y:auto}.mobile-menu__header{display:flex;align-items:center;justify-content:space-between}.mobile-menu__user{display:flex;align-items:center;gap:var(--space-2)}.mobile-menu__close{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;padding:var(--space-1);-webkit-tap-highlight-color:transparent}.mobile-menu__body{display:flex;flex-direction:column;gap:var(--space-2)}.mobile-menu__save-status{font-size:var(--text-xs);color:var(--color-text-tertiary);min-height:1em}}@media(min-width:769px){.mobile-tab-bar,.mobile-menu,.mobile-menu__backdrop{display:none}}.user-menu__trigger{display:flex;align-items:center;background:none;border:none;padding:0;cursor:pointer;border-radius:var(--radius-full);outline-offset:2px}.user-menu__trigger:focus-visible{outline:2px solid var(--color-accent)}.user-menu__name{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px;cursor:default;-webkit-user-select:none;user-select:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid transparent;font-family:var(--font-ui);font-size:var(--text-sm);font-weight:var(--weight-medium);line-height:1;cursor:pointer;white-space:nowrap;transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),opacity var(--transition-fast)}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn--sm{padding:var(--space-1) var(--space-2);font-size:var(--text-xs)}.btn--lg{padding:var(--space-3) var(--space-5);font-size:var(--text-base)}.btn--primary{background-color:var(--color-accent);color:var(--color-accent-text);border-color:var(--color-accent)}.btn--primary:hover:not(:disabled){background-color:var(--color-accent-hover);border-color:var(--color-accent-hover)}.btn--secondary{background-color:var(--color-surface-2);color:var(--color-text-secondary);border-color:var(--color-border)}.btn--secondary:hover:not(:disabled){background-color:var(--color-surface-3);color:var(--color-text-primary)}.btn--ghost{background-color:transparent;color:var(--color-text-secondary);border-color:transparent}.btn--ghost:hover:not(:disabled){background-color:var(--color-surface-2);color:var(--color-text-primary)}.btn--danger{background-color:var(--color-danger);color:var(--color-danger-text);border-color:var(--color-danger)}.btn--danger:hover:not(:disabled){background-color:var(--color-danger-hover);border-color:var(--color-danger-hover)}.btn--chrome{background-color:transparent;color:var(--color-text-secondary);border-color:transparent;opacity:var(--opacity-chrome);padding:var(--space-1)}.btn--chrome:hover:not(:disabled){opacity:var(--opacity-chrome-hover);background-color:var(--color-surface-2)}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);overflow:hidden;flex-shrink:0;background-color:var(--color-surface-2);color:var(--color-text-secondary);font-family:var(--font-ui);font-weight:var(--weight-semibold);-webkit-user-select:none;user-select:none;line-height:1}.avatar img{width:100%;height:100%;object-fit:cover;display:block}.avatar--overflow{background-color:var(--color-surface-3);color:var(--color-text-secondary);font-size:9px}.badge{display:inline-flex;align-items:center;padding:1px var(--space-2);border-radius:var(--radius-full);font-family:var(--font-ui);font-size:var(--text-xs);font-weight:var(--weight-medium);line-height:1.6;white-space:nowrap}.badge--default{background-color:var(--color-surface-2);color:var(--color-text-secondary)}.badge--accent{background-color:var(--color-accent-subtle);color:var(--color-accent)}.badge--danger{background-color:var(--color-danger-subtle);color:var(--color-danger)}.badge--dot{width:6px;height:6px;border-radius:var(--radius-full);background-color:var(--color-accent);padding:0}@keyframes spin{to{transform:rotate(360deg)}}.spinner{display:inline-block;border-radius:var(--radius-full);border:2px solid var(--color-border);border-top-color:var(--color-accent);animation:spin .7s linear infinite;flex-shrink:0}.spinner--sm{width:14px;height:14px}.spinner--md{width:20px;height:20px}.spinner--lg{width:28px;height:28px;border-width:3px}.toggle{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;-webkit-user-select:none;user-select:none}.toggle__input{position:absolute;width:1px;height:1px;margin:-1px;padding:0;border:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.toggle__track{position:relative;width:32px;height:18px;border-radius:var(--radius-full);background-color:var(--color-surface-3);border:1px solid var(--color-border);transition:background-color var(--transition-fast),border-color var(--transition-fast);flex-shrink:0}.toggle__track--checked{background-color:var(--color-accent);border-color:var(--color-accent)}.toggle__thumb{position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:var(--radius-full);background-color:var(--color-surface);transition:transform var(--transition-fast);box-shadow:0 1px 2px var(--color-scrim)}.toggle__track--checked .toggle__thumb{transform:translate(14px)}.toggle__label{font-size:var(--text-sm);color:var(--color-text-secondary)}.tab-list{display:flex;align-items:center;gap:2px;opacity:var(--opacity-chrome);transition:opacity var(--transition-fast)}.line-row:hover .tab-list,.tab-list:hover,.tab-list:focus-within{opacity:var(--opacity-chrome-hover)}.tab{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-sm);border:1px solid transparent;font-family:var(--font-ui);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--color-text-tertiary);background-color:transparent;cursor:pointer;white-space:nowrap;transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.tab:hover{color:var(--color-text-secondary);background-color:var(--color-surface-2)}.tab--active{color:var(--color-text-primary);background-color:var(--color-accent-subtle);border-color:var(--color-border-subtle)}.tab__chord-indicator{font-size:9px;color:var(--color-chord);line-height:1}.tab--add{color:var(--color-text-tertiary);font-size:var(--text-sm)}.tab--add:hover{color:var(--color-accent);background-color:var(--color-accent-subtle)}.popover-anchor{position:relative;display:inline-flex}.popover{position:fixed;z-index:var(--z-raised);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 4px 12px var(--color-scrim);min-width:120px;padding:var(--space-2) 0}.popover--chord{padding:var(--space-2) var(--space-3);min-width:100px}.popover__item{display:block;width:100%;padding:var(--space-2) var(--space-3);text-align:left;background:none;border:none;font-family:var(--font-ui);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.popover__item:hover{background-color:var(--color-surface-2);color:var(--color-text-primary)}.popover__item--danger:hover{color:var(--color-danger)}.popover__divider{height:1px;background-color:var(--color-border-subtle);margin:var(--space-1) 0}.theme-toggle{display:inline-flex;align-items:center;gap:var(--space-1);background:none;border:none;cursor:pointer;color:var(--color-text-tertiary);font-size:var(--text-sm);font-family:var(--font-ui);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);opacity:var(--opacity-chrome);transition:opacity var(--transition-fast),background-color var(--transition-fast)}.theme-toggle:hover{opacity:var(--opacity-chrome-hover);background-color:var(--color-surface-2)}.tooltip-wrapper{position:relative;display:inline-flex}.tooltip-wrapper:after{content:attr(data-tooltip);position:absolute;left:50%;transform:translate(-50%);background:var(--color-text-primary);color:var(--color-bg);font-family:var(--font-ui);font-size:var(--text-xs);font-weight:400;padding:4px 8px;border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--transition-fast);z-index:var(--z-tooltip)}.tooltip-wrapper--top:after{bottom:calc(100% + 6px)}.tooltip-wrapper--bottom:after{top:calc(100% + 6px)}.tooltip-wrapper:hover:after{opacity:1}.tooltip-wrapper--end:after{left:auto;right:0;transform:none}.toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-2);max-width:380px;pointer-events:none}.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);box-shadow:0 4px 16px var(--color-scrim);font-family:var(--font-ui);font-size:var(--text-sm);animation:toast-in .18s ease-out}@keyframes toast-in{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.toast--error{border-color:var(--color-danger);background:var(--color-danger-subtle)}.toast--success{border-color:var(--color-accent);background:var(--color-accent-subtle)}.toast__body{flex:1;min-width:0}.toast__message{color:var(--color-text-primary);font-weight:var(--weight-medium);line-height:var(--leading-tight)}.toast--error .toast__message{color:var(--color-danger)}.toast__detail{margin-top:var(--space-1);color:var(--color-text-secondary);font-size:var(--text-xs);line-height:var(--leading-normal);word-break:break-word}.toast__close{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast);flex-shrink:0}.toast__close:hover{color:var(--color-text-primary);background:var(--color-surface-3)}.meta-bar{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-6);margin-bottom:0;border:none;border-bottom:1px solid var(--color-border-subtle);border-radius:0;background:var(--color-surface);width:100%;box-sizing:border-box;justify-content:space-between}.meta-bar__field{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-1)}.meta-bar__label-row{display:flex;align-items:center;gap:var(--space-2);min-height:14px}.meta-bar__label{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.meta-bar__select{font-family:var(--font-ui);font-size:var(--text-sm);color:var(--color-text-primary);background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);padding:2px var(--space-2);cursor:pointer;outline:none;transition:border-color .15s,background .15s;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.meta-bar__select:hover,.meta-bar__select:focus{border-color:var(--color-border);background:var(--color-surface-2)}.meta-bar__bpm{display:flex;align-items:center;border:1px solid transparent;border-radius:var(--radius-sm);overflow:hidden;transition:border-color .15s}.meta-bar__bpm:focus-within,.meta-bar__bpm:hover{border-color:var(--color-border)}.meta-bar__stepper-btn{display:flex;align-items:center;justify-content:center;width:22px;height:24px;background:transparent;border:none;color:var(--color-text-secondary);font-size:var(--text-base);cursor:pointer;-webkit-user-select:none;user-select:none;line-height:1;padding:0;transition:color .1s,background .1s}.meta-bar__stepper-btn:hover{color:var(--color-text-primary);background:var(--color-surface-2)}.meta-bar__bpm-input{width:48px;font-family:var(--font-ui);font-size:var(--text-sm);color:var(--color-text-primary);background:transparent;border:none;outline:none;text-align:center;padding:2px 0;-moz-appearance:textfield}.meta-bar__bpm-input::-webkit-inner-spin-button,.meta-bar__bpm-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.meta-bar__bpm-input::placeholder{color:var(--color-text-tertiary)}.meta-bar__beat-dots{display:flex;align-items:center;gap:4px}.meta-bar__beat-dot{display:inline-block;width:5px;height:5px;border-radius:var(--radius-full);background:var(--color-border);transition:background .05s,transform .05s;flex-shrink:0}.meta-bar__beat-dot--downbeat{width:6px;height:6px}.meta-bar__beat-dot--active{background:var(--color-accent);transform:scale(1.35)}.meta-bar__beat-dot--downbeat.meta-bar__beat-dot--active{transform:scale(1.5)}.meta-bar__timesig{display:flex;align-items:center;gap:var(--space-2)}.meta-bar__timesig-custom{display:flex;align-items:center;gap:3px}.meta-bar__timesig-num{width:32px;font-family:var(--font-ui);font-size:var(--text-sm);color:var(--color-text-primary);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px 4px;text-align:center;outline:none;-moz-appearance:textfield}.meta-bar__timesig-num::-webkit-inner-spin-button,.meta-bar__timesig-num::-webkit-outer-spin-button{-webkit-appearance:none}.meta-bar__timesig-num:focus{border-color:var(--color-accent)}.meta-bar__timesig-slash{font-family:var(--font-ui);font-size:var(--text-sm);color:var(--color-text-tertiary);-webkit-user-select:none;user-select:none}.meta-bar__metronome-btn{display:flex;align-items:center;justify-content:center;width:22px;height:24px;margin-left:var(--space-1);background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-text-tertiary);cursor:pointer;transition:color .15s,background .15s,border-color .15s;padding:0;flex-shrink:0}.meta-bar__metronome-btn:hover{color:var(--color-text-primary);border-color:var(--color-border);background:var(--color-surface-2)}.meta-bar__metronome-btn--active{color:var(--color-accent);border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 10%,transparent)}.meta-bar__metronome-btn--active:hover{color:var(--color-accent);border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 18%,transparent)}.meta-bar__tuning{display:flex;align-items:center;gap:var(--space-2)}.meta-bar__custom-input{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-primary);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px var(--space-2);width:100px;outline:none}.meta-bar__custom-input:focus{border-color:var(--color-accent)}.meta-bar__divider{width:1px;align-self:stretch;background:var(--color-border);flex-shrink:0;margin:var(--space-1) 0}.section{margin-bottom:var(--space-6);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);position:relative}.section__header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3)}.section__label{font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-tertiary);flex:1}.section__label-input{font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;background:transparent;border:none;border-bottom:1px solid var(--color-border);color:var(--color-text-tertiary);outline:none;padding:0 0 1px;flex:1}.section__label-input:focus{border-bottom-color:var(--color-accent);color:var(--color-text-primary)}.section__actions{display:flex;gap:var(--space-1);opacity:0;transition:opacity var(--transition-base)}.section:hover .section__actions,.section:focus-within .section__actions{opacity:1}.section__scratch-toggle{display:flex;align-items:center;gap:var(--space-1);margin-top:var(--space-3);cursor:pointer;font-size:var(--text-xs);color:var(--color-text-tertiary);-webkit-user-select:none;user-select:none;width:fit-content}.section__scratch-toggle:hover{color:var(--color-text-secondary)}.section__scratch-area{margin-top:var(--space-2)}.drag-handle{opacity:0;cursor:grab;color:var(--color-text-tertiary);font-size:var(--text-sm);padding:0 var(--space-1);line-height:1;-webkit-user-select:none;user-select:none;touch-action:none;transition:opacity var(--transition-base);flex-shrink:0;align-self:center}.drag-handle:active{cursor:grabbing}.section__header .drag-handle{width:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.section:hover .section__header .drag-handle,.section:focus-within .section__header .drag-handle{opacity:1}.section__add-line{padding-left:20px}.sortable-line-row{display:flex;align-items:flex-start}.sortable-line-row>.line-drag-handle-cell{padding-top:var(--space-1);width:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sortable-line-row:hover .drag-handle,.sortable-line-row:focus-within .drag-handle{opacity:1}.sidebar-section-row{display:flex;align-items:center;gap:2px;width:100%}.sidebar-section-row:hover .drag-handle,.sidebar-section-row:focus-within .drag-handle{opacity:1}.line{margin-bottom:var(--space-3);position:relative}.line__content{position:relative;min-height:2rem}.line__actions{position:absolute;right:0;top:0;display:flex;gap:var(--space-1);opacity:0;transition:opacity var(--transition-base)}.line:hover .line__actions,.line:focus-within .line__actions{opacity:1}.variation-tabs{display:flex;align-items:center;gap:2px;flex-wrap:wrap;position:absolute;bottom:100%;left:0;z-index:var(--z-raised);opacity:0;padding:4px 6px 0;border-radius:var(--radius-sm) var(--radius-sm) 0 0;transition:opacity var(--transition-base),background var(--transition-base)}.line:hover .variation-tabs,.line:focus-within .variation-tabs{opacity:1;background:var(--color-surface-2)}.variation-tab{display:flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-sm) var(--radius-sm) 0 0;font-size:var(--text-xs);cursor:pointer;border:none;background:transparent;color:var(--color-text-secondary);transition:background var(--transition-base),color var(--transition-base)}.variation-tab:hover{background:var(--color-surface-3);color:var(--color-text-primary)}.variation-tab[aria-selected=true]{background:var(--color-surface);color:var(--color-text-primary);font-weight:500;box-shadow:0 -1px 0 0 var(--color-border) inset}.variation-tab__chord-indicator{color:var(--color-chord);font-size:10px;line-height:1}.variation-tab__delete{padding:1px 3px;background:transparent;border:none;color:var(--color-text-tertiary);font-size:9px;cursor:pointer;opacity:0;border-radius:var(--radius-sm);transition:opacity var(--transition-base),color var(--transition-base);line-height:1}.variation-tab-wrapper:hover .variation-tab__delete{opacity:1}.variation-tab__delete:hover{color:var(--color-danger)}.variation-tab__delete:disabled{cursor:not-allowed;color:var(--color-text-tertiary);opacity:0!important}.variation-tab__add{padding:2px 6px;background:transparent;color:var(--color-text-tertiary);border:1px dashed var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-xs);cursor:pointer}.variation-tab__add:hover{color:var(--color-text-secondary);border-color:var(--color-border-subtle)}.chord-line{display:flex;flex-wrap:wrap;align-items:flex-end;gap:0 .35em;padding:var(--space-1) 0;font-family:var(--font-lyric);line-height:1;min-height:2rem;cursor:pointer}.chord-line--has-chords{min-height:3rem}.chord-line:hover{background:color-mix(in srgb,var(--color-accent-subtle) 30%,transparent);border-radius:var(--radius-sm)}.chord-token{display:inline-flex;flex-direction:column;align-items:flex-start}.chord-token__symbol{font-size:var(--text-xs);font-weight:600;color:var(--color-chord);font-family:var(--font-ui);line-height:1.2;min-width:1ch;cursor:text}.chord-token__word{font-size:var(--text-lg);color:var(--color-text-primary);line-height:1.3;cursor:text}.chord-line--has-chords .chord-token--no-chord .chord-token__word{margin-top:calc(var(--text-xs) * 1.2)}.chord-token--hoverable:hover .chord-token__word{text-decoration:underline dotted var(--color-chord);cursor:pointer}.line-text-editor{width:100%;background:transparent;border:none;border-bottom:1px solid var(--color-accent);border-radius:0;padding:var(--space-1) 0;font-family:var(--font-lyric);font-size:var(--text-lg);color:var(--color-text-primary);outline:none;resize:none;line-height:1.5;min-height:2rem;overflow:hidden}.chord-input-popover{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-2) var(--space-3);min-width:180px}.chord-input-popover__suggestions{display:flex;flex-wrap:wrap;gap:var(--space-1)}.chord-input-popover__suggestion{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px var(--space-2);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:600;color:var(--color-text-secondary);cursor:pointer;transition:border-color var(--transition-base),color var(--transition-base)}.chord-input-popover__suggestion:hover{border-color:var(--color-accent);color:var(--color-accent)}.chord-input-popover__suggestion--active{border-color:var(--color-accent);color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 10%,transparent)}.chord-input-popover__row{display:flex;gap:var(--space-2);align-items:center}.chord-input-popover__input{flex:1;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--color-text-primary);outline:none}.chord-input-popover__input:focus{border-color:var(--color-accent)}.chord-input-popover__remove{background:transparent;border:none;padding:0;font-size:var(--text-xs);color:var(--color-text-tertiary);cursor:pointer;text-align:left;transition:color var(--transition-base)}.chord-input-popover__remove:hover{color:var(--color-danger)}.scratch-pad{background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);padding:var(--space-3)}.scratch-pad__label{font-size:var(--text-xs);color:var(--color-text-tertiary);margin-bottom:var(--space-2);font-style:italic}.scratch-pad__textarea{width:100%;background:transparent;border:none;color:var(--color-text-secondary);font-family:var(--font-ui);font-size:var(--text-sm);line-height:1.5;outline:none;resize:none;min-height:4rem}.variation-right-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.variation-right-panel__comments{flex:1;overflow-y:auto;min-height:0}.variation-right-panel__notes{flex-shrink:0;border-top:1px solid var(--color-border)}.variation-right-panel__empty{padding:var(--space-4);color:var(--color-text-tertiary);font-size:var(--text-sm)}.variation-notes{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.variation-notes__heading{font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary)}.variation-notes__private-label{font-size:var(--text-xs);color:var(--color-text-tertiary);font-style:italic}.variation-notes__textarea{width:100%;background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);padding:var(--space-3);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--color-text-primary);resize:none;outline:none;line-height:1.5;min-height:8rem}.variation-notes__textarea:focus{border-color:var(--color-accent)}.variation-notes__tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.variation-notes__tag{font-size:var(--text-xs);padding:2px 8px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-base),color var(--transition-base)}.variation-notes__tag:hover{background:var(--color-surface-2)}.variation-notes__tag[aria-pressed=true]{background:var(--color-accent-subtle);color:var(--color-accent-text);border-color:var(--color-accent)}.song-editor{padding:var(--space-4) var(--space-6);max-width:720px;margin:0 auto}.song-editor__add-section{margin-top:var(--space-6);text-align:center}.viewer-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full, 999px);border:1px solid var(--color-border);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--color-text-secondary);background:transparent;white-space:nowrap;-webkit-user-select:none;user-select:none}.save-indicator{font-size:var(--text-xs);color:var(--color-text-tertiary);min-width:6ch;text-align:center}.save-indicator--saving{color:var(--color-text-secondary)}.save-indicator--saved{color:var(--color-text-tertiary)}.comment-input{display:flex;flex-direction:column;gap:var(--space-2)}.comment-input__textarea{width:100%;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--color-text-primary);outline:none;resize:none;line-height:1.5;min-height:3.5rem}.comment-input__textarea:focus{border-color:var(--color-accent)}.comment-input__textarea::placeholder{color:var(--color-text-tertiary)}.comment-input__actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2)}.comment-input__record-btn{background:transparent;border:none;padding:4px;cursor:pointer;color:var(--color-text-tertiary);display:flex;align-items:center;transition:color var(--transition-base)}.comment-input__record-btn:hover:not(:disabled){color:var(--color-accent)}.comment-input__record-btn:disabled{opacity:.4;cursor:default}.comment-thread{display:flex;flex-direction:column;gap:var(--space-3)}.comment-thread__empty{font-size:var(--text-sm);color:var(--color-text-tertiary);font-style:italic;text-align:center;padding:var(--space-3) 0}.comment-thread__resolve-row{display:flex;justify-content:flex-end;margin-bottom:var(--space-1)}.comment-thread__resolve-btn--resolved{color:var(--color-text-tertiary);text-decoration:line-through}.comment-thread__comment{display:flex;flex-direction:column;gap:var(--space-1)}.comment-thread__header{display:flex;align-items:center;gap:var(--space-1)}.comment-thread__author{font-size:var(--text-xs);font-weight:600;color:var(--color-text-primary);flex:1}.comment-thread__time{font-size:var(--text-xs);color:var(--color-text-tertiary)}.comment-thread__delete{background:transparent;border:none;font-size:9px;color:var(--color-text-tertiary);cursor:pointer;padding:1px 3px;border-radius:var(--radius-sm);opacity:0;transition:opacity var(--transition-base),color var(--transition-base);line-height:1}.comment-thread__comment:hover .comment-thread__delete,.comment-thread__reply:hover .comment-thread__delete{opacity:1}.comment-thread__delete:hover{color:var(--color-danger)}.comment-thread__body{font-size:var(--text-sm);color:var(--color-text-primary);line-height:1.5;margin:0;white-space:pre-wrap;word-break:break-word}.comment-thread__replies{padding-left:var(--space-4);border-left:2px solid var(--color-border-subtle);display:flex;flex-direction:column;gap:var(--space-2)}.comment-thread__reply{display:flex;flex-direction:column;gap:var(--space-1)}.comment-thread__reply-btn{font-size:var(--text-xs);color:var(--color-text-tertiary);background:transparent;border:none;cursor:pointer;padding:0;text-align:left;width:fit-content;transition:color var(--transition-base)}.comment-thread__reply-btn:hover{color:var(--color-accent)}.comment-thread__reply-input{display:flex;flex-direction:column;gap:var(--space-1)}.discussion-feed{display:flex;flex-direction:column;height:100%;overflow:hidden}.discussion-feed__heading{flex-shrink:0;display:flex;flex-direction:column;gap:2px;padding:var(--space-4) var(--space-4) var(--space-3);border-bottom:1px solid var(--color-border-subtle)}.discussion-feed__title{font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary)}.discussion-feed__subtitle{font-size:var(--text-xs);color:var(--color-text-tertiary)}.discussion-feed__items{flex:1;overflow-y:auto;min-height:0;display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3) var(--space-4)}.discussion-feed__empty{font-size:var(--text-sm);color:var(--color-text-tertiary);font-style:italic;text-align:center;margin-top:var(--space-4)}.discussion-feed__song-comment{display:flex;gap:var(--space-2);padding:var(--space-2) 0}.discussion-feed__song-comment-body{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.discussion-feed__song-comment-meta{display:flex;align-items:center;gap:var(--space-2)}.discussion-feed__author{font-size:var(--text-xs);font-weight:600;color:var(--color-text-primary)}.discussion-feed__time{font-size:var(--text-xs);color:var(--color-text-tertiary)}.discussion-feed__delete-btn{margin-left:auto;background:transparent;border:none;padding:0 2px;font-size:14px;line-height:1;color:var(--color-text-tertiary);cursor:pointer;opacity:0;transition:opacity var(--transition-base),color var(--transition-base)}.discussion-feed__song-comment:hover .discussion-feed__delete-btn{opacity:1}.discussion-feed__delete-btn:hover{color:var(--color-danger)}.discussion-feed__comment-text{font-size:var(--text-sm);color:var(--color-text-primary);line-height:1.45;word-break:break-word;margin:0}.discussion-feed__reply{display:flex;gap:var(--space-2);margin-top:var(--space-1);padding-left:var(--space-3);border-left:2px solid var(--color-border-subtle)}.discussion-feed__reply-body{display:flex;flex-wrap:wrap;align-items:center;gap:4px;flex:1;min-width:0}.discussion-feed__reply-body .discussion-feed__comment-text{width:100%}.discussion-feed__variation-thread{display:flex;flex-direction:column;gap:var(--space-1);width:100%;text-align:left;background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);padding:var(--space-3);cursor:pointer;transition:background var(--transition-base),border-color var(--transition-base)}.discussion-feed__variation-thread:hover{background:var(--color-surface-3);border-color:var(--color-border)}.discussion-feed__variation-context{display:flex;flex-direction:column;gap:2px}.discussion-feed__variation-label{font-size:var(--text-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.discussion-feed__lyric-snippet{font-size:var(--text-xs);color:var(--color-text-tertiary);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.discussion-feed__variation-preview{display:flex;align-items:center;gap:var(--space-2)}.discussion-feed__variation-comment-text{font-size:var(--text-sm);color:var(--color-text-primary);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.discussion-feed__variation-arrow{flex-shrink:0;color:var(--color-text-tertiary)}.discussion-feed__variation-meta{display:flex;gap:var(--space-3)}.discussion-feed__thread-count{font-size:var(--text-xs);color:var(--color-text-tertiary)}.discussion-feed__new-comment{flex-shrink:0;padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border-subtle)}.song-comment-panel{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);height:100%;overflow-y:auto}.song-comment-panel__heading{display:flex;flex-direction:column;gap:2px;border-bottom:1px solid var(--color-border-subtle);padding-bottom:var(--space-2)}.song-comment-panel__title{font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary)}.song-comment-panel__subtitle{font-size:var(--text-xs);color:var(--color-text-tertiary)}.song-comment-panel__new-comment{margin-top:auto;padding-top:var(--space-3);border-top:1px solid var(--color-border-subtle)}.variation-comment-popover{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-3)}.variation-comment-popover__heading{border-bottom:1px solid var(--color-border-subtle);padding-bottom:var(--space-2);display:flex;flex-direction:column;gap:var(--space-1)}.variation-comment-popover__back{display:inline-flex;align-items:center;gap:4px;background:transparent;border:none;padding:0;font-size:var(--text-xs);color:var(--color-text-tertiary);cursor:pointer;transition:color var(--transition-base)}.variation-comment-popover__back:hover{color:var(--color-text-secondary)}.variation-comment-popover__title{font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary)}.variation-comment-popover__empty{font-size:var(--text-sm);color:var(--color-text-tertiary);font-style:italic;text-align:center;padding:var(--space-2) 0}.variation-comment-popover__thread{padding:var(--space-2);background:var(--color-surface-2);border-radius:var(--radius-sm);border:1px solid var(--color-border-subtle)}.variation-comment-popover__thread--resolved{opacity:.6}.variation-comment-popover__show-resolved{font-size:var(--text-xs);color:var(--color-text-tertiary);background:transparent;border:none;cursor:pointer;padding:0;text-align:left;transition:color var(--transition-base)}.variation-comment-popover__show-resolved:hover{color:var(--color-text-secondary)}.variation-comment-popover__new-thread{border-top:1px solid var(--color-border-subtle);padding-top:var(--space-2)}.variation-comment-popover__new-thread-label{font-size:var(--text-xs);color:var(--color-text-tertiary);margin-bottom:var(--space-1)}.sync-banner{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);background:var(--color-accent-subtle);border:1px solid var(--color-accent);border-radius:var(--radius-sm);font-size:var(--text-xs)}.sync-banner__message{flex:1;color:var(--color-accent-text);font-weight:500}.snapshot-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,var(--color-scrim) 40%,transparent);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.snapshot-modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:400px;max-width:calc(100vw - var(--space-8));box-shadow:0 8px 32px color-mix(in srgb,var(--color-scrim) 20%,transparent)}.snapshot-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-4) 0}.snapshot-modal__title{font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary)}.snapshot-modal__body{padding:var(--space-3) var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.snapshot-modal__label{font-size:var(--text-xs);font-weight:600;color:var(--color-text-secondary)}.snapshot-modal__optional{font-weight:400;color:var(--color-text-tertiary)}.snapshot-modal__input{width:100%;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--color-text-primary);outline:none}.snapshot-modal__input:focus{border-color:var(--color-accent)}.snapshot-modal__hint{font-size:var(--text-xs);color:var(--color-text-tertiary);margin:0;line-height:1.4}.snapshot-modal__footer{display:flex;justify-content:flex-end;gap:var(--space-2);padding:var(--space-3) var(--space-4) var(--space-4);border-top:1px solid var(--color-border-subtle)}.snapshot-modal__error{padding:0 var(--space-4) var(--space-3);font-size:var(--text-xs);color:var(--color-danger);margin:0}.history-panel{display:flex;flex-direction:column;height:100%;background:var(--color-surface)}.history-panel__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0}.history-panel__title{font-size:var(--text-base);font-weight:600;color:var(--color-text-primary)}.history-panel__body{display:flex;flex:1;overflow:hidden}.history-panel__list{width:280px;flex-shrink:0;border-right:1px solid var(--color-border);overflow-y:auto;padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-1)}.history-panel__loading,.history-panel__preview-loading{display:flex;justify-content:center;padding:var(--space-6)}.history-panel__error,.history-panel__empty{font-size:var(--text-sm);color:var(--color-text-tertiary);text-align:center;padding:var(--space-4);font-style:italic}.history-panel__preview{flex:1;overflow-y:auto;padding:var(--space-4) var(--space-6)}.history-panel__preview-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-tertiary);font-size:var(--text-sm);font-style:italic}.history-item{display:flex;flex-direction:column;gap:2px;width:100%;text-align:left;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);cursor:pointer;transition:background var(--transition-base),border-color var(--transition-base)}.history-item:hover{background:var(--color-surface-2)}.history-item--selected{background:var(--color-accent-subtle);border-color:var(--color-accent)}.history-item--auto-save{opacity:.55}.history-item--auto-save:hover,.history-item--auto-save.history-item--selected{opacity:.8}.history-item__meta{display:flex;align-items:center;gap:var(--space-2)}.history-item__label{font-size:var(--text-xs);font-weight:500;color:var(--color-text-primary);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-item__auto-save-label{color:var(--color-text-secondary)}.history-item__untitled{color:var(--color-text-tertiary)}.history-item__auto-badge{flex-shrink:0}.history-item__date{font-size:10px;color:var(--color-text-tertiary);flex-shrink:0}.history-item__by{font-size:10px;color:var(--color-text-tertiary)}.snapshot-preview{display:flex;flex-direction:column;gap:var(--space-4)}.snapshot-preview__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-subtle)}.snapshot-preview__meta{display:flex;flex-direction:column;gap:2px}.snapshot-preview__label{font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary)}.snapshot-preview__byline{font-size:var(--text-xs);color:var(--color-text-tertiary)}.snapshot-preview__actions{display:flex;gap:var(--space-2);flex-shrink:0}.snapshot-preview__diff{display:flex;flex-direction:column;gap:var(--space-3)}.snapshot-preview__no-diff{font-size:var(--text-sm);color:var(--color-text-tertiary);font-style:italic;text-align:center;padding:var(--space-6)}.diff-section{border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);border:1px solid var(--color-border-subtle)}.diff-section--added{background:color-mix(in srgb,var(--color-diff-added-bg) 60%,transparent);border-color:var(--color-diff-added-border)}.diff-section--removed{background:color-mix(in srgb,var(--color-diff-removed-bg) 60%,transparent);border-color:var(--color-diff-removed-border)}.diff-section--modified{background:var(--color-surface-2);border-color:var(--color-border)}.diff-section--unchanged{background:transparent;opacity:.6}.diff-section__label{font-size:var(--text-xs);font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:var(--space-2);display:flex;align-items:center;gap:var(--space-1)}.diff-section__status-icon{font-size:10px;color:var(--color-text-tertiary)}.diff-section__lines{display:flex;flex-direction:column;gap:var(--space-1)}.diff-line{font-family:var(--font-lyric);font-size:var(--text-base);padding:2px var(--space-1);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:2px}.diff-line__before{color:var(--color-diff-removed-text);text-decoration:line-through;opacity:.85}.diff-line__after{color:var(--color-diff-added-text)}.diff-line__unchanged{color:var(--color-text-secondary)}.diff-line--added{background:color-mix(in srgb,var(--color-diff-added-bg) 30%,transparent)}.diff-line--removed{background:color-mix(in srgb,var(--color-diff-removed-bg) 30%,transparent)}.restore-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,var(--color-scrim) 40%,transparent);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.restore-confirm-dialog{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-6);max-width:380px;width:calc(100vw - var(--space-8));display:flex;flex-direction:column;gap:var(--space-3);box-shadow:0 8px 32px color-mix(in srgb,var(--color-scrim) 20%,transparent)}.restore-confirm-dialog__title{font-size:var(--text-base);font-weight:600;color:var(--color-text-primary);margin:0}.restore-confirm-dialog__body{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.5;margin:0}.restore-confirm-dialog__actions{display:flex;justify-content:flex-end;gap:var(--space-2)}.song-scratch-footer{background:var(--color-surface);border-top:1px solid var(--color-border-subtle);flex-shrink:0}.song-scratch-footer__toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-2) var(--space-4);background:transparent;border:none;cursor:pointer;color:var(--color-text-tertiary);font-size:var(--text-xs);font-family:var(--font-ui);gap:var(--space-2);transition:color var(--transition-base)}.song-scratch-footer__toggle:hover{color:var(--color-text-secondary)}.song-scratch-footer__toggle-label{font-weight:500;letter-spacing:.04em;text-transform:uppercase}.song-scratch-footer__toggle-arrow{font-size:10px}.song-scratch-footer__body{padding:0 var(--space-4) var(--space-4)}.song-scratch-footer__textarea{width:100%;background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);padding:var(--space-3);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--color-text-primary);resize:none;outline:none;line-height:1.5;min-height:6rem}.song-scratch-footer__textarea:focus{border-color:var(--color-accent)}.song-scratch-footer__textarea::placeholder{color:var(--color-text-tertiary)}.export-menu{position:relative;display:inline-flex;align-items:center}.audio-clip{display:flex;gap:var(--space-2);padding:var(--space-2);background:var(--color-surface-2);border-radius:var(--radius-sm);border:1px solid var(--color-border-subtle)}.audio-clip__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.audio-clip__meta{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.audio-clip__author{font-size:var(--text-xs);font-weight:600;color:var(--color-text-primary)}.audio-clip__title{font-size:var(--text-xs);color:var(--color-text-secondary);font-style:italic}.audio-clip__duration{display:flex;align-items:center;gap:3px;font-size:var(--text-xs);color:var(--color-text-tertiary)}.audio-clip__controls{display:flex;align-items:center;gap:var(--space-2)}.audio-clip__play-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--color-accent);border:none;color:#fff;cursor:pointer;transition:opacity var(--transition-base)}.audio-clip__play-btn:disabled{opacity:.5;cursor:default}.audio-clip__play-btn:hover:not(:disabled){opacity:.85}.audio-clip__pin-btn,.audio-clip__delete-btn{background:transparent;border:none;padding:2px;cursor:pointer;color:var(--color-text-tertiary);transition:color var(--transition-base);display:flex;align-items:center}.audio-clip__pin-btn:hover,.audio-clip__pin-btn--active{color:var(--color-accent)}.audio-clip__delete-btn:hover{color:var(--color-danger)}.audio-clip--compact{background:transparent;border:none;padding:var(--space-1) 0;display:flex;align-items:center;gap:var(--space-2)}.audio-clip--compact .audio-clip__play-btn{width:22px;height:22px}.audio-clip--compact .audio-clip__duration{font-size:var(--text-xs)}.variation-pinned-clip{padding:var(--space-2) var(--space-3);background:color-mix(in srgb,var(--color-accent) 8%,transparent);border-bottom:1px solid var(--color-border-subtle)}.variation-pinned-clip__label{font-size:var(--text-xs);font-weight:600;color:var(--color-accent);margin-bottom:var(--space-1);display:flex;align-items:center;gap:4px}.variation-audio-clips{padding:var(--space-2) var(--space-3);border-top:1px solid var(--color-border-subtle);display:flex;flex-direction:column;gap:var(--space-2)}.variation-audio-clips__heading{display:flex;align-items:center;justify-content:space-between}.variation-audio-clips__title{font-size:var(--text-xs);font-weight:600;color:var(--color-text-secondary);display:flex;align-items:center;gap:4px}.variation-audio-clips__add-btn{background:transparent;border:none;font-size:var(--text-xs);color:var(--color-accent);cursor:pointer;display:flex;align-items:center;gap:3px;padding:2px 4px;border-radius:var(--radius-sm);transition:background var(--transition-base)}.variation-audio-clips__add-btn:hover{background:var(--color-surface-2)}.variation-comment-popover__thread-clip{margin-bottom:var(--space-2)}.audio-recorder{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:var(--color-surface-2);border-radius:var(--radius-sm);border:1px solid var(--color-border-subtle);flex-wrap:wrap}.audio-recorder__start-btn{display:flex;align-items:center;gap:4px;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:4px 10px;font-size:var(--text-sm);cursor:pointer;transition:opacity var(--transition-base)}.audio-recorder__start-btn:hover{opacity:.85}.audio-recorder__cancel-link{background:transparent;border:none;font-size:var(--text-xs);color:var(--color-text-tertiary);cursor:pointer;transition:color var(--transition-base)}.audio-recorder__cancel-link:hover{color:var(--color-text-secondary)}.audio-recorder__error{font-size:var(--text-xs);color:var(--color-danger)}.audio-recorder__status{font-size:var(--text-sm);color:var(--color-text-secondary)}.audio-recorder__dot{width:8px;height:8px;border-radius:50%;background:var(--color-danger);animation:audio-pulse 1s ease-in-out infinite;flex-shrink:0}@keyframes audio-pulse{0%,to{opacity:1}50%{opacity:.3}}.audio-recorder__timer{font-size:var(--text-sm);font-variant-numeric:tabular-nums;color:var(--color-text-primary);min-width:3ch}.audio-recorder__stop-btn{display:flex;align-items:center;gap:4px;background:var(--color-danger);color:#fff;border:none;border-radius:var(--radius-sm);padding:3px 8px;font-size:var(--text-xs);cursor:pointer}.audio-recorder__title-input{flex:1;min-width:0;background:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);padding:4px 8px;font-size:var(--text-sm);color:var(--color-text-primary);font-family:var(--font-ui);outline:none;width:100%}.audio-recorder__title-input:focus{border-color:var(--color-accent)}.audio-recorder__stopped-actions{display:flex;align-items:center;gap:var(--space-2);width:100%}.audio-recorder__confirm-btn{background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:4px 12px;font-size:var(--text-sm);cursor:pointer;transition:opacity var(--transition-base)}.audio-recorder__confirm-btn:disabled{opacity:.6;cursor:default}.variation-comment-popover__thread-mode{display:flex;gap:var(--space-1);margin-bottom:var(--space-2)}.variation-comment-popover__mode-btn{display:flex;align-items:center;gap:4px;background:transparent;border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);padding:3px 8px;font-size:var(--text-xs);cursor:pointer;color:var(--color-text-secondary);transition:background var(--transition-base),border-color var(--transition-base),color var(--transition-base)}.variation-comment-popover__mode-btn--active{background:var(--color-surface-2);border-color:var(--color-accent);color:var(--color-accent)}.meta-bar__ref-clip{display:flex;align-items:center;gap:var(--space-1)}.meta-bar__ref-clip-btn{display:flex;align-items:center;justify-content:center;width:22px;height:24px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-text-tertiary);cursor:pointer;transition:color .15s,background .15s,border-color .15s;padding:0;flex-shrink:0}.meta-bar__ref-clip-btn:hover{color:var(--color-text-primary);border-color:var(--color-border);background:var(--color-surface-2)}.meta-bar__ref-clip-btn:disabled{opacity:.5;cursor:default}.meta-bar__ref-clip-btn--active{color:var(--color-accent);border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 10%,transparent)}.meta-bar__ref-clip-btn--active:hover{color:var(--color-accent);border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 18%,transparent)}.meta-bar__ref-clip-btn--danger:hover{color:var(--color-danger);border-color:var(--color-danger);background:color-mix(in srgb,var(--color-danger) 10%,transparent)}.meta-bar__ref-clip-duration{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-tertiary);-webkit-user-select:none;user-select:none;min-width:28px;text-align:right}.meta-bar__ref-clip--has-clip .meta-bar__ref-clip-duration{color:var(--color-text-primary)}.meta-bar__ref-clip--has-clip .meta-bar__ref-clip-btn:not(.meta-bar__ref-clip-btn--active):not(.meta-bar__ref-clip-btn--danger){color:var(--color-text-primary)}@keyframes ref-clip-spin{to{transform:rotate(360deg)}}.meta-bar__ref-clip-spinner{display:block;width:10px;height:10px;border:1.5px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:ref-clip-spin .7s linear infinite}.meta-bar__ref-clip--recording{display:flex;align-items:center;gap:var(--space-1)}@keyframes ref-clip-pulse{0%,to{opacity:1}50%{opacity:.3}}.meta-bar__ref-clip-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--color-danger);animation:ref-clip-pulse 1s ease-in-out infinite;flex-shrink:0}.meta-bar__ref-clip-status{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary);-webkit-user-select:none;user-select:none}.meta-bar__ref-clip-cancel{background:none;border:none;padding:0;font-size:var(--text-xs);color:var(--color-text-tertiary);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.meta-bar__ref-clip-cancel:hover{color:var(--color-text-secondary)}.audio-clip__loop-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-text-tertiary);cursor:pointer;padding:0;transition:color .15s,background .15s,border-color .15s;flex-shrink:0}.audio-clip__loop-btn:hover{color:var(--color-text-primary);border-color:var(--color-border);background:var(--color-surface-2)}.audio-clip__loop-btn--active{color:var(--color-accent);border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 10%,transparent)}.audio-clip__loop-btn--active:hover{background:color-mix(in srgb,var(--color-accent) 18%,transparent)}.paste-indicator{display:flex;align-items:center;gap:6px;padding:4px 8px 4px 20px;font-size:var(--text-xs);color:var(--color-text-tertiary)}.paste-indicator__dots{display:flex;gap:3px}.paste-indicator__dots span{display:inline-block;width:4px;height:4px;border-radius:50%;background:currentColor;animation:paste-bounce .6s ease-in-out infinite alternate backwards}.paste-indicator__dots span:nth-child(2){animation-delay:.2s}.paste-indicator__dots span:nth-child(3){animation-delay:.4s}@keyframes paste-bounce{0%{transform:translateY(0);opacity:.4}to{transform:translateY(-4px);opacity:1}}@media(prefers-reduced-motion:reduce){.paste-indicator__dots span{animation:none;opacity:.7}}@media(max-width:768px){[data-mobile-tab=tune] .meta-bar{flex-direction:column;align-items:stretch;gap:var(--space-4);padding:var(--space-4)}[data-mobile-tab=tune] .meta-bar__field,[data-mobile-tab=tune] .meta-bar__select,[data-mobile-tab=tune] .meta-bar__bpm{width:100%}}.chord-shapes-panel{display:flex;flex-direction:column;padding:8px 20px 0;border-bottom:1px solid var(--color-border-subtle);background:var(--color-surface)}.chord-shapes-panel--collapsed{padding-bottom:8px}.chord-shapes-panel__toggle{display:flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;padding:0;color:var(--color-text-tertiary)}.chord-shapes-panel__toggle:hover{color:var(--color-text-secondary)}.chord-shapes-panel__toggle-label{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.06em;line-height:1}.chord-shapes-panel__chevron{transition:transform .2s ease;flex-shrink:0}.chord-shapes-panel--collapsed .chord-shapes-panel__chevron{transform:rotate(-90deg)}.chord-shapes-panel__count{background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:10px;font-size:10px;padding:1px 6px;color:var(--color-text-secondary);line-height:1.4}.chord-shapes-panel__body{display:flex;align-items:flex-start;gap:16px;padding:10px 0 12px;overflow-x:auto;scrollbar-width:none}.chord-shapes-panel__body::-webkit-scrollbar{display:none}.chord-shapes-panel__card{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0;cursor:grab;border-radius:8px;padding:4px;transition:background .1s}.chord-shapes-panel__card:hover{background:var(--color-surface-2)}.chord-shapes-panel__card-name{color:var(--color-accent, #c8d8b0);font-size:13px;font-weight:600;letter-spacing:.02em}.chord-shapes-panel__card-actions{position:absolute;top:-6px;right:-6px;display:flex;gap:2px;opacity:0;transition:opacity .15s}.chord-shapes-panel__card:hover .chord-shapes-panel__card-actions{opacity:1}.chord-shapes-panel__card-btn{width:18px;height:18px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-surface-2);color:var(--color-text-secondary);font-size:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;line-height:1}.chord-shapes-panel__card-btn--delete:hover{background:var(--color-error-subtle, #5a1a1a);color:var(--color-error, #f87171);border-color:var(--color-error, #f87171)}.chord-shapes-panel__add-btn{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;background:none;border:none;cursor:pointer;color:var(--color-text-tertiary);padding:4px;align-self:center}.chord-shapes-panel__add-btn svg{width:36px;height:36px;border-radius:50%;border:1.5px dashed var(--color-border);padding:8px;box-sizing:border-box;transition:border-color .1s,color .1s}.chord-shapes-panel__add-btn:hover svg{border-color:var(--color-text-secondary);color:var(--color-text-secondary)}.chord-shapes-panel__add-btn span{font-size:10px}.chord-shape-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.chord-shape-modal{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:12px;width:400px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.chord-shape-modal__header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px 14px;border-bottom:1px solid var(--color-border-subtle);flex-shrink:0}.chord-shape-modal__title{font-size:15px;font-weight:600;color:var(--color-text-primary);margin:0}.chord-shape-modal__close{background:none;border:none;color:var(--color-text-tertiary);font-size:18px;cursor:pointer;line-height:1;padding:0}.chord-shape-modal__section{padding:14px 20px;border-bottom:1px solid var(--color-border-subtle)}.common-voicings-strip{width:100%}.common-voicings-strip__select{width:100%;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-secondary);font-size:13px;padding:8px 12px;cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.fretboard-editor{display:flex;flex-direction:column;align-items:center;gap:8px}.fretboard-editor__grid{display:flex;align-items:flex-start;gap:4px}.fretboard-editor__controls{display:flex;flex-direction:column;justify-content:space-between;height:196px;padding:44px 0 4px}.fretboard-editor__arrow{background:none;border:none;color:var(--color-text-tertiary);font-size:13px;cursor:pointer;padding:0;line-height:1}.fretboard-editor__arrow:disabled{opacity:.3;cursor:default}.fretboard-editor__hint{font-size:10px;color:var(--color-text-tertiary);margin:0;text-align:center}.chord-shape-modal__name-section{border-bottom:1px solid var(--color-border-subtle)}.chord-shape-modal__name-label{display:flex;align-items:center;gap:8px;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);margin-bottom:8px}.chord-shape-modal__name-hint{text-transform:none;letter-spacing:0;font-style:italic;color:var(--color-text-tertiary);opacity:.7}.chord-shape-modal__name-field{position:relative;display:flex;align-items:center}.chord-shape-modal__name-input{width:100%;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:10px 14px;font-size:22px;font-weight:700;color:var(--color-accent, #c8d8b0);letter-spacing:.02em}.chord-shape-modal__auto-badge{position:absolute;right:14px;font-size:11px;color:var(--color-text-tertiary)}.chord-shape-modal__actions{display:flex;gap:10px;justify-content:flex-end;padding:14px 20px 18px}.chord-shape-modal__cancel{background:none;border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-secondary);font-size:13px;padding:8px 18px;cursor:pointer}.chord-shape-modal__save{background:var(--color-accent, #7c9f5e);border:none;border-radius:8px;color:#fff;font-size:13px;font-weight:600;padding:8px 22px;cursor:pointer}.settings-shell{display:flex;min-height:100vh;background:var(--color-surface)}.settings-sidebar{width:220px;flex-shrink:0;border-right:1px solid var(--color-border);padding:var(--space-6) 0;background:var(--color-surface-2)}.settings-sidebar__title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em;padding:0 var(--space-4) var(--space-3)}.settings-sidebar__nav{display:flex;flex-direction:column;gap:2px;padding:0 var(--space-2)}.settings-sidebar__link{display:block;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--color-text-secondary);text-decoration:none;transition:background .1s,color .1s}.settings-sidebar__link:hover{background:var(--color-surface-3);color:var(--color-text-primary)}.settings-sidebar__link[aria-current=page]{background:var(--color-surface-3);color:var(--color-text-primary);font-weight:var(--weight-medium)}.settings-content{flex:1;max-width:680px;padding:var(--space-8) var(--space-8)}.settings-content__heading{font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-6)}.notif-section-label{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin:var(--space-6) 0 var(--space-3)}.notif-section-label:first-of-type{margin-top:0}.notif-card{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-2);margin-bottom:var(--space-2)}.notif-card__info{flex:1}.notif-card__title{font-size:var(--text-base);font-weight:var(--weight-medium);color:var(--color-text-primary);margin:0 0 var(--space-1)}.notif-card__desc{font-size:var(--text-sm);color:var(--color-text-tertiary);margin:0}.notif-card__controls{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-2);flex-shrink:0}.notif-delivery-select{font-size:var(--text-sm);padding:var(--space-1) var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-primary);cursor:pointer}.settings-divider{border:none;border-top:1px solid var(--color-border);margin:var(--space-6) 0}.settings-back{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);color:var(--color-text-tertiary);text-decoration:none;margin-bottom:var(--space-6)}.settings-back:hover{color:var(--color-text-primary)}.settings-section{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-2);padding:var(--space-6);margin-bottom:var(--space-4)}.settings-section__heading{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-5)}.settings-field{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-4)}.settings-field__label{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:var(--weight-medium)}.settings-input{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-primary);font-family:var(--font-ui);font-size:var(--text-base);outline:none;transition:border-color var(--transition-fast)}.settings-input:focus{border-color:var(--color-accent)}.settings-input[readonly]{opacity:.6;cursor:default}.settings-feedback{font-size:var(--text-sm);margin:var(--space-3) 0 0}.settings-feedback--success{color:var(--color-success)}.settings-feedback--error{color:var(--color-error)}.settings-avatar-row{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4)}.settings-avatar-hint{font-size:var(--text-xs);color:var(--color-text-tertiary);margin-top:var(--space-1)}.settings-provider-note{font-size:var(--text-sm);color:var(--color-text-tertiary);margin:0}[data-mode=focus] .section--inactive{opacity:var(--opacity-dimmed);transition:opacity var(--transition-slow)}[data-mode=focus] .section--active{opacity:1}[data-mode=focus] .app-sidebar{opacity:.7;transition:opacity var(--transition-base)}[data-mode=focus] .app-sidebar:hover,[data-mode=overview] .section--inactive,[data-mode=overview] .app-sidebar{opacity:1}[data-mode=history] .history-overlay{display:flex}[data-mode=history] .app-editor{filter:blur(3px);pointer-events:none;-webkit-user-select:none;user-select:none}[data-mode=history] .app-sidebar,[data-mode=history] .app-right-panel{opacity:.3;pointer-events:none}[data-distraction-free=true] .app-sidebar,[data-distraction-free=true] .app-right-panel,[data-distraction-free=true] .app-header__actions{display:none}.project-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast);display:flex;flex-direction:column;gap:var(--space-3)}.project-card:hover{border-color:var(--color-border);background-color:var(--color-surface-2)}.project-card__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.project-card__title{font-size:var(--text-base);font-weight:var(--weight-medium);color:var(--color-text-primary);line-height:1.3;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-card__menu{background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-secondary);font-size:var(--text-base);line-height:1;padding:0 var(--space-1);opacity:0;transition:opacity var(--transition-fast),color var(--transition-fast);flex-shrink:0}.project-card:hover .project-card__menu{opacity:1}.project-card__menu:hover,.project-card__menu:focus-visible{opacity:1;color:var(--color-text-primary);outline:2px solid var(--color-border);outline-offset:1px}.project-card__subtitle{display:flex;align-items:center;gap:var(--space-2)}.project-card__type-flag{font-size:var(--text-xs);color:var(--color-text-secondary);background:var(--color-surface-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:1px 6px;white-space:nowrap;line-height:1.6}.project-card__song-count{font-size:var(--text-xs);color:var(--color-text-secondary)}.project-card__meta{display:flex;justify-content:space-between;align-items:center}.project-card__avatars{display:flex}.project-card__avatars>.avatar+.avatar{margin-left:-5px}.project-card:hover .avatar{background-color:var(--color-surface-3)}[data-theme=dark] .project-card:hover .avatar,[data-theme=dark] .project-card:hover .project-card__type-flag{background-color:var(--color-surface-2)}.project-card__updated{font-size:var(--text-xs);color:var(--color-text-secondary)}.project-card__actions{display:flex;gap:var(--space-2);opacity:0;transition:opacity var(--transition-fast);margin-top:auto}.project-card:hover .project-card__actions{opacity:1}.project-card__action{background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);color:var(--color-text-secondary);font-family:var(--font-ui);padding:0;transition:color var(--transition-fast)}.project-card__action:hover{color:var(--color-text-primary)}.project-card__action:focus-visible{outline:2px solid var(--color-border);outline-offset:2px;color:var(--color-text-primary)}.project-card__action--danger:hover,.project-card__action--danger:focus-visible{color:var(--color-danger)}.project-page{min-height:100dvh;background-color:var(--color-bg);display:flex;flex-direction:column}.project-page-loading{min-height:100dvh;background-color:var(--color-bg);display:flex;align-items:center;justify-content:center}.project-page__content{max-width:900px;margin:0 auto;width:100%;padding:var(--space-8) var(--space-6)}.project-page__subheader{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-3)}.project-page__nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.project-page__back{font-size:var(--text-sm);color:var(--color-text-secondary);text-decoration:none}.project-page__back:hover{color:var(--color-text-primary)}.project-page__toolbar-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.project-page__title{font-size:var(--text-xl);font-weight:700;color:var(--color-text-primary);flex:1;min-width:0}.project-page__header-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.project-page__members{display:flex}.project-page__members>.avatar+.avatar{margin-left:-5px}.project-page__settings-btn{background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);cursor:pointer;color:var(--color-text-secondary);display:flex;align-items:center}.project-page__settings-btn:hover{color:var(--color-text-primary);border-color:var(--color-border-hover)}.project-page__view-toggle{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.project-page__view-btn{background:none;border:none;padding:var(--space-1) var(--space-2);cursor:pointer;color:var(--color-text-secondary);display:flex;align-items:center}.project-page__view-btn:hover{background:var(--color-surface-3)}.project-page__view-btn--active{background:var(--color-surface-3);color:var(--color-text-primary)}.project-page__main{display:flex;flex-direction:column;gap:var(--space-2)}.project-song-list{display:flex;flex-direction:column;gap:4px}.project-song-row{display:flex;align-items:center;gap:var(--space-2);padding:0 var(--space-3);min-height:52px;border-radius:var(--radius-lg);cursor:pointer;background:var(--color-surface);border:1px solid var(--color-border);transition:background var(--transition-fast);-webkit-user-select:none;user-select:none}.project-song-row:hover{background:var(--color-surface-2)}.project-song-row--dragging{opacity:.5}.project-song-row__drag-handle{color:var(--color-text-secondary);font-size:14px;cursor:grab;flex-shrink:0}.project-song-row__left{display:flex;align-items:center;gap:var(--space-2);flex:1;min-width:0;overflow:hidden}.project-song-row__title{font-size:var(--text-sm);font-weight:500;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-song-row__clip-play{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--color-surface-2);border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast);padding:0;flex-shrink:0}.project-song-row__clip-play:hover,.project-song-row__clip-play--active{color:var(--color-accent);border-color:var(--color-accent)}.project-song-row__actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2);flex-shrink:0;min-width:160px;opacity:0;pointer-events:none;transition:opacity var(--transition-fast)}.project-song-row:hover .project-song-row__actions{opacity:1;pointer-events:auto}.project-song-row__action{background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);color:var(--color-text-secondary);font-family:var(--font-ui);padding:0;transition:color var(--transition-fast)}.project-song-row__action:hover{color:var(--color-text-primary)}.project-song-row__action:focus-visible{outline:2px solid var(--color-border);outline-offset:2px;color:var(--color-text-primary)}.project-song-row__action--danger:hover,.project-song-row__action--danger:focus-visible{color:var(--color-danger)}.project-song-row__meta{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.project-song-row__avatars{display:flex}.project-song-row__avatars>.avatar+.avatar{margin-left:-5px}.project-song-row:hover .avatar{background-color:var(--color-surface-3)}[data-theme=dark] .project-song-row:hover .avatar{background-color:var(--color-surface-2)}.project-song-row__updated{font-size:var(--text-xs);color:var(--color-text-secondary);min-width:55px;text-align:right}.project-song-row__menu{background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-secondary);font-size:var(--text-base);padding:0 var(--space-1);line-height:1;opacity:0;transition:opacity var(--transition-fast),color var(--transition-fast);flex-shrink:0}.project-song-row:hover .project-song-row__menu{opacity:1}.project-song-row__menu:hover,.project-song-row__menu:focus-visible{color:var(--color-text-primary);outline:2px solid var(--color-border);outline-offset:1px}.dashboard__toolbar-actions{display:flex;gap:var(--space-2)}.project-page__add-song-picker{font-size:var(--text-sm);padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer}
