@import "https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;500;600;700&family=Share+Tech+Mono&family=Cormorant+Garamond:wght@500;600&display=swap";: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;--track-tight:-.02em;--leading-tight:1.15;--focus-ring:0 0 0 3px rgba(var(--accent-rgb), .35)}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;--accent-50:#2a2240;--accent-100:#352a52;--accent-200:#4a3970;--accent-700:#a78fde;--accent-900:#c2b0ea;--success:#4caf50;--success-rgb:76, 175, 80;--warning:#ff9800;--warning-rgb:255, 152, 0;--danger:#f44336;--danger-rgb:244, 67, 54;--danger-dark:#dc2626;--heart:#e85a5a;--heart-rgb:232, 90, 90;--wish-gold:#e5be6c;--wish-gold-rgb:229, 190, 108;--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);--shadow-tactile:0 1px 2px #0006, 0 4px 12px rgba(var(--accent-rgb), .3), inset 0 1px 0 #ffffff24, inset 0 -2px 6px #0000004d;--shadow-tactile-pressed:0 1px 1px #00000073, 0 2px 4px rgba(var(--accent-rgb), .2), inset 0 -1px 0 #ffffff1a, inset 0 2px 4px #00000059}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;--accent-50:#3a2e20;--accent-100:#4e3e2a;--accent-200:#6a5238;--accent-700:#a67842;--accent-900:#7c5526;--success:#6b9e8a;--success-rgb:107, 158, 138;--warning:#d4a244;--warning-rgb:212, 162, 68;--danger:#c4644a;--danger-rgb:196, 100, 74;--danger-dark:#a8503a;--heart:#e85a5a;--heart-rgb:232, 90, 90;--wish-gold:#e5be6c;--wish-gold-rgb:229, 190, 108;--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);--shadow-tactile:0 1px 2px #0d0a0859, 0 4px 12px rgba(var(--accent-rgb), .22), inset 0 1px 0 #ffffff24, inset 0 -2px 6px #00000040;--shadow-tactile-pressed:0 1px 1px #0d0a0866, 0 2px 4px rgba(var(--accent-rgb), .16), inset 0 -1px 0 #ffffff1a, inset 0 2px 4px #0000004d}body.theme-workshop h1,body.theme-workshop h2,body.theme-workshop h3{font-family:var(--font-family-heading);letter-spacing:var(--track-tight);font-weight:400;line-height:var(--leading-tight)}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;--accent-50:#f6eee3;--accent-100:#ebdcc6;--accent-200:#dcc4a3;--accent-700:#7a5326;--accent-900:#4c3117;--success:#2e8b57;--success-rgb:46, 139, 87;--warning:#c87f00;--warning-rgb:200, 127, 0;--danger:#c0392b;--danger-rgb:192, 57, 43;--danger-dark:#a93226;--heart:#e85a5a;--heart-rgb:232, 90, 90;--wish-gold:#e5be6c;--wish-gold-rgb:229, 190, 108;--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);--shadow-tactile:0 1px 2px #00000014, 0 4px 10px rgba(var(--accent-rgb), .2), inset 0 1px 0 #ffffff38, inset 0 -2px 6px #0000001a;--shadow-tactile-pressed:0 1px 1px #0000001a, 0 2px 4px rgba(var(--accent-rgb), .15), inset 0 -1px 0 #ffffff26, inset 0 2px 4px #0000002e}body.theme-workshop-light h1,body.theme-workshop-light h2,body.theme-workshop-light h3{font-family:var(--font-family-heading);letter-spacing:var(--track-tight);font-weight:400;line-height:var(--leading-tight)}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}button:focus-visible,[role=button]:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{box-shadow:var(--focus-ring);outline:none}.btn{cursor:pointer;transition:opacity var(--transition-quick,.15s), transform var(--transition-instant,.1s), background var(--transition-quick,.15s), box-shadow var(--transition-quick,.15s);border:none;border-radius:8px;padding:.65rem 1.25rem;font-size:1rem;font-weight:500;line-height:1.25;position:relative}.btn:active{transform:scale(.97)}.btn:disabled,.btn[aria-disabled=true]{opacity:.5;cursor:default;pointer-events:none}.btn:focus-visible{box-shadow:var(--focus-ring);outline:none}.btn-primary{background:var(--accent);color:var(--text-on-accent);box-shadow:var(--shadow-tactile)}.btn-primary:hover:not(:disabled):not([aria-disabled=true]){background:var(--accent-light)}.btn-primary:active{box-shadow:var(--shadow-tactile-pressed)}.btn-primary:focus-visible{box-shadow:var(--shadow-tactile), var(--focus-ring)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled):not([aria-disabled=true]){background:var(--surface-alt)}.btn-ghost{color:var(--accent);box-shadow:none;background:0 0;border:none}.btn-ghost:hover:not(:disabled):not([aria-disabled=true]),.btn-ghost:focus-visible{background:var(--accent-50);color:var(--accent)}.btn.is-loading{color:#0000;pointer-events:none}.btn.is-loading:after{content:"";width:1em;height:1em;color:var(--text-on-accent);will-change:transform;border:2px solid;border-top-color:#0000;border-radius:50%;margin:-.5em 0 0 -.5em;animation:.7s linear infinite btn-spin;position:absolute;top:50%;left:50%}.btn-secondary.is-loading:after,.btn-ghost.is-loading:after{color:var(--accent)}@keyframes btn-spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion:reduce){.btn.is-loading:after{animation:none}.btn{transition:opacity var(--transition-quick,.15s), background var(--transition-quick,.15s)}.btn:active{transform:none}}: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}body.vintage-lab{--vtg-alu-hi:#ebebe7;--vtg-alu:#d3d3ce;--vtg-alu-lo:#b3b3ac;--vtg-alu-edge:#7a7a74;--vtg-poly-hi:#f2f2ef;--vtg-poly:#dfdfda;--vtg-poly-lo:#c4c4be;--vtg-texture:url(/textures/voss-subtle-brushed.jpg);--vtg-chassis-tint:#cfcfcb;--vtg-trim-tint:#e4e3df;--vtg-wood-hi:#7a4a22;--vtg-wood:#5b3414;--vtg-wood-lo:#3e220c;--vtg-wood-lacquer:#ffb43c59;--vtg-lamp-core:#ffd47a;--vtg-lamp:#f5a42a;--vtg-lamp-deep:#b86e10;--vtg-lamp-off:#8a6a30;--vtg-ink:#2a1808;--vtg-ink-soft:#5a4418}body.vintage-lab .vtg-wood-cap,body.vintage-lab .app-header:before,body.vintage-lab .app-header:after,body.vintage-lab .library-home:before,body.vintage-lab .library-home:after{content:"";background:repeating-linear-gradient(92deg, #00000026 0px, #ffffff0d 1px, #320f0a1a 3px, #50140a1f 6px), linear-gradient(180deg, var(--vtg-wood-hi) 0%, var(--vtg-wood) 50%, var(--vtg-wood-lo) 100%);width:8px;box-shadow: inset 0 2px 0 var(--vtg-wood-lacquer), inset 0 6px 10px #ffb43c2e,  inset -1px 0 0 #00000073, inset 1px 0 0 #00000073,  0 2px 4px #0000004d;z-index:10;pointer-events:none;position:absolute}body.vintage-lab .library-grid-view{overscroll-behavior-y:none}body.vintage-lab .app-header{position:relative}body.vintage-lab .app-header:before{top:0;bottom:0;left:0}body.vintage-lab .app-header:after{top:0;bottom:0;right:0}body.vintage-lab .library-home{position:relative;overflow:visible}body.vintage-lab .library-home:before{height:180px;top:0;left:0}body.vintage-lab .library-home:after{height:180px;top:0;right:0}body.vintage-lab .filter-bar{z-index:6;padding:var(--space-md) var(--space-lg);background:linear-gradient(180deg, #ffffff4d 0%, #0000 55%, #0000001a 100%), var(--vtg-texture) center / cover no-repeat;background-color:var(--vtg-trim-tint);background-blend-mode:normal, multiply;margin:0;position:sticky;top:0;box-shadow:inset 0 1px #ffffff8c,inset 0 -1px #0000002e,0 2px 4px #0003}body.vintage-lab .library-sections,body.vintage-lab .album-grid-container{background:linear-gradient(145deg, #ffffff2e 0%, #0000 45%, #0000001a 100%), var(--vtg-texture) center / cover no-repeat;background-color:var(--vtg-chassis-tint);background-blend-mode:normal, multiply;padding:14px 10px;box-shadow:inset 0 1px #ffffff8c,inset 0 8px 14px -4px #00000073,inset 0 -1px #ffffff59,inset 0 -8px 14px -4px #00000061}body.vintage-lab .album-card-title{color:var(--vtg-ink);text-shadow:0 1px #ffd28c80}body.vintage-lab .album-card-artist{color:var(--vtg-ink-soft);text-shadow:0 1px #ffd28c66}body.vintage-lab .app{max-width:none}body.vintage-lab .app,body.vintage-lab .app-main,body.vintage-lab .route-panel,body.vintage-lab .library-home{background:linear-gradient(145deg, #fff3 0%, #0000 45%, #0000001f 100%), var(--vtg-texture) center / cover no-repeat;background-color:var(--vtg-chassis-tint);background-blend-mode:normal, multiply}body.vintage-lab .app-header{background:linear-gradient(180deg, #ffffff59 0%, #0000 50%, #0000001a 100%), var(--vtg-texture) center / cover no-repeat;background-color:var(--vtg-trim-tint);background-blend-mode:normal, multiply;border-bottom:1px solid var(--vtg-alu-edge);position:relative;box-shadow:inset 0 1px #fffc,inset 0 -1px #00000040,0 1px 2px #00000026}body.vintage-lab .app-title{color:var(--vtg-ink);letter-spacing:.06em;text-shadow:0 1px #ffffff8c;align-items:center;gap:.5em;font-family:Cormorant Garamond,Georgia,serif;font-weight:600;display:inline-flex}body.vintage-lab .app-title:before{content:"";background:linear-gradient(180deg, var(--vtg-lamp-core), var(--vtg-lamp) 60%, var(--vtg-lamp-deep));border-radius:1px;width:14px;height:4px;display:inline-block;box-shadow:inset 0 1px #fff9,inset 0 -1px #0000004d,0 0 4px #ffaa3cb3,0 0 10px #ff962859}body.vintage-lab .build-info,body.vintage-lab .build-tag{color:var(--vtg-ink-soft);letter-spacing:.1em;text-shadow:0 1px #fff6;font-family:Share Tech Mono,ui-monospace,monospace;font-size:10px}body.vintage-lab .build-refresh-btn{color:var(--vtg-ink);background:linear-gradient(145deg, #ffffff4d 0%, #0000 50%, #00000014 100%), var(--vtg-texture) center / 240% auto no-repeat;background-color:var(--vtg-trim-tint);background-blend-mode:normal, multiply;border:1px solid var(--vtg-alu-edge);border-top-color:#ffffffb3;border-left-color:#ffffff80;box-shadow:inset 0 1px #fffc,inset 0 -1px #00000040,0 1px 2px #0003}body.vintage-lab .library-tab{background:linear-gradient(145deg, #ffffff4d 0%, #0000 50%, #00000014 100%), var(--vtg-texture) center / 240% auto no-repeat;background-color:var(--vtg-trim-tint);background-blend-mode:normal, multiply;border:1px solid var(--vtg-alu-edge);color:var(--vtg-ink);text-transform:uppercase;letter-spacing:.16em;border-top-color:#ffffffbf;border-left-color:#ffffff8c;border-radius:3px;padding:.6rem .5rem .75rem;font-family:Barlow Condensed,system-ui,sans-serif;font-weight:600;transition:transform 50ms,box-shadow 50ms;position:relative;overflow:visible;box-shadow:inset 0 1px #ffffffd9,inset 0 -1px #00000038,0 2px 3px #00000038}body.vintage-lab .library-tab:after{content:"";background:linear-gradient(#78501e73 0%,#5032148c 100%);border-radius:1px;width:22px;height:4px;transition:background .15s,box-shadow .15s;position:absolute;bottom:4px;left:50%;transform:translate(-50%);box-shadow:inset 0 1px #ffffff26,inset 0 -1px #00000059}body.vintage-lab .library-tab--active:after{background:linear-gradient(180deg, var(--vtg-lamp-core) 0%, var(--vtg-lamp) 60%, var(--vtg-lamp-deep) 100%);box-shadow:inset 0 1px #ffffffa6,inset 0 -1px #783c0080,0 0 5px #ffaa3ccc,0 0 14px #ff962873}body.vintage-lab .library-tab--active{background:radial-gradient(ellipse at 50% 110%, #ffb45038, transparent 60%), linear-gradient(145deg, #ffffff4d 0%, #0000 50%, #00000014 100%), var(--vtg-texture) center / 240% auto no-repeat;background-color:var(--vtg-trim-tint);background-blend-mode:normal, normal, multiply;color:var(--vtg-ink);border-color:var(--vtg-alu-edge)}body.vintage-lab .library-tab:active{transform:translateY(1px);box-shadow:inset 0 1px 2px #0006,inset 0 -1px #ffffff4d}body.vintage-lab .tab-count{color:var(--vtg-ink-soft);opacity:1;font-weight:500}body.vintage-lab .library-search-bar .search-bar{border:1px solid var(--vtg-alu-edge);background:linear-gradient(#f6dfa6 0%,#e6c47a 100%);border-radius:2px;box-shadow:inset 0 2px 4px #00000061,inset 0 -1px #ffffff73,inset 0 0 10px #ffaa3c40,0 1px #ffffff8c}body.vintage-lab .search-input{color:var(--vtg-ink);letter-spacing:.05em;background:0 0;font-family:Barlow Condensed,sans-serif;font-weight:500}body.vintage-lab .search-input::placeholder{color:var(--vtg-ink-soft);opacity:.65}body.vintage-lab .library-add-btn,body.vintage-lab .random-dice-btn{background:linear-gradient(145deg, #ffffff4d 0%, #0000 50%, #00000014 100%), var(--vtg-texture) center / 240% auto no-repeat;background-color:var(--vtg-trim-tint);background-blend-mode:normal, multiply;border:1px solid var(--vtg-alu-edge);color:var(--vtg-ink);border-top-color:#ffffffbf;border-left-color:#ffffff8c;border-radius:3px;box-shadow:inset 0 1px #ffffffd9,inset 0 -1px #00000038,0 2px 3px #00000038}body.vintage-lab .library-add-btn:active,body.vintage-lab .random-dice-btn:active{transform:translateY(1px);box-shadow:inset 0 1px 2px #0006,inset 0 -1px #ffffff4d}body.vintage-lab .album-card{box-shadow:none;background:0 0;border-radius:0}body.vintage-lab .album-card:hover{box-shadow:none;transform:translateY(-1px)}body.vintage-lab .album-cover,body.vintage-lab .album-cover-placeholder{border-radius:2px;box-shadow:inset 0 1px #ffffff8c,inset 0 -1px #00000073,inset 1px 0 #ffffff4d,inset -1px 0 #00000047,0 2px 5px #0000004d,0 1px #ffffff80}body.vintage-lab .album-card-info{padding:.4rem .1rem .2rem}body.vintage-lab .album-card-title{color:var(--vtg-ink);text-transform:uppercase;letter-spacing:.06em;text-shadow:0 1px #ffffff8c;font-family:Barlow Condensed,system-ui,sans-serif;font-weight:600}body.vintage-lab .album-card-artist{color:var(--vtg-ink-soft);letter-spacing:.1em;text-shadow:0 1px #ffffff73;font-family:Barlow Condensed,sans-serif}body.vintage-lab .sort-select{color:var(--vtg-ink);letter-spacing:.05em;text-transform:uppercase;border:1px solid var(--vtg-alu-edge);background-color:#0000;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%232a1808'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E"),linear-gradient(#f6dfa6 0%,#e6c47a 100%);background-position:right .75rem center,0 0;background-repeat:no-repeat,no-repeat;background-size:auto;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;border-radius:2px;font-family:Barlow Condensed,sans-serif;font-weight:500;box-shadow:inset 0 2px 4px #00000061,inset 0 -1px #ffffff73,inset 0 0 10px #ffaa3c40,0 1px #ffffff8c}body.vintage-lab .sort-select:focus{border-color:var(--vtg-lamp-deep);outline:none}body.vintage-lab .filter-fav-toggle,body.vintage-lab .filter-toggle{background:linear-gradient(145deg, #ffffff4d 0%, #0000 50%, #00000014 100%), var(--vtg-texture) center / 240% auto no-repeat;background-color:var(--vtg-trim-tint);background-blend-mode:normal, multiply;border:1px solid var(--vtg-alu-edge);color:var(--vtg-ink);text-transform:uppercase;letter-spacing:.14em;border-top-color:#ffffffbf;border-left-color:#ffffff8c;border-radius:3px;padding:.55rem .7rem .7rem;font-family:Barlow Condensed,system-ui,sans-serif;font-weight:600;position:relative;overflow:visible;box-shadow:inset 0 1px #ffffffd9,inset 0 -1px #00000038,0 2px 3px #00000038}body.vintage-lab .filter-fav-toggle:after,body.vintage-lab .filter-toggle:after{content:"";background:linear-gradient(#78501e73 0%,#5032148c 100%);border-radius:1px;width:18px;height:3px;transition:background .15s,box-shadow .15s;position:absolute;bottom:3px;left:50%;transform:translate(-50%);box-shadow:inset 0 1px #ffffff26,inset 0 -1px #00000059}body.vintage-lab .filter-fav-toggle:active,body.vintage-lab .filter-toggle:active{transform:translateY(1px);box-shadow:inset 0 1px 2px #0006,inset 0 -1px #ffffff4d}body.vintage-lab .filter-fav-toggle--active:after,body.vintage-lab .filter-toggle--active:after{background:linear-gradient(180deg, var(--vtg-lamp-core) 0%, var(--vtg-lamp) 60%, var(--vtg-lamp-deep) 100%);box-shadow:inset 0 1px #ffffffa6,inset 0 -1px #783c0080,0 0 5px #ffaa3ccc,0 0 14px #ff962873}body.vintage-lab .filter-fav-toggle--active,body.vintage-lab .filter-toggle--active{background:radial-gradient(ellipse at 50% 110%, #ffb45038, transparent 60%), linear-gradient(145deg, #ffffff4d 0%, #0000 50%, #00000014 100%), var(--vtg-texture) center / 240% auto no-repeat;background-color:var(--vtg-trim-tint);background-blend-mode:normal, multiply}body.vintage-lab .filter-fav-toggle svg{color:var(--vtg-ink-soft)}body.vintage-lab .filter-fav-toggle--active svg{color:var(--vtg-ink)}body.vintage-lab .filter-clear-btn{color:var(--vtg-ink-soft);text-transform:uppercase;letter-spacing:.12em;font-family:Barlow Condensed,sans-serif}body.vintage-lab .nav-bar{background:linear-gradient(180deg, #ffffff59 0%, #0000 50%, #0000001a 100%), var(--vtg-texture) center / cover no-repeat;background-color:var(--vtg-trim-tint);background-blend-mode:normal, multiply;border-top:1px solid var(--vtg-alu-edge);box-shadow:inset 0 1px #ffffffe6,inset 0 -1px #00000040,0 -2px 4px #00000026}body.vintage-lab .nav-link{color:var(--vtg-ink-soft);transition:color .15s;position:relative}body.vintage-lab .nav-link.active,body.vintage-lab .nav-link[aria-current=page]{color:var(--vtg-ink)}body.vintage-lab .nav-link.active:after,body.vintage-lab .nav-link[aria-current=page]:after{content:"";background:linear-gradient(180deg, var(--vtg-lamp-core), var(--vtg-lamp) 60%, var(--vtg-lamp-deep));border-radius:1px;width:18px;height:3px;position:absolute;bottom:4px;left:50%;transform:translate(-50%);box-shadow:inset 0 1px #fff9,inset 0 -1px #783c0066,0 0 4px #ffaa3cb3,0 0 10px #ff962859}body.vintage-lab .nav-badge{background:radial-gradient(circle at 35% 35%, var(--vtg-lamp-core), var(--vtg-lamp) 65%);color:var(--vtg-ink);font-family:Share Tech Mono,monospace;font-weight:600;box-shadow:inset 0 1px #ffffff80,inset 0 -1px #783c004d,0 0 5px #ffaa3c8c}.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);transition:border-color var(--transition-quick,.15s), background var(--transition-quick,.15s), box-shadow var(--transition-quick,.15s);padding-right:2.5rem;font-size:1rem}.search-input:hover:not(:disabled){border-color:rgba(var(--accent-rgb), .4)}.search-input:focus{border-color:var(--accent);outline:none}.search-input:focus-visible{border-color:var(--accent);box-shadow:var(--focus-ring);outline:none}.search-input:disabled{opacity:.5;cursor:not-allowed}.search-input[aria-invalid=true]{border-color:var(--danger);background:rgba(var(--danger-rgb), .06)}.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:visible}.album-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.album-card-cover-frame{width:100%;position:relative}.album-card-badges{gap:var(--space-xs);pointer-events:none;flex-direction:column;display:flex;position:absolute;top:50%;left:calc(100% - 14px);transform:translateY(-50%)}.album-card-badge{border-radius:var(--radius-circle);width:28px;height:28px;box-shadow:var(--shadow-card);border:2px solid #ffffff1a;justify-content:center;align-items:center;display:flex}.album-card-badge--heart{background:var(--heart);color:#fff}.album-card-badge--flag{background:var(--warning);color:var(--bg)}.album-cover{aspect-ratio:1;object-fit:cover;border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md);width:100%;display:block}.album-cover-placeholder{aspect-ratio:1;background:var(--surface-alt);width:100%;color:var(--text-secondary);border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md);justify-content:center;align-items:center;font-size:2rem;display:flex}.album-card-info{border-bottom-left-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md);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)}.find-sheet-backdrop{z-index:100;animation:find-sheet-backdrop-in var(--transition-sheet) var(--ease-sheet);background:#0009;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.find-sheet-backdrop--dismissing{animation:find-sheet-backdrop-out var(--transition-dismiss) var(--ease-dismiss);animation-fill-mode:forwards}.find-sheet-backdrop--suppressed{display:none}@keyframes find-sheet-backdrop-in{0%{background:0 0}to{background:#0009}}@keyframes find-sheet-backdrop-out{0%{background:#0009}to{background:0 0}}.find-sheet{--find-sheet-top-peek:max(40px, env(safe-area-inset-top,0px));width:100%;max-width:480px;height:calc(100vh - var(--find-sheet-top-peek));max-height:calc(100dvh - var(--find-sheet-top-peek));background:var(--bg);border-top-left-radius:var(--radius-xl);border-top-right-radius:var(--radius-xl);box-shadow:var(--shadow-modal);animation:find-sheet-slide-up var(--transition-sheet) var(--ease-sheet);padding-bottom:env(safe-area-inset-bottom,0);flex-direction:column;display:flex;overflow:hidden}@keyframes find-sheet-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.find-sheet-handle-row{padding:var(--space-md) var(--space-lg);touch-action:none;cursor:grab;flex:none;justify-content:center;align-items:center;display:flex;position:relative}.find-sheet-handle-row:active{cursor:grabbing}.find-sheet-handle{background:rgba(var(--white-rgb,240, 230, 210), .3);border-radius:var(--radius-pill);width:40px;height:4px}.find-sheet-dismiss{right:var(--space-base);top:var(--space-md);border-radius:var(--radius-circle);background:rgba(var(--white-rgb,240, 230, 210), .08);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-quick), color var(--transition-quick);border:none;justify-content:center;align-items:center;display:flex;position:absolute}.find-sheet-dismiss:hover,.find-sheet-dismiss:active{background:rgba(var(--white-rgb,240, 230, 210), .14);color:var(--text)}.find-sheet-body{-webkit-overflow-scrolling:touch;min-height:0;padding:var(--space-xs) var(--space-xl) var(--space-2xl);flex:auto;overflow-y:auto}.find-sheet-cover-wrap{margin:var(--space-md) 0 var(--space-lg);justify-content:center;display:flex}.find-sheet-cover-frame{display:inline-block;position:relative}.find-sheet-cover{background:var(--surface-alt);border-radius:var(--radius-md);width:220px;height:220px;box-shadow:var(--shadow-card);transition:box-shadow var(--transition-standard);overflow:hidden}.find-sheet-cover img{object-fit:cover;width:100%;height:100%;display:block}.find-sheet-cover-placeholder{width:100%;height:100%;color:var(--text-secondary);background:var(--surface-alt);justify-content:center;align-items:center;font-size:3rem;display:flex}.find-sheet-cover--wish{box-shadow:var(--shadow-card), 0 0 0 1.5px var(--wish-gold), 0 0 0 2.5px rgba(var(--wish-gold-rgb), .72), 0 0 0 3.5px rgba(var(--wish-gold-rgb), .42), 0 0 0 4.5px rgba(var(--wish-gold-rgb), .18), 0 0 16px rgba(var(--wish-gold-rgb), .3)}.find-sheet-cover-badges{pointer-events:none;flex-direction:column;gap:10px;display:flex;position:absolute;top:50%;left:calc(100% + 10px);transform:translateY(-50%)}.find-sheet-cover-badge{border-radius:var(--radius-circle);width:36px;height:36px;box-shadow:var(--shadow-card);border:2px solid #ffffff1a;justify-content:center;align-items:center;display:flex}.find-sheet-cover-badge--heart{background:var(--heart);color:#fff}.find-sheet-cover-badge--flag{background:var(--warning);color:var(--bg)}.find-sheet-cover-badge--wish{background:linear-gradient(135deg, var(--accent-light), var(--accent));color:var(--bg)}.find-sheet-header-row{align-items:flex-start;gap:var(--space-base);margin-bottom:var(--space-lg);padding:0 var(--space-xs);display:flex}.find-sheet-title-block{flex:auto;min-width:0}.find-sheet-title{font-family:var(--font-family-heading);font-size:var(--text-title-lg);letter-spacing:var(--track-tight);line-height:var(--leading-tight);margin:0 0 var(--space-2xs);color:var(--text)}.find-sheet-meta{font-size:var(--text-body-sm);color:var(--text-secondary);line-height:1.35}.find-sheet-meta-artist{color:var(--text-secondary)}.find-sheet-header-icons{gap:var(--space-3xs);margin-top:var(--space-2xs);flex-shrink:0;display:flex}.find-sheet-header-icon-btn{color:var(--text-secondary);border-radius:var(--radius-circle);cursor:pointer;width:36px;height:36px;transition:background var(--transition-quick), color var(--transition-quick);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.find-sheet-header-icon-btn:hover{background:rgba(var(--white-rgb,240, 230, 210), .06);color:var(--text)}.find-sheet-header-icon-btn:active{transform:scale(.92)}.find-sheet-header-icon-btn--heart-on{color:var(--heart)}.find-sheet-header-icon-btn--flag-on{color:var(--warning)}.find-sheet-banner{background:rgba(var(--success-rgb), .12);border:1px solid rgba(var(--success-rgb), .3);color:var(--success);padding:var(--space-md) var(--space-base);border-radius:var(--radius-md);font-size:var(--text-body-sm);margin-bottom:var(--space-base);align-items:center;gap:var(--space-sm);font-weight:500;display:flex}.find-sheet-banner--wanted{background:rgba(var(--wish-gold-rgb), .12);border-color:rgba(var(--wish-gold-rgb), .35);color:var(--wish-gold)}.find-sheet-banner-flag{color:var(--warning);font-weight:500}.find-sheet-slot-row{gap:var(--space-md);margin-bottom:var(--space-base);display:grid}.find-sheet-slot-row--3{grid-template-columns:1fr 1fr 1fr}.find-sheet-slot-row--2{grid-template-columns:1fr 1fr}.find-sheet-status-badge{background:var(--accent-100);color:var(--accent-light);border-radius:var(--radius-md);padding:var(--space-base) var(--space-md);font-size:var(--text-body-sm);justify-content:center;align-items:center;gap:var(--space-xs);border:1px solid var(--border);font-weight:600;line-height:1.2;display:flex}.find-sheet-status-badge--wish{background:rgba(var(--wish-gold-rgb), .12);color:var(--wish-gold);border-color:rgba(var(--wish-gold-rgb), .35)}.find-sheet-btn{color:var(--accent-light);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-base) var(--space-md);font-size:var(--text-body-sm);cursor:pointer;justify-content:center;align-items:center;gap:var(--space-sm);transition:background var(--transition-quick), transform var(--transition-instant);background:0 0;font-weight:600;line-height:1.2;display:flex}.find-sheet-btn:active{transform:scale(.97)}.find-sheet-btn:disabled{opacity:.55;cursor:default}.find-sheet-btn--primary{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent)}.find-sheet-btn--primary:active{background:var(--accent-700,var(--accent))}.find-sheet-btn--ghost{color:var(--accent-light);background:0 0}.find-sheet-btn--ghost:hover,.find-sheet-btn--ghost:active{background:var(--accent-50,rgba(var(--accent-rgb), .08))}.find-sheet-btn--swap{color:var(--accent-light);background:0 0}.find-sheet-btn--promote{width:100%;margin-bottom:var(--space-base)}.find-sheet-btn--sm{padding:var(--space-sm) var(--space-base);font-size:var(--text-caption)}.find-sheet-btn--collection{width:100%}.find-sheet-location-picker{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-base);gap:var(--space-md);flex-direction:column;grid-column:1/-1;display:flex}.find-sheet-location-label{font-size:var(--text-caption);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.find-sheet-location-list{gap:var(--space-xs);flex-wrap:wrap;display:flex}.find-sheet-location-opt{color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-badge);padding:var(--space-xs) var(--space-base);font-size:var(--text-caption);cursor:pointer;transition:background var(--transition-quick), color var(--transition-quick);background:0 0}.find-sheet-location-opt--active{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent)}.find-sheet-location-actions{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.find-sheet-links-row{justify-content:center;gap:var(--space-2xl);margin:var(--space-md) 0 var(--space-lg);font-size:var(--text-body-sm);flex-wrap:wrap;display:flex}.find-sheet-link{color:var(--text-secondary);align-items:center;gap:var(--space-xs);cursor:pointer;font-size:var(--text-body-sm);transition:color var(--transition-quick);background:0 0;border:none;padding:0;text-decoration:none;display:inline-flex}.find-sheet-link:hover{color:var(--text)}.find-sheet-link--push{color:var(--accent-light)}.find-sheet-link--in-collection{color:var(--success);cursor:default}.find-sheet-link-dot{border-radius:var(--radius-circle);background:var(--accent);width:6px;height:6px;display:inline-block}.find-sheet-link-dot--apple{background:#fa233b}.find-sheet-meta-extras{margin:var(--space-md) 0 var(--space-lg);padding:var(--space-base) 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);gap:var(--space-sm);flex-direction:column;display:flex}.find-sheet-note-add{color:var(--text-secondary);font-size:var(--text-body-sm);align-items:center;gap:var(--space-sm);cursor:pointer;text-align:left;background:0 0;border:none;padding:0;display:flex}.find-sheet-note-plus{color:var(--accent-light);font-weight:700}.find-sheet-note{font-size:var(--text-body-sm);color:var(--text);line-height:1.45}.find-sheet-note--empty{color:var(--text-secondary);font-style:italic}.find-sheet-note-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:var(--text-caption);margin-right:var(--space-xs)}.find-sheet-chips{gap:var(--space-sm);flex-wrap:wrap;align-items:center;display:flex}.find-sheet-chip{background:var(--accent-100);color:var(--accent-light);border-radius:var(--radius-badge);padding:var(--space-3xs) var(--space-base);font-size:var(--text-caption);align-items:center;gap:var(--space-xs);border:1px solid #0000;font-weight:500;display:inline-flex}.find-sheet-chip--add{color:var(--text-secondary);border:1px dashed var(--border);cursor:pointer;background:0 0}.find-sheet-chip--genre{background:var(--accent);color:var(--text-on-accent)}.find-sheet-chip--style{color:var(--accent-light);border-color:var(--border);background:0 0}.find-sheet-chip--active{background:var(--accent);color:var(--text-on-accent)}.find-sheet-chip-remove{color:inherit;cursor:pointer;padding:0 var(--space-2xs);opacity:.7;background:0 0;border:none;font-size:1rem;line-height:1}.find-sheet-chip-remove:hover{opacity:1}.find-sheet-collections{gap:var(--space-md);margin:var(--space-md) 0 var(--space-lg);flex-direction:column;display:flex}.find-sheet-collection-chips{gap:var(--space-xs);flex-wrap:wrap;display:flex}.find-sheet-collection-chip{background:rgba(var(--accent-rgb), .08);color:var(--accent-light);border:1px solid var(--border);border-radius:var(--radius-badge);padding:var(--space-3xs) var(--space-base);font-size:var(--text-caption)}.find-sheet-edit-fields{gap:var(--space-base);margin-top:var(--space-md);flex-direction:column;display:flex}.find-sheet-edit-field{gap:var(--space-xs);flex-direction:column;display:flex}.find-sheet-edit-label{font-size:var(--text-caption);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:500}.find-sheet-edit-input,.find-sheet-edit-textarea{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md) var(--space-base);transition:border-color var(--transition-quick);width:100%;font-family:inherit;font-size:1rem}.find-sheet-edit-input:focus,.find-sheet-edit-textarea:focus{border-color:var(--accent);outline:none}.find-sheet-edit-input--title{font-family:var(--font-family-heading);font-size:var(--text-title-lg);letter-spacing:var(--track-tight);padding:var(--space-sm) var(--space-base)}.find-sheet-edit-input--artist{margin-top:var(--space-xs)}.find-sheet-edit-textarea{resize:vertical;min-height:80px}.find-sheet-tag-input-container{gap:var(--space-xs);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-sm);flex-wrap:wrap;align-items:center;min-height:44px;display:flex;position:relative}.find-sheet-tag-text-input{min-width:80px;color:var(--text);padding:var(--space-2xs) var(--space-xs);background:0 0;border:none;outline:none;flex:auto;font-size:1rem}.find-sheet-tag-suggestions{top:calc(100% + var(--space-xs));background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-2xs);gap:var(--space-3xs);z-index:10;box-shadow:var(--shadow-card);flex-direction:column;display:flex;position:absolute;left:0;right:0}.find-sheet-tag-suggestion-item{color:var(--text);padding:var(--space-xs) var(--space-base);text-align:left;cursor:pointer;border-radius:var(--radius-sm);font-size:var(--text-body-sm);background:0 0;border:none}.find-sheet-tag-suggestion-item:hover{background:var(--surface-alt)}.find-sheet-edit-actions{gap:var(--space-md);margin-top:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.find-sheet-delete-section{margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--border)}.find-sheet-delete-btn{color:var(--danger);border:1px solid var(--danger);border-radius:var(--radius-md);padding:var(--space-base);font-size:var(--text-body-sm);cursor:pointer;width:100%;transition:background var(--transition-quick);background:0 0;font-weight:600}.find-sheet-delete-btn:hover,.find-sheet-delete-btn:active{background:rgba(var(--danger-rgb), .08)}.find-sheet-tracklist-header{margin:var(--space-base) 0 var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.find-sheet-tracklist-header h3{font-family:var(--font-family-heading);font-size:var(--text-title-sm);color:var(--text-secondary);letter-spacing:.02em;margin:0;font-weight:400}.find-sheet-am-sub{font-family:var(--font-family);font-size:var(--text-caption);color:var(--text-secondary);margin-left:var(--space-xs)}.find-sheet-dj-pill{border:1px solid var(--border);color:var(--text-secondary);font-size:var(--text-caption);letter-spacing:.08em;padding:var(--space-2xs) var(--space-base);border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition-quick);background:0 0;font-weight:700}.find-sheet-dj-pill--on{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent)}.find-sheet-dj-pill:disabled{opacity:.55;cursor:default}.find-sheet-essentia-banner{align-items:center;gap:var(--space-base);background:rgba(var(--accent-rgb), .08);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md) var(--space-base);margin-bottom:var(--space-md);display:flex}.find-sheet-essentia-banner-text{font-size:var(--text-body-sm);color:var(--text);flex:auto}.find-sheet-tracks{margin:0;padding:0;list-style:none}.find-sheet-track{padding:var(--space-md) 0;border-bottom:1px solid rgba(var(--white-rgb,240, 230, 210), .06);font-size:var(--text-body-sm)}.find-sheet-track:last-child{border-bottom:none}.find-sheet-track--heading{font-family:var(--font-family-heading);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-size:var(--text-caption);padding:var(--space-lg) 0 var(--space-md)}.find-sheet-track-row{align-items:center;gap:var(--space-sm);display:flex}.find-sheet-track-num{width:20px;color:var(--text-secondary);font-size:var(--text-caption);font-variant-numeric:tabular-nums;flex-shrink:0}.find-sheet-track-play{color:var(--accent);padding:var(--space-2xs);cursor:pointer;transition:transform var(--transition-instant), color var(--transition-quick);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.find-sheet-track-play:active{transform:scale(.9)}.find-sheet-track-play--active{color:var(--accent-light)}.find-sheet-track-title{padding-right:var(--space-sm);text-overflow:ellipsis;white-space:nowrap;color:var(--text);flex:auto;overflow:hidden}.find-sheet-track--playing .find-sheet-track-title{color:var(--accent-light)}.find-sheet-track-setlist{border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-circle);cursor:pointer;width:24px;height:24px;transition:color var(--transition-quick), border-color var(--transition-quick);background:0 0;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:1rem;line-height:1;display:flex}.find-sheet-track-setlist:hover{color:var(--accent-light);border-color:var(--accent)}.find-sheet-track-duration{color:var(--text-secondary);font-size:var(--text-caption);font-variant-numeric:tabular-nums;flex-shrink:0}.find-sheet-track-dj-line{margin-top:var(--space-2xs);min-height:1rem;padding-left:28px}.find-sheet-track-features{font-size:var(--text-caption);color:var(--text-secondary);font-family:var(--font-family-mono);letter-spacing:.03em}.find-sheet-loading{text-align:center;color:var(--text-secondary);padding:var(--space-2xl) 0;font-size:var(--text-body-sm)}.find-sheet-flag-prompt-overlay{z-index:200;animation:find-sheet-backdrop-in var(--transition-standard) ease-out;background:#0009;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.find-sheet-flag-prompt{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-xl);margin:var(--space-lg);gap:var(--space-base);width:100%;max-width:340px;box-shadow:var(--shadow-modal);flex-direction:column;display:flex}.find-sheet-flag-prompt-icon{color:var(--warning);justify-content:center;display:flex}.find-sheet-flag-prompt-title{text-align:center;font-family:var(--font-family-heading);font-size:var(--text-title-sm);color:var(--text);margin:0}.find-sheet-flag-prompt-options{gap:var(--space-sm);flex-wrap:wrap;justify-content:center;display:flex}@media (prefers-reduced-motion:reduce){.find-sheet-backdrop,.find-sheet-backdrop--dismissing,.find-sheet,.find-sheet-flag-prompt-overlay{animation:none}}.expand-search-backdrop{z-index:110;animation:expand-search-backdrop-in var(--transition-sheet) var(--ease-sheet);background:#0009;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.expand-search-backdrop--suppressed{display:none}.expand-search-backdrop--dismissing{animation:expand-search-backdrop-out var(--transition-dismiss) var(--ease-dismiss);animation-fill-mode:forwards}@keyframes expand-search-backdrop-in{0%{background:0 0}to{background:#0009}}@keyframes expand-search-backdrop-out{0%{background:#0009}to{background:0 0}}.expand-search-sheet{--expand-search-top-peek:max(40px, env(safe-area-inset-top,0px));width:100%;max-width:480px;height:calc(100vh - var(--expand-search-top-peek));max-height:calc(100dvh - var(--expand-search-top-peek));background:var(--bg);border-top-left-radius:var(--radius-xl);border-top-right-radius:var(--radius-xl);box-shadow:var(--shadow-modal);animation:expand-search-slide-up var(--transition-sheet) var(--ease-sheet);padding-bottom:env(safe-area-inset-bottom,0);flex-direction:column;display:flex;overflow:hidden}@keyframes expand-search-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.expand-search-handle-row{padding:var(--space-md) var(--space-lg);touch-action:none;cursor:grab;flex:none;justify-content:center;align-items:center;display:flex;position:relative}.expand-search-handle-row:active{cursor:grabbing}.expand-search-handle{background:rgba(var(--white-rgb,240, 230, 210), .3);border-radius:var(--radius-pill);width:40px;height:4px}.expand-search-dismiss{right:var(--space-base);top:var(--space-md);border-radius:var(--radius-circle);background:rgba(var(--white-rgb,240, 230, 210), .08);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-quick), color var(--transition-quick);border:none;justify-content:center;align-items:center;display:flex;position:absolute}.expand-search-dismiss:hover,.expand-search-dismiss:active{background:rgba(var(--white-rgb,240, 230, 210), .14);color:var(--text)}.expand-search-header{padding:0 var(--space-xl);margin-bottom:var(--space-sm);flex:none}.expand-search-header h2{font-family:var(--font-family-heading);font-size:var(--text-title-lg);letter-spacing:var(--track-tight);line-height:var(--leading-tight);margin:0 0 var(--space-2xs);color:var(--text)}.expand-search-subtitle{font-size:var(--text-caption);color:var(--text-secondary);min-height:1rem}.expand-search-body{-webkit-overflow-scrolling:touch;min-height:0;padding:var(--space-sm) var(--space-xl) var(--space-2xl);flex:auto;overflow-y:auto}.expand-search-field{align-items:center;gap:var(--space-sm);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-sm) var(--space-base);margin-bottom:var(--space-md);transition:border-color var(--transition-quick);display:flex}.expand-search-field:focus-within{border-color:var(--accent)}.expand-search-field-icon{color:var(--text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.expand-search-field-input{min-width:0;color:var(--text);padding:var(--space-2xs) 0;background:0 0;border:none;outline:none;flex:auto;font-family:inherit;font-size:1rem}.expand-search-field-input::placeholder{color:var(--text-secondary)}.expand-search-field-clear{color:var(--text-secondary);cursor:pointer;padding:var(--space-2xs);transition:color var(--transition-quick);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.expand-search-field-clear:hover,.expand-search-field-clear:active{color:var(--text)}.expand-search-tiles{gap:var(--space-sm);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.expand-search-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);transition:background var(--transition-quick), border-color var(--transition-quick);overflow:hidden}.expand-search-tile--library{border-color:var(--accent);background:rgba(var(--accent-rgb), .06)}.expand-search-tile--expanded{background:var(--surface-alt);border-color:var(--accent-light)}.expand-search-tile-hit{width:100%;color:inherit;text-align:left;gap:var(--space-md);padding:var(--space-md) var(--space-base);cursor:pointer;background:0 0;border:none;align-items:flex-start;font-family:inherit;display:flex}.expand-search-tile-hit:disabled{cursor:default}.expand-search-tile-num{min-width:16px;padding-top:var(--space-3xs);font-size:var(--text-caption);color:var(--text-secondary);font-variant-numeric:tabular-nums;text-align:right;flex-shrink:0}.expand-search-tile-thumb{border-radius:var(--radius-sm);background:var(--surface-alt);width:52px;height:52px;box-shadow:var(--shadow-card);flex-shrink:0;overflow:hidden}.expand-search-tile-thumb img{object-fit:cover;width:100%;height:100%;display:block}.expand-search-tile-thumb-placeholder{width:100%;height:100%;color:var(--text-secondary);justify-content:center;align-items:center;font-size:1.4rem;display:flex}.expand-search-tile-body{flex:auto;min-width:0}.expand-search-tile-title-row{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-3xs);display:flex}.expand-search-tile-title{font-size:var(--text-body-sm);color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:auto;min-width:0;font-weight:600;overflow:hidden}.expand-search-tile-pill{background:var(--accent);color:var(--text-on-accent);letter-spacing:.1em;padding:var(--space-3xs) var(--space-xs);border-radius:var(--radius-pill);flex-shrink:0;font-size:.58rem;font-weight:700;line-height:1.3}.expand-search-tile-artist{font-size:var(--text-caption);color:var(--text-secondary);margin-bottom:var(--space-3xs);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.expand-search-tile-meta{gap:var(--space-xs);font-size:var(--text-caption);color:var(--text-secondary);flex-wrap:wrap;align-items:center;line-height:1.35;display:flex}.expand-search-tile-chip{background:rgba(var(--accent-rgb), .1);color:var(--accent-light);padding:var(--space-3xs) var(--space-xs);border-radius:var(--radius-badge);font-size:.66rem;font-weight:500;line-height:1.4}.expand-search-tile-chip--format{background:rgba(var(--success-rgb), .1);color:var(--success)}.expand-search-tile-chip--limited{background:rgba(var(--wish-gold-rgb), .1);color:var(--wish-gold)}.expand-search-tile-detail{color:var(--text-secondary)}.expand-search-tile-actions{gap:var(--space-sm);padding:0 var(--space-base) var(--space-md);border-top:1px solid var(--border);padding-top:var(--space-md);margin-top:var(--space-2xs);display:grid}.expand-search-tile-actions--three{grid-template-columns:1fr 1fr 1fr}.expand-search-tile-actions--two{grid-template-columns:1fr 1fr}.expand-search-action-btn{color:var(--accent-light);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-xs);font-size:var(--text-caption);cursor:pointer;justify-content:center;align-items:center;gap:var(--space-2xs);transition:background var(--transition-quick), transform var(--transition-instant);background:0 0;font-family:inherit;font-weight:600;display:flex}.expand-search-action-btn:active{transform:scale(.97)}.expand-search-action-btn--primary{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent)}.expand-search-action-btn--primary:active{background:var(--accent-700,var(--accent))}.expand-search-empty{text-align:center;padding:var(--space-3xl) var(--space-lg);color:var(--text-secondary)}.expand-search-empty-icon{opacity:.4;margin-bottom:var(--space-md);font-size:2.5rem}.expand-search-empty h3{font-family:var(--font-family-heading);font-size:var(--text-title-sm);color:var(--text);margin:0 0 var(--space-sm);font-weight:400}.expand-search-empty p{font-size:var(--text-body-sm);max-width:260px;margin:0 auto var(--space-lg);line-height:1.5}.expand-search-empty-clear{color:var(--accent-light);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-lg);font-size:var(--text-body-sm);cursor:pointer;transition:background var(--transition-quick);background:0 0;font-family:inherit;font-weight:600}.expand-search-empty-clear:hover,.expand-search-empty-clear:active{background:var(--accent-50,rgba(var(--accent-rgb), .08))}@media (prefers-reduced-motion:reduce){.expand-search-backdrop,.expand-search-backdrop--dismissing,.expand-search-sheet{animation:none}}.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--wishes .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--success{border-color:rgba(var(--success-rgb), .35);box-shadow:0 6px 20px #00000040, inset 3px 0 0 var(--success)}.toast--danger{border-color:rgba(var(--danger-rgb), .35);box-shadow:0 6px 20px #00000040, inset 3px 0 0 var(--danger)}.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)}}@media (prefers-reduced-motion:reduce){.toast{animation:none}}.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}}.swap-confirm-overlay{z-index:130;padding:var(--space-lg);animation:swap-confirm-fade-in var(--transition-standard) ease-out;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@keyframes swap-confirm-fade-in{0%{background:0 0}to{background:#0009}}.swap-confirm{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-xl);gap:var(--space-md);width:100%;max-width:360px;box-shadow:var(--shadow-modal);flex-direction:column;display:flex}.swap-confirm-title{font-family:var(--font-family-heading);font-size:var(--text-title-sm);color:var(--text);text-align:center;margin:0}.swap-confirm-body{font-size:var(--text-body-sm);color:var(--text-secondary);text-align:center;margin:0;line-height:1.45}.swap-confirm-actions{gap:var(--space-sm);margin-top:var(--space-sm);flex-direction:column;display:flex}.swap-confirm-btn{color:var(--text);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-base) var(--space-md);font-size:var(--text-body-sm);cursor:pointer;transition:background var(--transition-quick), transform var(--transition-instant);background:0 0;font-family:inherit;font-weight:600}.swap-confirm-btn:active{transform:scale(.97)}.swap-confirm-btn--primary{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent)}.swap-confirm-btn--danger{color:var(--danger);border-color:rgba(var(--danger-rgb), .55)}.swap-confirm-btn--danger:hover,.swap-confirm-btn--danger:active{background:rgba(var(--danger-rgb), .08)}
