.loading-state,.loading-splash{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 300px);color:var(--text-secondary);padding:3rem 1rem}.loading-splash{min-height:100vh;background:var(--bg-primary)}.loading-splash .spinner{width:64px;height:64px;border-width:5px}.loading-splash p{font-size:1.1rem;margin-top:1.5rem;color:var(--accent);font-weight:500}.spinner{width:48px;height:48px;border:4px solid var(--bg-tertiary);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-state p{font-size:1rem;margin-top:1rem}.loading-more{display:flex;justify-content:center;align-items:center;padding:1.5rem}.loading-more .spinner{width:28px;height:28px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.app-container{animation:fadeIn .3s ease-in}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 300px);color:var(--text-secondary);padding:3rem 1rem}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.3}.primary-btn{background:var(--accent);border:none;color:var(--text-primary);padding:.75rem 2rem;border-radius:24px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s;min-height:44px}.primary-btn:hover{background:var(--accent-hover);transform:scale(1.05)}.secondary-btn{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);padding:.75rem 2rem;border-radius:24px;cursor:pointer;font-size:1rem;transition:all .2s;min-height:44px}.secondary-btn:hover{background:var(--bg-tertiary);border-color:var(--accent)}.primary-btn:disabled,.secondary-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);padding:.5rem 1rem;border-radius:20px;cursor:pointer;font-size:.9rem;transition:all .2s;min-height:44px}.action-btn:hover{background:var(--bg-tertiary);border-color:var(--accent)}.back-btn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:1rem;padding:.5rem 0;margin-bottom:1rem;min-height:44px}.back-btn:hover{text-decoration:underline}.action-buttons{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1rem}.detail-view{animation:slideIn .2s ease-out;padding-bottom:2rem}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.detail-title{font-size:2rem;margin-bottom:1rem}.detail-subtitle{font-size:1.1rem;color:var(--text-secondary);margin:-.5rem 0 1.5rem;font-weight:400}.detail-actions{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.track-list{display:flex;flex-direction:column;gap:.5rem}.track-item{width:100%;padding:.75rem;background:var(--bg-secondary);border-radius:8px;transition:background .2s;border:none;color:var(--text-primary);text-align:left;cursor:pointer;font-family:inherit}.track-item:hover{background:var(--bg-tertiary)}.track-item:active{background:var(--accent);opacity:.8}.search-container{display:flex;gap:12px;padding:12px 0;flex-shrink:0}.search-input-wrapper{position:relative;flex:1;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:#fff6;pointer-events:none;z-index:1}.search-input{width:100%;padding:10px 40px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:20px;color:#fff;font-size:14px;outline:none;transition:all .2s}.search-input:focus{background:#ffffff14;border-color:var(--accent)}.search-input::placeholder{color:#ffffff4d}.search-clear-btn{position:absolute;right:12px;padding:4px;background:none;border:none;color:#fff6;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s;z-index:1}.search-clear-btn:hover{color:#fffc}@media(max-width:480px){.detail-title{font-size:1.5rem}.empty-state{min-height:calc(100vh - 250px);padding:2rem 1rem}.empty-icon{font-size:3rem}.loading-splash .spinner{width:56px;height:56px}.loading-splash p{font-size:1rem}}.now-playing-queue-view{display:flex;flex-direction:column;height:100%;overflow:hidden}.now-playing-header-fixed{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem 1rem .5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.album-art-large{width:200px;height:200px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);border-radius:12px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;flex-shrink:0;box-shadow:0 4px 12px #0000004d}.album-art-large img,.album-art-image{width:100%;height:100%;object-fit:cover;position:absolute;top:0;left:0;z-index:1}.album-art-large .album-initial-large{font-size:5rem;font-weight:700;opacity:.3;position:relative;z-index:0}.track-info-large{width:100%;text-align:center}.track-title-large{font-size:1.25rem;font-weight:700;margin:0 0 .5rem;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.track-artist-large{font-size:1rem;color:var(--text-secondary);margin:0 0 .25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-album-large{font-size:.9rem;color:var(--text-secondary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.now-playing-queue-view .progress-container-large{width:100%;max-width:400px}.time-display{display:flex;justify-content:space-between;align-items:center;width:100%;font-size:.8rem;color:var(--text-secondary);margin-bottom:.25rem}.now-playing-queue-view .progress-bar{-webkit-appearance:none!important;appearance:none!important;width:100%;height:24px;background:transparent!important;cursor:pointer;display:block;margin:0;border:none}.now-playing-queue-view .progress-bar::-webkit-slider-runnable-track{width:100%;height:3px;background:var(--bg-tertiary);border-radius:2px}.now-playing-queue-view .progress-bar::-moz-range-track{width:100%;height:3px;background:var(--bg-tertiary);border-radius:2px}.now-playing-queue-view .progress-bar::-webkit-slider-thumb{-webkit-appearance:none;height:14px;width:14px;border-radius:50%;background:var(--text-primary);cursor:pointer;margin-top:-5.5px;box-shadow:0 2px 4px #00000080;border:none}.now-playing-queue-view .progress-bar::-moz-range-thumb{height:14px;width:14px;border:none;border-radius:50%;background:var(--text-primary);cursor:pointer}.now-playing-queue-view .progress-bar:focus{outline:none}.no-track-playing{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border);color:var(--text-secondary);flex-shrink:0}.no-track-icon{font-size:2rem;opacity:.5}.no-track-text{font-size:1rem}.queue-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:var(--bg-primary);flex-shrink:0}.queue-header h2{font-size:1.25rem;margin:0}.clear-all-btn{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);padding:.5rem 1rem;border-radius:20px;cursor:pointer;font-size:.9rem;transition:all .2s}.clear-all-btn:hover{background:var(--accent);border-color:var(--accent)}.queue-list-scrollable,.queue-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 1rem 1rem;display:flex;flex-direction:column;gap:.5rem;-webkit-overflow-scrolling:touch}.queue-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--bg-secondary);border-radius:8px;transition:background .2s;flex-shrink:0}.queue-item:hover{background:var(--bg-tertiary)}.queue-item.current-track{background:#9b59b633;border-left:3px solid var(--accent);padding-left:calc(.75rem - 3px)}.queue-item.current-track:hover{background:#9b59b64d}.reorder-buttons{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.reorder-btn{background:none;border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:all .2s;border-radius:4px;min-width:24px;min-height:20px}.reorder-btn:hover:not(:disabled){background:var(--bg-tertiary);color:var(--accent);border-color:var(--accent)}.reorder-btn:disabled{opacity:.3;cursor:not-allowed}.reorder-btn:active:not(:disabled){background:var(--accent);color:#fff;transform:scale(.95)}.play-track-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;transition:color .2s;flex-shrink:0}.play-track-btn:hover{color:var(--accent)}.track-details{flex:1;min-width:0}.track-name{font-size:1rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-meta{font-size:.85rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-duration{font-size:.85rem;color:var(--text-secondary);flex-shrink:0}.delete-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;transition:color .2s;flex-shrink:0}.delete-btn:hover{color:#f44}@media(max-width:768px){.album-art-large{width:180px;height:180px}.album-initial-large{font-size:4rem!important}.track-title-large{font-size:1.1rem}.track-artist-large,.track-album-large{font-size:.9rem}}@media(max-width:480px){.now-playing-header-fixed{padding:.75rem 1rem .5rem}.album-art-large{width:160px;height:160px}.album-initial-large{font-size:3.5rem!important}}.library-view{max-width:800px;margin:0 auto;padding:1rem 1rem 2rem;display:flex;flex-direction:column;height:100%}.library-tabs{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:1px solid var(--border);flex-shrink:0}.tab{background:none;border:none;color:var(--text-secondary);padding:.75rem 1.5rem;cursor:pointer;font-size:1rem;border-bottom:2px solid transparent;transition:all .2s;min-height:44px}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.albums-tab,.tracks-tab,.albums-grid-container{display:flex;flex-direction:column;flex:1;overflow:hidden;min-height:0}.albums-tab .detail-view{flex:1;overflow-y:auto;min-height:0;padding-bottom:2rem}.tracks-main{display:flex;flex-direction:column;flex:1;overflow:hidden;min-height:0}.filter-bar{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem 0;flex-shrink:0}.filter-group{display:flex;flex-direction:column;gap:.35rem;flex:0 1 auto}.filter-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.filter-select{padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:all .2s;min-width:140px}.filter-select:hover{border-color:var(--accent);background:var(--bg-secondary)}.filter-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #9b59b626}.quality-toggle{display:flex;gap:.5rem}.quality-btn{padding:.5rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:.85rem;font-weight:600;transition:all .2s;white-space:nowrap}.quality-btn:hover{background:var(--bg-secondary);border-color:var(--accent);color:var(--text-primary)}.quality-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.search-container{flex-shrink:0}.track-list-compact{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:.5rem;-webkit-overflow-scrolling:touch;padding-bottom:1rem}.track-row-compact{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:8px;transition:all .2s;border:1px solid transparent}.track-row-compact:hover{background:var(--bg-tertiary);border-color:var(--border)}.track-main-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.35rem}.track-title{font-size:.95rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-meta-row{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem;font-size:.85rem;color:var(--text-secondary);line-height:1.4}.track-meta-row>span{flex-shrink:0}.track-format{font-size:.8rem;color:var(--text-secondary);font-family:SF Mono,Monaco,Courier New,monospace;background:#9b59b61a;padding:.15rem .5rem;border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.clickable-link{background:none;border:none;color:var(--accent);padding:0;margin:0;cursor:pointer;font-size:inherit;text-decoration:none;transition:opacity .2s;display:inline}.clickable-link:hover{opacity:.8;text-decoration:underline}.add-track-btn{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary);padding:.5rem;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;width:36px;height:36px;flex-shrink:0}.add-track-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:scale(1.08)}.add-track-btn svg{width:18px;height:18px}.item-grid,.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;overflow-y:auto;overflow-x:hidden;flex:1;padding-bottom:1rem}.album-grid::-webkit-scrollbar,.track-list-compact::-webkit-scrollbar{width:8px}.album-grid::-webkit-scrollbar-track,.track-list-compact::-webkit-scrollbar-track{background:var(--bg-primary)}.album-grid::-webkit-scrollbar-thumb,.track-list-compact::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}.album-grid::-webkit-scrollbar-thumb:hover,.track-list-compact::-webkit-scrollbar-thumb:hover{background:var(--accent)}.grid-item{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:1rem;cursor:pointer;text-align:center;transition:all .2s}.grid-item:hover{background:var(--bg-tertiary);transform:translateY(-2px)}.item-art{width:100%;aspect-ratio:1;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:700;opacity:.7;margin-bottom:.75rem;overflow:hidden;position:relative}.item-art img{width:100%;height:100%;object-fit:cover;position:absolute;top:0;left:0;z-index:1}.item-art span{position:relative;z-index:0;opacity:.3}.item-name{font-size:.95rem;font-weight:500;margin-bottom:.25rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-meta{font-size:.8rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:768px){.filter-bar{flex-direction:column;gap:.75rem}.filter-group{width:100%}.filter-select{width:100%;min-width:auto}.quality-toggle{width:100%}.quality-btn{flex:1}.track-title{font-size:.9rem}.track-meta-row{font-size:.8rem}.track-format{font-size:.75rem}.item-grid,.album-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}}@media(max-width:480px){.library-view{padding:.75rem}.filter-bar{padding:.5rem 0;gap:.5rem}.filter-label{font-size:.7rem}.filter-select{font-size:.85rem;padding:.4rem .6rem}.quality-btn{font-size:.8rem;padding:.4rem .6rem}.track-row-compact{padding:.6rem .75rem}.add-track-btn{width:32px;height:32px}.add-track-btn svg{width:16px;height:16px}.item-grid,.album-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}}.bottom-controls-container{display:flex;flex-direction:column;background:var(--bg-secondary);border-top:1px solid var(--border);flex-shrink:0;position:sticky;bottom:0;left:0;right:0;z-index:100}.navigation-row{display:flex;justify-content:space-between;align-items:center;padding:.35rem .75rem;padding-bottom:calc(.35rem + var(--safe-area-inset-bottom))}.nav-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.nav-button:hover{color:var(--text-primary);background:var(--bg-tertiary)}.nav-button.active{color:var(--accent)}.settings-button{color:var(--text-secondary)}.settings-button:hover{color:var(--accent)}.control-btn{background:none;border:none;color:var(--text-primary);cursor:pointer;padding:.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;min-width:44px;min-height:44px}.control-btn:hover{background:var(--bg-tertiary);transform:scale(1.1)}.play-btn{background:var(--accent);padding:.75rem}.play-btn:hover{background:var(--accent-hover)}.control-btn.active{background:#9b59b633;color:var(--accent)}.control-btn.active:hover{background:#9b59b64d;color:var(--accent);transform:scale(1.1)}@media(max-width:768px){.navigation-row{padding:.3rem .6rem}.control-btn{padding:.4rem;min-width:40px;min-height:40px}.play-btn{padding:.6rem}}@media(max-width:480px){.navigation-row{padding:.5rem}.control-btn{padding:.35rem;min-width:38px;min-height:38px}.play-btn{padding:.5rem}}@supports (-webkit-touch-callout: none){.navigation-row{padding-bottom:calc(.35rem + max(var(--safe-area-inset-bottom),15px))!important}.content-area{padding-bottom:calc(100px + max(var(--safe-area-inset-bottom),15px))!important}}@media(hover:none)and (pointer:coarse){button:active,.grid-item:active,.tab:active{opacity:.7;transform:scale(.98);transition:all .1s ease}}.settings-modal{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center}.settings-modal.open{display:flex}.modal-backdrop{position:absolute;inset:0;background:#000000b3}.modal-content{position:relative;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;width:90%;max-width:700px;max-height:90vh;overflow:auto;z-index:1}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-secondary);z-index:1}.modal-header h2{margin:0;font-size:1.5rem}.close-btn{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;line-height:1}.close-btn:hover{color:var(--text-primary)}.modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:2rem}.settings-section{display:flex;flex-direction:column;gap:1rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}.settings-section:last-child{border-bottom:none;padding-bottom:0}.section-title{margin:0 0 .5rem;font-size:1.25rem;color:var(--text-primary)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-secondary)}.form-control{width:100%;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:1rem;font-family:inherit}.form-control:focus{outline:none;border-color:var(--accent)}.form-text{display:block;margin-top:.25rem;font-size:.85rem;color:var(--text-secondary);font-style:italic}.setting-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px;margin-bottom:1rem}.setting-info{flex:1}.setting-label{display:block;font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.setting-description{font-size:.85rem;color:var(--text-secondary);margin:0;line-height:1.4}.toggle-switch{position:relative;display:inline-block;width:56px;height:30px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--bg-secondary);border:2px solid var(--border);transition:all .3s;border-radius:30px}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:2px;bottom:2px;background-color:var(--text-secondary);transition:all .3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:var(--accent);border-color:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(26px);background-color:#fff}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 0 3px #9b59b64d}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.toggle-slider:hover{background-color:var(--bg-tertiary)}.toggle-switch input:checked+.toggle-slider:hover{background-color:var(--accent-hover)}.test-result{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border-radius:8px;animation:slideIn .3s ease-out;margin-bottom:1rem}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.test-success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3)}.test-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3)}.test-icon{font-size:1.5rem;flex-shrink:0;line-height:1}.test-success .test-icon{color:#4ade80}.test-error .test-icon{color:#f87171}.test-message{flex:1;display:flex;flex-direction:column;gap:.25rem}.test-message strong{font-size:1rem;font-weight:600}.test-success .test-message strong{color:#4ade80}.test-error .test-message strong{color:#f87171}.test-message span{font-size:.9rem;color:var(--text-secondary)}.error-banner,.success-banner{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:6px;font-size:.95rem;margin-bottom:1rem}.error-banner{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171}.success-banner{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#4ade80}.error-icon,.success-icon{font-size:1.25rem;flex-shrink:0}.dismiss-btn{margin-left:auto;background:none;border:none;color:inherit;font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;opacity:.7;transition:opacity .2s}.dismiss-btn:hover{opacity:1}.status-card{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;padding:1rem;margin-bottom:1rem}.status-indicator{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;margin-bottom:1rem;padding:.75rem;border-radius:6px}.status-indicator.status-running{background:#3b82f61a;border:1px solid rgba(59,130,246,.3);color:#60a5fa}.status-indicator.status-completed{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#4ade80}.status-indicator.status-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171}.status-indicator.status-idle{background:#9ca3af1a;border:1px solid rgba(156,163,175,.3);color:#9ca3af}.progress-section{display:flex;flex-direction:column;gap:1.5rem}.progress-subsection{display:flex;flex-direction:column;gap:.5rem}.progress-subsection h4{margin:0;font-size:.95rem;color:var(--text-secondary)}.progress-bar-container{width:100%;height:8px;background:var(--bg-primary);border-radius:4px;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-hover));transition:width .3s ease}.progress-info{display:flex;justify-content:space-between;font-size:.85rem;color:var(--text-secondary)}.current-album{font-size:.85rem;color:var(--text-secondary);font-style:italic;margin-top:.25rem}.stat-item{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-radius:6px;font-size:.9rem}.stat-item.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171}.stat-icon{font-size:1.25rem;flex-shrink:0}.error-message{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#f87171}.stats-panel{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;padding:1rem;margin-bottom:1rem}.stats-panel h4{margin:0 0 1rem;font-size:1rem;color:var(--text-primary)}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1rem}.stat-box{background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;padding:1rem;text-align:center}.stat-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.stat-value{font-size:1.5rem;font-weight:700;color:var(--accent);margin-bottom:.25rem}.stat-detail{font-size:.8rem;color:var(--text-secondary)}.codec-breakdown{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.codec-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.codec-badge{display:inline-block;padding:.25rem .75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;font-size:.85rem;color:var(--text-primary)}.last-indexed{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border);font-size:.85rem;color:var(--text-secondary);text-align:center}@media(max-width:768px){.setting-item{flex-direction:column;align-items:flex-start}.toggle-switch{align-self:flex-end}.action-buttons{flex-direction:column}.action-buttons button{width:100%}}@media(max-width:480px){.modal-content{max-width:95%;max-height:95vh}.test-result{padding:.75rem;gap:.5rem}.test-icon{font-size:1.25rem}.test-message strong{font-size:.95rem}.test-message span{font-size:.85rem}}.section-description{font-size:.88rem;color:var(--text-secondary);margin:-.5rem 0 .5rem;line-height:1.5}.section-description code{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:4px;padding:.1rem .4rem;font-size:.85em;color:var(--accent)}.index-steps{display:flex;align-items:center;gap:0;margin:.5rem 0 1rem;padding:1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px}.index-step{display:flex;flex-direction:column;align-items:center;gap:.4rem;flex:1;text-align:center}.step-icon{font-size:1.3rem;line-height:1}.step-label{font-size:.78rem;font-weight:500;line-height:1.3}.index-step.step-pending .step-icon,.index-step.step-pending .step-label{color:var(--text-secondary);opacity:.5}.index-step.step-active .step-label{color:#60a5fa;font-weight:700}.index-step.step-done .step-label{color:#4ade80}.step-connector{flex:0 0 24px;height:2px;background:var(--border);margin-bottom:1.2rem}:root{--bg-primary: #0a0a0a;--bg-secondary: #1a1a1a;--bg-tertiary: #2a2a2a;--text-primary: #ffffff;--text-secondary: #b3b3b3;--accent: #9b59b6;--accent-hover: #8e44ad;--border: #333333;--safe-area-inset-top: env(safe-area-inset-top, 0px);--safe-area-inset-right: env(safe-area-inset-right, 0px);--safe-area-inset-bottom: env(safe-area-inset-bottom, 0px);--safe-area-inset-left: env(safe-area-inset-left, 0px)}*{margin:0;padding:0;box-sizing:border-box;max-width:100%}body,html{margin:0;padding:0;width:100%;height:100%;overflow-x:hidden;overscroll-behavior:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow:hidden}img{max-width:100%;height:auto}button{font-family:inherit}.app-container{display:flex;flex-direction:column;height:100vh;max-width:100vw;padding-top:var(--safe-area-inset-top);padding-right:var(--safe-area-inset-right);padding-bottom:var(--safe-area-inset-bottom);padding-left:var(--safe-area-inset-left)}.content-area{flex:1;overflow:hidden;-webkit-overflow-scrolling:touch}.connection-indicator{position:fixed;top:var(--safe-area-inset-top);left:0;right:0;background:#fbbf24f2;color:#000;padding:.5rem 1rem;display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.9rem;font-weight:500;z-index:9998;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:slideDown .3s ease-out;cursor:pointer}.connection-indicator.reconnecting{background:#3b82f6f2;color:#fff}.connection-indicator.disconnected{background:#ef4444f2;color:#fff}.connection-icon{font-size:1.2rem;animation:pulse 2s infinite}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.connection-indicator~.app-container{padding-top:calc(var(--safe-area-inset-top) + 48px)}
