[data-testmode] *,[data-testmode] *:before,[data-testmode] *:after{animation-duration:0ms!important;transition-duration:0ms!important}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}:root{--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--bg-card: #242424;--bg-hover: #2a2a2a;--text-primary: #f5f5f5;--text-secondary: #a0a0a0;--text-muted: #666666;--accent: #f59e0b;--accent-hover: #d97706;--accent-muted: rgba(245, 158, 11, .15);--border: #333333;--shadow: rgba(0, 0, 0, .3);--font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "SF Mono", "Fira Code", "Consolas", monospace;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-card: #ffffff;--bg-hover: #f0f0f0;--text-primary: #1a1a1a;--text-secondary: #666666;--text-muted: #999999;--accent: #d97706;--accent-hover: #b45309;--accent-muted: rgba(217, 119, 6, .1);--border: #e0e0e0;--shadow: rgba(0, 0, 0, .1)}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;min-height:100dvh}#root,.app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.header{background-color:var(--bg-secondary);border-bottom:1px solid var(--border);padding:var(--spacing-md) var(--spacing-lg);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100}.header-actions{display:flex;align-items:center;gap:var(--spacing-md)}.header-logo{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.5rem;font-weight:700;color:var(--accent);cursor:pointer}.header-logo svg{width:28px;height:28px}.sidebar-backdrop{position:fixed;inset:0;background:#00000080;z-index:200}.sidebar{position:fixed;top:0;left:-300px;width:300px;height:100vh;height:100dvh;background-color:var(--bg-secondary);border-right:1px solid var(--border);z-index:201;display:flex;flex-direction:column;transition:left .25s ease;overflow-y:auto}.sidebar-open{left:0}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--border)}.sidebar-title{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.sidebar-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:color .2s}.sidebar-close-btn:hover{color:var(--text-primary)}.sidebar-profile{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg)}.sidebar-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover}.sidebar-avatar-placeholder{width:44px;height:44px;border-radius:50%;background-color:var(--bg-card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.sidebar-user-details{display:flex;flex-direction:column;min-width:0}.sidebar-user-name{font-weight:600;color:var(--text-primary);font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-email{font-size:.8rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-divider{height:1px;background-color:var(--border);margin:0 var(--spacing-lg)}.sidebar-section{padding:var(--spacing-sm) var(--spacing-md)}.sidebar-item{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md);background:none;border:none;border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;cursor:pointer;transition:background-color .2s}.sidebar-item:hover{background-color:var(--bg-hover)}.sidebar-footer{margin-top:auto;padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border)}.sidebar-footer-grid{display:grid;grid-template-columns:1fr 1fr;row-gap:var(--spacing-sm);column-gap:var(--spacing-sm)}.sidebar-link{font-size:.78rem;color:var(--text-muted);text-decoration:none;transition:color .2s}.sidebar-link:hover{color:var(--accent)}.sign-in-btn,.sign-out-btn{font-size:.9rem}.main{flex:1;padding:var(--spacing-lg);max-width:1200px;width:100%;margin:0 auto}.btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-primary{background-color:var(--accent);color:#000}.btn-primary:hover{background-color:var(--accent-hover)}.btn-secondary{background-color:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background-color:var(--bg-hover)}.btn-ghost{background:none;color:var(--text-secondary)}.btn-ghost:hover{background-color:var(--bg-hover);color:var(--text-primary)}.search-container{margin-bottom:var(--spacing-lg)}.search-input{width:100%;padding:var(--spacing-md);background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;transition:border-color .2s,box-shadow .2s}.search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}.search-input::placeholder{color:var(--text-muted)}.song-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.song-card{background-color:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--spacing-md);cursor:pointer;transition:all .2s}.song-card:hover{background-color:var(--bg-hover);border-color:var(--accent)}.song-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xs)}.song-title{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.song-key,.song-key-toggle{background-color:var(--accent-muted);color:var(--accent);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.song-key-toggle{border:none;cursor:pointer;transition:opacity .15s}.song-key-toggle--hidden{text-decoration:line-through;opacity:.5}.song-artist{color:var(--text-secondary);font-size:.875rem}.collaborators-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-lg);width:100%;max-width:480px;max-height:80vh;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-md)}.collaborators-modal-header{display:flex;align-items:center;justify-content:space-between}.collaborators-modal-header h3{margin:0;font-size:1.1rem}.collaborators-modal-close{background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--text-secondary);line-height:1;padding:0 var(--spacing-xs)}.collaborators-add-row{display:flex;gap:var(--spacing-sm)}.collaborators-add-row .collaborator-email-input{flex:1}.collaborator-error{color:#ef4444;font-size:.875rem;margin:0}.collaborators-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.collaborators-empty{color:var(--text-secondary);font-size:.875rem;text-align:center;padding:var(--spacing-md) 0}.collaborator-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border)}.collaborator-info{display:flex;flex-direction:column;gap:2px;min-width:0}.collaborator-name{font-weight:500;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.collaborator-email{font-size:.8rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.collaborator-remove-btn{flex-shrink:0;font-size:.8rem}.kebab-manage-collaborators-btn{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;cursor:pointer;color:var(--text-primary);font-size:.9rem;text-align:left;white-space:nowrap}.kebab-manage-collaborators-btn:hover{background:var(--bg-secondary);color:var(--accent)}.tag-input-wrapper{position:relative;width:100%}.tag-suggestions{position:absolute;top:calc(100% + 2px);left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);list-style:none;padding:var(--spacing-xs) 0;margin:0;z-index:200;box-shadow:0 4px 16px #00000026}.tag-suggestion-item{padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;font-size:.9rem;color:var(--text-primary);transition:background .1s,color .1s}.tag-suggestion-item:hover,.tag-suggestion-item--focused{background:var(--bg-primary);color:var(--accent)}.song-tags{display:flex;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.song-tag{background-color:var(--bg-secondary);color:var(--text-muted);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.75rem}.song-views{color:var(--text-muted);font-size:.75rem;margin-top:var(--spacing-sm)}.visibility-indicator{display:inline-block;width:8px;height:8px;border-radius:50%;margin-left:6px;vertical-align:middle;background-color:#6b7280}.visibility-indicator[data-visibility=public]{background-color:#22c55e}.visibility-indicator[data-visibility=private]{background-color:#6b7280}.visibility-select{max-width:200px}.song-card-actions{display:flex;justify-content:flex-end;align-items:center;margin-top:var(--spacing-sm)}.share-btn{font-size:.85rem}.share-panel{margin-top:var(--spacing-sm);padding:var(--spacing-sm);border:1px solid var(--border);border-radius:var(--radius-sm);background-color:var(--bg-secondary)}.share-panel-compact .share-link-input{width:100%}.share-label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:var(--spacing-xs)}.share-link-input{width:100%;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);border:1px solid var(--border);background-color:var(--bg-primary);color:var(--text-primary);font-size:.85rem}.song-view{max-width:820px;width:100%;margin:0 auto;padding-bottom:calc(64px + var(--spacing-xl))}@media(min-width:1400px){.song-view{max-width:980px}}@media(min-width:1800px){.song-view{max-width:1150px}}.song-view-header{margin-bottom:var(--spacing-xl)}.song-view-title-row{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.song-view-title{font-size:2rem;font-weight:700;margin-bottom:0;flex:1}.song-view-meta{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);color:var(--text-secondary);flex-wrap:wrap;margin-bottom:var(--spacing-xs)}.song-view-details{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;color:var(--text-secondary);font-size:.875rem}.share-icon-btn{padding:var(--spacing-xs)}.song-view-meta-separator{color:var(--text-muted)}.song-view-count{color:var(--text-muted);font-size:.85rem}.song-tempo-group{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;color:var(--text-secondary);background-color:var(--bg-card);border:1px solid var(--border);padding:2px var(--spacing-sm);border-radius:var(--radius-sm)}.song-view-actions{margin-top:1rem;display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.transpose-control{display:flex;flex-direction:column;align-items:center;background-color:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--spacing-xs);gap:2px}.transpose-btn{width:28px;height:20px;display:flex;align-items:center;justify-content:center;background-color:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.transpose-btn.transpose-up{border-radius:var(--radius-sm) var(--radius-sm) 0 0}.transpose-btn.transpose-down{border-radius:0 0 var(--radius-sm) var(--radius-sm)}.transpose-btn:hover{background-color:var(--accent);color:#000;border-color:var(--accent)}.transpose-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);padding:2px 4px;min-width:24px;text-align:center}.transpose-label.transpose-active{color:var(--accent);cursor:pointer}.transpose-label.transpose-active:hover{text-decoration:underline}.font-size-control{display:flex;flex-direction:column;align-items:center;background-color:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--spacing-xs);gap:2px}.font-size-btn{width:28px;height:20px;display:flex;align-items:center;justify-content:center;background-color:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.font-size-btn.font-size-up{border-radius:var(--radius-sm) var(--radius-sm) 0 0}.font-size-btn.font-size-down{border-radius:0 0 var(--radius-sm) var(--radius-sm)}.font-size-btn:hover:not(:disabled){background-color:var(--accent);color:#000;border-color:var(--accent)}.font-size-btn:disabled{opacity:.4;cursor:not-allowed}.font-size-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);padding:2px 0}.romanized-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.romanized-toggle:hover{background-color:var(--bg-card);color:var(--text-primary);border-color:var(--accent)}.romanized-toggle.active{background-color:var(--accent);color:#000;border-color:var(--accent)}.song-view-actions-left{display:flex;gap:var(--spacing-sm);align-items:center}.song-view-actions-right{display:flex;gap:var(--spacing-sm);align-items:center;margin-left:auto}.chord-editor{background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);min-height:300px}.chord-editor-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--border);font-size:.875rem;color:var(--text-secondary)}.chord-editor-header .btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem}.chord-editor-textarea{border:none;border-radius:0;min-height:250px}.chord-editor-actions{display:flex;gap:var(--spacing-sm);padding:var(--spacing-md);border-top:1px solid var(--border)}.chord-editor-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;cursor:pointer;color:var(--text-secondary);transition:background-color .2s}.chord-editor-empty:hover{background-color:var(--bg-hover)}.chord-editor-empty p{margin:0}.chord-editor-empty .text-muted{font-size:.875rem;color:var(--text-muted);margin-top:var(--spacing-xs)}.chord-editor-content{padding:var(--spacing-md);font-family:var(--font-mono);line-height:1.2}.chord-editor-line{margin-bottom:var(--spacing-lg);display:flex;flex-wrap:wrap;align-items:flex-end}.chord-editor-line.empty{height:1em}.chord-editor-line.section{color:var(--text-secondary);font-weight:600;margin-bottom:var(--spacing-sm)}.chord-editor-space{white-space:pre}.chord-editor-word{display:inline-flex;flex-direction:column;align-items:flex-start;cursor:pointer;padding:2px 4px;margin:-2px -4px;border-radius:var(--radius-sm);transition:background-color .15s}.chord-editor-word:hover,.chord-editor-word.editing{background-color:var(--accent-muted)}.chord-editor-word.has-chord .chord-editor-chord{color:var(--accent)}.chord-editor-chord{font-size:.875rem;font-weight:600;min-height:1.4em;color:var(--text-muted)}.chord-editor-text{color:var(--text-primary)}.chord-input{width:60px;padding:2px 4px;font-size:.875rem;font-family:var(--font-mono);font-weight:600;background-color:var(--bg-card);border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--accent);outline:none}.chord-input:focus{box-shadow:0 0 0 2px var(--accent-muted)}.song-view-content{position:relative;background-color:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-xl)}.song-view-floating-actions{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);display:flex;align-items:center;gap:var(--spacing-xs);z-index:10}.song-view-edit-btn{display:inline-flex;align-items:center;gap:4px;padding:3px var(--spacing-sm);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:color .15s,border-color .15s}.song-view-edit-btn:hover{color:var(--text-primary);border-color:var(--text-primary)}.song-add-to-album-btn{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;padding:4px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;transition:color .15s,border-color .15s}.song-add-to-album-btn:hover{color:var(--text-primary);border-color:var(--text-primary)}.song-view-kebab{position:relative}.song-view-kebab-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:1rem;letter-spacing:.05em;cursor:pointer;transition:color .15s,border-color .15s}.song-view-kebab-btn:hover{color:var(--text-primary);border-color:var(--text-primary)}.song-view-kebab-backdrop{position:fixed;inset:0;z-index:10}.song-view-kebab-menu{position:absolute;top:calc(100% + 4px);right:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--spacing-xs);min-width:120px;z-index:11;box-shadow:0 4px 12px var(--shadow)}.kebab-delete-btn{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-xs) var(--spacing-sm);background:none;border:none;border-radius:var(--radius-sm);color:#ef4444;font-size:.875rem;cursor:pointer;text-align:left;transition:background-color .15s}.kebab-delete-btn:hover{background-color:#ef44441a}.song-lyrics{font-family:var(--font-mono);font-size:1rem;line-height:1.8;white-space:pre-wrap;color:var(--text-primary)}.chord-lyrics{font-family:var(--font-mono);font-size:1rem;line-height:1.2;overflow-wrap:break-word;word-break:break-word}.lyrics-line-container{margin-bottom:.25rem;break-inside:avoid}.lyrics-line-break{margin-bottom:1.25rem}.chord-line-wrapper{white-space:pre-wrap}.chord-word-pair{display:inline-block;vertical-align:top;max-width:100%}.chord-word-pair .chord{display:block;color:var(--accent);font-weight:600;min-height:1.1em}.chord-word-pair .word{display:block;color:var(--text-primary);overflow-wrap:break-word}.lyrics-line{color:var(--text-primary)}.section-label{color:var(--accent);font-weight:700;font-size:1em;text-transform:uppercase;letter-spacing:.05em;margin-top:var(--spacing-sm);margin-bottom:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--accent-muted);border-radius:var(--radius-sm);display:inline-block}.lyrics-line-container:first-child .section-label{margin-top:0}.chord-progression-line{color:var(--accent);font-weight:600;white-space:pre-wrap;padding:var(--spacing-xs) 0}.lyrics-line .word{white-space:pre-wrap}.song-form{max-width:800px;margin:0 auto}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;font-weight:500;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.form-input,.form-textarea{width:100%;padding:var(--spacing-md);background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}.form-textarea{font-family:var(--font-mono);min-height:300px;resize:vertical;line-height:1.8}.chord-editor{font-family:var(--font-mono);white-space:pre}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.form-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end}.empty-state{text-align:center;padding:var(--spacing-xl) var(--spacing-lg);color:var(--text-secondary)}.empty-state h3{font-size:1.25rem;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.back-btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);margin-bottom:var(--spacing-lg);cursor:pointer;transition:color .2s}.back-btn:hover{color:var(--accent)}.share-modal-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.share-modal{background:var(--bg-secondary);border-radius:var(--radius-lg);max-width:480px;width:100%;box-shadow:0 20px 40px #0000004d}.share-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.share-modal-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.share-modal-close{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:var(--spacing-xs);line-height:1;transition:color .2s}.share-modal-close:hover{color:var(--text-primary)}.share-modal-content{padding:var(--spacing-lg)}.share-link-section{margin-bottom:var(--spacing-lg)}.share-link-label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.share-link-row{display:flex;gap:var(--spacing-sm)}.share-link-row .share-link-input{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem}.share-copy-btn{white-space:nowrap}.share-platforms-section{border-top:1px solid var(--border-color);padding-top:var(--spacing-lg)}.share-platforms-label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--spacing-md);text-align:center}.share-platforms{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sm)}.share-platform-btn{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:all .2s}.share-platform-btn:hover{border-color:var(--accent);background:var(--bg-tertiary)}.share-platform-btn span{font-size:.75rem}.share-platform-btn svg{opacity:.9}.share-facebook:hover{color:#1877f2}.share-twitter:hover{color:#1da1f2}.share-whatsapp:hover{color:#25d366}.share-email:hover,.share-others:hover{color:var(--accent)}@media(max-width:640px){.header{padding:var(--spacing-sm) var(--spacing-md)}.header-logo{font-size:1.25rem}.header-logo svg{width:24px;height:24px}.main{padding:var(--spacing-md)}.form-row{grid-template-columns:1fr}.song-view-title{font-size:1.5rem}.share-platforms{grid-template-columns:repeat(2,1fr)}}.sidebar-share-app-btn{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--text-muted);font-size:.78rem;cursor:pointer;padding:0;transition:color .2s}.sidebar-share-app-btn:hover{color:var(--accent)}.sidebar-contact-btn{color:var(--text-muted);font-size:.78rem;text-decoration:none;transition:color .2s}.sidebar-contact-btn:hover{color:var(--accent)}.app-share-modal{background:var(--bg-secondary);border-radius:var(--radius-lg);max-width:480px;width:100%;box-shadow:0 20px 40px #0000004d}.app-share-thumbnail{background:linear-gradient(135deg,#f59e0b,#b45309);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:var(--spacing-lg)}.app-share-thumbnail-left{display:flex;flex-direction:column;gap:var(--spacing-sm);flex:1}.app-share-logo{display:flex;align-items:center;gap:var(--spacing-sm);color:#fff}.app-share-name{font-size:1.4rem;font-weight:700;color:#fff;letter-spacing:-.02em}.app-share-motto{color:#ffffffe6;font-size:.8rem;line-height:1.6;margin:0}.app-share-qr{display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0}.app-share-qr-label{font-size:.7rem;color:#ffffffbf;white-space:nowrap}.album-share-modal{background:var(--bg-secondary);border-radius:var(--radius-lg);max-width:480px;width:100%;box-shadow:0 20px 40px #0000004d}.album-share-thumbnail{background:linear-gradient(135deg,#f59e0b,#b45309);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:var(--spacing-lg)}.album-share-thumbnail-title{font-size:1.1rem;font-weight:700;color:#fff;letter-spacing:-.02em}.album-share-thumbnail-count{font-size:.8rem;color:#fffc}.album-share-copy-row{margin-bottom:var(--spacing-lg)}.album-share-copy-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px}body:has(.live-view-overlay) .header{display:none}.live-view-overlay{position:fixed;inset:0;z-index:9999;background:var(--bg-primary);display:flex;flex-direction:column;padding:var(--spacing-lg)}.live-view-exit-btn{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background:transparent;border:1px solid var(--border);color:var(--text-secondary);font-size:1.25rem;width:2.5rem;height:2.5rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.live-view-exit-btn:hover{color:var(--text-primary);border-color:var(--text-primary)}.live-view-font-control{position:absolute;top:var(--spacing-md);left:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-xs)}.live-view-font-up,.live-view-font-down{background:transparent;border:1px solid var(--border);color:var(--text-secondary);width:2rem;height:2rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem}.live-view-font-up:hover,.live-view-font-down:hover{color:var(--text-primary);border-color:var(--text-primary)}.live-view-font-label{color:var(--text-secondary);font-size:.875rem;min-width:1.5rem;text-align:center}.live-view-content{position:absolute;top:calc(var(--spacing-lg) + 3.5rem);left:var(--spacing-lg);right:var(--spacing-lg);bottom:var(--spacing-lg);overflow:hidden;column-gap:2rem}.live-view-columns-btn{position:absolute;top:var(--spacing-md);right:calc(var(--spacing-md) + 10rem);background:transparent;border:1px solid var(--border);color:var(--text-secondary);padding:.25rem .6rem;border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;letter-spacing:.05em}.live-view-columns-btn:hover{color:var(--accent);border-color:var(--accent)}.live-view-autoscroll-control{position:absolute;top:var(--spacing-md);right:calc(var(--spacing-md) + 3.5rem);display:flex;align-items:center;gap:var(--spacing-xs)}.live-view-autoscroll-btn{background:transparent;border:1px solid var(--border);color:var(--text-secondary);width:2.5rem;height:2.5rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem}.live-view-autoscroll-btn:hover{color:var(--text-primary);border-color:var(--text-primary)}.live-view-autoscroll-btn.active{color:var(--accent);border-color:var(--accent);background:#7c3aed1a}.live-view-autoscroll-speed{background:transparent;border:1px solid var(--border);color:var(--text-secondary);padding:.25rem .5rem;border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;min-width:2rem;text-align:center}.live-view-autoscroll-speed:hover{color:var(--accent);border-color:var(--accent)}.live-view-song-nav{position:absolute;bottom:var(--spacing-md);left:var(--spacing-md);right:var(--spacing-md);display:flex;justify-content:space-between;gap:var(--spacing-sm);pointer-events:none}.live-view-song-nav-btn{pointer-events:all;background:#0006;border:1px solid var(--border);color:var(--text-secondary);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;transition:background .15s,color .15s}.live-view-song-nav-btn:hover:not(:disabled){background:#0009;color:var(--text-primary)}.live-view-song-nav-btn:disabled{opacity:.3;cursor:default}.bottom-bar{position:fixed;bottom:0;left:0;right:0;background-color:var(--bg-secondary);border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) var(--spacing-md);z-index:100}.bottom-bar-item{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:.7rem;transition:color .2s,background-color .2s}.bottom-bar-item:hover{color:var(--text-primary);background-color:var(--bg-hover)}.bottom-bar-live-btn{color:var(--accent)}.bottom-bar-live-btn:hover{color:#000;background-color:var(--accent)}.bottom-bar-control{display:flex;align-items:center;gap:2px;background-color:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:2px}.bottom-bar-ctrl-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-primary);font-size:1rem;font-weight:600;cursor:pointer;border-radius:var(--radius-sm);transition:background-color .2s,color .2s}.bottom-bar-ctrl-btn:hover{background-color:var(--accent);color:#000}.bottom-bar-ctrl-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);min-width:20px;text-align:center}.footer{border-top:1px solid var(--border);padding:var(--spacing-md) var(--spacing-lg);padding-bottom:calc(var(--spacing-md) + 56px);margin-top:auto}.footer-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-sm)}.footer-copyright{font-size:.8rem;color:var(--text-muted)}.footer-links{display:flex;gap:var(--spacing-md)}.footer-link{font-size:.8rem;color:var(--text-muted);text-decoration:none;transition:color .2s}.footer-link:hover{color:var(--accent)}.legal-page{max-width:800px;margin:0 auto}.legal-page h1{font-size:2rem;font-weight:700;margin-bottom:var(--spacing-sm)}.legal-updated{color:var(--text-muted);font-size:.875rem;margin-bottom:var(--spacing-xl)}.legal-page section{margin-bottom:var(--spacing-xl)}.legal-page h2{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.legal-page h3{font-size:1rem;font-weight:600;margin-top:var(--spacing-md);margin-bottom:var(--spacing-xs);color:var(--text-secondary)}.legal-page p{color:var(--text-secondary);line-height:1.7;margin-bottom:var(--spacing-sm)}.legal-page ul{color:var(--text-secondary);line-height:1.7;margin-left:var(--spacing-lg);margin-bottom:var(--spacing-sm)}.legal-page li{margin-bottom:var(--spacing-xs)}.legal-page a{color:var(--accent);text-decoration:none}.legal-page a:hover{text-decoration:underline}.form-disclaimer{font-size:.8rem;color:var(--text-muted);line-height:1.5;margin-bottom:var(--spacing-md)}.form-disclaimer a{color:var(--accent);text-decoration:none}.form-disclaimer a:hover{text-decoration:underline}.admin-panel{max-width:min(90vw,1600px);margin:0 auto;padding:var(--spacing-lg)}@media(max-width:640px){.admin-panel{max-width:100%;padding:var(--spacing-md)}}.admin-tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:var(--spacing-lg)}.admin-tab{background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;padding:var(--spacing-sm) var(--spacing-lg);font-size:.9375rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:color .15s,border-color .15s}.admin-tab:hover{color:var(--text-primary)}.admin-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.admin-tab-content{animation:fadeIn .15s ease}.admin-add-form{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.admin-add-form .form-input{flex:1}.admin-error{color:#ef4444;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md);font-size:.875rem}.admin-loading,.admin-empty{color:var(--text-secondary);padding:var(--spacing-lg) 0;text-align:center}.admin-access-denied{text-align:center;padding:var(--spacing-xl) 0;color:var(--text-secondary)}.admin-access-denied h2{margin-bottom:var(--spacing-sm);color:var(--text-primary)}.admin-moderator-list{list-style:none}.admin-moderator-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:var(--spacing-sm);background:var(--bg-card)}.admin-moderator-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.admin-moderator-name{font-weight:500;color:var(--text-primary)}.admin-moderator-email{font-size:.875rem;color:var(--text-secondary)}.admin-remove-btn{color:var(--text-secondary)}.admin-remove-btn:hover{color:#ef4444}.admin-permission-item{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:var(--spacing-sm);background:var(--bg-card);gap:var(--spacing-md)}.admin-perm-checkboxes{display:flex;flex-direction:column;gap:var(--spacing-xs);flex-shrink:0}.admin-perm-checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:.9rem;color:var(--text-primary);-webkit-user-select:none;user-select:none;white-space:nowrap}.admin-perm-checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.admin-permission-list{list-style:none}.admin-perm-add-form{margin-bottom:var(--spacing-md)}.admin-perm-new-checkboxes{margin-top:var(--spacing-sm);padding-left:var(--spacing-xs)}.admin-perm-hint{font-size:.8rem;color:var(--text-secondary);margin-top:var(--spacing-md);text-align:center}.sidebar-admin-link{text-decoration:none;color:var(--text-primary)}@media(max-width:640px){.admin-add-form{flex-direction:column}}@media(max-width:640px){.footer-content{flex-direction:column;text-align:center}}.lyrics-field-wrapper{position:relative}.image-lyrics-fab{position:absolute;top:.5rem;right:.5rem;width:2.5rem;height:2.5rem;border-radius:50%;background:var(--accent);color:#000;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;box-shadow:0 2px 8px #0003;transition:transform .2s,box-shadow .2s}.image-lyrics-fab:hover{transform:scale(1.1);box-shadow:0 4px 12px #0000004d}.song-note-section{margin:var(--spacing-xl) 0 var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color)}.song-note-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.song-note-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.song-note-edit-btn{font-size:.75rem;padding:2px 8px}.song-note-content{font-size:.9rem;color:var(--text-secondary);line-height:1.6;margin:0 0 var(--spacing-xs);white-space:pre-wrap}.song-note-attribution{font-size:.78rem;color:var(--text-muted);margin:0}.song-note-editor{display:flex;flex-direction:column;gap:var(--spacing-sm)}.song-note-textarea{width:100%;padding:var(--spacing-sm);border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:.9rem;line-height:1.6;resize:vertical;font-family:inherit}.song-note-textarea:focus{outline:none;border-color:var(--accent-color)}.song-note-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.audio-player{position:fixed;bottom:calc(64px + var(--spacing-md));right:var(--spacing-md);z-index:200}.audio-player-btn{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;border:none;cursor:pointer;background:#f59e0b66;color:#000;box-shadow:0 2px 8px #00000040;transition:transform .15s ease,box-shadow .15s ease}.audio-player-btn:hover{transform:scale(1.06);box-shadow:0 4px 12px #00000059}.audio-spinner{animation:audio-spin 1s cubic-bezier(.4,0,.2,1) infinite}@keyframes audio-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.audio-player--playing .audio-player-btn{background:#f59e0b99;color:#000;box-shadow:0 2px 8px #00000040;animation:audio-glow-pulse 2s ease-in-out infinite}@keyframes audio-glow-pulse{0%,to{box-shadow:0 0 0 2px #f59e0be6,0 0 8px 3px #f59e0b80,0 2px 8px #00000040}50%{box-shadow:0 0 0 2px #f59e0b,0 0 18px 6px #f59e0bd9,0 2px 8px #00000040}}.audio-progress-bar{position:fixed;bottom:64px;left:0;right:0;height:4px;z-index:150}.audio-progress-range{display:block;width:100%;height:4px;margin:0;padding:0;-webkit-appearance:none;appearance:none;background:transparent;cursor:pointer;padding-block:10px}.audio-progress-range::-webkit-slider-runnable-track{height:4px;border-radius:2px;background:linear-gradient(to right,var(--accent) 0%,var(--accent) var(--progress, 0%),rgba(255,255,255,.15) var(--progress, 0%),rgba(255,255,255,.15) 100%)}.audio-progress-range::-moz-range-track{height:4px;border-radius:2px;background:#ffffff26}.audio-progress-range::-moz-range-progress{height:4px;border-radius:2px 0 0 2px;background:var(--accent)}.audio-progress-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);border:none;box-shadow:0 1px 4px #0006;margin-top:-5px;transition:transform .1s ease}.audio-progress-range::-webkit-slider-thumb:hover,.audio-progress-range:active::-webkit-slider-thumb{transform:scale(1.3)}.audio-progress-range::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent);border:none;box-shadow:0 1px 4px #0006;cursor:pointer;transition:transform .1s ease}.audio-progress-range::-moz-range-thumb:hover{transform:scale(1.3)}.audio-progress-range:focus{outline:none}.audio-progress-range:focus-visible::-webkit-slider-thumb{outline:2px solid var(--accent);outline-offset:2px}.audio-field-current{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md)}.audio-field-filename{flex:1;font-size:.875rem;color:var(--text-secondary)}.audio-remove-btn{font-size:.8rem;color:var(--error-color, #ef4444);padding:2px 8px}.audio-upload-input{padding:var(--spacing-sm)}.audio-upload-error{font-size:.8rem;color:#ef4444;margin:var(--spacing-xs) 0 0}.image-lyrics-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.image-lyrics-modal{background:var(--bg-secondary);border-radius:var(--radius-lg);max-width:560px;width:100%;box-shadow:0 20px 40px #0000004d}.image-lyrics-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.image-lyrics-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.image-lyrics-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-xs);line-height:1;transition:color .2s}.image-lyrics-close:hover{color:var(--text-primary)}.image-lyrics-content{padding:var(--spacing-lg)}.image-lyrics-error{background:#ef44441a;color:#ef4444;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:.875rem}.image-lyrics-warning{background:#f59e0b1a;color:#f59e0b;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:.875rem}.image-lyrics-dropzone{border:2px dashed var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-xl) var(--spacing-lg);text-align:center;transition:border-color .2s,background .2s}.image-lyrics-dropzone:hover{border-color:var(--accent);background:#f59e0b0d}.image-lyrics-hint{color:var(--text-secondary);font-size:.8rem;margin-top:var(--spacing-xs)}.image-lyrics-dropzone-actions{display:flex;gap:var(--spacing-sm);justify-content:center;margin-top:var(--spacing-md)}.image-lyrics-detected{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-sm);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-sm);font-size:.875rem;color:var(--text-primary)}.image-lyrics-detected-hint{color:var(--text-secondary);font-size:.8rem}.image-lyrics-preview{text-align:center}.image-lyrics-preview img{max-width:100%;max-height:300px;border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.image-lyrics-result textarea{width:100%;min-height:200px;margin-bottom:var(--spacing-md)}.image-lyrics-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-md)}.ios-install-overlay{position:fixed;inset:0;background:#00000080;z-index:500;display:flex;align-items:flex-end}.ios-install-guide,.open-in-browser-guide{background:var(--bg-secondary);border-radius:16px 16px 0 0;padding:var(--spacing-xl);width:100%;padding-bottom:calc(var(--spacing-xl) + env(safe-area-inset-bottom,0px));animation:slide-up .25s ease-out}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.ios-install-guide-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.ios-install-guide-title{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.ios-install-guide-close{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;display:flex;align-items:center}.ios-install-guide-body{margin-bottom:var(--spacing-lg)}.ios-install-guide-intro{color:var(--text-secondary);margin-bottom:var(--spacing-md);font-size:.95rem}.ios-install-guide-steps{list-style:decimal;padding-left:var(--spacing-lg);color:var(--text-primary);display:flex;flex-direction:column;gap:var(--spacing-sm);font-size:.95rem;line-height:1.5}.ios-share-icon{width:18px;height:18px;vertical-align:middle;display:inline-block;color:var(--accent)}.ios-install-guide-dismiss{width:100%;padding:var(--spacing-md);background:var(--accent);color:#000;border:none;border-radius:var(--radius-md);font-weight:600;font-size:1rem;cursor:pointer}.album-card{background-color:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--spacing-md);cursor:pointer;transition:all .2s}.album-card:hover{background-color:var(--bg-hover);border-color:var(--accent)}.album-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xs)}.album-card-title{font-weight:600;font-size:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.album-card-actions{display:flex;align-items:center;gap:4px;flex-shrink:0;margin-left:var(--spacing-sm)}.album-card-count{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.album-card-share-btn{padding:2px 4px;color:var(--text-secondary);line-height:1}.album-card-share-btn:hover{color:var(--accent)}.album-card-description{font-size:.85rem;color:var(--text-secondary)}.album-view-header{padding:var(--spacing-md) var(--spacing-lg)}.album-view-title-row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);margin-bottom:4px}.album-view-meta{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--spacing-sm)}.album-view-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.album-view-title{font-size:1.5rem;font-weight:700;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.album-view-description{color:var(--text-secondary);margin:0 0 4px;font-size:.9rem}.album-view-count{color:var(--text-secondary);font-size:.8rem;margin:0}.album-song-wrapper{position:relative;display:flex;align-items:stretch}.album-song-card-area{flex:1;position:relative;min-width:0}.album-drag-handle{display:flex;align-items:center;padding:0 var(--spacing-sm);color:var(--text-muted, var(--text-secondary));font-size:1.1rem;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;flex-shrink:0;opacity:.4;transition:opacity .15s}.album-drag-handle:hover{opacity:.9}.album-drag-handle:active{cursor:grabbing}.album-song-remove-badge{position:absolute;top:8px;right:8px;z-index:1;width:22px;height:22px;border-radius:50%;border:none;background:var(--btn-danger-bg, #ef4444);color:#fff;font-size:13px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;opacity:0;transition:opacity .15s}.album-song-wrapper:hover .album-song-remove-badge,.album-song-remove-badge:focus{opacity:1}@media(hover:none){.album-song-remove-badge{opacity:.7}}.album-songs-empty{text-align:center}.album-add-songs-btn{margin:var(--spacing-md) var(--spacing-lg)}.song-picker-backdrop{position:fixed;inset:0;background:#00000080;z-index:200;display:flex;align-items:flex-end;justify-content:center}@media(min-width:480px){.song-picker-backdrop{align-items:center}}.song-picker{background:var(--bg);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;padding:var(--spacing-lg)}@media(min-width:480px){.song-picker{border-radius:var(--radius-lg);max-height:70vh}}.song-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.song-picker-header h3{margin:0;font-size:1.1rem;font-weight:700}.song-picker-search{margin-bottom:var(--spacing-sm)}.song-picker-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px;margin-bottom:var(--spacing-md)}.song-picker-item{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);cursor:pointer;border:1px solid transparent;transition:background .1s,border-color .1s;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.song-picker-item:hover:not(.already-added){background:#f59e0b14;border-color:var(--accent)}.song-picker-item.selected{background:#f59e0b26;border-color:var(--accent)}.song-picker-item.already-added{opacity:.5;cursor:not-allowed}.song-picker-item-info{display:flex;flex-direction:column;min-width:0}.song-picker-item-title{display:block;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-picker-item-artist{display:block;font-size:.8rem;color:var(--text-secondary)}.song-picker-item-added{font-size:.75rem;color:var(--accent);flex-shrink:0}.song-picker-item-check{font-size:1rem;color:var(--accent);font-weight:700;flex-shrink:0}.song-picker-footer{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.album-picker-backdrop{position:fixed;inset:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.album-picker{background:var(--bg-secondary);border-radius:var(--radius-lg);width:100%;max-width:400px;max-height:70vh;display:flex;flex-direction:column;padding:var(--spacing-lg);box-shadow:0 20px 60px #0006}.album-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.album-picker-header h3{margin:0;font-size:1.1rem;font-weight:700}.album-picker-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.album-picker-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);cursor:pointer;border:1px solid transparent;transition:background .1s}.album-picker-item:hover{background:#f59e0b14;border-color:var(--accent)}.album-picker-item-title{font-weight:500}.album-picker-item-count{font-size:.8rem;color:var(--text-secondary)}.album-strip{padding:0}.search-container+.album-strip{margin-top:calc(-1 * var(--spacing-md))}.album-strip-header{display:flex;align-items:center;justify-content:flex-end;padding:0 var(--spacing-lg) 4px}.album-strip-heading{display:none}.album-strip-see-all{font-size:.72rem;color:var(--text-secondary);text-decoration:none;opacity:.7;transition:opacity .15s}.album-strip-see-all:hover{opacity:1;color:var(--accent)}.album-strip-scroll-wrapper{display:flex;align-items:center;gap:4px;padding:0 8px var(--spacing-md);overflow:hidden}.album-strip-arrow{flex-shrink:0;align-self:center;width:26px;height:26px;border-radius:50%;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-size:1.1rem;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 1px 4px #0000002e;transition:background .15s,color .15s;padding:0}.album-strip-arrow:hover{background:var(--accent);color:#000;border-color:var(--accent)}.album-strip-scroll{flex:1;display:flex;gap:8px;overflow-x:auto;justify-content:safe center;scrollbar-width:none;-ms-overflow-style:none}.album-strip-scroll::-webkit-scrollbar{display:none}.album-strip-card{flex-shrink:0;padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);font-size:.82rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,color .15s}.album-strip-card:hover{border-color:var(--accent);color:var(--accent)}.album-strip-card--active{background:var(--accent);border-color:var(--accent);color:#000}.album-strip-card--active:hover{color:#000}.song-list-album-label{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-xs) var(--spacing-lg);font-size:.8rem;font-weight:600;color:var(--text-secondary)}.song-list-album-clear{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:.75rem;padding:2px 6px;border-radius:50%;line-height:1;transition:color .15s}.song-list-album-clear:hover{color:var(--text-primary)}.audio-line{display:flex;align-items:center;gap:var(--spacing-sm);margin:var(--spacing-sm) 0;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);background-color:var(--bg-secondary);border:1px solid var(--border-color)}.audio-line--player{gap:var(--spacing-sm)}.audio-line-play-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;border:1.5px solid var(--accent);background:transparent;color:var(--accent);cursor:pointer;flex-shrink:0;transition:background .15s}.audio-line-play-btn:hover,.audio-line-play-btn--playing{background:var(--accent-muted)}.audio-line-progress{position:relative;flex:1;height:4px;background:var(--border-color);border-radius:2px;overflow:hidden}.audio-line-range{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;margin:0}.audio-line-progress-fill{height:100%;background:var(--accent);border-radius:2px;pointer-events:none;transition:width .1s linear}.audio-line-label{font-size:.7rem;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.audio-clip-name{flex:1;min-width:4rem;background:transparent;border:none;border-bottom:1px solid transparent;outline:none;font-size:.78rem;font-family:inherit;color:var(--text-primary);padding:0 .1rem;transition:border-color .15s ease}.audio-clip-name::placeholder{color:var(--text-secondary, #888)}.audio-clip-name:focus{border-bottom-color:var(--accent)}.audio-line--recorder{gap:var(--spacing-xs);cursor:default}.audio-line-record-btn{display:flex;align-items:center;gap:5px;padding:3px var(--spacing-sm);border-radius:var(--radius-sm);border:1.5px solid var(--accent);background:transparent;color:var(--accent);font-size:.75rem;font-weight:600;cursor:pointer;flex-shrink:0;transition:background .15s}.audio-line-record-btn:hover{background:var(--accent-muted)}.audio-line-record-dot{width:8px;height:8px;border-radius:50%;background:#ef4444;flex-shrink:0}.audio-line-record-dot--active{animation:record-pulse 1s ease-in-out infinite}@keyframes record-pulse{0%,to{opacity:1}50%{opacity:.3}}.audio-line-play-btn--recording{border-color:#ef4444;color:#ef4444}.audio-line-play-btn--recording:hover{background:#ef44441a}.audio-line-recording-label{font-size:.75rem;color:#ef4444;flex:1}.audio-line-uploading{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;color:var(--text-secondary)}.audio-line-spinner{display:inline-block;width:12px;height:12px;border:2px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:audio-spin .6s linear infinite;flex-shrink:0}@keyframes audio-spin{to{transform:rotate(360deg)}}.audio-line-icon-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-size:.8rem;line-height:1;cursor:pointer;flex-shrink:0;transition:color .15s,border-color .15s}.audio-line-icon-btn:hover{color:var(--text-primary);border-color:var(--text-secondary)}.audio-line-icon-btn--remove:hover{color:#ef4444;border-color:#ef4444}.audio-line-remove-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-size:.8rem;line-height:1;cursor:pointer;flex-shrink:0;transition:color .15s,border-color .15s}.audio-line-remove-btn:hover{color:#ef4444;border-color:#ef4444}.audio-line-error{font-size:.75rem;color:#ef4444;margin:0}.lyrics-segments{display:flex;flex-direction:column;gap:0}.lyrics-segment-text{display:flex;flex-direction:column}.lyrics-segment-audio{border-left:2px solid var(--accent);padding-left:var(--spacing-sm);margin:var(--spacing-xs) 0}.audio-insert-zone{display:flex;justify-content:flex-start;padding:.25rem 0}.audio-insert-btn{padding:.2rem .6rem;border-radius:var(--radius-sm);border:1px solid color-mix(in srgb,var(--accent) 40%,transparent);background:transparent;color:var(--accent);font-size:.72rem;font-weight:600;cursor:pointer;white-space:nowrap;opacity:0;transition:opacity .15s ease,background .15s ease,color .15s ease}.lyrics-segment-text:focus-within .audio-insert-btn{opacity:1}.audio-insert-btn:hover{background:color-mix(in srgb,var(--accent) 15%,transparent)}.lyrics-assist-container{margin-top:.75rem}.lyrics-assist-toggle-btn{font-size:.8rem;padding:.3rem .75rem;border:1.5px solid var(--accent);color:var(--accent);border-radius:var(--radius-sm)}.lyrics-assist-panel{margin-top:.75rem;border:1px solid var(--border-color, #333);border-radius:var(--radius-md);overflow:hidden}.lyrics-assist-section{padding:1rem}.lyrics-assist-section+.lyrics-assist-section{border-top:1px solid var(--border-color, #333)}.lyrics-assist-heading{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary, #888);margin:0 0 .75rem}.lyrics-assist-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.lyrics-assist-section-header .lyrics-assist-heading{margin:0}.lyrics-assist-refresh-btn{font-size:1rem;padding:.1rem .4rem;line-height:1;border:1px solid var(--border-color, #333);border-radius:var(--radius-sm)}.lyrics-assist-refresh-btn:disabled{opacity:.4}.lyrics-assist-loading{font-size:.78rem;color:var(--text-secondary, #888)}.lyrics-assist-fallback-msg{font-size:.75rem;color:var(--text-secondary, #888);margin:0 0 .5rem;font-style:italic}.lyrics-assist-progression-list{display:flex;flex-direction:column;gap:.5rem}.lyrics-assist-progression-card{background:var(--bg-secondary, #1a1a1a);border:1px solid var(--border-color, #2a2a2a);border-radius:var(--radius-sm);padding:.6rem .75rem}.progression-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}.progression-card-label{font-size:.75rem;font-weight:600;color:var(--text-secondary, #888)}.lyrics-assist-insert-btn{font-size:.68rem;padding:.15rem .5rem;border:1px solid var(--accent);color:var(--accent);border-radius:var(--radius-sm);white-space:nowrap}.lyrics-assist-insert-btn:hover{background:var(--accent);color:var(--bg-primary)}.progression-card-chips{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.3rem}.chord-chip{font-size:.78rem;font-weight:700;font-family:monospace;padding:.15rem .4rem;border-radius:3px;border:1px solid transparent}.chord-chip.chip--major{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,transparent)}.chord-chip.chip--maj7{color:#fbbf24;border-color:color-mix(in srgb,#fbbf24 40%,transparent)}.chord-chip.chip--minor{color:#93c5fd;border-color:color-mix(in srgb,#93c5fd 40%,transparent)}.chord-chip.chip--min7{color:#60a5fa;border-color:color-mix(in srgb,#60a5fa 40%,transparent)}.chord-chip.chip--dom7{color:#fb923c;border-color:color-mix(in srgb,#fb923c 40%,transparent)}.chord-chip.chip--dim{color:#c084fc;border-color:color-mix(in srgb,#c084fc 40%,transparent)}.chord-chip.chip--aug{color:#4ade80;border-color:color-mix(in srgb,#4ade80 40%,transparent)}.chord-chip.chip--sus{color:#94a3b8;border-color:color-mix(in srgb,#94a3b8 40%,transparent)}.progression-card-numerals{font-size:.68rem;color:var(--text-secondary, #888);font-style:italic;letter-spacing:.02em}.lyrics-assist-direction{margin-bottom:.5rem;font-size:.85rem}.lyrics-assist-polish-btn{font-size:.85rem}.lyrics-assist-error{margin-top:.5rem;font-size:.8rem;color:#f87171}.lyrics-assist-suggestion{background:var(--bg-secondary, #1a1a1a);border-radius:var(--radius-sm);padding:.75rem}.lyrics-assist-suggestion-text{font-family:inherit;font-size:.85rem;white-space:pre-wrap;margin:0 0 .75rem;line-height:1.6}.lyrics-assist-suggestion-actions{display:flex;gap:.5rem}.admin-dashboard{display:flex;flex-direction:column;gap:1.25rem}.dashboard-header{display:flex;align-items:center;justify-content:space-between}.dashboard-title{font-size:1rem;font-weight:700;margin:0}.dashboard-refresh-btn{font-size:.78rem;padding:.25rem .6rem;border:1px solid var(--border-color, #333)}.dashboard-loading{padding:2rem;text-align:center;color:var(--text-secondary, #888);font-size:.85rem}.dashboard-error{color:#f87171;font-size:.85rem}.dashboard-stat-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem}@media(max-width:640px){.dashboard-stat-row{grid-template-columns:repeat(2,1fr)}}.dashboard-stat-card{background:var(--bg-secondary, #1a1a1a);border:1px solid var(--border-color, #2a2a2a);border-radius:var(--radius-md);padding:.9rem 1rem}.dashboard-stat-value{font-size:1.6rem;font-weight:800;color:var(--accent);line-height:1;margin-bottom:.25rem}.dashboard-stat-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #888)}.dashboard-stat-sub{font-size:.7rem;color:var(--text-secondary, #888);margin-top:.2rem}.dashboard-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}@media(max-width:640px){.dashboard-charts-row{grid-template-columns:1fr}}.dashboard-chart-panel{background:var(--bg-secondary, #1a1a1a);border:1px solid var(--border-color, #2a2a2a);border-radius:var(--radius-md);padding:.9rem 1rem}.dashboard-bottom-row{display:grid;grid-template-columns:2fr 1fr 1fr;gap:.75rem}@media(max-width:768px){.dashboard-bottom-row{grid-template-columns:1fr}}.dashboard-panel{background:var(--bg-secondary, #1a1a1a);border:1px solid var(--border-color, #2a2a2a);border-radius:var(--radius-md);padding:.9rem 1rem}.dashboard-panel--wide{overflow-x:auto}.dashboard-section-heading{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary, #888);margin:0 0 .75rem}.dashboard-top-songs{width:100%;border-collapse:collapse;font-size:.82rem}.dashboard-top-songs th{text-align:left;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #888);padding:0 .5rem .5rem 0;border-bottom:1px solid var(--border-color, #2a2a2a)}.dashboard-top-songs td{padding:.4rem .5rem .4rem 0;border-bottom:1px solid rgba(255,255,255,.04)}.dashboard-bar-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.45rem;font-size:.8rem}.dashboard-bar-label{width:4.5rem;flex-shrink:0;font-size:.75rem;color:var(--text-secondary, #888)}.dashboard-bar-track{flex:1;height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden}.dashboard-bar-fill{height:100%;background:var(--accent);border-radius:3px;min-width:2px;transition:width .3s ease}.dashboard-bar-count{width:2rem;text-align:right;font-size:.75rem;color:var(--text-secondary, #888);flex-shrink:0}.dashboard-users-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}@media(max-width:768px){.dashboard-users-row{grid-template-columns:1fr}}.dashboard-user-table{width:100%;border-collapse:collapse;font-size:.82rem;margin-top:.5rem}.dashboard-user-table th{text-align:left;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #888);padding:0 .5rem .5rem 0;border-bottom:1px solid var(--border-color, #2a2a2a)}.dashboard-user-table td{padding:.4rem .5rem .4rem 0;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}.dashboard-user-table .col-rank{width:1.5rem;color:var(--text-secondary, #888)}.dashboard-user-table .col-name{font-weight:500;word-break:break-all}.dashboard-user-table .col-date{width:5.5rem;white-space:nowrap;color:var(--text-secondary, #888);font-size:.75rem}.dashboard-user-table .col-num{width:3rem;text-align:right;font-variant-numeric:tabular-nums}.favourite-btn{font-size:1.1rem;line-height:1;padding:.2rem .4rem;color:var(--text-secondary, #888);transition:color .15s ease,transform .1s ease}.favourite-btn:hover{color:#f87171;transform:scale(1.15)}.favourite-btn--active{color:#f87171}.chord--tappable{cursor:pointer;border-radius:3px;transition:background .1s ease}.chord--tappable:hover,.chord--tappable:focus{background:color-mix(in srgb,var(--accent) 20%,transparent);outline:none}.chord-popup{position:fixed;background:var(--bg-secondary, #1a1a1a);border:1px solid var(--border-color, #333);border-radius:var(--radius-md);padding:.6rem .75rem;box-shadow:0 8px 24px #0006;z-index:1000;text-align:center}.chord-popup-name{font-size:.85rem;font-weight:700;color:var(--accent);margin-bottom:.35rem}.chord-popup-not-found{font-size:.75rem;color:var(--text-secondary, #888);margin:.5rem 0;padding:0 .5rem}.chord-sheet-backdrop{position:fixed;inset:0;background:#0000008c;z-index:900;display:flex;align-items:flex-end;justify-content:center}.chord-sheet-panel{background:var(--bg-primary, #242424);border-top:1px solid var(--border-color, #333);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:700px;max-height:80vh;overflow-y:auto;padding:1rem 1rem 2rem}.chord-sheet-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.chord-sheet-title{font-size:.9rem;font-weight:700;margin:0}.chord-sheet-close{background:none;border:none;font-size:1rem;cursor:pointer;color:var(--text-secondary, #888);padding:.2rem}.chord-sheet-search{margin-bottom:.75rem;font-size:.85rem}.chord-sheet-not-found{font-size:.8rem;color:var(--text-secondary, #888);text-align:center;padding:1rem 0;margin:0}.chord-sheet-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.chord-sheet-card{background:var(--bg-secondary, #1a1a1a);border:1px solid var(--border-color, #2a2a2a);border-radius:var(--radius-sm);padding:.5rem;text-align:center}.chord-sheet-card-name{font-size:.82rem;font-weight:700;color:var(--accent);margin-bottom:.3rem}.chord-sheet-card-missing{font-size:.7rem;color:var(--text-secondary, #888);margin:.5rem 0}.chord-sheet-trigger{font-size:.78rem;padding:.2rem .6rem;border:1px solid var(--border-color, #333)}.live-view-chords-btn{position:absolute;top:1rem;left:9rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);color:#fff;font-size:1rem;padding:.3rem .6rem;cursor:pointer}.smart-album-icon{color:var(--accent);font-style:normal}.collaborator-row{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border)}.collaborator-actions{display:flex;align-items:center;gap:var(--spacing-xs);flex-shrink:0}.collaborator-manager-badge{font-size:.7rem;font-weight:600;color:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-sm);padding:1px 6px;white-space:nowrap}.collaborator-grant-manager-btn,.collaborator-revoke-manager-btn{font-size:.75rem;padding:2px 8px;color:var(--text-secondary)}.collaborator-grant-manager-btn:hover{color:var(--accent)}.collaborator-revoke-manager-btn:hover{color:var(--text-primary)}.album-section-card{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--spacing-lg)}.album-section-card-body{padding:var(--spacing-md);background:var(--bg-primary)}.album-section-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:.875rem var(--spacing-md);border-left:4px solid var(--accent);background:var(--bg-secondary);border-bottom:1px solid var(--border)}.album-section-header-icon{font-style:normal;font-size:1.1rem;color:var(--accent);flex-shrink:0}.album-section-header-label{font-size:.875rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-secondary);flex:1}.album-section-header-count{font-size:.75rem;font-weight:600;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);border-radius:999px;padding:2px 9px;flex-shrink:0}.album-section-header-chevron{font-size:.75rem;color:var(--text-muted);margin-left:var(--spacing-xs);flex-shrink:0}.album-section-header--btn{width:100%;cursor:pointer;border:none;text-align:left;transition:background .15s}.album-section-header--btn:hover{background:var(--bg-hover)}.album-section-header--btn[aria-expanded=true] .album-section-header-chevron{color:var(--accent)}.album-occasion-list{display:flex;flex-direction:column;gap:0;margin:calc(-1 * var(--spacing-md))}.album-occasion{border-top:1px solid var(--border);overflow:hidden}.album-occasion:first-child{border-top:none}.album-occasion-trigger{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:.875rem var(--spacing-md);background:var(--bg-card);border:none;cursor:pointer;text-align:left;color:var(--text-primary);transition:background .15s}.album-occasion-trigger:hover{background:var(--bg-hover)}.album-occasion--open .album-occasion-trigger{background:var(--accent-muted)}.album-occasion-chevron{font-size:.7rem;color:var(--text-muted);width:.9rem;flex-shrink:0}.album-occasion--open .album-occasion-chevron{color:var(--accent)}.album-occasion-name{flex:1;font-weight:600;font-size:.95rem}.album-occasion-count{font-size:.8rem;color:var(--text-muted);flex-shrink:0}.album-occasion-content{padding:var(--spacing-md);background:var(--bg-primary);border-top:1px solid var(--border)}.album-subsection-empty{font-size:.85rem;color:var(--text-muted);padding:var(--spacing-sm) 0}.album-section-controls{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-bottom:var(--spacing-md)}.album-section-manager{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.album-section-manager-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.album-section-manager-header h3{font-size:.95rem;font-weight:600;color:var(--text-primary)}.album-section-manager-form{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-bottom:var(--spacing-md)}.album-section-manager-form .form-input{flex:1;min-width:160px}.album-section-manager-list{list-style:none;display:flex;flex-direction:column;gap:var(--spacing-xs)}.album-section-manager-item{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem}.album-section-manager-item-actions{display:flex;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap}.album-section-manager-item .form-input-sm{padding:2px 6px;font-size:.8rem;width:120px}.album-section-manager-empty{font-size:.85rem;color:var(--text-muted);padding:var(--spacing-xs) var(--spacing-sm)}.tag-category-tags{font-size:.75rem;color:var(--text-muted);margin-left:var(--spacing-xs)}.song-book-checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:.95rem;color:var(--text-primary);padding:var(--spacing-xs) 0}.song-book-checkbox-label input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--accent);cursor:pointer}.form-hint{font-size:.85rem;color:var(--text-muted);margin-top:var(--spacing-xs)}.song-provenance{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:var(--text-muted);margin-top:var(--spacing-xs)}.song-added-by{font-size:.75rem;color:var(--text-muted);margin-right:auto}.song-view-provenance{font-size:.8rem;color:var(--text-muted);padding:var(--spacing-sm) 0;border-top:1px solid var(--border);margin-top:var(--spacing-md);text-align:center}.song-view-print-btn{display:inline-flex;align-items:center;padding:3px var(--spacing-sm);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:color .15s,border-color .15s}.song-view-print-btn:hover{color:var(--text-primary);border-color:var(--text-primary)}.print-panel-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;align-items:flex-start;justify-content:center;z-index:1000;padding:var(--spacing-md);overflow-y:auto}.print-panel{background:var(--bg-secondary);border-radius:var(--radius-lg);width:100%;max-width:680px;box-shadow:0 20px 40px #0000004d;overflow:hidden}.print-options{padding:var(--spacing-lg);border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:var(--spacing-md)}.print-options-header{display:flex;align-items:center;justify-content:space-between}.print-options-title{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.print-options-close{font-size:1rem;line-height:1}.print-options-chords-label{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-primary);cursor:pointer;font-size:.95rem}.print-options-chords-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.print-options-columns{display:flex;align-items:center;gap:var(--spacing-md)}.print-options-label{color:var(--text-secondary);font-size:.9rem}.print-options-column-btns{display:flex;gap:var(--spacing-xs)}.print-column-btn{padding:4px 16px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;font-size:.9rem;transition:all .15s}.print-column-btn--active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}.print-options-font{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.print-options-font-controls{display:flex;align-items:center;gap:var(--spacing-xs)}.print-font-btn{width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:1rem;cursor:pointer}.print-font-btn:hover{border-color:var(--accent);color:var(--accent)}.print-font-size{font-size:.85rem;color:var(--text-secondary);min-width:36px;text-align:center}.print-options-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.print-options-actions .btn-primary{display:flex;align-items:center;gap:6px;min-width:80px;justify-content:center}.print-spinner{animation:audio-spin .8s linear infinite;flex-shrink:0}.print-content{padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-lg) 48px;background:#fff;overflow-y:auto;position:relative}.print-page-break{position:absolute;left:0;right:0;height:0;border-top:2px dashed #bbb;pointer-events:none;display:flex;align-items:flex-start;padding-top:4px;padding-left:var(--spacing-lg)}.print-page-break-label{font-size:.7rem;color:#bbb;background:#fff;padding:0 4px;line-height:1;position:relative;top:-.5em;pointer-events:none}.print-two-columns{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl);align-items:start}.print-metadata{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border);overflow:hidden}.print-qr{float:right;margin-left:1rem}.print-qr svg{display:block}.print-metadata-title{font-size:1.4rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.print-metadata-sub{font-size:.9rem;color:var(--text-primary);margin:0}.print-content .word,.print-content .lyrics-line,.print-content .section-label,.print-content .print-metadata-title,.print-content .print-metadata-sub{color:#000}.print-body{display:none}@media print{@page{margin:.5in .4in .7in .6in;size:letter}body>*{display:none!important}.print-body{display:block!important;padding:0;background:#fff!important;color:#000!important;font-family:SF Mono,Fira Code,Consolas,monospace;-webkit-print-color-adjust:exact;print-color-adjust:exact}.print-body .print-two-columns{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}.print-body *{color:#000!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.print-body .chord{color:#f59e0b!important}.print-body .section-label{font-weight:700}}
