:root{--space-3xs:.15rem;--space-2xs:.25rem;--space-xs:.3rem;--space-sm:.4rem;--space-md:.5rem;--space-base:.75rem;--space-lg:1rem;--space-xl:1.25rem;--space-2xl:1.5rem;--space-3xl:2rem;--space-4xl:3rem;--content-padding-x:var(--space-lg);--content-padding-y:var(--space-base);--sheet-padding:var(--space-xl);--radius-sm:6px;--radius-md:8px;--radius-lg:10px;--radius-badge:12px;--radius-xl:16px;--radius-circle:50%;--radius-pill:9999px;--transition-instant:.1s;--transition-quick:.15s;--transition-standard:.2s;--transition-sheet:.35s;--transition-dismiss:.4s;--ease-sheet:cubic-bezier(.2, .9, .3, 1);--ease-dismiss:cubic-bezier(.4, 0, 1, 1);--ease-route:cubic-bezier(.4, 0, .2, 1);--text-display:2rem;--text-title-lg:1.5rem;--text-title:1.25rem;--text-title-sm:1rem;--text-body:.95rem;--text-body-sm:.85rem;--text-caption:.75rem;--text-micro:.65rem}body.theme-classic{--bg:#1a1a2e;--surface:#22223a;--surface-alt:#2a2a44;--camera-bg:#000;--text:#e0e0e0;--text-secondary:#8a8a9a;--text-on-accent:#fff;--text-inverse:#000;--border:#335;--accent:#7c5cbf;--accent-light:#9b7dd4;--accent-rgb:124, 92, 191;--success:#4caf50;--success-rgb:76, 175, 80;--warning:#ff9800;--warning-rgb:255, 152, 0;--danger:#f44336;--danger-rgb:244, 67, 54;--danger-dark:#dc2626;--scanner-accent-rgb:99, 59, 159;--scanner-confirm:#22c55e;--scanner-confirm-rgb:34, 197, 94;--scanner-confirm-dark:#16a34a;--scanner-confirm-bright:#4ade80;--scanner-laser:#ff2020;--scanner-laser-rgb:255, 30, 30;--scanner-laser-dot:#ff6060;--scanner-laser-dot-lit:#ff3030;--scanner-laser-dot-rgb:255, 40, 40;--scanner-warning:#f59e0b;--scanner-warning-rgb:245, 158, 11;--pipeline-gemini:#4285f4;--pipeline-barcode:#f59e0b;--pipeline-vision:#a855f7;--overlay-rgb:0, 0, 0;--white-rgb:255, 255, 255;--match-placeholder-bg:#333;--match-placeholder-text:#888;--manual-placeholder-text:#666;--font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--shadow-flat:0 1px 3px #0000004d;--shadow-subtle:0 1px 4px #0000004d;--shadow-card:0 2px 8px #0000004d;--shadow-hover:0 4px 16px #0003;--shadow-modal:0 8px 32px #0006;--shadow-danger:0 4px 16px rgba(var(--danger-rgb), .5)}body.theme-workshop{--bg:#1a1512;--surface:#2d2620;--surface-alt:#342e27;--camera-bg:#0d0a08;--text:#f0e6d2;--text-secondary:#a09078;--text-on-accent:#1a1512;--text-inverse:#f0e6d2;--border:#4a3f34;--accent:#c4935f;--accent-light:#d4a244;--accent-rgb:196, 147, 95;--success:#6b9e8a;--success-rgb:107, 158, 138;--warning:#d4a244;--warning-rgb:212, 162, 68;--danger:#c4644a;--danger-rgb:196, 100, 74;--danger-dark:#a8503a;--scanner-accent-rgb:160, 120, 60;--scanner-confirm:#6b9e8a;--scanner-confirm-rgb:107, 158, 138;--scanner-confirm-dark:#548272;--scanner-confirm-bright:#82b49e;--scanner-laser:#c4644a;--scanner-laser-rgb:196, 100, 74;--scanner-laser-dot:#d47a62;--scanner-laser-dot-lit:#c4644a;--scanner-laser-dot-rgb:196, 100, 74;--scanner-warning:#d4a244;--scanner-warning-rgb:212, 162, 68;--pipeline-gemini:#6b9e8a;--pipeline-barcode:#d4a244;--pipeline-vision:#c4935f;--overlay-rgb:13, 10, 8;--white-rgb:240, 230, 210;--match-placeholder-bg:#2d2620;--match-placeholder-text:#8b7d6d;--manual-placeholder-text:#6b5d4d;--font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-family-heading:Georgia, "Times New Roman", serif;--font-family-mono:"SF Mono", Menlo, "Courier New", monospace;--shadow-flat:0 1px 3px #0d0a0866;--shadow-subtle:0 1px 4px #0d0a0866;--shadow-card:0 2px 8px #0d0a0866;--shadow-hover:0 4px 16px #0d0a084d;--shadow-modal:0 8px 32px #0d0a0880;--shadow-danger:0 4px 16px rgba(var(--danger-rgb), .5)}body.theme-workshop h1,body.theme-workshop h2,body.theme-workshop h3{font-family:var(--font-family-heading);font-weight:400}body.theme-workshop .settings h2,body.theme-workshop .settings h3{font-family:var(--font-family-heading)}body.theme-workshop .album-detail-overlay{background:#0d0a08d1}body.theme-workshop .detail-cover-zone{position:relative}body.theme-workshop .detail-cover-zone:before{content:"";z-index:2;pointer-events:none;background:radial-gradient(at 50% 30%,#c4935f2e 0%,#c4935f1a 45%,#0000 75%);animation:4s ease-in-out infinite workshopLampGlow;position:absolute;inset:0}body.theme-workshop .detail-filmstrip{z-index:1;position:relative}body.theme-workshop .detail-close{z-index:5}body.theme-workshop .detail-flag-banner{z-index:3;position:relative}body.theme-workshop .detail-cover{box-shadow:0 4px 30px #c4935f26,0 0 60px #c4935f0f}body.theme-workshop .detail-body{box-shadow:0 -2px 20px #c4935f0f}@keyframes workshopLampGlow{0%,to{opacity:.8}50%{opacity:1}}body.theme-workshop .album-card:hover{border-color:#c4935f26;box-shadow:0 4px 20px #c4935f1a}body.theme-workshop .genre-tag{background:var(--accent);color:var(--text-on-accent);font-weight:500}body.theme-workshop .style-tag{border-color:#c4935f80}body.theme-workshop .meta-chip{background:#c4935f1a;border:1px solid #c4935f1f}body.theme-workshop .track-duration{font-family:var(--font-family-mono);letter-spacing:.02em;font-size:.78rem}body.theme-workshop .detail-tracklist h3{letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);font-size:.7rem;font-family:var(--font-family);font-weight:500}body.theme-workshop .metadata-label,body.theme-workshop .edit-label{font-family:var(--font-family);letter-spacing:.08em}body.theme-workshop .collection-chip{background:#c4935f14;border-color:#c4935f40}body.theme-workshop .detail-drag-pill{background:#c4935f59}body.theme-workshop .detail-close{color:var(--text);background:#2d2620b3;border:1px solid #c4935f4d}body.theme-workshop .detail-close:active{background:#2d2620e6}body.theme-workshop .nav-icon.active{color:var(--accent)}body.theme-workshop .search-input:focus,body.theme-workshop input[type=text]:focus{border-color:#c4935f66;box-shadow:0 0 0 2px #c4935f14}body.theme-workshop select{background:var(--surface);color:var(--text);border-color:var(--border)}body.theme-workshop .detail-collection-btn{color:var(--accent);border-color:#c4935f40}body.theme-workshop .detail-collection-btn:active{background:#c4935f14}body.theme-workshop .location-icon{color:#0000;vertical-align:middle;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23C4935F'%3E%3Cpath d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5a2.5 2.5 0 1 1 0-5 2.5 2.5 0 0 1 0 5z'/%3E%3C/svg%3E") 50%/contain no-repeat;width:16px;height:16px;margin-right:4px;font-size:0;display:inline-block}body.theme-workshop .filter-chip--active{background:var(--accent-light);border-color:var(--accent-light);box-shadow:0 0 0 2px #c4935f4d}body.theme-workshop ::-webkit-scrollbar{width:6px}body.theme-workshop ::-webkit-scrollbar-track{background:var(--bg)}body.theme-workshop ::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}body.theme-workshop ::-webkit-scrollbar-thumb:hover{background:#c4935f66}:root,body.theme-workshop-light{--bg:#f5f0e8;--surface:#fdfbf7;--surface-alt:#ede8e0;--camera-bg:#000;--text:#3d3227;--text-secondary:#6b5d4f;--text-on-accent:#fff;--text-inverse:#f0e6d2;--border:#d8d0c4;--accent:#9a6b3a;--accent-light:#b07e4a;--accent-rgb:154, 107, 58;--success:#2e8b57;--success-rgb:46, 139, 87;--warning:#c87f00;--warning-rgb:200, 127, 0;--danger:#c0392b;--danger-rgb:192, 57, 43;--danger-dark:#a93226;--scanner-accent-rgb:160, 120, 60;--scanner-confirm:#6b9e8a;--scanner-confirm-rgb:107, 158, 138;--scanner-confirm-dark:#548272;--scanner-confirm-bright:#82b49e;--scanner-laser:#c4644a;--scanner-laser-rgb:196, 100, 74;--scanner-laser-dot:#d47a62;--scanner-laser-dot-lit:#c4644a;--scanner-laser-dot-rgb:196, 100, 74;--scanner-warning:#d4a244;--scanner-warning-rgb:212, 162, 68;--pipeline-gemini:#3672d0;--pipeline-barcode:#c87f00;--pipeline-vision:#8b5cc0;--overlay-rgb:60, 50, 40;--white-rgb:255, 255, 255;--match-placeholder-bg:#ede7dd;--match-placeholder-text:#a09080;--manual-placeholder-text:#b0a090;--font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-family-heading:Georgia, "Times New Roman", serif;--font-family-mono:"SF Mono", Menlo, "Courier New", monospace;--shadow-flat:0 1px 3px #00000014;--shadow-subtle:0 1px 4px #0000000f;--shadow-card:0 2px 8px #00000012;--shadow-hover:0 4px 16px #0000000f;--shadow-modal:0 8px 32px #0000001f;--shadow-danger:0 4px 16px rgba(var(--danger-rgb), .45)}body.theme-workshop-light h1,body.theme-workshop-light h2,body.theme-workshop-light h3{font-family:var(--font-family-heading);font-weight:400}body.theme-workshop-light .settings h2,body.theme-workshop-light .settings h3{font-family:var(--font-family-heading)}body.theme-workshop-light .album-detail-overlay{background:#3c3228a6}body.theme-workshop-light .detail-cover-zone{position:relative}body.theme-workshop-light .detail-cover-zone:before{content:"";z-index:2;pointer-events:none;background:radial-gradient(at 50% 30%,#c8a0501f 0%,#c8a0500f 45%,#0000 75%);animation:4s ease-in-out infinite workshopLightLampGlow;position:absolute;inset:0}body.theme-workshop-light .detail-filmstrip{z-index:1;position:relative}body.theme-workshop-light .detail-close{z-index:5}body.theme-workshop-light .detail-flag-banner{z-index:3;position:relative}body.theme-workshop-light .detail-cover{box-shadow:0 4px 24px #64461e26,0 0 40px #b48c3c0f}body.theme-workshop-light .detail-body{box-shadow:0 -2px 16px #b48c3c0a}@keyframes workshopLightLampGlow{0%,to{opacity:.7}50%{opacity:1}}body.theme-workshop-light .album-card:hover{border-color:#9a6b3a33;box-shadow:0 4px 20px #64461e1a}body.theme-workshop-light .genre-tag{background:var(--accent);color:var(--text-on-accent);font-weight:500}body.theme-workshop-light .style-tag{border-color:#9a6b3a66}body.theme-workshop-light .meta-chip{background:#9a6b3a14;border:1px solid #9a6b3a1f}body.theme-workshop-light .track-duration{font-family:var(--font-family-mono);letter-spacing:.02em;font-size:.78rem}body.theme-workshop-light .detail-tracklist h3{letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);font-size:.7rem;font-family:var(--font-family);font-weight:500}body.theme-workshop-light .metadata-label,body.theme-workshop-light .edit-label{font-family:var(--font-family);letter-spacing:.08em}body.theme-workshop-light .collection-chip{background:#9a6b3a0f;border-color:#9a6b3a33}body.theme-workshop-light .detail-drag-pill{background:#9a6b3a4d}body.theme-workshop-light .detail-close{color:#3d3227;background:#f5f0e8cc;border:1px solid #9a6b3a33}body.theme-workshop-light .detail-close:active{background:#f5f0e8f2}body.theme-workshop-light .nav-icon.active{color:var(--accent)}body.theme-workshop-light .search-input:focus,body.theme-workshop-light input[type=text]:focus{border-color:#9a6b3a80;box-shadow:0 0 0 2px #9a6b3a1a}body.theme-workshop-light select{background:var(--surface);color:var(--text);border-color:var(--border)}body.theme-workshop-light .detail-collection-btn{color:var(--accent);border-color:#9a6b3a40}body.theme-workshop-light .detail-collection-btn:active{background:#9a6b3a0f}body.theme-workshop-light .location-icon{color:#0000;vertical-align:middle;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%239A6B3A'%3E%3Cpath d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5a2.5 2.5 0 1 1 0-5 2.5 2.5 0 0 1 0 5z'/%3E%3C/svg%3E") 50%/contain no-repeat;width:16px;height:16px;margin-right:4px;font-size:0;display:inline-block}body.theme-workshop-light .filter-chip--active{background:var(--accent);border-color:var(--accent);color:var(--text-on-accent);box-shadow:0 0 0 2px #9a6b3a40}body.theme-workshop-light ::-webkit-scrollbar{width:6px}body.theme-workshop-light ::-webkit-scrollbar-track{background:var(--bg)}body.theme-workshop-light ::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}body.theme-workshop-light ::-webkit-scrollbar-thumb:hover{background:#9a6b3a59}body.theme-workshop-light .toggle-row input[type=checkbox]{background:#d0c8bc}body.theme-workshop-light .toggle-row input[type=checkbox]:after{background:#fdfbf7}body.theme-workshop-light .toggle-row input[type=checkbox]:checked{background:var(--accent)}body.theme-workshop-light .toggle-row input[type=checkbox]:checked:after{background:#fff}:root{font-family:var(--font-family);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.5}*{box-sizing:border-box}html,body{overscroll-behavior:none;background-color:var(--bg,#f5f0e8);width:100%;height:100%;margin:0;position:fixed;overflow:hidden}#root{height:100%;overflow:hidden}h1,h2,h3{color:var(--text);font-weight:600}.btn{cursor:pointer;border:none;border-radius:8px;padding:.65rem 1.25rem;font-size:1rem;font-weight:500;transition:opacity .15s,transform .1s}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:default}.btn-primary{background:var(--accent);color:var(--text-on-accent)}.btn-primary:hover:not(:disabled){background:var(--accent-light)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-alt)}:root{--keyboard-height:0px;--navbar-height:36px;--navbar-total-height:calc(var(--navbar-height) + env(safe-area-inset-bottom,0px))}.keyboard-open .create-collection-overlay,.keyboard-open .atc-overlay,.keyboard-open .manual-add-overlay,.keyboard-open .album-detail-overlay{bottom:var(--keyboard-height,0px)}.keyboard-open .create-collection,.keyboard-open .atc-sheet,.keyboard-open .manual-add,.keyboard-open .album-detail{max-height:calc(100dvh - var(--keyboard-height,0px))}.keyboard-open .create-collection-footer{padding-bottom:1.25rem}.auth-screen{background:var(--bg);justify-content:center;align-items:center;min-height:100dvh;padding:1.5rem;display:flex}.auth-card{text-align:center;width:100%;max-width:360px}.auth-logo{letter-spacing:-.03em;color:var(--text);margin:0 0 .25rem;font-size:2rem;font-weight:800}.auth-tagline{color:var(--text-secondary);margin:0 0 2rem;font-size:.95rem}.auth-form{flex-direction:column;gap:.75rem;display:flex}.auth-input{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);border-radius:8px;outline:none;padding:.75rem 1rem;font-size:16px;transition:border-color .15s}.auth-input:focus{border-color:var(--accent)}.auth-input::placeholder{color:var(--text-secondary)}.auth-submit{width:100%;margin-top:.25rem;padding:.85rem;font-size:1rem}.auth-error{color:var(--danger);text-align:left;margin:0;font-size:.85rem}.auth-message{color:var(--success);text-align:left;margin:0;font-size:.85rem}.auth-links{flex-direction:column;gap:.5rem;margin-top:1.25rem;display:flex}.auth-link{color:var(--accent-light);cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:.85rem}.auth-link:hover{text-decoration:underline}.auth-beta-notice{border:1px solid var(--border);background:var(--surface);text-align:left;border-radius:10px;margin:0 0 1.25rem;padding:.9rem 1rem}.auth-beta-heading{letter-spacing:.04em;text-transform:uppercase;color:var(--accent);margin:0 0 .4rem;font-size:.85rem;font-weight:600}.auth-beta-body{color:var(--text-secondary);margin:0;font-size:.9rem;line-height:1.45}.auth-powered-by{border-top:1px solid var(--border);text-align:center;color:var(--text-secondary);margin-top:2rem;padding-top:1rem}.auth-powered-label{letter-spacing:.02em;margin:0 0 .4rem;font-size:.75rem}.auth-powered-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:.45rem;margin:0;font-size:.8rem;display:flex}.auth-powered-link{color:var(--text-secondary);text-underline-offset:2px;align-items:center;gap:.3rem;font-weight:500;text-decoration:underline;transition:color .15s;display:inline-flex}.auth-powered-link:hover{color:var(--accent)}.auth-powered-mark{flex-shrink:0;width:14px;height:14px}.auth-powered-and{opacity:.7}.nav-bar{height:var(--navbar-total-height);padding:var(--space-lg) 0 calc(0rem + env(safe-area-inset-bottom,0px));background:var(--surface);border-top:1px solid var(--border);z-index:150;justify-content:space-around;align-items:center;max-width:480px;margin:0 auto;transition:transform .2s;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-bar--hidden{pointer-events:none;transform:translateY(100%)}.nav-link{color:var(--text-secondary);padding:.35rem var(--space-base);-webkit-tap-highlight-color:transparent;flex-direction:column;justify-content:center;align-items:center;text-decoration:none;transition:color .2s,transform .2s,filter .2s;display:flex;position:relative}.nav-link:active{transform:scale(.9)}.nav-link.active{color:var(--accent);filter:drop-shadow(0 0 6px rgba(var(--accent-rgb), .5));transform:scale(1.15)}.nav-link.active:active{transform:scale(1.05)}.nav-icon{justify-content:center;align-items:center;width:24px;height:24px;line-height:1;display:flex}.nav-icon svg{width:24px;height:24px;display:block}.nav-badge{background:var(--accent);color:var(--text-on-accent);border-radius:var(--radius-md);justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-size:.6rem;font-weight:700;display:flex;position:absolute;top:-2px;right:4px}.album-grid-container{padding:var(--space-lg)}.search-bar{margin-bottom:var(--space-lg);position:relative}.search-input{width:100%;padding:var(--space-base) var(--space-lg);border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);color:var(--text);padding-right:2.5rem;font-size:1rem}.search-input:focus{border-color:var(--accent);outline:none}.search-input::placeholder{color:var(--text-secondary)}.search-clear{right:var(--space-base);color:var(--text-secondary);cursor:pointer;padding:0 var(--space-2xs);background:0 0;border:none;font-size:1.3rem;position:absolute;top:50%;transform:translateY(-50%)}.album-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(140px,1fr));display:grid}.album-card{background:var(--surface);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:transform var(--transition-quick), box-shadow var(--transition-quick);color:var(--text);border:none;flex-direction:column;padding:0;display:flex;position:relative;overflow:hidden}.album-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.album-card--flagged{border:2px solid var(--warning);border-radius:var(--radius-lg)}.album-card-flag{background:var(--warning);border-radius:var(--radius-circle);width:22px;height:22px;color:var(--text-inverse);z-index:1;justify-content:center;align-items:center;font-size:.7rem;display:flex;position:absolute;top:4px;right:4px}.album-card-heart{background:var(--danger);border-radius:var(--radius-circle);color:#fff;z-index:1;justify-content:center;align-items:center;width:22px;height:22px;display:flex;position:absolute;top:4px;left:4px;box-shadow:0 1px 4px #0000004d}.album-cover{aspect-ratio:1;object-fit:cover;width:100%;display:block}.album-cover-placeholder{aspect-ratio:1;background:var(--surface-alt);width:100%;color:var(--text-secondary);justify-content:center;align-items:center;font-size:2rem;display:flex}.album-card-info{padding:.5rem .6rem}.album-card-title{white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.85rem;font-weight:600;overflow:hidden}.album-card-artist{margin:var(--space-3xs) 0 0;color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.grid-empty{text-align:center;padding:var(--space-4xl) var(--space-lg)}.empty-title{margin:0;font-size:1.1rem}.empty-hint{color:var(--text-secondary);margin:var(--space-md) 0 0}.grid-count{text-align:center;padding:var(--space-lg);color:var(--text-secondary);font-size:.8rem}.filter-bar{padding:0 var(--space-lg);margin-bottom:var(--space-md)}.filter-bar-row{gap:var(--space-md);align-items:center;display:flex}.sort-select{padding:var(--space-md) var(--space-base);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238a8a9a'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-base) center;padding-right:var(--space-3xl);flex:1;font-size:.85rem}.sort-select:focus{border-color:var(--accent);outline:none}.filter-toggle{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);padding:var(--space-md) var(--space-base);cursor:pointer;white-space:nowrap;font-size:.85rem;transition:border-color .15s,background .15s}.filter-toggle--active{border-color:var(--accent);background:var(--surface-alt)}.filter-clear-btn{color:var(--accent-light);cursor:pointer;padding:var(--space-2xs);white-space:nowrap;background:0 0;border:none;font-size:.8rem}.filter-panels{margin-top:var(--space-base);gap:var(--space-base);flex-direction:column;display:flex}.filter-group-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin:0 0 .35rem;font-size:.75rem;font-weight:500}.filter-chips{gap:var(--space-sm);flex-wrap:wrap;display:flex}.filter-chip{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-badge);color:var(--text);padding:var(--space-xs) .7rem;cursor:pointer;font-size:.8rem;transition:background .15s,border-color .15s}.filter-chip:hover{background:var(--surface-alt)}.filter-chip--active{background:var(--accent);border-color:var(--accent);color:var(--text-on-accent)}.filter-fav-toggle{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,border-color .15s,color .15s;display:flex}.filter-fav-toggle--active{background:var(--accent);border-color:var(--accent);color:var(--text-on-accent)}.filter-fav-toggle:active{transform:scale(.9)}.collection-grid{gap:var(--space-lg);padding:0 var(--space-lg) var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(130px,1fr));display:grid}.collection-card{cursor:pointer;text-align:center;color:var(--text);background:0 0;border:none;flex-direction:column;align-items:center;padding:0;display:flex;position:relative}.collection-card:active{opacity:.8}.collection-stack{width:120px;height:120px;margin-bottom:.1rem;position:relative;overflow:visible}.stack-layer{border-radius:var(--radius-sm);box-shadow:var(--shadow-subtle);position:absolute;overflow:hidden}.stack-layer img{object-fit:cover;width:100%;height:100%;display:block}.stack-layer--back{opacity:.45;width:86px;height:86px;top:0;left:0}.stack-layer--mid{opacity:.7;width:94px;height:94px;top:8px;left:8px}.stack-layer--front{opacity:1;width:100px;height:100px;bottom:0;right:0}.stack-placeholder-icon{color:var(--text-secondary);opacity:.5;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.stack-empty{border-radius:var(--radius-md);background:var(--surface-alt);width:100%;height:100%;color:var(--text-secondary);justify-content:center;align-items:center;display:flex}.stack-layer--placeholder{background:var(--surface-alt);border:2px solid var(--border);justify-content:center;align-items:center;display:flex}.stack-layer--new-front{background:var(--surface);border:2px solid var(--border);justify-content:center;align-items:center;display:flex}.stack-new-plus{color:var(--accent-light);font-size:3.2rem;font-weight:300;line-height:1}.collection-card-heart{background:var(--danger);border-radius:var(--radius-circle);color:#fff;z-index:3;justify-content:center;align-items:center;width:22px;height:22px;display:flex;position:absolute;top:9px;right:-5px;box-shadow:0 1px 4px #0000004d}.collection-card-name{white-space:nowrap;text-overflow:ellipsis;max-width:130px;margin:.35rem 0 0;font-size:.75rem;font-weight:600;overflow:hidden}.collection-card-count{color:var(--text-secondary);margin:.1rem 0 0;font-size:.68rem}.collection-no-results{text-align:center;padding:var(--space-3xl) var(--space-lg);color:var(--text-secondary);grid-column:1/-1;font-size:.9rem}.random-pick-overlay{background:rgba(var(--overlay-rgb), .8);z-index:150;flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;animation:.2s rpOverlayIn;display:flex;position:fixed;inset:0}@keyframes rpOverlayIn{0%{opacity:0}to{opacity:1}}.random-pick-close{background:rgba(var(--white-rgb), .1);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s;display:flex;position:absolute;top:1rem;right:1rem}.random-pick-close:active{background:rgba(var(--white-rgb), .2)}.random-pick-card{flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:280px;display:flex}.random-pick-card--spinning .random-pick-cover{animation:.1s rpShuffle}.random-pick-card--landed{animation:.35s cubic-bezier(.2,.9,.3,1) rpLand}@keyframes rpLand{0%{opacity:.7;transform:scale(.85)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes rpShuffle{0%{opacity:1}50%{opacity:.6}to{opacity:1}}.random-pick-cover{width:220px;height:220px;box-shadow:0 8px 32px rgba(var(--overlay-rgb), .5), 0 0 0 1px rgba(var(--white-rgb), .05);border-radius:8px;overflow:hidden}.random-pick-img{object-fit:cover;width:100%;height:100%}.random-pick-placeholder{background:var(--surface);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.random-pick-info{text-align:center;cursor:pointer;animation:.3s .1s both rpInfoIn}@keyframes rpInfoIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.random-pick-title{color:var(--text);margin:0;font-size:1.25rem;font-weight:600;line-height:1.3}.random-pick-artist{color:var(--text-secondary);margin:.25rem 0 0;font-size:.95rem}.random-pick-hint{color:var(--accent-light);text-transform:uppercase;letter-spacing:.06em;margin:.75rem 0 0;font-size:.75rem;font-weight:500}.random-pick-label{color:var(--text-secondary);letter-spacing:.03em;font-size:.85rem;font-weight:500;animation:.6s infinite alternate rpPulse}@keyframes rpPulse{0%{opacity:.5}to{opacity:1}}.random-dice-btn{border:1px solid var(--border);background:var(--surface);width:42px;height:42px;color:var(--accent-light);cursor:pointer;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:background .15s,transform .15s;display:flex}.random-dice-btn:active{background:var(--surface-alt);transform:scale(.93)}.library-home{flex-direction:column;flex:1;min-height:0;display:flex}.library-tab-bar{flex-shrink:0;gap:.5rem;padding:.5rem .75rem 0;display:flex}.library-tab{background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:.35rem;padding:.65rem .5rem;font-size:1rem;font-weight:600;transition:all .15s;display:flex;position:relative}.library-tab--active{color:var(--text-on-accent);background:var(--accent);border-color:var(--accent)}.library-tab:active{opacity:.8}.tab-count{opacity:.7;font-size:.72rem;font-weight:400}.library-search-bar{flex-shrink:0;align-items:stretch;gap:.5rem;padding:.75rem 1rem;display:flex}.library-search-bar .search-bar{flex:1;margin-bottom:0}.library-search-bar .random-dice-btn{height:auto}.library-add-btn{border:1px solid var(--border);background:var(--surface);width:42px;height:42px;color:var(--accent-light);cursor:pointer;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.5rem;line-height:1;transition:background .15s;display:flex}.library-add-btn:active{background:var(--surface-alt)}.library-sections{flex:1;min-height:0;padding-top:1rem;overflow-y:auto}.library-empty{text-align:center;padding:3rem 1rem}.empty-add-btn{border:1px solid var(--accent);background:rgba(var(--accent-rgb), .1);color:var(--accent-light);cursor:pointer;border-radius:10px;margin-top:1.25rem;padding:.7rem 1.5rem;font-size:.9rem;font-weight:500}.empty-add-btn:active{background:rgba(var(--accent-rgb), .25)}.library-grid-view{flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.grid-view-header{align-items:center;gap:.25rem;padding:.5rem 1rem;display:flex}.grid-back-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0 .25rem;font-size:1.6rem;line-height:1}.grid-view-title{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;margin:0;font-size:1.05rem;font-weight:600;overflow:hidden}.collection-view-header{background:var(--bg);border-bottom:2px solid var(--accent);z-index:10;flex-direction:column;gap:.6rem;padding:.7rem 1rem .85rem;display:flex;position:sticky;top:0}.collection-header-top{align-items:center;gap:.4rem;display:flex}.collection-header-top .grid-back-btn{border:1px solid var(--border);background:var(--surface);width:42px;height:42px;color:var(--accent-light);cursor:pointer;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:1.8rem;font-weight:600;line-height:1;display:flex}.collection-header-top .grid-back-btn:active{background:var(--surface-alt)}.collection-search{flex:1;margin-bottom:0}.collection-header-info{align-items:center;gap:.75rem;padding-left:.1rem;display:flex}.collection-header-icon{width:48px;height:48px;color:var(--accent-light);opacity:.8;flex-shrink:0}.collection-header-text{flex-direction:column;flex:1;gap:.25rem;min-width:0;display:flex}.collection-header-title-row{align-items:center;display:flex}.collection-view-title{color:var(--text);margin:0;font-size:1.6rem;font-weight:700;line-height:1.15}.collection-header-meta-row{align-items:center;gap:.5rem;display:flex}.collection-album-count{color:var(--text-secondary);white-space:nowrap;font-size:.9rem;font-weight:400;line-height:1}.collection-description{color:var(--text-secondary);margin:.4rem 0 0;font-size:.85rem;line-height:1.4}.collection-meta-tags{flex-wrap:wrap;gap:.3rem;margin-top:.4rem;display:flex}.collection-meta-tag{background:rgba(var(--accent-rgb), .15);color:var(--accent-light);white-space:nowrap;border-radius:12px;padding:.15rem .5rem;font-size:.7rem}.collection-notes{color:var(--text-secondary);opacity:.7;margin:.4rem 0 0;font-size:.8rem;font-style:italic;line-height:1.4}.collection-header-actions{flex-shrink:0;align-items:center;gap:.4rem;margin-left:auto;display:flex}.collection-smart-badge{text-transform:uppercase;letter-spacing:.04em;color:var(--accent-light);border:1px solid var(--accent);border-radius:6px;padding:.15rem .4rem;font-size:.6rem}.collection-fav-btn{width:36px;height:36px;color:var(--text-secondary);cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;padding:0;transition:color .15s,transform .15s;display:flex}.collection-fav-btn:active{transform:scale(.85)}.collection-fav-btn--active{color:var(--danger);opacity:1}.collection-edit-btn{border:1px solid var(--border);background:var(--surface);width:42px;height:42px;color:var(--text-secondary);cursor:pointer;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.collection-edit-btn:active{background:var(--surface-alt)}.collection-empty{text-align:center;color:var(--text-secondary);padding:3rem 1.5rem;font-size:.9rem}.stc-overlay{background:rgba(var(--overlay-rgb), .65);z-index:200;justify-content:center;align-items:center;padding:1.5rem;animation:.2s stc-fade-in;display:flex;position:fixed;inset:0}@keyframes stc-fade-in{0%{opacity:0}to{opacity:1}}.stc-modal{background:var(--bg);width:100%;max-width:340px;box-shadow:var(--shadow-modal);border-radius:16px;flex-direction:column;gap:1rem;padding:1.5rem;animation:.2s stc-scale-in;display:flex}@keyframes stc-scale-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.stc-title{color:var(--danger);text-align:center;font-size:.95rem;font-weight:600;line-height:1.3}.slide-track{background:rgba(var(--danger-rgb), .12);border:1px solid rgba(var(--danger-rgb), .3);-webkit-user-select:none;user-select:none;touch-action:none;border-radius:26px;align-items:center;height:52px;display:flex;position:relative;overflow:hidden}.slide-track--confirmed{background:rgba(var(--danger-rgb), .25);border-color:rgba(var(--danger-rgb), .5)}.slide-label{text-align:center;width:100%;color:var(--danger);pointer-events:none;letter-spacing:.02em;font-size:.82rem;font-weight:500;transition:opacity .15s;position:absolute}.slide-thumb{z-index:2;background:var(--danger);width:48px;height:48px;color:var(--text-on-accent);cursor:grab;box-shadow:0 2px 8px rgba(var(--danger-rgb), .4);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-left:2px;display:flex;position:relative}.slide-thumb--dragging{cursor:grabbing;box-shadow:0 4px 16px rgba(var(--danger-rgb), .5)}.slide-thumb--confirmed{background:var(--danger-dark)}.slide-thumb svg{pointer-events:none}.stc-cancel-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;text-align:center;border-radius:8px;padding:.65rem;font-size:.9rem;font-weight:500}.stc-cancel-btn:active{background:var(--surface-alt)}.album-detail-overlay{background:rgba(var(--overlay-rgb), .7);z-index:100;justify-content:center;align-items:flex-end;animation:.25s ease-out album-overlay-fade-in;display:flex;position:fixed;inset:0}@keyframes album-overlay-fade-in{0%{opacity:0}to{opacity:1}}.album-detail{background:var(--bg);overscroll-behavior:contain;border-radius:12px 12px 0 0;flex-direction:column;width:100%;max-width:480px;height:calc(100% - 12px);transition:transform .35s cubic-bezier(.2,.9,.3,1);animation:.35s cubic-bezier(.2,.9,.3,1) album-detail-slide-up;display:flex;position:relative;overflow:hidden}@keyframes album-detail-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.detail-drag-handle{z-index:5;background:0 0;border-radius:12px 12px 0 0;flex-shrink:0;justify-content:center;align-items:center;padding:.5rem 0;display:flex;position:relative;overflow:hidden}.detail-drag-handle:before{content:"";background-image:linear-gradient(#0000004d, #0000004d), var(--drag-handle-cover,none);filter:blur(20px)saturate(1.4);background-position:top;background-size:cover;position:absolute;inset:0 -24px -24px}.detail-drag-handle:after{content:"";background:rgba(var(--white-rgb,255, 255, 255), .7);z-index:1;border-radius:3px;width:40px;height:6px;position:relative;box-shadow:0 1px 2px #0003}.album-detail--dismissing{transition:transform .4s cubic-bezier(.4,0,1,1)!important;transform:translateY(110vh)!important}.detail-cover-zone{touch-action:none;-webkit-user-select:none;user-select:none;flex-shrink:0;position:relative;overflow:hidden}.detail-filmstrip{will-change:transform;width:300%;margin-left:-100%;display:flex}.filmstrip-frame{flex-shrink:0;width:33.333%}.filmstrip-empty{aspect-ratio:1;background:var(--bg);width:100%}.detail-cover{aspect-ratio:1;object-fit:cover;width:100%;display:block}.detail-cover-placeholder{aspect-ratio:1;background:var(--surface-alt);width:100%;color:var(--text-secondary);justify-content:center;align-items:center;font-size:1.2rem;display:flex}.detail-close{background:rgba(var(--overlay-rgb), .5);width:42px;height:42px;color:var(--text-on-accent);cursor:pointer;box-shadow:var(--shadow-card);z-index:4;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.4rem;display:flex;position:absolute;top:.5rem;right:.5rem}.detail-action-btns{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.detail-dj-view-btn{min-width:44px;height:36px;padding:0 var(--space-md);border-radius:var(--radius-pill);border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:var(--text-body-sm);letter-spacing:.04em;cursor:pointer;transition:background var(--transition-quick), border-color var(--transition-quick), color var(--transition-quick);flex-shrink:0;justify-content:center;align-items:center;font-weight:600;display:inline-flex}.detail-dj-view-btn:active{transform:scale(.95)}.detail-dj-view-btn--active{background:var(--accent);border-color:var(--accent);color:var(--text-on-accent)}.detail-dj-view-btn--active:active{background:var(--accent-light,var(--accent))}.detail-dj-view-btn:disabled{opacity:.6;cursor:default}.detail-fav-btn{border:1px solid var(--border);background:var(--surface);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:color .15s,border-color .15s,background .15s;display:flex}.detail-fav-btn:active{transform:scale(.9)}.detail-fav-btn--active{color:var(--danger);border-color:var(--danger);background:rgba(var(--danger-rgb), .1)}.detail-fav-btn--active:active{background:rgba(var(--danger-rgb), .2)}.detail-flag-btn{border:1px solid var(--border);background:var(--surface);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:color .15s,border-color .15s,background .15s;display:flex}.detail-flag-btn:active{background:var(--surface-alt)}.detail-flag-btn--active{color:var(--warning);border-color:var(--warning);background:#ff98001a}.detail-flag-btn--active:active{background:#ff980033}.detail-edit-btn{border:1px solid var(--border);background:var(--surface);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.detail-edit-btn:active{background:var(--surface-alt);color:var(--text)}.detail-close:active{background:rgba(var(--overlay-rgb), .8)}.detail-flag-banner{color:var(--text);z-index:3;-webkit-backdrop-filter:blur(4px);background:#000000a6;align-items:center;gap:.4rem;padding:.4rem 1rem;font-size:.8rem;font-weight:500;display:flex;position:absolute;top:0;left:0;right:0}.flag-banner-icon{color:var(--warning);font-size:.9rem}.flag-banner-note{opacity:.75;margin-left:.25rem;font-size:.75rem;font-style:italic;font-weight:400}.detail-body{z-index:2;background:var(--bg);padding:0 1.25rem calc(1.25rem + var(--navbar-total-height));border-radius:16px 16px 0 0;flex:1;min-height:0;margin-top:-16px;transition:margin-top .3s cubic-bezier(.2,.9,.3,1);position:relative;overflow-y:auto}.detail-body--pulled-up{margin-top:calc(-50vw - 16px)}@media (width>=481px){.detail-body--pulled-up{margin-top:-256px}}.detail-drag-pill{background:rgba(var(--white-rgb), .2);border-radius:2px;width:36px;height:4px;margin:10px auto 12px}.detail-title-row{align-items:flex-start;gap:.5rem;display:flex}.detail-title{flex:1;min-width:0;margin:0;font-size:1.4rem}.detail-artist{color:var(--text-secondary);margin:.25rem 0 0;font-size:1rem}.detail-discogs-title{color:var(--text-secondary);opacity:.7;margin:.3rem 0 0;font-size:.8rem;font-style:italic}.detail-external-links{gap:1rem;margin-top:.4rem;margin-bottom:.25rem;display:flex}.detail-external-link{align-items:center;gap:.35rem;font-size:.8rem;text-decoration:none;transition:opacity .15s;display:inline-flex}.detail-external-link:active{opacity:.7}.detail-external-link svg{flex-shrink:0}.detail-discogs-link{color:var(--accent-light)}.detail-discogs-push{border:1px solid var(--accent-light);color:var(--accent-light);cursor:pointer;background:0 0;border-radius:12px;padding:.15rem .5rem;font-size:.75rem}.detail-discogs-push:active{opacity:.7}.detail-discogs-push:disabled{opacity:.5}.detail-discogs-in-collection{color:var(--success);opacity:.8;font-size:.75rem}.detail-meta{flex-wrap:wrap;gap:.4rem;margin-top:.75rem;display:flex}.meta-chip{background:var(--surface);color:var(--text-secondary);border-radius:12px;padding:.2rem .6rem;font-size:.8rem}.detail-location{color:var(--accent);margin-top:.75rem;font-size:.9rem}.location-icon{font-style:normal}.detail-tags{flex-wrap:wrap;gap:.35rem;margin-top:.75rem;display:flex}.tag{border-radius:12px;padding:.2rem .6rem;font-size:.75rem}.tag--editable{align-items:center;gap:.15rem;padding-right:.3rem;display:inline-flex}.tag-inline-remove{color:inherit;opacity:.6;cursor:pointer;background:0 0;border:none;padding:0 .1rem;font-size:.85rem;line-height:1}.tag-inline-remove:active{opacity:1}.genre-tag{background:var(--accent);color:var(--text-on-accent)}.style-tag{border:1px solid var(--accent);color:var(--accent);background:0 0}.user-tag{background:var(--surface-alt);color:var(--text)}.detail-collections-section{margin-top:1rem}.detail-collection-chips{flex-wrap:wrap;gap:.35rem;margin-bottom:.5rem;display:flex}.collection-chip{background:rgba(var(--accent-rgb), .12);border:1px solid rgba(var(--accent-rgb), .3);color:var(--accent-light);white-space:nowrap;border-radius:12px;align-items:center;gap:.3rem;padding:.2rem .55rem;font-size:.75rem;display:inline-flex}.collection-chip svg{opacity:.7;flex-shrink:0}.detail-collection-btn{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--accent-light);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:.45rem;padding:.6rem;font-size:.85rem;font-weight:500;transition:background .15s;display:flex}.detail-collection-btn:active{background:var(--surface-alt)}.detail-tracklist{margin-top:1.25rem}.detail-tracklist-header{justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:.5rem;display:flex}.detail-essentia-banner{justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);margin:0 0 var(--space-sm);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);display:flex}.detail-essentia-banner-text{min-width:0;color:var(--text-secondary);font-size:var(--text-body-sm);text-overflow:ellipsis;font-variant-numeric:tabular-nums;flex:1;line-height:1.3;overflow:hidden}.detail-essentia-banner-btn{padding:var(--space-2xs) var(--space-md);border-radius:var(--radius-pill);border:1px solid var(--accent);color:var(--accent);font-size:var(--text-body-sm);cursor:pointer;transition:background var(--transition-quick), color var(--transition-quick), border-color var(--transition-quick);background:0 0;flex-shrink:0;font-weight:600}.detail-essentia-banner-btn:active{background:var(--accent);color:var(--text-on-accent);transform:scale(.96)}.detail-essentia-banner-btn:disabled{opacity:.6;cursor:default}.detail-essentia-banner-btn--cancel{border-color:var(--border);color:var(--text-secondary)}.detail-essentia-banner-btn--cancel:active{background:var(--surface-alt,var(--surface));color:var(--text)}.detail-tracklist-header h3{margin:0;font-size:1rem}.detail-tracklist h3{margin:0 0 .5rem;font-size:1rem}.detail-tracklist ol{margin:0;padding:0;list-style:none}.track-item{border-bottom:1px solid var(--border);flex-direction:column;padding:.4rem 0;font-size:.9rem;display:flex}.track-star-btn{width:28px;height:28px;color:var(--text-secondary);cursor:pointer;opacity:.5;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:color .15s,opacity .15s;display:flex}.track-star-btn:active{transform:scale(.9)}.track-star-btn--active{color:var(--warning);opacity:1}.track-title{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text);flex:1;overflow:hidden}.track-duration{color:var(--text-secondary);flex-shrink:0;font-size:.8rem}.track-audio-features{color:var(--text-secondary);font-size:var(--text-micro);letter-spacing:.02em;font-variant-numeric:tabular-nums;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.track-dj-line{padding-left:calc(28px + var(--space-sm));padding-top:var(--space-2xs);padding-bottom:var(--space-2xs);min-height:calc(var(--text-micro) * 1.25 + var(--space-2xs) * 2);white-space:nowrap;text-overflow:ellipsis;line-height:1.25;display:block;overflow:hidden}.detail-notes{margin-top:1.25rem}.detail-notes h3{margin:0 0 .5rem;font-size:1rem}.detail-notes p{color:var(--text-secondary);margin:0;font-size:.9rem}.detail-delete-section{border-top:1px solid var(--border);margin-top:2rem;padding-top:1.25rem}.detail-delete-btn{border:1px solid rgba(var(--danger-rgb), .3);width:100%;color:var(--danger);cursor:pointer;background:0 0;border-radius:8px;padding:.7rem;font-size:.9rem}.detail-delete-btn:active{background:rgba(var(--danger-rgb), .1)}.detail-delete-confirm p{color:var(--text);text-align:center;margin:0 0 .75rem;font-size:.9rem}.delete-confirm-actions{gap:.75rem;display:flex}.delete-confirm-cancel,.delete-confirm-yes{cursor:pointer;border-radius:8px;flex:1;padding:.7rem;font-size:.9rem;font-weight:500}.delete-confirm-cancel{background:var(--surface);border:1px solid var(--border);color:var(--text)}.delete-confirm-yes{background:var(--danger);color:var(--text-on-accent);border:none}.delete-confirm-yes:active{opacity:.8}.detail-nav-hint{text-align:center;color:var(--text-secondary);padding:1.25rem 0 .5rem;font-size:.75rem}.edit-field{margin-top:.75rem}.edit-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.35rem;font-size:.75rem;display:block}.edit-input{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);box-sizing:border-box;border-radius:8px;padding:.5rem .75rem;font-size:.9rem}.edit-input:focus{border-color:var(--accent);outline:none}.edit-title-input{flex:1;min-width:0;padding:.4rem .75rem;font-size:1.3rem;font-weight:600}.edit-artist-input{margin-top:.25rem;font-size:.95rem}.edit-year-input{width:80px;padding:.2rem .5rem;font-size:.8rem}.edit-textarea{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);resize:vertical;box-sizing:border-box;border-radius:8px;min-height:60px;padding:.5rem .75rem;font-family:inherit;font-size:.9rem}.edit-textarea:focus{border-color:var(--accent);outline:none}.tag-input-container{border:1px solid var(--border);background:var(--surface);border-radius:8px;flex-wrap:wrap;align-items:center;gap:.3rem;min-height:38px;padding:.4rem .5rem;display:flex;position:relative}.tag-input-container:focus-within{border-color:var(--accent)}.tag-chip{background:var(--accent);color:var(--text-on-accent);white-space:nowrap;border-radius:12px;align-items:center;gap:.2rem;padding:.15rem .35rem .15rem .5rem;font-size:.75rem;display:inline-flex}.tag-chip-remove{color:rgba(var(--white-rgb), .7);cursor:pointer;background:0 0;border:none;padding:0 .15rem;font-size:.9rem;line-height:1}.tag-chip-remove:hover{color:var(--text-on-accent)}.tag-text-input{min-width:60px;color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:.15rem 0;font-size:.85rem}.tag-text-input::placeholder{color:var(--text-secondary)}.tag-add-btn{background:var(--accent);color:var(--text-on-accent);cursor:pointer;white-space:nowrap;border:none;border-radius:6px;flex-shrink:0;padding:.2rem .55rem;font-size:.75rem;font-weight:600}.tag-add-btn:active{opacity:.8}.tag-suggestions{background:var(--surface-alt);border:1px solid var(--border);z-index:10;border-radius:8px;flex-direction:column;gap:.1rem;padding:.25rem;display:flex;position:absolute;bottom:calc(100% + 4px);left:0;right:0}.tag-suggestion-item{color:var(--text);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.4rem .6rem;font-size:.8rem}.tag-suggestion-item:hover,.tag-suggestion-item:active{background:rgba(var(--white-rgb), .08)}.edit-actions{border-top:1px solid var(--border);gap:.75rem;margin-top:1.5rem;padding-top:1rem;display:flex}.edit-cancel-btn,.edit-save-btn{cursor:pointer;border-radius:8px;flex:1;padding:.7rem;font-size:.9rem;font-weight:500}.edit-cancel-btn{background:var(--surface);border:1px solid var(--border);color:var(--text)}.edit-save-btn{background:var(--accent);color:var(--text-on-accent);border:none}.edit-save-btn:active{opacity:.85}.edit-save-btn:disabled{opacity:.5;cursor:default}.flag-prompt-overlay{z-index:10;background:#0009;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:absolute;inset:0}.flag-prompt{background:var(--surface);text-align:center;border-radius:16px;width:100%;max-width:340px;padding:1.5rem;box-shadow:0 8px 32px #0006}.flag-prompt-icon{margin-bottom:.75rem}.flag-prompt-title{color:var(--text);margin:0 0 .35rem;font-size:1.15rem}.flag-prompt-desc{color:var(--text-secondary);margin:0 0 .75rem;font-size:.85rem}.flag-quick-options{flex-wrap:wrap;justify-content:center;gap:.4rem;margin-bottom:.75rem;display:flex}.flag-quick-chip{border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;border-radius:20px;max-width:100%;padding:.35rem .7rem;font-size:.8rem;transition:border-color .15s,background .15s,color .15s;overflow:hidden}.flag-quick-chip:active{background:var(--surface-alt)}.flag-quick-chip--active{border-color:var(--warning);color:var(--warning);background:#ff98001f;font-weight:500}.flag-quick-chip--last{font-style:italic}.flag-prompt-input{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);resize:none;box-sizing:border-box;border-radius:8px;margin-bottom:1rem;padding:.6rem .75rem;font-family:inherit;font-size:.9rem}.flag-prompt-input:focus{border-color:var(--warning);outline:none}.flag-prompt-input::placeholder{color:var(--text-secondary)}.flag-prompt-actions{gap:.75rem;display:flex}.flag-prompt-cancel,.flag-prompt-confirm{cursor:pointer;border-radius:8px;flex:1;padding:.65rem;font-size:.9rem;font-weight:500}.flag-prompt-cancel{background:var(--bg);border:1px solid var(--border);color:var(--text)}.flag-prompt-cancel:active{background:var(--surface-alt)}.flag-prompt-confirm{background:var(--warning);color:var(--text-inverse);border:none}.flag-prompt-confirm:active{opacity:.85}.detail-apple-music-link{color:#fc3c44}.apple-match-indicator{color:var(--text-secondary);margin-left:.5rem;font-size:.75rem;font-weight:400}.apple-match-fallback{opacity:.7;margin-top:.15rem;margin-left:0;font-size:.7rem;font-style:italic;display:block}.track-play-btn{width:28px;height:28px;color:var(--accent);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:color .15s,opacity .15s;display:flex}.track-play-btn:active{transform:scale(.9)}.track-play-btn--active{color:var(--accent-light)}.track-setlist-btn{width:28px;height:28px;color:var(--text-secondary);cursor:pointer;opacity:.5;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:color .15s,opacity .15s;display:flex}.track-setlist-btn:active{color:var(--accent);opacity:1;transform:scale(.9)}.track-item--playing{background:rgba(var(--accent-rgb), .06)}.track-row{cursor:pointer;align-items:center;gap:.4rem;width:100%;display:flex}.track-scrub{align-items:center;gap:.4rem;margin-top:.2rem;padding:.35rem 0 .15rem;animation:.2s ease-out track-scrub-expand;display:flex}@keyframes track-scrub-expand{0%{opacity:0;max-height:0}to{opacity:1;max-height:40px}}.track-scrub-time{color:var(--text-secondary);text-align:center;font-variant-numeric:tabular-nums;flex-shrink:0;min-width:2.2em;font-size:.65rem}.track-scrub-bar{cursor:pointer;touch-action:none;flex:1;align-items:center;height:28px;display:flex}.track-scrub-track{background:var(--surface-alt);border-radius:1.5px;width:100%;height:3px;position:relative}.track-scrub-fill{background:var(--accent);border-radius:1.5px;height:100%;transition:width .1s linear;position:absolute;top:0;left:0}.track-scrub-thumb{background:var(--accent-light);border-radius:50%;width:10px;height:10px;position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 1px 3px #0000004d}.track-scrub-badge{text-transform:uppercase;letter-spacing:.05em;background:rgba(var(--accent-rgb), .15);color:var(--accent-light);border-radius:3px;flex-shrink:0;padding:.1rem .25rem;font-size:.55rem}.manual-add-overlay{background:rgba(var(--overlay-rgb), .7);z-index:100;overscroll-behavior:none;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.manual-add{background:var(--bg);width:100%;max-width:480px;max-height:92vh;padding-bottom:var(--navbar-total-height);border-radius:16px 16px 0 0;position:relative;overflow-y:auto}.manual-add-drag-pill{background:rgba(var(--white-rgb), .3);border-radius:2px;width:36px;height:4px;margin:8px auto 0}.manual-add-close{background:rgba(var(--overlay-rgb), .5);width:36px;height:36px;color:var(--text-on-accent);cursor:pointer;z-index:1;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.3rem;display:flex;position:absolute;top:.75rem;right:.75rem}.manual-add-title{margin:1rem 0 0;padding:0 1.25rem;font-size:1.2rem;font-weight:600}.manual-add-cover-row{align-items:flex-end;gap:.5rem;padding:1rem 1.25rem 0;display:flex}.manual-add-cover{border:2px dashed var(--border);background:var(--surface);cursor:pointer;width:160px;height:160px;color:var(--text-secondary);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:border-color .2s;display:flex;overflow:hidden}.manual-add-cover:active{border-color:var(--accent)}.manual-add-cover-img{object-fit:cover;width:100%;height:100%}.manual-add-cover-placeholder{flex-direction:column;align-items:center;gap:.4rem;font-size:.8rem;display:flex}.cover-camera-icon{font-size:1.8rem;font-style:normal}.cover-recrop-btn{border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;border-radius:6px;margin-bottom:.25rem;padding:.4rem .8rem;font-size:.8rem}.cover-recrop-btn:active{background:var(--surface-alt)}.manual-add-file-input{display:none}.manual-add-form{padding:1rem 1.25rem 0}.form-field{margin-bottom:.9rem}.form-row{gap:.75rem;display:flex}.form-field--half{flex:1}.form-label{color:var(--text-secondary);margin-bottom:.3rem;font-size:.8rem;font-weight:500;display:block}.form-hint{opacity:.7;font-weight:400}.form-input{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);border-radius:8px;padding:.6rem .75rem;font-family:inherit;font-size:.95rem}.form-input:focus{border-color:var(--accent);outline:none}.form-input::placeholder{color:var(--text-secondary);opacity:.6}.form-textarea{resize:vertical;min-height:60px}.format-toggle{border:1px solid var(--border);border-radius:8px;gap:0;display:flex;overflow:hidden}.format-btn{background:var(--surface);color:var(--text-secondary);cursor:pointer;border:none;flex:1;padding:.55rem 0;font-size:.9rem;transition:background .15s,color .15s}.format-btn--active{background:var(--accent);color:var(--text-on-accent)}.location-field{position:relative}.location-suggestions{background:var(--surface-alt);border:1px solid var(--border);z-index:5;border-top:none;border-radius:0 0 8px 8px;max-height:140px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.location-suggestion{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;padding:.5rem .75rem;font-size:.9rem;display:block}.location-suggestion:hover,.location-suggestion:focus{background:var(--surface)}.manual-add-actions{padding:1rem 1.25rem 1.5rem}.manual-add-save{background:var(--accent);width:100%;color:var(--text-on-accent);cursor:pointer;border:none;border-radius:10px;padding:.85rem;font-size:1rem;font-weight:600;transition:opacity .15s}.manual-add-save:disabled{opacity:.4;cursor:default}.manual-add-save:not(:disabled):active{opacity:.8}.crop-tool{background:var(--camera-bg);touch-action:none;overscroll-behavior:none;flex-direction:column;width:100%;height:100%;display:flex}.crop-header{padding:.75rem 1rem;padding-top:max(.75rem, env(safe-area-inset-top,0px));flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.crop-cancel-btn,.crop-done-btn{cursor:pointer;background:0 0;border:none;padding:.4rem .5rem;font-size:.95rem}.crop-cancel-btn{color:rgba(var(--white-rgb), .7)}.crop-done-btn{color:var(--accent-light);font-weight:600}.crop-title{color:var(--text-on-accent);font-size:.95rem;font-weight:500}.crop-image-container{touch-action:none;flex:1;justify-content:center;align-items:center;min-height:0;display:flex;overflow:visible}.crop-image-wrapper{max-width:100%;max-height:100%;line-height:0;display:inline-block;position:relative}.crop-image{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;max-width:100%;max-height:100%;display:block}.crop-svg-overlay{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.crop-handle{touch-action:none;-webkit-touch-callout:none;cursor:grab;z-index:2;width:56px;height:56px;position:absolute;transform:translate(-50%,-50%)}.crop-handle:before{content:"";background:var(--text-on-accent);border:2px solid rgba(var(--overlay-rgb), .3);width:16px;height:16px;box-shadow:0 1px 4px rgba(var(--overlay-rgb), .5);border-radius:50%;transition:transform .1s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.crop-handle--active:before{background:var(--accent-light);transform:translate(-50%,-50%)scale(1.3)}.crop-loupe{pointer-events:none;z-index:200;filter:drop-shadow(0 2px 8px rgba(var(--overlay-rgb), .6));position:fixed;transform:translate(-50%)}.crop-loupe-canvas{border-radius:50%;width:120px;height:120px}.crop-hint{color:rgba(var(--white-rgb), .5);text-align:center;padding:.75rem;padding-bottom:max(.75rem, env(safe-area-inset-bottom,0px));flex-shrink:0;margin:0;font-size:.8rem}.review-list{gap:var(--space-2xl);box-sizing:border-box;flex-direction:column;width:100%;display:flex}.review-list-section{gap:var(--space-sm);flex-direction:column;display:flex}.review-list-section-header{align-items:center;gap:var(--space-md);padding:0 var(--space-3xs);display:flex}.review-list-section-label{font-size:var(--text-body-sm);color:var(--text-secondary);letter-spacing:.01em;font-weight:600}.review-list-section-count{font-size:var(--text-caption);color:var(--text-secondary);background:var(--surface-alt);padding:var(--space-3xs) var(--space-sm);border-radius:var(--radius-md)}.review-list-section-divider{background:var(--border);height:1px;margin-bottom:var(--space-xs)}.review-list-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;color:var(--text);box-sizing:border-box;align-items:stretch;gap:0;display:flex;overflow:hidden}.review-list-item-main{gap:var(--space-base);min-width:0;padding:var(--space-md);cursor:pointer;text-align:left;color:inherit;transition:background var(--transition-quick);font:inherit;background:0 0;border:none;flex:1;align-items:center;display:flex}.review-list-item-main:active{background:var(--surface-alt)}.review-list-thumb{border-radius:var(--radius-sm);flex-shrink:0;width:56px;height:56px;overflow:hidden}.review-list-thumb img{object-fit:cover;width:100%;height:100%}.review-list-thumb-placeholder{background:var(--surface-alt);width:100%;height:100%;color:var(--text-secondary);justify-content:center;align-items:center;font-size:1.1rem;display:flex}.review-list-info{gap:var(--space-3xs);flex-direction:column;flex:1;min-width:0;display:flex}.review-list-primary{font-size:var(--text-body);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.review-list-secondary{font-size:var(--text-body-sm);color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.review-list-notes{font-size:var(--text-caption);color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-style:italic;overflow:hidden}.review-list-badge{font-size:var(--text-caption);color:var(--text-secondary);background:var(--surface-alt);padding:var(--space-3xs) var(--space-sm);border-radius:var(--radius-badge);flex-shrink:0;align-self:center;font-weight:600}.review-list-action-btn{border:none;border-left:1px solid var(--border);width:40px;min-height:56px;color:var(--text-secondary);cursor:pointer;transition:color var(--transition-quick), background var(--transition-quick);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.review-list-action-btn:active{background:rgba(var(--danger-rgb), .1);color:var(--danger)}.review-list--flagged .review-list-item{border-left:3px solid var(--warning)}.review-list--flagged .review-list-section-label{color:var(--warning)}.review-list--setlist .review-list-section-label,.review-list--wantlist .review-list-section-label{color:var(--text)}.review-list-empty{text-align:center;width:100%;padding:var(--space-4xl) var(--space-3xl);align-items:center;gap:var(--space-md);box-sizing:border-box;flex-direction:column;display:flex}.review-list-empty h3{font-size:var(--text-title);color:var(--text);margin:0}.review-list-empty p{color:var(--text-secondary);font-size:var(--text-body);max-width:28ch;margin:0}.review-list-empty-cta{margin-top:var(--space-md);padding:var(--space-md) var(--space-xl);border-radius:var(--radius-md);border:1px solid var(--accent);background:var(--accent);color:var(--text-on-accent);font-size:var(--text-body);cursor:pointer;transition:transform var(--transition-quick), filter var(--transition-quick);font-weight:600}.review-list-empty-cta:active{filter:brightness(.95);transform:scale(.97)}.lists-screen{box-sizing:border-box;width:100%;padding:var(--content-padding-y) var(--content-padding-x);gap:var(--space-lg);will-change:transform;flex-direction:column;display:flex}.lists-header{align-items:center;gap:var(--space-md);width:100%;display:flex}.lists-segment{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-3xs);gap:var(--space-3xs);flex:1;display:flex;overflow:hidden}.lists-segment-btn{padding:var(--space-md) var(--space-base);color:var(--text-secondary);font-size:var(--text-body-sm);cursor:pointer;border-radius:var(--radius-md);transition:background var(--transition-standard), color var(--transition-standard);-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex:1;font-family:inherit;font-weight:500}.lists-segment-btn:active{transform:scale(.97)}.lists-segment-btn--active{background:var(--accent);color:var(--text-on-accent);font-weight:600}.lists-create-row{box-sizing:border-box;width:100%;min-height:44px;padding:var(--space-md) var(--space-base);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-family:inherit;font-size:var(--text-body-sm);letter-spacing:.01em;text-align:center;cursor:pointer;transition:background var(--transition-quick), transform var(--transition-quick);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;font-weight:600;display:flex}.lists-create-row:active{background:var(--surface-alt);transform:scale(.99)}.lists-body{width:100%}.create-collection-overlay{background:rgba(var(--overlay-rgb), .7);z-index:110;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.create-collection{background:var(--bg);border-radius:16px 16px 0 0;flex-direction:column;width:100%;max-width:480px;max-height:85dvh;padding-bottom:0;display:flex;overflow:hidden}.create-collection-header{flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.25rem .5rem;display:flex}.create-collection-header h2{margin:0;font-size:1.15rem}.create-collection-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1.5rem;line-height:1}.create-collection-body{flex:1;min-height:0;padding:.5rem 1.25rem 1rem;overflow-y:auto}.cc-field{margin-bottom:1rem}.cc-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.35rem;font-size:.75rem;display:block}.cc-input{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);box-sizing:border-box;border-radius:8px;padding:.5rem .75rem;font-size:.95rem}.cc-input:focus{border-color:var(--accent);outline:none}.cc-textarea{resize:vertical;min-height:2.5rem;font-family:inherit;line-height:1.4}.cc-tag-input-container{border:1px solid var(--border);background:var(--surface);border-radius:8px;flex-wrap:wrap;align-items:center;gap:.3rem;min-height:38px;padding:.4rem .5rem;display:flex;position:relative}.cc-tag-input-container:focus-within{border-color:var(--accent)}.cc-tag-chip{background:var(--accent);color:var(--text-on-accent);white-space:nowrap;border-radius:12px;align-items:center;gap:.2rem;padding:.15rem .35rem .15rem .5rem;font-size:.75rem;display:inline-flex}.cc-tag-chip-remove{color:#ffffffb3;cursor:pointer;background:0 0;border:none;padding:0 .15rem;font-size:.9rem;line-height:1}.cc-tag-chip-remove:hover{color:var(--text-on-accent)}.cc-tag-text-input{min-width:60px;color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:.15rem 0;font-size:.85rem}.cc-tag-text-input::placeholder{color:var(--text-secondary)}.cc-tag-add-btn{background:var(--accent);color:var(--text-on-accent);cursor:pointer;white-space:nowrap;border:none;border-radius:6px;flex-shrink:0;padding:.2rem .55rem;font-size:.75rem;font-weight:600}.cc-tag-add-btn:active{opacity:.8}.cc-tag-suggestions{background:var(--surface-alt);border:1px solid var(--border);z-index:10;border-radius:8px;flex-direction:column;gap:.1rem;padding:.25rem;display:flex;position:absolute;bottom:calc(100% + 4px);left:0;right:0}.cc-tag-suggestion-item{color:var(--text);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.4rem .6rem;font-size:.8rem}.cc-tag-suggestion-item:hover,.cc-tag-suggestion-item:active{background:#ffffff14}.cc-type-toggle{border:1px solid var(--border);border-radius:8px;gap:0;display:flex;overflow:hidden}.cc-type-btn{background:var(--surface);color:var(--text-secondary);cursor:pointer;border:none;flex:1;padding:.55rem .75rem;font-size:.85rem;font-weight:500;transition:background .15s,color .15s}.cc-type-btn--active{background:var(--accent);color:var(--text-on-accent)}.cc-type-hint{color:var(--text-secondary);margin:.4rem 0 0;font-size:.75rem}.cc-filters{margin-top:.25rem}.cc-filter-group{margin-bottom:.85rem}.cc-filter-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.3rem;font-size:.7rem;display:block}.cc-filter-chips{flex-wrap:wrap;gap:.3rem;display:flex}.cc-chip{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:12px;padding:.25rem .65rem;font-size:.75rem;transition:all .15s}.cc-chip--active{background:var(--accent);border-color:var(--accent);color:var(--text-on-accent)}.cc-chip:active{opacity:.8}.cc-year-range{align-items:center;gap:.5rem;display:flex}.cc-year-input{border:1px solid var(--border);background:var(--surface);width:80px;color:var(--text);text-align:center;border-radius:8px;padding:.4rem .5rem;font-size:.85rem}.cc-year-input:focus{border-color:var(--accent);outline:none}.cc-year-dash{color:var(--text-secondary)}.cc-preview{background:rgba(var(--accent-rgb), .1);color:var(--accent-light);text-align:center;border-radius:8px;margin-top:.5rem;padding:.5rem .75rem;font-size:.82rem}.cc-delete-section{margin-bottom:.75rem;padding:0 1.25rem}.cc-delete-btn{border:1px solid rgba(var(--danger-rgb), .3);width:100%;color:var(--danger);cursor:pointer;background:0 0;border-radius:8px;padding:.7rem;font-size:.9rem}.cc-delete-btn:active{background:rgba(var(--danger-rgb), .1)}.create-collection-footer{padding:.75rem 1.25rem calc(1.25rem + var(--navbar-total-height));border-top:1px solid var(--border);flex-shrink:0;gap:.75rem;display:flex}.cc-cancel-btn,.cc-save-btn{cursor:pointer;border-radius:8px;flex:1;padding:.7rem;font-size:.9rem;font-weight:500}.cc-cancel-btn{background:var(--surface);border:1px solid var(--border);color:var(--text)}.cc-save-btn{background:var(--accent);color:var(--text-on-accent);border:none}.cc-save-btn:active{opacity:.85}.cc-save-btn:disabled{opacity:.5;cursor:default}.atc-overlay{background:rgba(var(--overlay-rgb), .6);z-index:120;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.atc-sheet{background:var(--bg);width:100%;max-width:480px;max-height:60vh;padding-bottom:var(--navbar-total-height);border-radius:16px 16px 0 0;flex-direction:column;display:flex;overflow:hidden}.atc-header{flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.25rem .5rem;display:flex}.atc-header h3{margin:0;font-size:1.05rem}.atc-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1.5rem;line-height:1}.atc-body{flex:1;min-height:0;padding:.5rem 1.25rem 1.25rem;overflow-y:auto}.atc-empty{text-align:center;color:var(--text-secondary);padding:1rem 0;font-size:.85rem}.atc-item{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:.6rem;padding:.7rem .5rem;font-size:.9rem;display:flex}.atc-item:last-of-type{border-bottom:none}.atc-item:active:not(:disabled){background:rgba(var(--white-rgb), .04)}.atc-item--smart{opacity:.6;cursor:default}.atc-check{border:2px solid var(--border);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;transition:all .15s;display:flex}.atc-item--active .atc-check{background:var(--accent);border-color:var(--accent);color:var(--text-on-accent)}.atc-name{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.atc-smart-badge{text-transform:uppercase;letter-spacing:.04em;color:var(--accent-light);border:1px solid var(--accent);border-radius:6px;flex-shrink:0;padding:.15rem .4rem;font-size:.65rem}.atc-new-btn{border:1px dashed var(--border);width:100%;color:var(--accent-light);cursor:pointer;background:0 0;border-radius:8px;margin-top:.5rem;padding:.65rem;font-size:.85rem;font-weight:500}.atc-new-btn:active{background:rgba(var(--accent-rgb), .1)}.atc-create-inline{align-items:center;gap:.4rem;margin-top:.5rem;display:flex}.atc-create-input{border:1px solid var(--accent);background:var(--surface);color:var(--text);border-radius:8px;flex:1;padding:.5rem .65rem;font-size:.85rem}.atc-create-input:focus{outline:none}.atc-create-save{background:var(--accent);color:var(--text-on-accent);cursor:pointer;border:none;border-radius:8px;flex-shrink:0;padding:.5rem .75rem;font-size:.8rem;font-weight:500}.atc-create-save:disabled{opacity:.5}.atc-create-cancel{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:.25rem;font-size:1.2rem}.ats-overlay{background:rgba(var(--overlay-rgb), .6);z-index:130;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.ats-sheet{background:var(--bg);width:100%;max-width:480px;max-height:60vh;padding-bottom:calc(var(--navbar-total-height) + var(--mini-player-height,0px) + 1.5rem);border-radius:16px 16px 0 0;flex-direction:column;display:flex;overflow:hidden}.ats-header{flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:1rem 1.25rem .5rem;display:flex}.ats-header h3{margin:0;font-size:1.05rem}.ats-track-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:280px;margin:.2rem 0 0;font-size:.8rem;overflow:hidden}.ats-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1.5rem;line-height:1}.ats-body{flex:1;min-height:0;padding:.5rem 1.25rem 1.25rem;overflow-y:auto}.ats-empty{text-align:center;color:var(--text-secondary);padding:1rem 0;font-size:.85rem}.ats-item{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:.6rem;padding:.7rem .5rem;font-size:.9rem;display:flex}.ats-item:last-of-type{border-bottom:none}.ats-item:active{background:rgba(var(--white-rgb), .04)}.ats-item--added{background:rgba(var(--accent-rgb), .08)}.ats-item-name{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.ats-item-count{color:var(--text-secondary);flex-shrink:0;font-size:.75rem}.ats-item-check{color:var(--success);flex-shrink:0;font-size:.75rem;font-weight:500}.ats-new-btn{border:1px dashed var(--border);width:100%;color:var(--accent-light);cursor:pointer;background:0 0;border-radius:8px;margin-top:.5rem;padding:.65rem;font-size:.85rem;font-weight:500}.ats-new-btn:active{background:rgba(var(--accent-rgb), .1)}.ats-create-inline{align-items:center;gap:.4rem;margin-top:.5rem;display:flex}.ats-create-input{border:1px solid var(--accent);background:var(--surface);color:var(--text);border-radius:8px;flex:1;padding:.5rem .65rem;font-size:.85rem}.ats-create-input:focus{outline:none}.ats-create-save{background:var(--accent);color:var(--text-on-accent);cursor:pointer;border:none;border-radius:8px;flex-shrink:0;padding:.5rem .75rem;font-size:.8rem;font-weight:500}.ats-create-save:disabled{opacity:.5}.ats-create-cancel{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:.25rem;font-size:1.2rem}.sld-overlay{background:rgba(var(--overlay-rgb), .7);z-index:120;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.sld-panel{background:var(--bg);border-radius:16px 16px 0 0;flex-direction:column;width:100%;max-width:480px;height:85vh;display:flex;overflow:hidden}.sld-header{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:.5rem;padding:1rem 1.25rem .75rem;display:flex}.sld-back{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;padding:.25rem;display:flex}.sld-header-info{flex:1;min-width:0}.sld-name{cursor:pointer;text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:1.15rem;font-weight:600;overflow:hidden}.sld-name-input{border:1px solid var(--accent);background:var(--surface);width:100%;color:var(--text);border-radius:6px;padding:.3rem .5rem;font-size:1.15rem;font-weight:600}.sld-name-input:focus{outline:none}.sld-meta{color:var(--text-secondary);margin:.15rem 0 0;font-size:.8rem}.sld-play-controls{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.sld-play-btn{background:var(--accent);width:40px;height:40px;color:var(--bg);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sld-play-btn:active{opacity:.8}.sld-shuffle-btn{border:1px solid var(--border);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sld-shuffle-btn:active{color:var(--accent);border-color:var(--accent)}.sld-track-item--active{background:rgba(var(--accent-rgb), .08)}.sld-track-item--active .sld-track-title{color:var(--accent);font-weight:600}.sld-track-item--active .sld-track-pos{color:var(--accent)}.sld-tracks{-webkit-overflow-scrolling:touch;flex:1;min-height:0;padding:0 1.25rem;overflow-y:auto}.sld-empty{text-align:center;color:var(--text-secondary);padding:2rem 0;font-size:.85rem}.sld-track-list{margin:0;padding:0;list-style:none}.sld-track-item{border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;padding:.6rem 0;transition:background .15s,opacity .15s;display:flex}.sld-track-item--dragging{opacity:.4;background:rgba(var(--accent-rgb), .05)}.sld-track-item--dragover-above{border-top:2px solid var(--accent)}.sld-track-item--dragover-below{border-bottom:2px solid var(--accent)}.sld-drag-handle{width:28px;height:28px;color:var(--text-secondary);opacity:.5;cursor:grab;touch-action:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sld-track-pos{width:24px;color:var(--text-secondary);text-align:center;flex-shrink:0;font-size:.8rem}.sld-track-info{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.sld-track-title{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;overflow:hidden}.sld-track-artist{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.sld-track-delete{width:28px;height:28px;color:var(--text-secondary);cursor:pointer;opacity:.5;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:color .15s,opacity .15s;display:flex}.sld-track-delete:active{color:var(--danger);opacity:1}.sld-footer{padding:.75rem 1.25rem;padding-bottom:calc(.75rem + var(--navbar-total-height));border-top:1px solid var(--border);flex-shrink:0}.sld-delete-btn{border:1px solid var(--danger);width:100%;color:var(--danger);cursor:pointer;background:0 0;border-radius:8px;padding:.6rem;font-size:.85rem;font-weight:500}.sld-delete-btn:active{background:rgba(var(--danger-rgb), .1)}.sld-confirm-delete{text-align:center}.sld-confirm-delete p{color:var(--text);margin:0 0 .5rem;font-size:.9rem}.sld-confirm-btns{justify-content:center;gap:.5rem;display:flex}.sld-confirm-yes{background:var(--danger);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.5rem 1.25rem;font-size:.85rem;font-weight:500}.sld-confirm-no{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;padding:.5rem 1.25rem;font-size:.85rem}.sld-export-btn{border:1px solid var(--border);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sld-export-btn:active{color:var(--accent);border-color:var(--accent)}.sld-export-btn:disabled{opacity:.4;pointer-events:none}.sld-export-confirm-overlay{z-index:10;background:#0009;border-radius:16px 16px 0 0;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.sld-export-confirm{background:var(--surface);border-radius:12px;max-width:320px;margin:1rem;padding:1.25rem;box-shadow:0 8px 32px #0006}.sld-export-confirm-title{color:var(--text);margin:0 0 .5rem;font-size:1rem;font-weight:600}.sld-export-confirm-body{color:var(--text-secondary);margin:0 0 1rem;font-size:.85rem;line-height:1.4}.sld-export-skip-note{color:var(--warning)}.sld-export-confirm-btns{gap:.5rem;display:flex}.sld-export-confirm-yes{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;flex:1;padding:.5rem 1rem;font-size:.85rem;font-weight:500}.sld-export-confirm-yes:active{opacity:.8}.sld-export-confirm-no{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;flex:1;padding:.5rem 1rem;font-size:.85rem}.sld-export-exists-btns{flex-direction:column;gap:.5rem;display:flex}.sld-export-exists-btns .sld-export-confirm-yes,.sld-export-exists-btns .sld-export-confirm-no{text-align:center;flex:none;width:100%}.sld-export-rename-btn{border:1px solid var(--accent);width:100%;color:var(--accent);cursor:pointer;background:0 0;border-radius:8px;padding:.5rem 1rem;font-size:.85rem;font-weight:500}.sld-export-rename-btn:active{background:rgba(var(--accent-rgb), .1)}.sld-export-name-input{border:1px solid var(--accent);background:var(--bg);width:100%;color:var(--text);box-sizing:border-box;border-radius:8px;margin-bottom:.75rem;padding:.5rem .75rem;font-size:16px}.sld-export-name-input:focus{outline:none}.sld-toast{bottom:calc(1rem + var(--navbar-total-height));text-align:center;z-index:20;border-radius:8px;padding:.75rem 1rem;font-size:.85rem;font-weight:500;animation:.25s ease-out sld-toast-in;position:absolute;left:1rem;right:1rem}.sld-toast--success{background:var(--success);color:#fff}.sld-toast--error{background:var(--danger);color:#fff}@keyframes sld-toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.mini-player{bottom:var(--navbar-total-height);z-index:145;background:var(--surface);border-top:1px solid var(--border);max-width:480px;margin:0 auto;transition:transform .25s cubic-bezier(.2,.9,.3,1);position:fixed;left:0;right:0;overflow:hidden;transform:translateY(100%)}.mini-player--visible{transform:translateY(0)}.mini-player--hidden{pointer-events:none;transform:translateY(200%)}.mini-player-content{align-items:stretch;gap:.5rem;padding:.35rem .6rem 1.25rem;display:flex}.mini-player-art{cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:6px;flex-shrink:0;align-self:center;width:48px;height:48px;overflow:hidden}.mini-player-art img{object-fit:cover;width:100%;height:100%}.mini-player-art-placeholder{background:var(--surface-alt);width:100%;height:100%;color:var(--text-secondary);justify-content:center;align-items:center;display:flex}.mini-player-right{flex-direction:column;flex:1;justify-content:center;gap:.2rem;min-width:0;display:flex}.mini-player-top-row{align-items:center;gap:.25rem;display:flex}.mini-player-info{cursor:pointer;-webkit-tap-highlight-color:transparent;flex-direction:column;flex:1;justify-content:center;gap:.1rem;min-width:0;display:flex}.mini-player-source{color:var(--accent-light);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;text-overflow:ellipsis;font-size:.6rem;overflow:hidden}.mini-player-title-container{position:relative;overflow:hidden}.mini-player-title{white-space:nowrap;color:var(--text);font-size:.85rem;font-weight:500;line-height:1.2;display:inline-block}.mini-player-title--scroll{animation:8s ease-in-out 2s infinite mini-player-marquee}@keyframes mini-player-marquee{0%,15%{transform:translate(0)}45%,55%{transform:translate(-50%)}85%,to{transform:translate(0)}}.mini-player-controls{flex-shrink:0;align-items:center;gap:.1rem;display:flex}.mini-player-btn{width:30px;height:30px;color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:opacity .15s,transform .15s;display:flex}.mini-player-btn:active{transform:scale(.9)}.mini-player-btn:disabled{opacity:.3;cursor:default}.mini-player-btn:disabled:active{transform:none}.mini-player-btn--play{width:34px;height:34px;color:var(--accent-light)}.mini-player-btn--add{color:var(--text-secondary)}.mini-player-scrub-row{flex-shrink:0;align-items:center;gap:.3rem;display:flex}.mini-player-time{color:var(--text-secondary);font-variant-numeric:tabular-nums;flex-shrink:0;min-width:2.2em;font-size:.6rem;line-height:1}.mini-player-time:last-child{text-align:right}.mini-player-scrub{cursor:pointer;touch-action:none;flex:1;align-items:center;width:100%;min-width:0;height:16px;display:flex;position:relative}.mini-player-scrub-track{background:var(--surface-alt);border-radius:1.5px;width:100%;height:3px;position:relative}.mini-player-scrub-fill{background:var(--accent);border-radius:1.5px;height:100%;transition:width .1s linear;position:absolute;top:0;left:0}.mini-player-scrub-thumb{background:var(--accent-light);border-radius:50%;width:10px;height:10px;position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 1px 3px #0000004d}.mini-player-badge{text-transform:uppercase;letter-spacing:.05em;background:rgba(var(--accent-rgb), .15);color:var(--accent-light);pointer-events:none;border-radius:3px;padding:.1rem .25rem;font-size:.5rem;position:absolute;top:5px;right:8px}.toast-host{left:0;right:0;bottom:calc(var(--navbar-total-height,80px) + var(--space-md));max-width:480px;padding:0 var(--space-lg);z-index:160;gap:var(--space-md);pointer-events:none;flex-direction:column;margin:0 auto;display:flex;position:fixed}.toast{pointer-events:auto;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--surface-raised,var(--surface));color:var(--text);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-body-sm);line-height:1.3;animation:.18s ease-out toast-enter;display:flex;box-shadow:0 6px 20px #00000040}.toast-message{flex:1;min-width:0}.toast-action{color:var(--accent,var(--brand));font-weight:600;font-size:var(--text-body-sm);padding:var(--space-2xs) var(--space-sm);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0}.toast-action:active{opacity:.6}@keyframes toast-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.app{flex-direction:column;max-width:480px;height:100dvh;margin:0 auto;display:flex;overflow:hidden}.app-header{padding:calc(.75rem + env(safe-area-inset-top,0px)) 1rem .75rem;border-bottom:1px solid var(--border);background:var(--bg);z-index:40;flex-shrink:0;align-items:center;display:flex;position:relative}.header-back-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;margin-left:-.25rem;padding:0 .5rem 0 0;display:flex}.app-title{letter-spacing:-.02em;margin:0;font-size:1.25rem;font-weight:700}.build-info{align-items:center;gap:.4rem;margin-left:auto;display:flex}.build-tag{color:var(--text);opacity:.7;white-space:nowrap;font-variant-numeric:tabular-nums;font-size:.7rem;font-weight:500}.build-refresh-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:.15rem .4rem;font-size:.7rem}.build-refresh-btn:active{background:var(--surface)}.app-main{flex:1;min-height:0;position:relative;overflow:hidden}.route-slider{will-change:transform;height:100%;transition:transform .32s cubic-bezier(.4,0,.2,1);display:flex}.route-panel{width:100%;min-height:0;padding-bottom:calc(var(--navbar-total-height) + var(--mini-player-height,0px));flex-direction:column;flex:0 0 100%;display:flex;overflow-y:auto}.processing-indicator{background:var(--accent);color:#fff;text-align:center;z-index:200;padding:.4rem;font-size:.85rem;animation:1.5s ease-in-out infinite pulse;position:fixed;top:0;left:0;right:0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}
