.tab-bar-mobile{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;background:var(--bg-surface);border-top:1px solid var(--border);padding-bottom:var(--safe-bottom);height:calc(var(--tab-height) + var(--safe-bottom))}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:var(--space-2) 0;color:var(--text-muted);transition:color .15s;min-height:44px;-webkit-tap-highlight-color:transparent}.tab-item:active{opacity:.7}.tab-item.active{color:var(--accent)}.tab-label{font-size:.625rem;font-weight:600;letter-spacing:.02em}.chat-panel{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;flex-direction:column;background:var(--bg-page)}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--page-px);padding-top:calc(var(--safe-top) + var(--space-4));border-bottom:1px solid var(--border);background:var(--bg-surface);min-height:60px}.chat-header-title{font-weight:700;font-size:var(--text-lg)}.chat-header-actions{display:flex;align-items:center;gap:var(--space-2)}.chat-new-btn{color:var(--text-muted);padding:var(--space-2);min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.chat-new-btn:active{opacity:.6;background:var(--bg-elevated)}.chat-close{color:var(--text-muted);padding:var(--space-2);min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.chat-close:active{opacity:.6;background:var(--bg-elevated)}.chat-messages{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:var(--page-px);display:flex;flex-direction:column;gap:var(--space-3)}.chat-welcome{padding:var(--space-5) var(--page-px)}.chat-welcome-text{text-align:center;color:var(--text-secondary);font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-4)}.chat-starters{display:flex;flex-direction:column;gap:var(--space-2)}.chat-starter{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--page-px);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);text-align:left;color:var(--text-secondary);font-size:var(--text-sm);line-height:1.4;-webkit-tap-highlight-color:transparent}.chat-starter:active{background:var(--bg-elevated)}.chat-starter-icon{font-size:var(--text-base);flex-shrink:0;margin-top:1px}.chat-starter-text{flex:1}.chat-msg{display:flex}.chat-msg-user{justify-content:flex-end}.chat-msg-bubble{max-width:80%;padding:var(--space-3) var(--page-px);border-radius:var(--radius-lg);font-size:var(--text-sm);line-height:1.5}.chat-msg-user .chat-msg-bubble{background:var(--accent);color:#000;border-bottom-right-radius:var(--space-1)}.chat-msg-assistant .chat-msg-bubble{background:var(--bg-surface);color:var(--text-primary);border-bottom-left-radius:var(--space-1)}.chat-typing{color:var(--text-muted);font-style:italic}.chat-thinking{display:flex;align-items:center;padding:var(--space-2) 0;gap:var(--space-3);flex-wrap:wrap}.chat-retry-btn{font-size:var(--text-xs);color:var(--accent);background:none;border:none;padding:var(--space-1) 0;cursor:pointer;text-decoration:underline;text-underline-offset:2px;opacity:0;animation:fadeIn .3s ease forwards}@keyframes fadeIn{to{opacity:1}}.chat-vinyl{width:40px;height:40px;border-radius:50%;background:conic-gradient(from 0deg,#111,#222,#111,#1a1a1a 90deg,#222 150deg,#111,#1a1a1a 210deg,#252525,#111 330deg,#111 360deg);position:relative;animation:chatVinylSpin 1.6s linear infinite;box-shadow:0 0 0 2px #444,0 0 8px #00000080}.chat-vinyl:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:linear-gradient(135deg,transparent 30%,rgba(255,255,255,.15) 45%,rgba(255,255,255,.05) 50%,transparent 65%);z-index:2;pointer-events:none}.chat-vinyl-groove{position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:50%;border:1px solid rgba(255,255,255,.08)}.chat-vinyl-groove-2{top:10px;right:10px;bottom:10px;left:10px;border-color:#ffffff0f}.chat-vinyl-label{position:absolute;width:14px;height:14px;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;background:var(--accent, #e5a00d);z-index:3}.chat-vinyl-label:after{content:"";position:absolute;width:3px;height:3px;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;background:#1a1a1a}@keyframes chatVinylSpin{to{transform:rotate(360deg)}}.chat-start-session-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;margin-top:var(--space-3);padding:var(--space-3);background:#22c55e1a;border:1px solid rgba(34,197,94,.25);border-radius:var(--radius-md);color:#4ade80;font-size:var(--text-sm);font-weight:600;-webkit-tap-highlight-color:transparent}.chat-start-session-btn:active:not(:disabled){background:#22c55e33}.chat-start-session-btn:disabled{opacity:.5}.chat-msg-bubble .chat-md-p{margin:0 0 .4em}.chat-msg-bubble .chat-md-p:last-child{margin-bottom:0}.chat-msg-bubble .chat-md-heading{display:block;margin:.5em 0 .25em;font-size:var(--text-base)}.chat-msg-bubble .chat-md-list{margin:.25em 0;padding-left:1.5em}.chat-msg-bubble ol.chat-md-list{list-style:decimal}.chat-msg-bubble ul.chat-md-list{list-style:disc}.chat-msg-bubble .chat-md-list li{font-size:inherit;line-height:1.45;margin-bottom:.5em}.chat-msg-bubble .chat-md-link{color:var(--accent);text-decoration:underline;text-underline-offset:2px;word-break:break-word}.chat-msg-bubble .chat-md-album-link{color:var(--accent);text-decoration:none;border-bottom:1px dotted var(--accent)}.chat-msg-bubble .chat-md-img{display:block;max-width:180px;border-radius:var(--radius-md);margin:var(--space-2) 0;box-shadow:0 2px 8px #0000004d}.chat-album-cards{display:flex;gap:var(--space-2);overflow-x:auto;padding:var(--space-3) 0 var(--space-1);-webkit-overflow-scrolling:touch;scrollbar-width:none}.chat-album-cards::-webkit-scrollbar{display:none}.chat-album-card{flex:0 0 auto;width:100px;text-decoration:none;color:inherit;text-align:center}.chat-album-card-img{width:100px;height:100px;object-fit:cover;border-radius:var(--radius-sm);box-shadow:0 2px 8px #0000004d}.chat-album-card-title{display:block;font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1);line-height:1.2;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.chat-input-bar{display:flex;gap:var(--space-2);padding:var(--space-3) var(--page-px);padding-bottom:calc(var(--space-3) + var(--safe-bottom));border-top:1px solid var(--border);background:var(--bg-surface)}.chat-input{flex:1;padding:var(--space-3) var(--page-px);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-lg);font-size:var(--text-base);color:var(--text-primary);min-height:44px}.chat-input:focus{outline:none;border-color:var(--accent)}.chat-input::placeholder{color:var(--text-muted)}.chat-send{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent);color:#000;flex-shrink:0}.chat-send:active:not(:disabled){transform:scale(.92)}.chat-send:disabled{opacity:.3}.chat-history-btn{color:var(--text-muted);padding:var(--space-2);min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.chat-history-btn:active{opacity:.6;background:var(--bg-elevated)}.chat-session-list{border-bottom:1px solid var(--border);background:var(--bg-surface);max-height:50vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.chat-session-list-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--page-px);border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-surface);z-index:1}.chat-session-list-title{font-size:var(--text-sm);font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.04em}.chat-session-list-close{width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);border-radius:var(--radius-md)}.chat-session-list-close:active{background:var(--bg-elevated)}.chat-session-new-btn{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--page-px);font-size:var(--text-sm);font-weight:600;color:var(--accent);background:none;border:none;border-bottom:1px solid var(--border);-webkit-tap-highlight-color:transparent}.chat-session-new-btn:active{background:var(--bg-elevated)}.chat-session-empty{padding:var(--space-4) var(--page-px);color:var(--text-muted);font-size:var(--text-sm);text-align:center}.chat-session-item{display:flex;align-items:center;width:100%;padding:0;border-bottom:1px solid var(--border);text-align:left;color:var(--text-primary);font-size:var(--text-sm);-webkit-tap-highlight-color:transparent}.chat-session-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;padding:var(--space-4) var(--page-px);color:inherit;font-size:inherit;text-align:left;min-height:60px;justify-content:center;-webkit-tap-highlight-color:transparent}.chat-session-main:active{background:var(--bg-elevated)}.chat-session-item:last-child{border-bottom:none}.chat-session-item--active{background:var(--bg-elevated)}.chat-session-actions{display:flex;flex-shrink:0}.chat-session-action-btn{display:flex;align-items:center;justify-content:center;width:48px;height:60px;color:var(--text-muted);-webkit-tap-highlight-color:transparent}.chat-session-action-btn:active{color:var(--accent);background:var(--bg-elevated)}.chat-session-delete-btn:active{color:#f87171}.chat-session-rename-row{display:flex;flex-direction:column;gap:var(--space-3);width:100%;padding:var(--space-4) var(--page-px)}.chat-session-rename-input{width:100%;background:var(--bg-input);border:1px solid var(--accent);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-base);padding:var(--space-3) var(--space-4);min-height:48px;outline:none;font-family:inherit}.chat-session-rename-input::placeholder{color:var(--text-muted)}.chat-session-rename-charcount{font-size:var(--text-xs);color:var(--text-muted);text-align:right;margin-top:calc(-1 * var(--space-2))}.chat-session-rename-actions{display:flex;gap:var(--space-3)}.chat-session-save-btn{flex:1;padding:var(--space-3);background:var(--accent);color:#000;font-size:var(--text-sm);font-weight:600;border:none;border-radius:var(--radius-md);min-height:48px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.chat-session-save-btn:active{opacity:.8}.chat-session-cancel-btn{flex:1;padding:var(--space-3);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);min-height:48px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.chat-session-cancel-btn:active{opacity:.7}.chat-session-preview{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.chat-session-date{color:var(--text-muted);font-size:var(--text-xs)}.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:var(--bg-page);display:flex;flex-direction:column;animation:search-slide-up .25s cubic-bezier(.4,0,.2,1)}@keyframes search-slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.search-header{display:flex;align-items:center;gap:var(--space-2);padding:calc(var(--safe-top) + var(--space-2)) var(--page-px) var(--space-2);border-bottom:1px solid var(--border);background:var(--bg-surface)}.search-back{width:36px;height:36px;border:none;background:none;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.search-input-wrap{flex:1;position:relative;display:flex;align-items:center}.search-input{width:100%;height:40px;border:none;border-radius:var(--radius-md);background:var(--bg-input);color:var(--text-primary);font-size:var(--text-base);padding:0 36px 0 var(--space-3);outline:none}.search-clear{position:absolute;right:4px;width:28px;height:28px;border:none;background:none;color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer}.search-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:var(--space-3) var(--page-px) calc(var(--safe-bottom) + var(--space-4))}.search-loading{display:flex;align-items:center;justify-content:center;padding:var(--space-8) 0;color:var(--text-muted);font-size:var(--text-sm)}.search-empty-title{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:var(--space-4) 0 var(--space-2)}.search-empty-title:first-child{margin-top:0}.search-recent-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;color:var(--text-primary);font-size:var(--text-sm);cursor:pointer;border:none;background:none;width:100%;text-align:left}.search-recent-item svg{color:var(--text-muted);flex-shrink:0}.search-recent-clear{border:none;background:none;color:var(--text-muted);font-size:var(--text-xs);cursor:pointer;padding:var(--space-1) 0}.search-trending-item{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:var(--bg-elevated);border-radius:var(--radius-full);border:1px solid var(--border);color:var(--text-primary);font-size:var(--text-sm);margin:0 var(--space-1) var(--space-2) 0;cursor:pointer}.search-trending-item:active{background:var(--border)}.search-trending-wrap{display:flex;flex-wrap:wrap}.search-group{margin-bottom:var(--space-4)}.search-group-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.search-group-title{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.search-group-count{font-size:var(--text-2xs);color:var(--text-muted)}.search-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--border);cursor:pointer;text-decoration:none;color:inherit}.search-card:last-child{border-bottom:none}.search-card:active{opacity:.7}.search-card-thumb{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-elevated);flex-shrink:0}.search-card-icon{width:48px;height:48px;border-radius:var(--radius-sm);background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-muted)}.search-card-body{flex:1;min-width:0}.search-card-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-card-sub{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.search-card-meta{display:flex;gap:var(--space-2);margin-top:2px}.search-card-badge{font-size:var(--text-2xs);font-weight:600;padding:1px 6px;border-radius:var(--radius-full);white-space:nowrap}.search-card-badge--collection{background:#f59e0b26;color:var(--accent)}.search-card-badge--grade{background:#22c55e26;color:var(--grade-a)}.search-card-badge--aaa{background:#f59e0b26;color:var(--audio-aaa)}.search-card-badge--pressings{background:#3b82f626;color:var(--grade-b)}.search-card-badge--fomo{background:#ef444426;color:var(--fomo-high)}.search-hero{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3);margin-bottom:var(--space-4);cursor:pointer}.search-hero:active{opacity:.85}.search-hero-label{font-size:var(--text-2xs);font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-2)}.search-hero-row{display:flex;align-items:center;gap:var(--space-3)}.search-hero-thumb{width:64px;height:64px;border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-elevated);flex-shrink:0}.search-hero-icon{width:64px;height:64px;border-radius:var(--radius-sm);background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-muted)}.search-hero-body{flex:1;min-width:0}.search-hero-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.search-hero-sub{font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.search-hero-meta{display:flex;gap:var(--space-2);margin-top:var(--space-1)}.search-section{margin-bottom:var(--space-5)}.search-section-header{display:flex;justify-content:space-between;align-items:center}.search-recent-scroll{display:flex;gap:var(--space-2);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:var(--space-1)}.search-recent-scroll::-webkit-scrollbar{display:none}.search-recent-chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-primary);font-size:var(--text-sm);white-space:nowrap;cursor:pointer;flex-shrink:0}.search-recent-chip svg{color:var(--text-muted);flex-shrink:0}.search-recent-chip:active{background:var(--border)}.search-vinyl-scroll{display:flex;gap:var(--space-3);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:var(--space-1)}.search-vinyl-scroll::-webkit-scrollbar{display:none}.search-vinyl-card{flex-shrink:0;width:100px;border:none;background:none;padding:0;cursor:pointer;text-align:left;color:inherit}.search-vinyl-card:active{opacity:.7}.search-vinyl-cover{width:100px;height:100px;border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-elevated);display:block}.search-vinyl-title{font-size:var(--text-xs);font-weight:500;color:var(--text-primary);margin-top:var(--space-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-vinyl-artist{font-size:var(--text-2xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-guides-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.search-guide-card{border:none;background:var(--bg-surface);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;text-align:left;color:inherit;padding:0}.search-guide-card:active{opacity:.7}.search-guide-cover{width:100%;aspect-ratio:1;object-fit:cover;background:var(--bg-elevated);display:block}.search-guide-placeholder{width:100%;aspect-ratio:1;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.search-guide-body{padding:var(--space-2)}.search-guide-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-guide-artist{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.search-guide-meta{display:flex;gap:var(--space-1);margin-top:var(--space-1)}.search-no-results{text-align:center;padding:var(--space-8) 0;color:var(--text-muted);font-size:var(--text-sm)}.power-fab-stack{position:fixed;bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-5));right:var(--page-px);z-index:90;display:flex;flex-direction:column;align-items:center;gap:10px}.power-fab{width:48px;height:48px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0006;cursor:pointer;-webkit-tap-highlight-color:transparent}.power-fab:active{transform:scale(.92)}.power-fab--ai{background:#a78bfa;color:#fff}.power-fab--search{background:var(--accent);color:#000}.ask-ai-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:#8b5cf61f;border:1px solid rgba(139,92,246,.3);border-radius:20px;color:#a78bfa;font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background .15s,border-color .15s;-webkit-tap-highlight-color:transparent}.ask-ai-btn:active{background:#8b5cf638;border-color:#8b5cf680}.ask-ai-inline{display:inline-flex;align-items:center;gap:5px;background:none;border:none;color:#a78bfa;font-size:var(--text-sm);font-weight:600;cursor:pointer;padding:4px 0;-webkit-tap-highlight-color:transparent}.ask-ai-inline:active{opacity:.7}.ask-ai-chip-single{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.25);border-radius:16px;color:#a78bfa;font-size:var(--text-sm);font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}.ask-ai-chip-single:active{background:#8b5cf638}.ask-ai-chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:center;padding:var(--space-3, 12px);background:var(--bg-surface, #1a1a2e);border:1px solid var(--border, rgba(255,255,255,.08));border-radius:var(--radius-md, 8px);margin:var(--space-3, 12px) 0}.ask-ai-chips-label{display:inline-flex;align-items:center;gap:5px;font-size:var(--text-sm);font-weight:700;color:#a78bfa;margin-right:2px}.ask-ai-chip{padding:7px 12px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.22);border-radius:16px;color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:background .15s,border-color .15s;-webkit-tap-highlight-color:transparent}.ask-ai-chip:active,.ask-ai-chip--active{background:#8b5cf638;color:#a78bfa;border-color:#8b5cf666}.ask-ai-params{width:100%;margin-top:var(--space-2, 8px);padding-top:var(--space-2, 8px);border-top:1px solid rgba(139,92,246,.15);display:flex;flex-direction:column;gap:var(--space-2, 8px)}.ask-ai-param-label{font-size:var(--text-xs, .75rem);font-weight:600;color:var(--text-muted, #888);text-transform:uppercase;letter-spacing:.04em}.ask-ai-param-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.ask-ai-param-chip{padding:6px 12px;background:#8b5cf60f;border:1px solid rgba(139,92,246,.15);border-radius:14px;color:var(--text-secondary, #aaa);font-size:var(--text-sm, .85rem);font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s;-webkit-tap-highlight-color:transparent}.ask-ai-param-chip--active{background:#8b5cf633;border-color:#a78bfa;color:#a78bfa;font-weight:600}.ask-ai-param-slider{display:flex;align-items:center;gap:var(--space-2, 8px);margin-top:4px}.ask-ai-param-slider input[type=range]{flex:1;accent-color:#a78bfa;height:4px}.ask-ai-param-slider-val{font-size:var(--text-sm, .85rem);font-weight:700;color:#a78bfa;min-width:50px;text-align:right}.ask-ai-param-list{display:flex;flex-direction:column;gap:2px;margin-top:4px;max-height:200px;overflow-y:auto}.ask-ai-param-list-item{display:flex;align-items:center;gap:var(--space-2, 8px);padding:8px 12px;background:none;border:1px solid transparent;border-radius:var(--radius-sm, 6px);color:var(--text-secondary, #aaa);font-size:var(--text-sm, .85rem);cursor:pointer;-webkit-tap-highlight-color:transparent;text-align:left}.ask-ai-param-list-item:active{background:#8b5cf614}.ask-ai-param-list-item--active{background:#8b5cf61f;border-color:#8b5cf64d;color:#a78bfa;font-weight:600}.ask-ai-param-list-item:disabled{opacity:.3;cursor:default}.ask-ai-param-check{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:4px;border:2px solid rgba(139,92,246,.5);color:#a78bfa;font-size:13px;font-weight:700;flex-shrink:0}.ask-ai-param-list-item--active .ask-ai-param-check{background:#8b5cf640;border-color:#a78bfa}.ask-ai-param-hint{font-size:var(--text-xs, .75rem);color:var(--text-muted, #888);text-align:center;padding:4px}.ask-ai-param-actions{display:flex;gap:var(--space-2, 8px);justify-content:center;margin-top:var(--space-1, 4px)}.ask-ai-param-go{display:inline-flex;align-items:center;gap:5px;padding:8px 20px;background:#8b5cf633;border:1px solid #a78bfa;border-radius:16px;color:#a78bfa;font-size:var(--text-sm, .85rem);font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent}.ask-ai-param-go:active{background:#8b5cf659}.ask-ai-param-go:disabled{opacity:.3;cursor:default}.ask-ai-param-cancel{padding:8px 16px;background:none;border:1px solid var(--border, rgba(255,255,255,.1));border-radius:16px;color:var(--text-muted, #888);font-size:var(--text-sm, .85rem);cursor:pointer}.ask-ai-param-cancel:active{opacity:.6}.connect-prompt{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem 1.5rem;margin:1rem 0;background:var(--card-bg, #1a1a1a);border:1px solid var(--border, #282828);border-radius:12px}.connect-prompt-icon{margin-bottom:1rem;opacity:.8}.connect-prompt-title{margin:0 0 .5rem;font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.connect-prompt-text{margin:0 0 1.25rem;font-size:var(--text-sm);color:var(--text-muted);max-width:280px;line-height:1.4}.connect-prompt-btn{padding:.6rem 1.5rem;border-radius:8px;border:none;background:var(--accent, #f59e0b);color:var(--bg-page, #0f0f0f);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:opacity .15s}.connect-prompt-btn:hover{opacity:.9}.listen-page .page-subtitle{margin-bottom:var(--space-4)}.listen-section{margin-bottom:var(--space-6)}.listen-page .page-subtitle{margin-bottom:var(--space-5)}.listen-intro{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;margin-bottom:var(--space-4)}.listen-error{color:#f87171;font-size:var(--text-sm);text-align:center;padding:var(--space-3);margin-bottom:var(--space-4)}.listen-starting{text-align:center;color:var(--text-muted);font-size:var(--text-sm);padding:var(--space-3)}.listen-back-btn{margin-top:var(--space-3)}.pick-mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.pick-mode-grid--3col{grid-template-columns:1fr 1fr 1fr}.pick-mode-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-2);padding:var(--space-4) var(--space-3);-webkit-tap-highlight-color:transparent;min-height:120px;justify-content:center}.pick-mode-card:active{opacity:.85;transform:scale(.97)}.pick-mode-card>svg:last-child{display:none}.pick-mode-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.pick-mode-text{min-width:0}.pick-mode-label{display:block;font-size:var(--text-base);font-weight:700;color:var(--text-primary)}.pick-mode-desc{display:block;font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.pick-mode-panel{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4) 0 0;background:transparent;border-radius:0}.pick-mode-subtitle{font-size:var(--text-lg);font-weight:700}.pick-loading{display:flex;flex-direction:column;align-items:center;padding:var(--space-8) 0;gap:var(--space-3)}.pick-loading-icon{animation:spin 1.5s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pick-loading-text{font-size:var(--text-sm);color:var(--text-muted)}.pick-error{color:#f87171;font-size:var(--text-sm);text-align:center;padding:var(--space-2)}.pick-empty{text-align:center;color:var(--text-muted);font-size:var(--text-sm);padding:var(--space-6) 0}.pick-narrative{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;font-style:italic}.pick-album-list{display:flex;flex-direction:column;gap:var(--space-2)}.pick-album-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0}.pick-album-cover{width:56px;height:56px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.pick-album-info{flex:1;min-width:0}.pick-album-artist{font-size:var(--text-sm);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pick-album-title{font-size:var(--text-base);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pick-album-seed{border-left:3px solid var(--accent);padding-left:var(--space-2)}.pick-album-seed-label{font-size:var(--text-xs);color:var(--accent);font-weight:600;margin-top:2px}.pick-album-btn{width:100%;text-align:left;-webkit-tap-highlight-color:transparent}.pick-album-btn:active{opacity:.8}.pick-actions{display:flex;gap:var(--space-3);margin-top:var(--space-2)}.pick-cancel-btn{flex:0 0 auto}.pick-start-btn{flex:1}.vibe-pills{display:flex;flex-wrap:wrap;gap:var(--space-2)}.vibe-pill{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border);min-height:36px;display:inline-flex;align-items:center;transition:border-color .15s,background .15s,color .15s}.vibe-pill:active{opacity:.8}.vibe-pill--active{font-weight:600;border-color:var(--vibe-color)!important;color:var(--vibe-color)!important;background:color-mix(in srgb,var(--vibe-color) 12%,transparent)!important}.vibe-custom-row{display:flex;gap:var(--space-2);margin-top:var(--space-2)}.vibe-custom-input{flex:1;padding:var(--space-2) var(--space-3);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-primary);min-height:40px}.vibe-custom-input:focus{outline:none;border-color:var(--accent)}.vibe-custom-input::placeholder{color:var(--text-muted)}.vibe-add-btn{width:40px;height:40px;flex-shrink:0;background:var(--accent);color:#000;border-radius:var(--radius-md);font-size:var(--text-lg);font-weight:700;display:flex;align-items:center;justify-content:center}.vibe-selected{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-2)}.vibe-tag{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;color:var(--vibe-color);background:color-mix(in srgb,var(--vibe-color) 12%,transparent);border:1px solid var(--vibe-color)}.vibe-tag-x{font-size:var(--text-base);font-weight:700;color:inherit;opacity:.7;margin-left:2px;line-height:1}.vibe-tag-x:active{opacity:1}.browse-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2);padding:var(--space-1) 0}.browse-item{display:flex;flex-direction:column;width:100%;text-align:center;gap:3px;-webkit-tap-highlight-color:transparent;background:none;border:none;padding:0}.browse-item:active{opacity:.7}.browse-cover-wrap{position:relative;width:100%;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-elevated)}.browse-cover{width:100%;height:100%;object-fit:cover}.browse-item--selected .browse-cover-wrap{outline:2px solid var(--accent);outline-offset:2px}.browse-item--selected .browse-cover{opacity:.75}.browse-check{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:28px;height:28px;background:var(--accent);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;pointer-events:none}.browse-title{font-size:10px;font-weight:600;line-height:1.2;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-primary)}.browse-artist{font-size:9px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.browse-queue-bar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);margin-bottom:var(--space-3);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--accent)}.browse-queue-albums{flex:1;display:flex;gap:var(--space-2);overflow-x:auto;scrollbar-width:none}.browse-queue-albums::-webkit-scrollbar{display:none}.browse-queue-chip{position:relative;flex-shrink:0;width:40px;height:40px;border-radius:var(--radius-sm);overflow:hidden;-webkit-tap-highlight-color:transparent}.browse-queue-chip-img{width:100%;height:100%;object-fit:cover}.browse-queue-chip-x{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000080;color:#fff;font-size:var(--text-base);font-weight:700;opacity:0;transition:opacity .15s}.browse-queue-chip:active .browse-queue-chip-x{opacity:1}.browse-queue-count{flex:1;font-size:var(--text-sm);font-weight:600;color:var(--accent)}.session-list{display:flex;flex-direction:column;gap:var(--space-2)}.session-card{display:flex;align-items:center;gap:0;width:100%;padding:0;-webkit-tap-highlight-color:transparent}.session-card-main{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0;text-align:left;padding:var(--space-3) 0 var(--space-3) var(--page-px)}.session-card-main:active{opacity:.85}.session-card--active{border-left:3px solid var(--accent)}.session-card-cover{width:52px;height:52px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.session-card-info{flex:1;min-width:0}.session-card-name{font-size:var(--text-base);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.session-card-meta{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.session-card-mood{font-size:var(--text-xs);color:var(--text-secondary);margin-top:2px;font-style:italic}.session-card-badge{font-size:var(--text-2xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:var(--radius-full);flex-shrink:0}.session-badge--active{background:#f59e0b26;color:var(--accent)}.session-badge--done{background:#64748b26;color:var(--text-muted)}.session-delete-btn{width:44px;height:44px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-muted);margin-right:var(--space-2)}.session-delete-btn:active{background:#f871711a}.session-delete-btn--confirm{background:#f8717126;animation:pulse-delete .3s ease}@keyframes pulse-delete{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.log-spin-btn{display:flex;align-items:center;gap:var(--space-3);width:100%;text-align:left;padding:var(--space-4);-webkit-tap-highlight-color:transparent}.log-spin-btn:active{opacity:.85;transform:scale(.98)}.log-spin-btn-icon{width:44px;height:44px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#f59e0b1f;border-radius:var(--radius-md)}.log-spin-btn-text{flex:1;min-width:0}.log-spin-btn-label{display:block;font-size:var(--text-base);font-weight:700;color:var(--text-primary)}.log-spin-btn-desc{display:block;font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.log-spin-panel{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.log-spin-header{display:flex;align-items:center;justify-content:space-between}.log-spin-title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary)}.log-spin-close{font-size:var(--text-sm);color:var(--text-secondary);padding:var(--space-1) var(--space-2)}.log-spin-searching{font-size:var(--text-sm);color:var(--text-muted);text-align:center;padding:var(--space-2)}.log-spin-empty{font-size:var(--text-sm);color:var(--text-muted);text-align:center;padding:var(--space-3)}.log-spin-results{display:flex;flex-direction:column;gap:0}.log-spin-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--border);width:100%;text-align:left;-webkit-tap-highlight-color:transparent}.log-spin-item:last-child{border-bottom:none}.log-spin-item:active{opacity:.8}.log-spin-item--done{opacity:.6}.log-spin-cover{width:44px;height:44px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.log-spin-info{flex:1;min-width:0}.log-spin-artist{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.log-spin-item-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.log-spin-action{flex-shrink:0;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:var(--accent);color:#000;font-size:var(--text-xs);font-weight:700}.log-spin-action--done{background:#14532d;color:#86efac}.history-group{margin-bottom:var(--space-4)}.history-group:last-child{margin-bottom:0}.history-group-label{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-2)}.history-list{display:flex;flex-direction:column;gap:var(--space-2)}.history-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md)}.history-cover{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.history-info{flex:1;min-width:0}.history-artist{font-size:var(--text-sm);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-title{font-size:var(--text-base);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-time{font-size:var(--text-xs);color:var(--text-muted);flex-shrink:0;white-space:nowrap}.pick-mode-icon--spin{background:#f59e0b1f}.pick-mode-icon--browse{background:#60a5fa1f}.pick-mode-icon--ai{background:#34d3991f}.mycoll-header{padding:var(--space-2) 0 var(--space-3)}.mycoll-header-top{display:flex;justify-content:space-between;align-items:flex-start}.mycoll-logo{height:32px;width:auto;margin-bottom:var(--space-2)}.mycoll-greeting{font-size:var(--text-xl);font-weight:700;color:var(--text-primary)}.mycoll-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin:0 0 var(--space-2)}.mycoll-scan-btn{position:fixed;top:calc(var(--safe-top, 0px) + var(--space-2) + var(--page-px));right:calc(var(--page-px) + 48px);z-index:80;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border);border-radius:50%;box-shadow:0 2px 8px #0003}.mycoll-scan-btn:active{background:var(--bg-elevated);color:var(--accent)}.mycoll-insight-section{margin-bottom:var(--space-4)}.mycoll-insight-card{display:block;position:relative;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-surface);color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}a.mycoll-insight-card:active{opacity:.95}.mycoll-insight-cover{width:100%;height:180px;object-fit:cover;display:block;background:var(--bg-elevated)}.mycoll-insight-overlay{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);background:linear-gradient(to bottom,rgba(0,0,0,.6) 0%,transparent 100%)}.mycoll-insight-label{font-size:var(--text-xs);font-weight:700;color:#ffffffd9;text-transform:uppercase;letter-spacing:.06em}.mycoll-insight-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;color:#fffc;background:#0000004d;border:none;-webkit-tap-highlight-color:transparent}.mycoll-insight-close:active{background:#00000080}.mycoll-insight-body{padding:var(--space-3)}.mycoll-insight-text{font-size:var(--text-base);color:var(--text-secondary);line-height:1.5;margin:0}.mycoll-insight-meta{font-size:var(--text-sm);color:var(--text-muted);margin:var(--space-2) 0 0}.mycoll-section-label{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0}.mycoll-stat-val{display:block;font-size:var(--text-base);font-weight:700;color:var(--text-primary);line-height:1.2}.mycoll-stat-lbl{display:block;font-size:var(--text-2xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.mycoll-toolbar{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3)}.mycoll-nav-select{flex:1;min-width:0;height:38px;padding:0 var(--space-5) 0 var(--space-3);background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .65rem center}.mycoll-nav-select:focus{outline:none;border-color:var(--accent)}.mycoll-nav-select optgroup{font-weight:700;color:var(--text-muted)}.mycoll-icon-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-sm);background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);flex-shrink:0;-webkit-tap-highlight-color:transparent}.mycoll-icon-btn:active{background:var(--bg-elevated)}.mycoll-search-row{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3)}.mycoll-search-row .coll-search{flex:1;margin-bottom:0}.mycoll-search-row .coll-sort-count{flex-shrink:0}.mycoll-panel{min-height:200px}.mycoll-upgrades-section{margin-top:var(--space-4)}.mycoll-upgrades-panel{background:var(--bg-surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);padding:var(--space-3) var(--page-px) var(--page-px)}.mycoll-upgrades-more{display:block;width:100%;font-size:var(--text-xs);font-weight:600;color:var(--accent);text-align:center;margin:var(--space-3) 0 0;padding:var(--space-3);background:#f59e0b0f;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-md);cursor:pointer;-webkit-tap-highlight-color:transparent}.mycoll-upgrades-more:active{opacity:.7}.today-feed-section-see-all{background:none;border:none;font-size:var(--text-xs);font-weight:600;color:var(--accent);cursor:pointer;padding:var(--space-1) 0;white-space:nowrap;align-self:center;flex-shrink:0}.today-feed-section-see-all:active{opacity:.6}.mycoll-sync-status{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-bottom:var(--space-2);padding:6px var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm)}.mycoll-sync-time{font-size:var(--text-xs);color:var(--text-muted);flex:1;min-width:0}.mycoll-sync-enriching{color:var(--accent);opacity:.8}.mycoll-sync-now-btn{font-size:var(--text-xs);font-weight:600;color:var(--accent);background:none;border:1px solid var(--border);border-radius:var(--radius-full);padding:3px 10px;min-height:28px;white-space:nowrap;flex-shrink:0;display:flex;align-items:center;gap:4px}.mycoll-sync-now-btn:disabled{opacity:.5}.mycoll-sync-now-btn:active{background:var(--bg-elevated)}.mycoll-filter-chips{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-3)}.mycoll-filter-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);min-height:30px;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s,border-color .15s}.mycoll-filter-chip.active{color:var(--accent);border-color:var(--accent);background:#f59e0b14}.mycoll-filter-chip:active{opacity:.7}.mycoll-filter-select-wrap{position:relative;display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2) var(--space-1) var(--space-3);border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);font-size:var(--text-xs);font-weight:600;min-height:30px;white-space:nowrap;flex-shrink:0;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.mycoll-filter-select-wrap.active{color:var(--accent);border-color:var(--accent);background:#f59e0b14}.mycoll-filter-select{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;font-size:16px;border:none;background:none}.mycoll-filter-select-label{pointer-events:none;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;max-width:110px}.mycoll-filter-select-arrow{color:currentColor;flex-shrink:0;pointer-events:none}.mycoll-filter-select-clear{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:#f59e0b33;color:var(--accent);border:none;padding:0;cursor:pointer;flex-shrink:0;margin-left:2px}.mycoll-filter-select-clear:active{opacity:.6}.mycoll-filter-clear-all{color:var(--text-muted)!important;border-color:var(--border)!important;background:transparent!important;font-weight:500}.mycoll-setup-prompt{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);text-decoration:none;color:inherit;-webkit-tap-highlight-color:transparent}.mycoll-setup-prompt:active{opacity:.85}.mycoll-setup-prompt-icon{font-size:22px;flex-shrink:0;width:36px;text-align:center}.mycoll-setup-prompt-body{flex:1;min-width:0}.mycoll-setup-prompt-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin-bottom:2px}.mycoll-setup-prompt-sub{font-size:var(--text-xs);color:var(--text-muted);line-height:1.4}.mycoll-coverage-list{display:flex;flex-direction:column;gap:var(--space-3)}.mycoll-coverage-row{display:flex;align-items:center;gap:var(--space-3)}.mycoll-coverage-label{font-size:var(--text-sm);color:var(--text-secondary);flex:1;min-width:0}.mycoll-coverage-bar-track{flex:1;height:6px;background:var(--bg-elevated);border-radius:var(--radius-full);overflow:hidden;min-width:60px}.mycoll-coverage-bar-fill{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width .4s ease}.mycoll-coverage-pct{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);white-space:nowrap;min-width:36px;text-align:right}.mycoll-coverage-note{font-size:var(--text-xs);color:var(--text-muted);margin:var(--space-3) 0 0;font-style:italic}.mycoll-activity-section{margin-bottom:var(--space-5)}.st-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.st-section-header .st-section-title{margin-bottom:0}.mycoll-toggle-btn{font-size:var(--text-xs);font-weight:600;color:var(--accent);padding:4px 10px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);min-height:28px}.mycoll-toggle-btn:active{opacity:.7}.mycoll-detail-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.stats-drill-back{display:flex;align-items:center;gap:var(--space-2);color:var(--accent);font-size:var(--text-base);font-weight:600;background:none;border:none;padding:0;margin-bottom:var(--space-4)}.stats-drill-back:active{opacity:.7}.today-intro{color:var(--text-muted);font-size:var(--text-sm);line-height:1.45;margin:0 0 var(--space-3) 0;padding:0 var(--space-1)}.today-hero{display:block;position:relative;width:100%;height:300px;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-3);text-decoration:none;color:inherit;-webkit-tap-highlight-color:transparent}.today-ask-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md)}.today-ask-hint{font-size:var(--text-xs);color:var(--text-muted);flex:1}.today-hero-img{width:100%;height:100%;object-fit:cover;display:block;background:var(--bg-elevated)}.today-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.4) 40%,transparent 70%);pointer-events:none}.today-hero-info{position:absolute;bottom:0;left:0;right:0;padding:var(--space-4) var(--space-4) var(--space-5)}.today-hero-badge{display:inline-block;font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#000;background:var(--accent);padding:2px 8px;border-radius:var(--radius-full);margin-bottom:var(--space-2)}.today-hero-title{font-size:var(--text-xl);font-weight:700;color:#fff;line-height:1.2;margin:0;text-shadow:0 1px 4px rgba(0,0,0,.5)}.today-hero-artist{font-size:var(--text-base);color:#fffc;margin:var(--space-1) 0 0;text-shadow:0 1px 3px rgba(0,0,0,.4)}.today-picker{display:flex;gap:var(--space-3);justify-content:center;padding:var(--space-2) 0 var(--space-4)}.today-picker-item{width:56px;height:56px;border-radius:var(--radius-md);overflow:hidden;border:2px solid transparent;padding:0;flex-shrink:0;transition:border-color .2s,transform .2s;-webkit-tap-highlight-color:transparent}.today-picker-item.active{border-color:var(--accent);transform:scale(1.08)}.today-picker-item:not(.active):active{transform:scale(.95)}.today-picker-img{width:100%;height:100%;object-fit:cover;display:block;background:var(--bg-elevated)}.today-detail{padding:0 var(--space-1);display:flex;flex-direction:column;gap:var(--space-3)}.today-oneline{font-size:var(--text-lg);font-style:italic;color:var(--accent);line-height:1.4;margin:0}.today-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3)}.today-card-icon{float:left;margin-right:var(--space-2);margin-top:2px}.today-card-label{display:block;font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.today-card-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.55;margin:0}.today-card-meta{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);margin:0 0 var(--space-2)}.today-card-text-secondary{margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--border);color:var(--text-muted)}.today-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.today-tag{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border);padding:4px 10px;border-radius:var(--radius-full);white-space:nowrap}.today-story{border-radius:var(--radius-md);overflow:hidden}.today-story-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.today-story.expanded .today-story-toggle{border-radius:var(--radius-md) var(--radius-md) 0 0;border-bottom-color:transparent}.today-story-chevron{transition:transform .2s;color:var(--text-muted)}.today-story-chevron.open{transform:rotate(180deg)}.today-story-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;padding:0 var(--space-3) var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);margin:0}.today-forum-link{display:block;padding:var(--space-2) 0;text-decoration:none;-webkit-tap-highlight-color:transparent}.today-forum-link+.today-forum-link{border-top:1px solid var(--border)}.today-forum-link:active{opacity:.8}.today-forum-thread{display:block;font-size:var(--text-sm);color:var(--accent);font-weight:500;line-height:1.3}.today-forum-excerpt{display:block;font-size:var(--text-xs);color:var(--text-secondary);line-height:1.5;margin-top:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.today-forum-meta{display:block;font-size:var(--text-xs);color:var(--text-muted);margin-top:3px}.today-meta{font-size:var(--text-xs);color:var(--text-muted);padding-top:var(--space-2);border-top:1px solid var(--border)}.today-actions{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.today-action-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;font-size:var(--text-xs);font-weight:600;border-radius:var(--radius-full);text-decoration:none;-webkit-tap-highlight-color:transparent;background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);transition:opacity .15s}.today-action-btn:active{opacity:.7}.today-action-spotify{background:#1db954;border-color:#1db954;color:#fff}.today-spin-cta{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:#8b5cf60f;border:1px solid rgba(139,92,246,.15);border-radius:var(--radius-md);text-decoration:none;color:inherit;-webkit-tap-highlight-color:transparent}.today-spin-cta:active{opacity:.8}.today-spin-icon{width:40px;height:40px;border-radius:50%;background:#8b5cf61f;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#a78bfa}.today-spin-body{flex:1;min-width:0}.today-spin-label{display:block;font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.today-spin-desc{display:block;font-size:var(--text-xs);color:var(--text-muted);margin-top:2px;line-height:1.4}.today-listen-actions{display:flex;gap:var(--space-2)}.today-listen-action{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:var(--space-3) var(--space-2);background:#ffffff0a;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-xs);font-weight:500;text-decoration:none;cursor:pointer;-webkit-tap-highlight-color:transparent}.today-listen-action:active{opacity:.7;background:#ffffff14}.today-session-card{display:block;padding:var(--space-2) var(--space-3);background:#ffffff0a;border:1px solid var(--border);border-radius:var(--radius-md);text-decoration:none;color:inherit;margin-top:var(--space-2);-webkit-tap-highlight-color:transparent}.today-session-card:active{opacity:.8}.today-session-active{border-color:#22c55e4d;background:#22c55e0f}.today-session-status{font-size:var(--text-xs);font-weight:700;color:#22c55e;text-transform:uppercase;letter-spacing:.5px}.today-session-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.today-session-detail{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.today-session-resume{font-size:var(--text-xs);font-weight:600;color:#22c55e;margin-top:4px;display:block}.today-recent-sessions{margin-top:var(--space-2)}.today-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-8) var(--space-4)}.today-empty-icon{margin-bottom:var(--space-4);opacity:.5}.today-empty-text{font-size:var(--text-lg);font-weight:600;color:var(--text-secondary);margin:0 0 var(--space-2)}.today-empty-sub{font-size:var(--text-sm);color:var(--text-muted);margin:0}.today-feed-section{margin-top:calc(var(--space-8) + var(--space-3));display:flex;flex-direction:column;gap:var(--space-2)}.today-feed-section-title{width:calc(100% + 2 * var(--page-px));margin-left:calc(-1 * var(--page-px));padding:var(--space-2) var(--page-px);margin-bottom:var(--space-3);background:var(--bg-elevated);border-top:2px solid var(--accent);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--accent)}.today-feed-card{display:flex;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md);text-decoration:none;color:inherit;-webkit-tap-highlight-color:transparent}.today-feed-cover{width:112px;height:112px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.today-feed-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:2px}.today-feed-title{font-size:var(--text-sm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.today-feed-text{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.today-feed-badge{display:inline-block;font-size:var(--text-2xs);padding:1px 6px;border-radius:3px;background:#1e3a5f;color:#7dd3fc;margin-top:2px;align-self:flex-start}.today-feed-badge-signal{background:#8b5cf626;color:#a78bfa;margin-left:4px}.today-feed-badge-grade{background:#f59e0b26;color:#f59e0b;margin-left:4px}.today-feed-badges{display:flex;flex-wrap:wrap;gap:4px;margin-top:var(--space-1)}.today-feed-meta{font-size:var(--text-xs);color:var(--text-muted);margin-top:1px}.today-following-actor{font-weight:600;color:var(--text);cursor:pointer}.today-following-actor:hover{color:var(--accent)}.today-feed-more{display:block;text-align:center;font-size:var(--text-sm);color:var(--accent);text-decoration:none;padding:var(--space-2, 8px) 0;margin-top:var(--space-2, 8px)}.today-feed-section-header{width:calc(100% + 2 * var(--page-px));margin-left:calc(-1 * var(--page-px));padding:var(--space-2) var(--page-px);margin-bottom:var(--space-3);background:var(--bg-elevated);border-top:2px solid var(--accent);display:flex;justify-content:space-between;align-items:flex-start}.today-feed-section-header .today-feed-section-title{width:auto;margin-left:0;padding:0;margin-bottom:0;background:none;border:none;color:var(--accent)}.today-feed-section-sub{font-size:var(--text-xs);color:var(--text-muted);margin:var(--space-1) 0 0;line-height:1.4}.today-feed-header-link{font-size:var(--text-xs);font-weight:600;color:var(--accent);text-decoration:none;white-space:nowrap;padding-top:3px}.upgrade-card{background:var(--bg-surface);border-radius:var(--radius-md);overflow:hidden}.upgrade-main{display:flex;gap:var(--space-3);align-items:center;padding:var(--page-px);cursor:pointer;-webkit-tap-highlight-color:transparent}.upgrade-main:active{background:var(--bg-elevated)}.upgrade-cover{width:96px;height:96px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.upgrade-body{min-width:0;flex:1;display:flex;flex-direction:column;gap:3px}.upgrade-title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upgrade-artist{font-size:var(--text-base);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upgrade-scores{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-1)}.upgrade-yours{font-size:var(--text-sm);color:var(--text-muted);font-weight:500}.upgrade-arrow{display:flex;align-items:center}.upgrade-best{font-size:var(--text-base);font-weight:700;color:#4ade80}.upgrade-meta{font-size:var(--text-xs);color:var(--text-muted)}.upgrade-chevron{flex-shrink:0;color:var(--text-muted);transition:transform .2s ease}.upgrade-chevron.open{transform:rotate(180deg)}.upgrade-details{padding:0 var(--page-px) var(--page-px);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:var(--space-3);padding-top:var(--space-3)}.upgrade-detail-label{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;color:var(--text-muted);margin-bottom:2px}.upgrade-detail-meta{font-size:var(--text-sm);color:var(--text-secondary)}.upgrade-detail-rating{font-size:var(--text-sm);color:var(--text-primary);margin-top:2px}.upgrade-rating-count{color:var(--text-muted);font-size:var(--text-xs)}.upgrade-alt{display:flex;gap:var(--space-3);align-items:center;padding:var(--space-2) var(--space-3);background:#4ade800f;border-radius:var(--radius-sm);border-left:3px solid #4ade80;color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}.upgrade-alt:active{background:#4ade801f}.upgrade-alt-thumb{width:40px;height:40px;border-radius:4px;object-fit:cover;flex-shrink:0}.upgrade-alt-info{min-width:0;flex:1}.upgrade-alt-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upgrade-alt-meta{display:flex;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-muted)}.upgrade-alt-rating{color:#4ade80;font-weight:600}.upgrade-friend-badge{font-size:var(--text-xs);color:#7dd3fc;font-weight:500;margin-left:var(--space-2)}.coll-empty{grid-column:1 / -1;padding:var(--space-8) var(--space-4)}.coll-empty-start{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-3);max-width:320px;margin:0 auto}.coll-empty-icon{width:72px;height:72px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-2)}.coll-empty-title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin:0}.coll-empty-sub{font-size:var(--text-sm);color:var(--text-muted);line-height:1.5;margin:0}.coll-empty-action{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;cursor:pointer;min-height:44px;border:none}.coll-empty-action-primary{background:var(--accent);color:var(--bg-page)}.coll-empty-action-secondary{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary)}.coll-empty-action:active{opacity:.8}.coll-empty-action:disabled{opacity:.5;cursor:not-allowed}.coll-empty-hint{font-size:var(--text-xs);color:var(--text-muted);margin:var(--space-2) 0 0;line-height:1.5}.coll-empty-no-results{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);text-align:center;color:var(--text-muted);font-size:var(--text-sm);padding:var(--space-4) 0}.coll-empty-no-results p{margin:0}.coll-empty-clear{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:600;padding:var(--space-2) var(--space-4);cursor:pointer;min-height:36px}.coll-empty-clear:active{opacity:.7}.coll-daily-insight{display:flex;gap:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md);padding:var(--page-px);margin-bottom:var(--space-4);border-left:3px solid #f59e0b}.coll-insight-cover{width:64px;height:64px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.coll-insight-body{min-width:0;flex:1}.coll-insight-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.55;margin:0 0 var(--space-2)}.coll-insight-link{font-size:var(--text-xs);font-weight:600;color:var(--accent);text-decoration:none}.coll-insight-link:active{opacity:.6}.coll-summary{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg, 12px);padding:var(--space-4, 1rem);margin-bottom:var(--space-4, 1rem)}.coll-summary-grid{display:flex;gap:var(--space-2, .5rem);flex-wrap:wrap}.coll-summary-stat{flex:1;min-width:60px;text-align:center;background:var(--bg-elevated, #222);border-radius:var(--radius-md);padding:var(--space-3, .75rem) var(--space-2, .5rem)}.coll-summary-stat--hl{border:1px solid rgba(167,139,250,.3);background:#a78bfa14}.coll-summary-val{display:block;font-size:var(--text-xl);font-weight:700;color:var(--text-primary)}.coll-summary-label{display:block;font-size:var(--text-2xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;margin-top:.15rem}.coll-summary-detail{font-size:var(--text-sm);color:var(--text-secondary);margin:.5rem 0 0}.coll-summary-detail strong{color:var(--text-muted)}.coll-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.coll-tab{padding:var(--space-3) var(--page-px);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border);min-height:44px;display:inline-flex;align-items:center}.coll-tab.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:600}.coll-tab:active{opacity:.8}.coll-toolbar{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3)}.coll-toolbar .coll-search{margin-bottom:0;flex:1}.coll-search{width:100%;padding:var(--space-3) var(--page-px);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-lg);font-size:var(--text-base);color:var(--text-primary);min-height:44px}.coll-search:focus{outline:none;border-color:var(--accent)}.coll-search::placeholder{color:var(--text-muted)}.coll-view-toggle{display:flex;gap:var(--space-1);margin-left:auto}.coll-view-btn{padding:var(--space-3);border-radius:var(--radius-sm);color:var(--text-muted);background:none;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.coll-view-btn.active{color:var(--accent);background:var(--bg-elevated)}.coll-view-btn:active{opacity:.7}.coll-toolbar-wrap{margin-bottom:var(--space-3)}.coll-toolbar-wrap .coll-toolbar{margin-bottom:var(--space-2)}.coll-sort-row{display:flex;align-items:center;gap:var(--space-2)}.coll-sort-select{flex:0 1 auto;padding:6px 26px 6px 10px;font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);min-height:32px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.coll-sort-select:focus{outline:none;border-color:var(--accent)}.coll-sort-count{font-size:var(--text-xs);color:var(--text-muted);margin-left:auto;white-space:nowrap}.coll-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.coll-album-tile{text-align:center;overflow:hidden}.coll-tile-cover{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--radius-sm);background:var(--bg-elevated);display:block}.coll-tile-title{font-size:var(--text-xs);font-weight:600;margin-top:var(--space-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 var(--space-1)}.coll-tile-artist{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 var(--space-1)}.coll-list{display:flex;flex-direction:column;gap:var(--space-2)}.coll-list-row{display:flex;align-items:center;gap:0;background:var(--bg-surface);border-radius:var(--radius-md)}.coll-list-row .coll-list-item{flex:1;min-width:0;background:none}.coll-list-ask{padding:0 var(--space-3) 0 0;flex-shrink:0}.coll-list-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md)}.coll-list-cover{width:56px;height:56px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.coll-list-info{min-width:0;flex:1}.coll-list-title{font-size:var(--text-base);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.coll-list-artist{font-size:var(--text-sm);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.coll-grid-letter{grid-column:1 / -1;font-size:var(--text-sm);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-3, .75rem) 0 var(--space-1, .25rem);border-bottom:2px solid var(--accent, #d4a853);margin-bottom:var(--space-1, .25rem)}.coll-grid-letter:first-child{padding-top:0}.coll-list-letter{font-size:var(--text-sm);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-3, .75rem) 0 var(--space-1, .25rem);border-bottom:2px solid var(--accent, #d4a853)}.coll-list-letter:first-child{padding-top:0}a.coll-album-tile,a.coll-list-item{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}a.coll-album-tile:active,a.coll-list-item:active{opacity:.7}.coll-loading{display:flex;justify-content:center;padding:var(--space-8) 0}.coll-empty{text-align:center;color:var(--text-muted);padding:var(--space-8) 0;grid-column:1 / -1;font-size:var(--text-sm)}.coll-empty .sync-btn{margin-top:var(--space-4);padding:var(--space-2) var(--space-6);background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer}.pick-section{margin-bottom:var(--space-4)}.pick-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-3) var(--page-px);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--accent);font-size:var(--text-base);font-weight:600;min-height:48px}.pick-toggle:active{opacity:.8}.pick-panel{background:var(--bg-surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);padding:var(--space-3) var(--page-px) var(--page-px)}.pick-label{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--space-2);margin-top:var(--space-3)}.pick-label:first-child{margin-top:0}.pick-pills{display:flex;flex-wrap:wrap;gap:var(--space-2)}.pick-pill{padding:var(--space-3) var(--page-px);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);min-height:44px;display:inline-flex;align-items:center}.pick-pill.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:600}.pick-pill:active{opacity:.8}.pick-find-btn{width:100%;margin-top:var(--space-4);padding:var(--space-3);background:var(--accent);color:#000;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:700;min-height:48px}.pick-find-btn:active:not(:disabled){opacity:.85;transform:scale(.98)}.pick-find-btn:disabled{opacity:.5}.pick-error{color:#f87171;font-size:var(--text-sm);margin-top:var(--space-2)}.pick-results{margin-top:var(--space-3)}.pick-results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.pick-results-title{font-size:var(--text-sm);font-weight:700;color:var(--text-primary)}.pick-again-btn{font-size:var(--text-sm);color:var(--text-muted);padding:var(--space-2) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-full);min-height:44px;display:inline-flex;align-items:center}.pick-again-btn:active{color:var(--text-primary)}.pick-results-list{display:flex;flex-direction:column;gap:var(--space-2)}a.pick-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-elevated);border-radius:var(--radius-md);border-left:3px solid var(--accent);color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}a.pick-item:active{opacity:.8}.pick-cover{width:56px;height:56px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-surface)}.pick-info{min-width:0;flex:1}.pick-title{font-size:var(--text-base);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pick-artist{font-size:var(--text-sm);color:var(--accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pick-meta{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.spins-list{display:flex;flex-direction:column;gap:var(--space-2)}.spin-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md)}.spin-cover{width:56px;height:56px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.spin-body{min-width:0;flex:1}.spin-title{font-size:var(--text-base);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spin-artist{font-size:var(--text-sm);color:var(--text-secondary)}.spin-date{font-size:var(--text-xs);color:var(--text-muted)}.disc-albums-coming-soon{text-align:center;padding:var(--space-6, 2rem) var(--space-4)}.disc-albums-coming-soon h3{font-size:var(--text-lg);color:var(--text-primary);margin:0 0 var(--space-2)}.disc-albums-coming-soon p{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;margin:0 0 var(--space-3)}.album-rec-card{background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border);overflow:hidden;margin-bottom:var(--space-3)}.album-rec-main{display:flex;gap:var(--space-3);padding:var(--space-3);color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}.album-rec-cover{width:96px;height:96px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.album-rec-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.album-rec-intro{font-size:var(--text-sm);color:var(--text-muted);margin:0 0 var(--space-3);line-height:1.4}.album-rec-score-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-1)}.album-rec-score-label{font-size:var(--text-xs);font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.03em}.album-rec-score-num{font-size:var(--text-lg);font-weight:800;color:var(--text-primary);line-height:1}.album-rec-badge{display:inline-block;align-self:flex-start;font-size:var(--text-xs);font-weight:700;text-transform:uppercase;background:#d4a85326;color:var(--accent);padding:2px var(--space-2);border-radius:var(--radius-sm)}.album-rec-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.album-rec-artist{font-size:var(--text-sm);color:var(--text-secondary)}.album-rec-date{color:var(--text-muted)}.album-rec-graph{display:flex;align-items:baseline;gap:var(--space-1);margin-top:var(--space-1)}.album-rec-conn-count{font-size:var(--text-xl);font-weight:800;color:var(--accent);line-height:1}.album-rec-conn-label{font-size:var(--text-xs);color:var(--text-muted)}.album-rec-via{padding:var(--space-2) var(--space-3)}.album-rec-via-label{font-size:var(--text-xs);color:var(--text-muted);display:block;margin-bottom:var(--space-1)}.album-rec-via-chips{display:flex;flex-wrap:wrap;gap:4px}.album-rec-via-chip{font-size:var(--text-xs);font-weight:500;padding:2px 8px;border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--accent);white-space:nowrap;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent}button.album-rec-via-chip:active{opacity:.7}.album-rec-via-more{font-size:var(--text-xs);color:var(--text-muted);padding:2px 4px}.album-rec-match-detail{font-size:var(--text-xs);color:var(--accent);font-weight:500}.album-rec-reason{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;padding:0 var(--space-3);margin:0 0 var(--space-2)}.album-rec-links{display:flex;gap:var(--space-3);padding:0 var(--space-3) var(--space-3)}.album-rec-link{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-decoration:none;-webkit-tap-highlight-color:transparent}.album-rec-link:active{color:var(--accent)}.album-rec-link-spotify{color:#1db954}.album-rec-pressing{padding:var(--space-3);border-top:1px solid var(--border);background:#ffffff05}.album-rec-pressing-header{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;color:var(--accent);letter-spacing:.05em;margin-bottom:var(--space-2)}.album-rec-pressing-meta{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-2)}.album-rec-pressing-reason{font-size:var(--text-sm);color:var(--text-muted);line-height:1.4;margin:var(--space-2) 0}.explore-prompt{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-3)}.explore-search{width:100%;padding:var(--space-2) var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-sm);margin-bottom:var(--space-3);box-sizing:border-box}.explore-search:focus{outline:none;border-color:var(--accent)}.explore-artist-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:var(--space-2)}@media(min-width:400px){.explore-artist-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:700px){.explore-artist-grid{grid-template-columns:repeat(3,1fr)}}.explore-artist-chip{display:flex;align-items:center;gap:var(--space-3, 12px);padding:var(--space-2, 8px) var(--space-3, 12px);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md, 8px);color:var(--text-primary);font-size:var(--text-base);text-align:left;min-width:0;overflow:hidden;-webkit-tap-highlight-color:transparent}.explore-artist-chip:active{background:var(--bg-elevated)}.explore-artist-img{width:52px;height:52px;border-radius:var(--radius-sm, 4px);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.explore-artist-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.explore-back{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);color:var(--text-muted);background:none;border:none;padding:0;margin-bottom:var(--space-3);-webkit-tap-highlight-color:transparent}.explore-back:active{color:var(--accent)}.explore-selected-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.explore-selected-cover{width:72px;height:72px;border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-elevated)}.explore-selected-artist{font-size:var(--text-lg);font-weight:700;color:var(--text-primary)}.explore-selected-sub{font-size:var(--text-sm);color:var(--text-muted)}.explore-related-section{margin-bottom:var(--space-4)}.explore-related-header{display:flex;align-items:baseline;gap:var(--space-2);margin-bottom:var(--space-2)}.explore-related-artist{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.explore-related-type{font-size:var(--text-xs);color:var(--accent);font-weight:500}.explore-album-list{display:flex;flex-direction:column;gap:var(--space-2)}.explore-album-card{display:flex;gap:var(--space-3, 12px);padding:var(--space-3, 12px);background:var(--bg-surface);border-radius:var(--radius-md, 8px);border:1px solid var(--border);color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}.explore-album-card:active{background:var(--bg-elevated)}.explore-album-cover{width:96px;height:96px;border-radius:var(--radius-sm, 6px);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.explore-album-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:3px}.explore-album-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.explore-album-meta{font-size:var(--text-sm);color:var(--text-muted)}.explore-album-rating{font-size:var(--text-sm);color:var(--text-secondary)}.discover-page .disc-alerts-btn{position:fixed;top:calc(var(--safe-top, 0px) + var(--space-2) + var(--page-px));right:calc(var(--page-px) + 48px);z-index:80;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border);border-radius:50%;padding:0;-webkit-tap-highlight-color:transparent;box-shadow:0 2px 8px #0003}.discover-page .disc-alerts-btn.active{color:var(--accent);border-color:var(--accent)}.discover-page .disc-alerts-btn:active{background:var(--bg-elevated);color:var(--accent)}.disc-header{padding:var(--space-2) 0 var(--space-5)}.disc-header-top{margin-bottom:var(--space-3)}.disc-logo{height:36px;width:auto}.disc-greeting{font-size:var(--text-xl);font-weight:700;color:var(--text-primary)}.disc-stats-line{font-size:var(--text-base);color:var(--text-muted);margin-top:var(--space-1)}.disc-section{margin-bottom:var(--space-8)}.disc-section-bar{width:calc(100% + 2 * var(--page-px));margin-left:calc(-1 * var(--page-px));padding:var(--space-2) var(--page-px);margin-bottom:var(--space-3);background:var(--bg-elevated);border-top:2px solid var(--accent);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--accent)}.disc-spins-scroll{display:flex;gap:var(--space-3);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:var(--space-2);scroll-snap-type:x mandatory}.disc-spins-scroll::-webkit-scrollbar{display:none}.disc-spin-card{flex-shrink:0;scroll-snap-align:start;width:130px;-webkit-tap-highlight-color:transparent}a.disc-spin-card{display:block;color:inherit;text-decoration:none}a.disc-spin-card:active{opacity:.8;transform:scale(.97)}.disc-spin-img{width:130px;height:130px;border-radius:var(--radius-md);object-fit:cover;background:var(--bg-elevated);margin-bottom:var(--space-2)}.disc-spin-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.disc-spin-artist{font-size:var(--text-sm);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.disc-tidbits-scroll{display:flex;gap:var(--space-3);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:var(--space-2);scroll-snap-type:x mandatory}.disc-tidbits-scroll::-webkit-scrollbar{display:none}.disc-tidbit-card{flex-shrink:0;width:80vw;max-width:340px;background:var(--bg-surface);border-radius:var(--radius-md);padding:var(--page-px);display:flex;gap:var(--page-px);border-left:3px solid var(--accent);scroll-snap-align:start;-webkit-tap-highlight-color:transparent;transition:transform .1s}a.disc-tidbit-card{color:inherit;text-decoration:none}a.disc-tidbit-card:active{transform:scale(.97)}.disc-tidbit-anniversary{border-left-color:#f59e0b}.disc-tidbit-pressing{border-left-color:#8b5cf6}.disc-tidbit-cover{width:80px;height:80px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.disc-tidbit-body{min-width:0;display:flex;flex-direction:column;gap:var(--space-2)}.disc-tidbit-badge{display:inline-block;align-self:flex-start;font-size:var(--text-xs);font-weight:700;text-transform:uppercase;background:#f59e0b33;color:#f59e0b;padding:3px var(--space-2);border-radius:var(--radius-sm)}.disc-badge-anniversary{background:#f59e0b33;color:#f59e0b}.disc-badge-pressing{background:#86efac26;color:#86efac}.disc-badge-expert{background:#7dd3fc26;color:#7dd3fc}.disc-badge-pipeline{background:#fca5a526;color:#fca5a5}.disc-badge-story{background:#fcd34d26;color:#fcd34d}.disc-badge-impact{background:#a78bfa26;color:#a78bfa}.disc-tidbit-text{font-size:var(--text-base);color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.disc-feed-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.disc-refresh{font-size:var(--text-sm);color:var(--accent);font-weight:600;padding:var(--space-2) var(--space-3);min-height:44px;display:inline-flex;align-items:center}.disc-refresh:active:not(:disabled){opacity:.7}.disc-refresh:disabled{opacity:.4}.disc-feed-list{display:flex;flex-direction:column;gap:var(--page-px)}.disc-error{color:#f87171;text-align:center;padding:var(--page-px);font-size:var(--text-base)}.disc-radar-filters{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.disc-radar-filter{font-size:var(--text-sm);font-weight:600;color:var(--text-muted);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);background:var(--bg-surface);border:1px solid var(--border);min-height:36px}.disc-radar-filter.active{color:var(--text-primary);background:var(--bg-elevated);border-color:var(--accent)}.disc-time-filters{display:flex;gap:var(--space-2);margin-bottom:var(--space-4);overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}.disc-time-filters::-webkit-scrollbar{display:none}.disc-time-chip{flex-shrink:0;font-size:var(--text-xs);font-weight:600;color:var(--text-muted);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:none;border:1px solid var(--border);white-space:nowrap;min-height:32px;-webkit-tap-highlight-color:transparent}.disc-time-chip.active{color:var(--accent);border-color:var(--accent);background:#f59e0b14}.rec-freshness{font-size:var(--text-xs);color:var(--text-muted);background:var(--bg-elevated);padding:2px 8px;border-radius:var(--radius-full);white-space:nowrap}.rec-alert-modal{background:var(--bg-surface);border-radius:var(--radius-lg);width:100%;max-width:420px;padding:var(--space-5);animation:fmo-slide .2s ease-out}.rec-alert-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.rec-alert-modal-title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary)}.rec-alert-modal-desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;margin:0 0 var(--space-4)}.rec-alert-modal-option{margin-bottom:var(--space-4)}.rec-alert-toggle{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3);background:var(--bg-elevated);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.rec-alert-toggle input[type=checkbox]{width:20px;height:20px;accent-color:var(--accent)}.rec-alert-score-label{display:block;font-size:var(--text-xs);font-weight:700;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--space-2);letter-spacing:.04em}.rec-alert-score-pills{display:flex;gap:var(--space-2)}.rec-alert-pill{flex:1;padding:var(--space-2);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);font-size:var(--text-sm);font-weight:600;text-align:center;min-height:40px;-webkit-tap-highlight-color:transparent}.rec-alert-pill.active{background:#f59e0b26;border-color:var(--accent);color:var(--accent)}.rec-alert-hint{font-size:var(--text-xs);color:var(--text-muted);margin:var(--space-2) 0 0}.rec-alert-save{width:100%;padding:var(--space-3);background:var(--accent);color:var(--bg-page);border:none;border-radius:var(--radius-md);font-weight:600;font-size:var(--text-sm);min-height:48px}.rec-alert-save:disabled{opacity:.6}.rec-alert-save:active{opacity:.8}.factor-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0009;display:flex;align-items:flex-end;justify-content:center;padding:var(--space-4);animation:fmo-fade .15s ease-out}@keyframes fmo-fade{0%{opacity:0}to{opacity:1}}.factor-modal{background:var(--bg-surface);border-radius:var(--radius-lg);width:100%;max-width:420px;padding:var(--space-5);animation:fmo-slide .2s ease-out}@keyframes fmo-slide{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.factor-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.factor-modal-name{font-size:var(--text-lg);font-weight:700}.factor-modal-close{width:32px;height:32px;border-radius:50%;background:var(--bg-elevated);color:var(--text-muted);font-size:var(--text-base);display:flex;align-items:center;justify-content:center}.factor-modal-score{margin-bottom:var(--space-4)}.factor-modal-bar{height:8px;background:var(--bg-elevated);border-radius:4px;overflow:hidden;margin-bottom:var(--space-2)}.factor-modal-bar-fill{height:100%;border-radius:4px;transition:width .3s ease-out}.factor-modal-pts{font-size:var(--text-sm);color:var(--text-muted);font-weight:600}.factor-modal-detail{margin-top:var(--space-2)}.factor-modal-detail-text{font-size:var(--text-base);color:var(--text-secondary);line-height:1.6}.factor-modal-detail-row{font-size:var(--text-base);color:var(--text-secondary);line-height:1.6;padding:var(--space-2) 0;border-bottom:1px solid var(--border)}.factor-modal-detail-row:last-child{border-bottom:none}.debate-section-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-3);line-height:1.5}.debate-intro-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3);font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-3)}.debate-thread-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3);margin-bottom:var(--space-3)}.debate-thread-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1);line-height:1.35}.debate-thread-meta{font-size:var(--text-xs);color:var(--text-muted);display:flex;flex-wrap:wrap;align-items:center;gap:.3rem;margin-bottom:var(--space-2)}.debate-thread-source{color:var(--accent);font-weight:500}.debate-thread-dot{color:var(--text-muted)}.debate-thread-summary{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.55;margin:0 0 var(--space-2)}.debate-thread-points{margin:0 0 var(--space-2);padding-left:1rem;list-style:disc}.debate-thread-points li{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.5;margin-bottom:.25rem}.debate-thread-footer{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2)}.debate-thread-sentiment{font-size:var(--text-xs);font-weight:600;padding:.15rem .5rem;border-radius:4px;white-space:nowrap}.debate-thread-relevance{font-size:var(--text-xs);color:var(--text-muted);font-style:italic;flex:1;min-width:0}.debate-thread-link{font-size:var(--text-xs);color:var(--accent);text-decoration:none;font-weight:500;white-space:nowrap;margin-left:auto}.debate-updated-at{font-size:var(--text-xs);color:var(--text-muted);text-align:center;margin-top:var(--space-2)}.gear-sections{display:flex;flex-direction:column;gap:var(--space-4)}.gear-section-title{font-size:var(--text-sm);font-weight:700;margin:0 0 var(--space-2)}.gear-tier{margin-bottom:var(--space-3)}.gear-tier-label{font-size:var(--text-2xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:var(--space-1)}.gear-card{display:block;background:var(--bg-surface);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-1);text-decoration:none;color:inherit;-webkit-tap-highlight-color:transparent}.gear-card:active{opacity:.8}.gear-card-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.gear-card-meta{display:flex;gap:var(--space-2);font-size:var(--text-2xs);color:var(--text-muted);margin-top:2px}.gear-card-price{color:var(--accent);font-weight:600}.gear-card-context{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-1);line-height:1.3}.gear-card-reviewers{display:flex;flex-wrap:wrap;gap:3px;margin-top:var(--space-1)}.gear-see-all{display:block;text-align:center;padding:var(--space-3);color:var(--accent);font-size:var(--text-sm);font-weight:600;text-decoration:none;-webkit-tap-highlight-color:transparent}.album-rec-card .rec-actions{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;margin-top:var(--space-2);border-top:1px solid var(--border)}.album-rec-card .rec-feedback-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .15s}.album-rec-card .rec-feedback-btn:active{opacity:.7}.album-rec-card .rec-feedback-btn.active-up{color:var(--success, #22c55e);border-color:var(--success, #22c55e);background:#22c55e1a}.album-rec-card .rec-downvote-reasons{padding:var(--space-3) 0;border-top:1px solid var(--border)}.album-rec-card .rec-downvote-title{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);margin-bottom:var(--space-2)}.album-rec-card .rec-downvote-reason{display:block;width:100%;text-align:left;padding:var(--space-2) var(--space-3);margin-bottom:var(--space-1);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;-webkit-tap-highlight-color:transparent}.album-rec-card .rec-downvote-reason:active{background:var(--bg-page)}.disc-section-label{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:var(--space-3)}.disc-social-section{margin-bottom:var(--space-2)}.disc-social-list{display:flex;flex-direction:column;gap:var(--space-2)}.disc-social-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.disc-social-actor{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:none;border:none;width:100%;text-align:left;cursor:pointer}.disc-social-avatar{width:24px;height:24px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.disc-social-name{font-size:var(--text-sm);font-weight:600;color:var(--text)}.disc-social-action{font-size:var(--text-xs);color:var(--accent);font-weight:500}.disc-social-time{font-size:var(--text-xs);color:var(--text-muted);margin-left:auto}.disc-social-album{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3) var(--space-2);border-top:1px solid var(--border);background:none;border-left:none;border-right:none;border-bottom:none;width:100%;text-align:left;cursor:pointer}.disc-social-album:disabled{cursor:default}.disc-social-cover{width:40px;height:40px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0;background:var(--bg-surface)}.disc-social-album-body{flex:1;min-width:0}.disc-social-album-title{font-size:var(--text-sm);font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.disc-social-album-sub{font-size:var(--text-xs);color:var(--text-muted);margin-top:1px}.disc-social-loading{display:flex;flex-direction:column;gap:var(--space-2)}.disc-social-skeleton{height:72px;border-radius:var(--radius-md);background:var(--surface);animation:pp-shimmer 1.4s ease-in-out infinite}.disc-social-empty{font-size:var(--text-sm);color:var(--text-muted);padding:var(--space-3) 0}.disc-social-find-link{background:none;border:none;color:var(--accent);font-size:var(--text-sm);font-weight:600;padding:0;cursor:pointer}.disc-browse-cards{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-5)}.disc-browse-card{display:flex;align-items:center;gap:var(--space-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3);cursor:pointer;text-align:left;width:100%;transition:border-color .15s;-webkit-tap-highlight-color:transparent}.disc-browse-card:active{border-color:var(--accent);opacity:.85}.disc-browse-card-icon{width:40px;height:40px;border-radius:var(--radius-sm);background:#6366f11a;color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.disc-browse-card-spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.disc-browse-card-avatars{display:flex;align-items:center}.disc-browse-mini-avatar{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--surface);margin-left:-6px}.disc-browse-mini-avatar:first-child{margin-left:0}.disc-browse-card-body{flex:1;min-width:0}.disc-browse-card-title{font-size:var(--text-sm);font-weight:600;color:var(--text);margin-bottom:2px}.disc-browse-card-sub{font-size:var(--text-xs);color:var(--text-muted);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.disc-browse-card-arrow{color:var(--text-muted);flex-shrink:0}.stats-page{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-6))}.st-loading{display:flex;align-items:center;justify-content:center;min-height:50vh}.st-error{color:#f87171;text-align:center;padding:var(--space-8);font-size:var(--text-sm)}.st-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0 var(--space-5)}.st-back{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);border-radius:var(--radius-full)}.st-back:active{color:var(--accent)}.st-title{font-size:var(--text-xl);font-weight:700}.st-summary{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);margin-bottom:var(--space-6)}.st-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-4);display:flex;flex-direction:column;align-items:center}.st-card-value{font-size:var(--text-lg);font-weight:700;color:var(--accent)}.st-card-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1);text-transform:uppercase;letter-spacing:.05em}.st-section{margin-bottom:var(--space-6)}.st-section-title{font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-3)}.st-bars{display:flex;flex-direction:column;gap:var(--space-2)}.st-bar-row{display:flex;align-items:center;gap:var(--space-2)}.st-bar-label{width:48px;font-size:var(--text-xs);color:var(--text-secondary);text-align:right;flex-shrink:0}.st-bar-label-wide{width:100px}.st-bar-track{flex:1;height:20px;background:var(--bg-elevated);border-radius:var(--radius-sm);overflow:hidden}.st-bar-fill{height:100%;background:var(--accent);border-radius:var(--radius-sm);min-width:2px;transition:width .3s ease}.st-bar-fill-genre{background:#8b5cf6}.st-bar-fill-year{background:#34d399}.st-bar-count{width:36px;font-size:var(--text-xs);color:var(--text-muted)}.st-format-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.st-format-chip{font-size:var(--text-sm);color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);padding:var(--space-1) var(--space-3)}.st-format-count{color:var(--text-muted);font-size:var(--text-xs)}.st-bar-row-btn{cursor:pointer;border-radius:var(--radius-sm);padding:2px 4px;margin:-2px -4px;transition:background .15s}.st-bar-row-btn:active{background:#ffffff0f}.st-bar-chevron{flex-shrink:0;color:var(--text-muted);margin-left:4px}.st-chip-btn{cursor:pointer;transition:background .15s}.st-chip-btn:active{background:#ffffff1f}.stats-drill .coll-list-meta{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.st-bar-fill-buying{background:#3b82f6}.st-section-subtitle{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin:var(--space-4) 0 var(--space-2)}.st-recent-adds{margin-top:var(--space-3)}.st-recent-adds .coll-list-meta{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.feed-card{background:var(--bg-surface);border-radius:var(--radius-md);overflow:hidden}a.feed-card{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;display:block}a.feed-card:active{opacity:.85}.fc-album-card{border-left:3px solid transparent}.fc-border-purple{border-left-color:#a78bfa}.fc-border-green{border-left-color:#4ade80}.fc-border-red{border-left-color:#f87171}.fc-border-blue{border-left-color:#60a5fa}.fc-border-amber{border-left-color:#f59e0b}.fc-border-teal{border-left-color:#2dd4bf}.fc-main{display:flex;gap:var(--space-3);padding:var(--page-px);color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}.fc-main:active{background:var(--bg-elevated)}.fc-cover{width:112px;height:112px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.fc-body{min-width:0;flex:1;display:flex;flex-direction:column;justify-content:center;gap:2px}.fc-right{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:4px;min-width:60px;text-align:right}.fc-right-price{font-size:var(--text-base);font-weight:700;color:var(--accent)}.fc-right-date{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.3}.fc-right-shops{font-size:var(--text-xs);color:var(--text-muted)}.fc-right-grade{font-size:var(--text-xs);font-weight:700;color:#4ade80;background:#14532d;padding:1px 6px;border-radius:3px}.fc-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1);flex-wrap:wrap}.fc-tag{display:inline-block;font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:var(--radius-sm)}.fc-tag-purple{background:#a78bfa33;color:#a78bfa}.fc-tag-green{background:#22c55e26;color:#4ade80}.fc-tag-amber{background:#f59e0b26;color:#f59e0b}.fc-tag-red{background:#ef444426;color:#f87171}.fc-tag-blue{background:#3b82f626;color:#60a5fa}.fc-tag-teal{background:#2dd4bf26;color:#2dd4bf}.fc-pressing-signals{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.fc-signal{font-size:.65rem;color:var(--text-muted);background:#ffffff0f;padding:1px 5px;border-radius:3px}.fc-signal-grade{color:#f59e0b;background:#f59e0b1f}.fc-age{font-size:var(--text-xs);color:var(--text-muted);margin-left:auto}.fc-status{display:inline-block;padding:1px 6px;border-radius:4px;font-size:var(--text-xs);font-weight:600;white-space:nowrap}.fc-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fc-artist{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fc-meta{font-size:var(--text-sm);color:var(--text-muted);margin-top:1px}.fc-reviewer-line{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.fc-sentiment{font-size:var(--text-xs);font-weight:600;padding:2px 8px;border-radius:var(--radius-sm);text-transform:capitalize}.fc-sentiment-positive{background:#22c55e26;color:#4ade80}.fc-sentiment-mixed{background:#f59e0b26;color:#fbbf24}.fc-sentiment-negative{background:#ef444426;color:#f87171}.fc-bar-wrap{padding-top:var(--space-2);position:relative}.fc-bar{height:4px;border-radius:2px;background:var(--bg-elevated);overflow:hidden}.fc-bar-fill{height:100%;border-radius:2px;transition:width .4s ease}.fc-bar-purple{background:linear-gradient(90deg,#a78bfa,#f59e0b)}.fc-bar-label{position:absolute;right:0;top:calc(var(--space-2) + 6px);font-size:var(--text-xs);font-weight:600;color:var(--text-muted)}.fc-labels{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;padding:0 var(--page-px) var(--space-2)}.fc-label{display:inline-block;padding:1px 6px;border-radius:4px;font-size:var(--text-xs);font-weight:600;white-space:nowrap}.fc-label-date{background:#7dd3fc1f;color:#7dd3fc}.fc-label-score{background:#f59e0b1f;color:var(--accent)}.fc-label-grade{background:#22c55e1f;color:#4ade80}.fc-cover-radar{align-self:flex-start}.fc-footer{padding:var(--space-2) var(--page-px) var(--page-px);border-top:1px solid var(--border)}.fc-reason{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin:0}.fc-actions{display:flex;gap:var(--space-2);margin-top:var(--space-2)}.fc-footer-row{display:flex;align-items:center;justify-content:space-between}.fc-footer-row .fc-source-link{margin-top:0}.fc-footer-actions{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;margin-top:var(--space-2)}.fc-footer-actions .fc-source-link{margin-top:0}.fc-source-link{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:600;color:var(--accent);margin-top:var(--space-2);-webkit-tap-highlight-color:transparent}.fc-source-link:active{opacity:.6}.fc-text-card{padding:var(--page-px)}.fc-text-card .fc-tag{margin-bottom:var(--space-2)}.fc-text-body{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;margin:0}.fc-price-row{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2)}.fc-price-old{text-decoration:line-through;color:var(--text-muted);font-size:var(--text-sm)}.fc-price-arrow{color:var(--text-muted);font-size:var(--text-sm)}.fc-price-new{font-weight:700;color:var(--grade-a);font-size:var(--text-base)}.fc-price-pct{font-size:var(--text-xs);color:#f87171;font-weight:600}.fc-stores{display:flex;flex-wrap:wrap;gap:6px;padding:var(--space-2, 8px) var(--page-px, 16px) var(--page-px, 16px);border-top:1px solid var(--border, #333)}.fc-store-link{display:inline-flex;align-items:center;font-size:var(--text-sm);color:var(--accent);text-decoration:none;padding:4px 10px;border:1px solid var(--border, #333);border-radius:6px;background:var(--bg-elevated);white-space:nowrap;-webkit-tap-highlight-color:transparent}.fc-store-link:active{background:var(--bg-elevated, #2a2a2a)}.fc-price{color:var(--accent);font-weight:600}.spotify-btn{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--radius-full);border:none;background:#1db95426;color:#1db954;font-size:var(--text-xs);font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.spotify-btn:active{background:#1db95440}.pg-page{padding-bottom:calc(var(--tab-height) + var(--space-4))}.pg-header{margin-bottom:var(--space-4)}.pg-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin:var(--space-1) 0 0}.pg-search-wrap{position:relative;margin-bottom:var(--space-3)}.pg-search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.pg-search{width:100%;padding:var(--space-2) var(--space-3) var(--space-2) 38px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);font-size:var(--text-sm);outline:none;box-sizing:border-box}.pg-search:focus{border-color:var(--accent)}.pg-categories{display:flex;gap:var(--space-2);overflow-x:auto;margin-bottom:var(--space-4);-webkit-overflow-scrolling:touch;scrollbar-width:none}.pg-categories::-webkit-scrollbar{display:none}.pg-cat-btn{flex-shrink:0;padding:var(--space-1) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-full);background:transparent;color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;transition:all .15s;white-space:nowrap}.pg-cat-btn.active{background:var(--accent);color:#000;border-color:var(--accent)}.pg-grid{display:flex;flex-direction:column;gap:var(--space-3)}.pg-card{display:flex;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md);text-decoration:none;color:inherit;-webkit-tap-highlight-color:transparent}.pg-card:active{opacity:.8}.pg-card-cover{width:96px;height:96px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}.pg-card-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:var(--space-1)}.pg-card-title{font-weight:600;font-size:var(--text-base);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pg-card-artist{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pg-card-meta{display:flex;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-muted);align-items:center}.pg-card-rating{color:var(--accent);font-weight:600}.pg-card-rating:before{content:"★"}.pg-badges{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:2px}.pg-badge{font-size:var(--text-2xs);padding:1px var(--space-1);border-radius:var(--radius-sm);font-weight:600;white-space:nowrap}.pg-badge-aaa{background:#14532d;color:#4ade80}.pg-badge-eng{background:#1e1b4b;color:#a78bfa}.pg-badge-plant{background:#422006;color:#fbbf24}.pg-badge-audio{background:#0c4a6e;color:#38bdf8}.pg-loading,.pg-empty{padding:var(--space-8) 0;text-align:center;color:var(--text-muted)}.pg-load-more{display:block;width:100%;padding:var(--space-3);margin-top:var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);background:transparent;color:var(--accent);font-size:var(--text-sm);cursor:pointer}.sg-loading{display:flex;align-items:center;justify-content:center;min-height:40vh}.sg-page{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-6))}.sg-subtitle{font-size:var(--text-xs);color:var(--text-muted);margin:0 var(--page-px) var(--space-3)}.sg-filters{display:flex;gap:var(--space-2);padding:0 var(--page-px) var(--space-4);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.sg-filters::-webkit-scrollbar{display:none}.sg-filter-pill{flex-shrink:0;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:var(--text-xs);font-weight:500;cursor:pointer;-webkit-tap-highlight-color:transparent}.sg-filter-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}.sg-sections{padding:0 var(--page-px)}.sg-section{margin-bottom:var(--space-6)}.sg-section-title{font-size:var(--text-base);font-weight:700;margin:0 0 var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.sg-section-icon{font-size:var(--text-lg)}.sg-tier{margin-bottom:var(--space-4)}.sg-tier-label{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 var(--space-2)}.sg-card{background:var(--bg-surface);border-radius:var(--radius-md);padding:var(--space-3);margin-bottom:var(--space-2)}.sg-card-header{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-2)}.sg-card-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.sg-card-price{font-size:var(--text-xs);font-weight:600;color:var(--accent);flex-shrink:0}.sg-card-meta{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-2xs);color:var(--text-muted);margin-top:var(--space-1)}.sg-card-sep{opacity:.4}.sg-sentiment-dot{display:inline-block;width:6px;height:6px;border-radius:50%;flex-shrink:0}.sg-card-context{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-2);line-height:1.4}.sg-card-compare{font-size:var(--text-2xs);color:var(--text-muted);margin-top:var(--space-1);font-style:italic}.sg-card-reviewers{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-2)}.sg-reviewer-pill{font-size:var(--text-2xs);padding:2px var(--space-2);border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--text-muted)}.sg-my-setup{margin:0 var(--page-px) var(--space-4);padding:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md)}.sg-my-setup-header{display:flex;justify-content:space-between;align-items:center}.sg-my-setup-header .sg-section-title{margin:0}.sg-edit-btn{font-size:var(--text-xs);color:var(--accent);background:transparent;border:none;font-weight:600;cursor:pointer;padding:var(--space-1) var(--space-2);-webkit-tap-highlight-color:transparent}.sg-my-setup-items{margin-top:var(--space-2);display:flex;flex-direction:column;gap:var(--space-1)}.sg-my-item{display:flex;justify-content:space-between;font-size:var(--text-xs)}.sg-my-item-label{color:var(--text-muted);font-weight:500}.sg-my-item-value{color:var(--text-primary);font-weight:600}.sg-my-setup-empty{font-size:var(--text-xs);color:var(--text-muted);margin:var(--space-2) 0 0}.sg-my-setup-form{margin-top:var(--space-3);display:flex;flex-direction:column;gap:var(--space-3)}.sg-form-row{display:flex;flex-direction:column;gap:var(--space-1)}.sg-form-label{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary)}.sg-form-inputs{display:flex;gap:var(--space-2)}.sg-form-input{flex:1;padding:var(--space-2);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-page);color:var(--text-primary);font-size:var(--text-xs)}.sg-form-input::placeholder{color:var(--text-muted)}.sg-save-btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);background:var(--accent);color:#fff;border:none;font-size:var(--text-sm);font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}.sg-save-btn:disabled{opacity:.5}.sg-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;text-align:center;padding:var(--space-6) var(--page-px);color:var(--text-muted)}.sg-empty-icon{margin-bottom:var(--space-3);opacity:.4}.sg-empty h2{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-1)}.sg-empty p{font-size:var(--text-sm);margin:0}.comm-source-icon{width:100px;height:100px;flex-shrink:0;border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px}.comm-source-label{font-size:var(--text-xs);font-weight:700;line-height:1;text-align:center;max-width:88px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.comm-source-monogram{font-size:24px;font-weight:800;line-height:1;letter-spacing:-.03em}.community-page .feed-section-title{width:calc(100% + 2 * var(--page-px));margin-left:calc(-1 * var(--page-px));padding:var(--space-2) var(--page-px);margin-bottom:var(--space-3);background:var(--bg-elevated);border-top:2px solid var(--accent);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--accent)}.community-page .feed-section{margin-top:calc(var(--space-8) + var(--space-3));margin-bottom:0}.community-page .feed-section:first-of-type{margin-top:0}.community-search{margin-bottom:var(--space-4)}.comm-match-reason{display:flex;align-items:center;gap:4px;font-size:var(--text-xs);font-weight:600;color:var(--accent);margin-bottom:var(--space-1);line-height:1.2}.collectors-grid{display:flex;flex-direction:column;gap:var(--space-3)}.collector-card{display:flex;align-items:flex-start;gap:var(--space-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-4);width:100%;text-align:left;cursor:pointer;transition:border-color .15s}.collector-card:active{border-color:var(--accent)}.collector-avatar{flex-shrink:0;width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;font-size:var(--text-xl);font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}.collector-body{flex:1;min-width:0}.collector-name-row{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-2);margin-bottom:3px}.collector-name{font-size:var(--text-base);font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.collector-count{flex-shrink:0;font-size:var(--text-sm);font-weight:600;color:var(--accent)}.collector-location{display:flex;align-items:center;gap:4px;font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-2)}.collector-bio{font-size:var(--text-sm);color:var(--text-muted);line-height:1.45;margin:0 0 var(--space-2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.collector-badges{display:flex;flex-wrap:wrap;gap:var(--space-1)}.collector-badge{font-size:var(--text-xs);font-weight:600;padding:3px 8px;border-radius:20px;background:#6366f11f;color:var(--accent);letter-spacing:.02em}.comm-empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-10) var(--space-6)}.comm-empty-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-2)}.comm-empty-sub{font-size:var(--text-sm);color:var(--text-muted);line-height:1.6;margin:0;max-width:280px}.feed-page{padding-bottom:var(--space-6)}.feed-title{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-4)}.feed-skeleton{display:flex;flex-direction:column;gap:var(--space-4)}.feed-skeleton-card{background:var(--bg-surface);border-radius:var(--radius-md);padding:var(--space-4);display:flex;gap:var(--space-3)}.feed-skeleton-img{width:112px;height:112px;flex-shrink:0;background:var(--bg-elevated);border-radius:var(--radius-sm);animation:feed-sk-pulse 1.2s ease-in-out infinite}.feed-skeleton-body{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.feed-skeleton-bar{height:14px;width:70%;background:var(--bg-elevated);border-radius:4px;animation:feed-sk-pulse 1.2s ease-in-out infinite}.feed-skeleton-bar.wide{width:90%}.feed-skeleton-bar.narrow{width:45%}@keyframes feed-sk-pulse{0%,to{opacity:.4}50%{opacity:.8}}.feed-section{margin-bottom:var(--space-8)}.feed-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin:0 0 var(--space-3)}.feed-section-more{margin-left:auto;color:var(--text-muted);display:flex;align-items:center;-webkit-tap-highlight-color:transparent}.feed-section-more:active{color:var(--accent)}.feed-section-icon{font-size:var(--text-base)}.feed-section-cards{display:flex;flex-direction:column;gap:var(--space-3)}.feed-section-toggle{display:block;width:100%;margin-top:var(--space-3);padding:var(--space-3) 0;background:none;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--accent);font-size:var(--text-sm);font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}.feed-section-toggle:active{opacity:.7}.feed-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.feed-card-main{display:flex;gap:var(--space-3);padding:var(--space-4);color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}a.feed-card-main:active{opacity:.9}.feed-card-cover{width:112px;height:112px;flex-shrink:0;border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-elevated)}.feed-card-icon{width:100px;height:100px;flex-shrink:0;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.feed-card-icon--debate{background:#a78bfa14;color:#a78bfa}.feed-card-icon--tidbit{background:#f59e0b14;color:#f59e0b}.feed-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.feed-card-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);line-height:1.35}.feed-card-artist{font-size:var(--text-sm);color:var(--text-secondary)}.feed-card-sub{font-size:var(--text-sm);color:var(--text-muted)}.feed-card-accent{color:var(--accent);font-weight:500}.feed-card-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.55;margin:4px 0 0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.feed-card-badges{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:var(--space-1)}.feed-card-actions{display:inline-flex;align-items:stretch;margin:0 var(--page-px, 1rem) var(--space-2, 8px);background:#8b5cf60f;border:1px solid rgba(139,92,246,.18);border-radius:var(--radius-full);overflow:hidden}.feed-card-actions .ask-ai-inline{padding:var(--space-1) var(--space-3);font-size:var(--text-xs);border-radius:0}.feed-card-actions .ask-ai-inline+.ask-ai-inline{border-left:1px solid rgba(139,92,246,.2)}.feed-badge{font-size:var(--text-xs);font-weight:600;padding:3px 8px;border-radius:4px;white-space:nowrap}.feed-badge--date{font-weight:700;color:var(--text-primary);background:var(--bg-elevated)}.feed-badge--deal{background:#f59e0b26;color:#fbbf24}.feed-badge--news{background:#3b82f626;color:#60a5fa}.feed-badge--muted{background:var(--bg-elevated);color:var(--text-muted)}.feed-card-footer{padding:0 var(--space-4) var(--space-3)}.feed-card-link{font-size:var(--text-sm);color:var(--accent);text-decoration:none;font-weight:500}.fc-buzz{padding:var(--space-2) var(--space-3);display:flex;flex-wrap:wrap;gap:var(--space-1);align-items:center}.fc-buzz-badge{font-size:var(--text-xs);font-weight:600;padding:2px 8px;border-radius:4px;white-space:nowrap}.fc-buzz-expert{background:#a78bfa26;color:#a78bfa}.fc-buzz-blog{background:#3b82f626;color:#60a5fa}.fc-buzz-forum{background:#22c55e26;color:#4ade80}.fc-buzz-quote{width:100%;font-size:var(--text-xs);color:var(--text-muted);font-style:italic;line-height:1.4;margin:var(--space-1) 0 0}.fc-tldr{padding:0 var(--space-3) var(--space-2);font-size:var(--text-xs);color:var(--text-secondary);line-height:1.4}.community-browse-link{display:block;text-align:center;padding:var(--space-3, 12px) var(--space-4, 16px);margin-top:var(--space-4, 16px);border:1px solid var(--border, #333);border-radius:var(--radius-md, 8px);color:var(--accent);text-decoration:none;font-size:var(--text-sm);font-weight:500}.feed-see-all{display:block;width:100%;text-align:center;padding:var(--space-3, 12px);margin-top:var(--space-2, 8px);background:none;border:1px solid var(--border, #333);border-radius:var(--radius-md, 8px);color:var(--accent);font-size:var(--text-sm);font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}.rec-connections{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-1)}.rec-connection-pill{display:inline-flex;align-items:center;gap:4px;font-size:var(--text-2xs);font-weight:500;color:var(--text-muted);background:var(--bg-elevated);border-radius:var(--radius-full);padding:2px 8px 2px 5px;line-height:1.3}.rec-connection-pill svg{color:var(--accent);opacity:.7}.rec-actions{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-top:1px solid var(--border)}.rec-feedback-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .15s}.rec-feedback-btn:active{opacity:.7}.rec-feedback-btn.active-up{color:var(--success, #22c55e);border-color:var(--success, #22c55e);background:#22c55e1a}.rec-downvote-reasons{padding:var(--space-3) var(--space-4);border-top:1px solid var(--border);background:var(--bg-elevated)}.rec-downvote-title{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);margin-bottom:var(--space-2)}.rec-downvote-reason{display:block;width:100%;text-align:left;padding:var(--space-2) var(--space-3);margin-bottom:var(--space-1);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;-webkit-tap-highlight-color:transparent}.rec-downvote-reason:active{background:var(--bg-page)}.social-act-list{display:flex;flex-direction:column;gap:var(--space-3)}.social-act-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.social-act-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-3) var(--space-2);gap:var(--space-2)}.social-act-actor{display:flex;align-items:center;gap:var(--space-2);text-decoration:none;color:inherit;flex:1;min-width:0}.social-act-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.social-act-name{font-size:var(--text-sm);font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.social-act-right{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.social-act-stars{color:#f59e0b;font-size:var(--text-sm);letter-spacing:-1px}.social-act-time{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap}.social-act-album{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3) var(--space-3);text-decoration:none;color:inherit;border-top:1px solid var(--border)}.social-act-cover{width:52px;height:52px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0;background:var(--bg-surface)}.social-act-album-body{flex:1;min-width:0}.social-act-action{font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--accent);font-weight:600;margin-bottom:2px}.social-act-album-title{font-size:var(--text-sm);font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.social-act-album-sub{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.social-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-10) var(--space-6) var(--space-6);gap:var(--space-2)}.social-empty-title{font-size:var(--text-base);font-weight:600;color:var(--text);margin:var(--space-3) 0 0}.social-empty-sub{font-size:var(--text-sm);color:var(--text-muted);line-height:1.5;max-width:280px;margin:0}.social-empty-cta{margin-top:var(--space-3);background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;padding:var(--space-2) var(--space-5);cursor:pointer}.fs-page{padding:var(--page-px);max-width:600px;margin:0 auto}.fs-title{font-size:var(--text-xl);font-weight:700;margin:0 0 var(--space-4);color:var(--text-primary)}.fs-search-input{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-primary);box-sizing:border-box;outline:none;transition:border-color .15s;margin-bottom:var(--space-3)}.fs-search-input:focus{border-color:var(--accent)}.fs-search-input::placeholder{color:var(--text-muted)}.fs-filters{display:flex;align-items:flex-start;gap:var(--space-2);margin-bottom:var(--space-4);flex-wrap:wrap}.fs-filters .filter-chips{flex:1;margin-bottom:0}.fs-filters .filter-dropdown{margin-bottom:0;flex-shrink:0}.fs-filters .filter-dropdown select{font-size:var(--text-xs);padding:var(--space-1) var(--space-5) var(--space-1) var(--space-2);min-height:30px}.fs-summary-text{-webkit-line-clamp:unset;display:block;overflow:visible}.community-search{padding:0 var(--page-px);margin-bottom:var(--space-2)}.community-section-intro{font-size:var(--text-sm);color:var(--text-muted);line-height:1.6;margin:0 0 var(--space-3)}.fs-empty{color:var(--text-muted);text-align:center;padding:var(--space-8) 0;font-size:var(--text-sm)}.session-page{padding-bottom:calc(var(--space-8) + var(--tab-height))}.session-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3)}.session-back{width:44px;height:44px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-secondary)}.session-back:active{background:var(--bg-elevated)}.session-header-title{flex:1;font-size:var(--text-lg);font-weight:700;text-align:center;color:var(--text-primary);min-width:0}.session-end-btn{padding:var(--space-2) var(--space-4);background:#ef44441f;color:#f87171;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;min-height:44px;display:inline-flex;align-items:center}.session-end-btn:active:not(:disabled){opacity:.8}.session-end-btn:disabled{opacity:.4}.session-name-row{margin-bottom:var(--space-5)}.session-name-display{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-4) var(--page-px);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);min-height:56px;-webkit-tap-highlight-color:transparent}.session-name-display:active{border-color:var(--accent)}.session-name-text{flex:1;min-width:0;font-size:var(--text-base);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left}.session-name-display:not(:has(.session-name-text:not(:empty))) .session-name-text,.session-name-text:empty{color:var(--text-muted)}.session-name-pencil{flex-shrink:0;color:var(--text-muted);margin-left:var(--space-3)}.session-name-edit{background:var(--bg-surface);border:1px solid var(--accent);border-radius:var(--radius-md);padding:var(--page-px)}.session-name-input{width:100%;font-size:var(--text-lg);font-weight:600;color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);min-height:52px}.session-name-input:focus{outline:none;border-color:var(--accent)}.session-name-input::placeholder{color:var(--text-muted);font-weight:400}.session-name-charcount{display:block;font-size:var(--text-xs);color:var(--text-muted);text-align:right;margin-top:var(--space-1);padding-right:var(--space-1)}.session-name-actions{display:flex;gap:var(--space-3);margin-top:var(--space-3)}.session-name-cancel{flex:1;padding:var(--space-3);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);min-height:48px;display:flex;align-items:center;justify-content:center}.session-name-cancel:active{opacity:.7}.session-name-save{flex:1;padding:var(--space-3);font-size:var(--text-sm);font-weight:700;color:var(--bg-page);background:var(--accent);border:none;border-radius:var(--radius-md);min-height:48px;display:flex;align-items:center;justify-content:center}.session-name-save:active{opacity:.8}.session-error{color:#f87171;font-size:var(--text-sm);text-align:center;padding:var(--space-2);margin-bottom:var(--space-3)}.session-section{margin-bottom:var(--space-6)}.listen-loading{display:flex;flex-direction:column;gap:var(--space-3)}.now-playing{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-3)}.now-playing-cover{width:200px;height:200px;border-radius:var(--radius-lg);object-fit:cover;background:var(--bg-elevated);box-shadow:0 8px 32px #0006}.now-playing-info{width:100%}.now-playing-artist{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:2px}.now-playing-title{font-size:var(--text-lg);font-weight:700}.now-playing-pressing{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-1)}.now-playing-empty{display:flex;flex-direction:column;align-items:center;padding:var(--space-8) 0;gap:var(--space-3)}.now-playing-empty-icon{opacity:.4}.now-playing-empty-text{font-size:var(--text-sm);color:var(--text-muted)}.queue-list{display:flex;flex-direction:column;gap:var(--space-2)}.queue-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md)}.queue-item--playing{border-left:3px solid var(--accent)}.queue-cover{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.queue-info{flex:1;min-width:0}.queue-artist{font-size:var(--text-sm);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-title{font-size:var(--text-base);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-remove{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);color:var(--text-muted)}.queue-remove:active{background:var(--bg-elevated);color:#f87171}.queue-empty{text-align:center;color:var(--text-muted);font-size:var(--text-sm);padding:var(--space-4) 0}.queue-item-wrap{border-radius:var(--radius-md);overflow:hidden}.queue-item-wrap--expanded{background:var(--bg-surface)}.queue-item-main{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0;background:none;border:none;padding:0;text-align:left;color:inherit;-webkit-tap-highlight-color:transparent}.queue-chevron{flex-shrink:0;transition:transform .2s ease}.track-list{padding:0 var(--space-3) var(--space-3);display:flex;flex-direction:column;border-top:1px solid var(--border)}.track-loading,.track-empty{font-size:var(--text-sm);color:var(--text-muted);padding:var(--space-3) 0;text-align:center}.track-item{padding:var(--space-2) 0;border-bottom:1px solid rgba(255,255,255,.04)}.track-item:last-child{border-bottom:none}.track-row{display:flex;align-items:center;gap:var(--space-2)}.track-pos{width:28px;flex-shrink:0;font-size:var(--text-xs);color:var(--text-muted);text-align:center}.track-name{flex:1;min-width:0;font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-dur{flex-shrink:0;font-size:var(--text-xs);color:var(--text-muted);font-variant-numeric:tabular-nums}.track-rating{display:flex;gap:2px;padding:var(--space-1) 0 var(--space-1) 28px}.track-star{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);-webkit-tap-highlight-color:transparent}.track-star:active{transform:scale(.9)}.track-note-existing{font-size:var(--text-xs);color:var(--text-secondary);padding:var(--space-1) 0 var(--space-1) 28px;line-height:1.4}.track-note-input-row{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) 0 0 28px}.track-note-input{flex:1;padding:var(--space-1) var(--space-2);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-xs);color:var(--text-primary);min-height:30px}.track-note-input:focus{outline:none;border-color:var(--accent)}.track-note-input::placeholder{color:var(--text-muted)}.track-note-save{width:30px;height:30px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--accent);-webkit-tap-highlight-color:transparent}.track-note-save:disabled{opacity:.3}.track-note-save:active:not(:disabled){transform:scale(.9)}.add-album-btn{margin-top:var(--space-3)}.add-album-panel{margin-top:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md);padding:var(--page-px);border:1px solid var(--border)}.add-album-panel .search-input{margin-bottom:var(--space-3)}.add-results{max-height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-3)}.add-result-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);text-align:left;width:100%;-webkit-tap-highlight-color:transparent}.add-result-item:active{background:var(--bg-elevated)}.add-result-cover{width:40px;height:40px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.add-result-info{flex:1;min-width:0}.add-result-title{font-size:var(--text-sm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.add-result-artist{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.add-empty{text-align:center;color:var(--text-muted);font-size:var(--text-sm);padding:var(--space-4) 0}.add-cancel-btn{width:100%;justify-content:center}.notes-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-3) var(--page-px);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);min-height:48px}.notes-toggle:active{opacity:.8}.notes-toggle-label{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.notes-panel{background:var(--bg-surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);padding:var(--page-px)}.note-form{display:flex;flex-direction:column;gap:var(--space-3)}.note-input{width:100%;padding:var(--space-3);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--text-primary);resize:vertical;min-height:72px;line-height:1.5}.note-input:focus{outline:none;border-color:var(--accent)}.note-input::placeholder{color:var(--text-muted)}.note-type-row{display:flex;gap:var(--space-2)}.note-type-pill{padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border);min-height:36px;display:inline-flex;align-items:center}.note-type-pill--active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:600}.note-type-pill:active{opacity:.8}.star-rating{display:flex;gap:var(--space-1)}.star-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.star-btn:active{transform:scale(.9)}.note-actions{display:flex;align-items:center;gap:var(--space-3)}.note-voice-btn{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);font-size:var(--text-xs);min-height:40px;opacity:.5;cursor:not-allowed}.voice-soon{font-size:var(--text-xs);color:var(--text-muted)}.note-submit-btn{flex:1}.notes-list{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border)}.note-card{background:var(--bg-elevated);border-radius:var(--radius-md);padding:var(--space-3)}.note-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.note-card-type{font-size:var(--text-xs);font-weight:600;text-transform:capitalize;color:var(--accent)}.note-card-rating{display:flex;gap:1px}.note-card-body{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;white-space:pre-wrap}.note-card-time{display:block;font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-2)}.session-summary{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-8) 0;gap:var(--space-6)}.summary-icon{width:80px;height:80px;background:#f59e0b1a;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.summary-heading{font-size:var(--text-xl);font-weight:700}.summary-stats{display:flex;gap:var(--space-6)}.summary-stat{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.summary-stat-value{font-size:var(--text-xl);font-weight:700;color:var(--accent)}.summary-stat-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.session-danger-zone{margin-top:var(--space-6)}.session-delete-trigger{width:100%;padding:var(--space-3);font-size:var(--text-sm);font-weight:600;color:var(--text-muted);background:none;border:1px solid var(--border);border-radius:var(--radius-md)}.session-delete-trigger:active{color:#f87171;border-color:#f87171}.session-delete-confirm{background:#ef444414;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);padding:var(--page-px)}.session-delete-msg{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-3);line-height:1.5}.session-delete-actions{display:flex;gap:var(--space-3)}.session-delete-yes{flex:1;padding:var(--space-3);font-size:var(--text-sm);font-weight:700;color:#fff;background:#ef4444;border-radius:var(--radius-md)}.session-delete-yes:active{background:#dc2626}.session-delete-actions .btn-secondary{flex:1}.menu-page{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-6))}.menu-header{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) 0 var(--space-6)}.menu-avatar{width:56px;height:56px;border-radius:50%;background:var(--bg-elevated);border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);font-weight:700;color:var(--accent);flex-shrink:0}.menu-user-info{flex:1;min-width:0}.menu-username{font-size:var(--text-lg);font-weight:700}.menu-collection-count{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}.menu-nav{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-6)}.menu-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;transition:background .1s}.menu-item:active{background:var(--bg-elevated)}.menu-item-icon{color:var(--text-muted);flex-shrink:0;display:flex}.menu-item-label{flex:1;font-size:var(--text-base);font-weight:500}.menu-item-chevron{color:var(--text-muted);flex-shrink:0;display:flex}.menu-section{margin-bottom:var(--space-5)}.menu-section-title{font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-3)}.menu-connected-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-muted)}.menu-connected-label{flex:1;font-size:var(--text-sm)}.menu-connected-badge{font-size:var(--text-xs);font-weight:600;color:#22c55e;background:#22c55e1a;padding:2px var(--space-2);border-radius:var(--radius-full)}.menu-connected-row+.menu-connected-row{margin-top:var(--space-1)}.menu-connect-btn{font-size:var(--text-xs);font-weight:600;color:var(--accent);background:#f59e0b1a;padding:4px var(--space-3);border-radius:var(--radius-full);border:1px solid rgba(245,158,11,.3);cursor:pointer;min-height:32px}.menu-connect-btn:active{opacity:.7}.menu-message{padding:var(--space-2) var(--space-3);background:#34d3991a;color:#34d399;border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--space-3);text-align:center}.menu-syncing{font-size:var(--text-xs);color:var(--accent);margin-top:2px}.menu-logout-btn{width:100%;padding:var(--space-3);background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:#f87171;font-weight:600;font-size:var(--text-sm);min-height:48px}.menu-logout-btn:active{opacity:.7}.menu-theme{padding:var(--space-3) 0 var(--space-4);border-bottom:1px solid var(--border);margin-bottom:var(--space-4)}.menu-theme-controls{display:flex;gap:var(--space-2)}.menu-theme-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-2);min-height:48px;font-size:var(--text-sm);font-weight:600;color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);-webkit-tap-highlight-color:transparent;transition:all .15s}.menu-theme-btn.active{color:var(--accent);border-color:var(--accent);background:#f59e0b14}[data-theme=light] .menu-theme-btn.active{background:#d9770614}[data-theme=vinyl] .menu-theme-btn.active{color:#22c55e;border-color:#22c55e;background:#22c55e1a}.menu-theme-btn--vinyl svg{color:#22c55e;opacity:.6}.menu-theme-btn:active{opacity:.8}.menu-text-size{padding:var(--space-3) 0}.menu-text-size-label{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);display:block;margin-bottom:var(--space-3)}.menu-text-size-controls{display:flex;gap:var(--space-2)}.menu-text-size-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-2) var(--space-1);min-height:56px;font-size:var(--text-sm);font-weight:600;color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);-webkit-tap-highlight-color:transparent;transition:all .15s}.menu-text-size-btn--lg{font-size:var(--text-base)}.menu-text-size-btn--xl{font-size:var(--text-lg)}.menu-text-size-btn.active{color:var(--accent);border-color:var(--accent);background:#f59e0b14}.menu-text-size-btn:active{opacity:.8}.menu-text-size-hint{font-size:var(--text-2xs);font-weight:500;color:var(--text-muted)}.friends-page{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-6))}.fr-loading{display:flex;align-items:center;justify-content:center;min-height:50vh}.fr-back{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);border-radius:var(--radius-full);flex-shrink:0}.fr-back:active{color:var(--accent)}.fr-header-center{flex:1;display:flex;flex-direction:column;align-items:center}.fr-header-count{font-size:var(--text-xs);color:var(--text-muted);margin-top:1px}.fr-refresh-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);border-radius:var(--radius-full);transition:color .15s;flex-shrink:0}.fr-refresh-btn:active{color:var(--accent)}.fr-refresh-btn:disabled{opacity:.5}@keyframes fr-spin{to{transform:rotate(360deg)}}.fr-spinning svg{animation:fr-spin .7s linear infinite}.fr-error{padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-md);font-size:var(--text-sm);color:#f87171}.fr-empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-3);padding:var(--space-8) var(--space-4)}.fr-empty-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0}.fr-empty-sub{font-size:var(--text-sm);color:var(--text-muted);line-height:1.6;max-width:280px;margin:0}.fr-empty-btn{margin-top:var(--space-2);padding:var(--space-2) var(--space-5);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;color:var(--text-primary);transition:border-color .15s}.fr-empty-btn:active{border-color:var(--accent);color:var(--accent)}.fr-empty-btn:disabled{opacity:.5}.fr-vnv-section{margin-bottom:var(--space-6)}.fr-section-label{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--accent);margin-bottom:var(--space-3)}.fr-vnv-list{display:flex;flex-direction:column;gap:var(--space-2)}.fr-vnv-item{display:flex;align-items:center;gap:var(--space-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3)}.fr-vnv-profile{flex:1;display:flex;align-items:center;gap:var(--space-3);text-align:left;min-width:0}.fr-vnv-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;font-size:var(--text-base);font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1}.fr-vnv-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.fr-vnv-name{font-size:var(--text-base);font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fr-vnv-meta{font-size:var(--text-xs);color:var(--text-muted)}.fr-vnv-follow{flex-shrink:0;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;padding:var(--space-1) var(--space-4);cursor:pointer;transition:opacity .15s;min-width:80px;text-align:center}.fr-vnv-follow:active{opacity:.8}.fr-vnv-follow:disabled{opacity:.6;cursor:default}.fr-vnv-follow--following{background:var(--surface);color:var(--text-muted);border:1px solid var(--border)}.fr-list{display:flex;flex-direction:column;gap:var(--space-2)}.fr-item{display:flex;align-items:stretch;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.fr-item-main{flex:1;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);text-align:left;min-width:0;transition:background .12s}.fr-item-main:active{background:var(--bg-elevated)}.fr-avatar{width:44px;height:44px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center}.fr-avatar-img{width:100%;height:100%;object-fit:cover}.fr-avatar-letter{font-size:var(--text-base);font-weight:700;color:var(--accent)}.fr-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.fr-username{font-size:var(--text-base);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fr-meta{font-size:var(--text-xs);color:var(--text-muted)}.fr-unsynced{color:var(--text-muted);font-style:italic}.fr-chevron{color:var(--text-muted);flex-shrink:0;opacity:.5}.fr-sync-btn{width:44px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0;border-left:1px solid var(--border);transition:color .15s,background .12s}.fr-sync-btn:active{color:var(--accent);background:var(--bg-elevated)}.fr-sync-btn:disabled{opacity:.4}.spinner-sm{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:fr-spin .6s linear infinite}.qb{display:inline-flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700;padding:2px 8px;border-radius:var(--radius-full);letter-spacing:.03em;line-height:1.4}.qb-grade-aplus{background:var(--grade-aplus);color:#000}.qb-grade-a{background:var(--grade-a);color:#000}.qb-grade-b{background:var(--grade-b);color:#fff}.qb-grade-c{background:var(--grade-c);color:#000}.qb-grade-d{background:var(--grade-d);color:#fff}.qb-audio-aaa{background:var(--audio-aaa);color:#000}.qb-audio-aad,.qb-audio-add{background:#334155;color:#94a3b8}.qb-audio-ddd{background:#1e293b;color:#64748b}.qb-fomo-high{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3)}.qb-fomo-med{background:#f59e0b26;color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.sap-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#0009;display:flex;align-items:flex-end;-webkit-tap-highlight-color:transparent}.sap-panel{width:100%;max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--bg-page);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:var(--space-3) var(--page-px) calc(var(--space-8) + var(--safe-bottom));animation:sap-slide-up .3s ease-out}@keyframes sap-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sap-handle{width:36px;height:4px;background:var(--border);border-radius:var(--radius-full);margin:0 auto var(--space-4)}.sap-status-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--bg-surface);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.sap-status-left{display:flex;align-items:center;gap:var(--space-2)}.sap-status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.sap-status-dot.sap-status-active{background:#34d399;box-shadow:0 0 6px #34d39980}.sap-status-label{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary)}.sap-toggle{position:relative;width:48px;height:28px;border-radius:var(--radius-full);background:var(--bg-elevated);border:1px solid var(--border);cursor:pointer;flex-shrink:0;transition:background .2s,border-color .2s;padding:0}.sap-toggle-on{background:var(--accent);border-color:var(--accent)}.sap-toggle-thumb{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:var(--text-primary);transition:transform .2s}.sap-toggle-on .sap-toggle-thumb{transform:translate(20px);background:#000}.sap-album-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5)}.sap-album-cover{width:56px;height:56px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.sap-album-info{flex:1;min-width:0}.sap-album-title{font-size:var(--text-base);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sap-album-artist{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.sap-heading{font-size:var(--text-lg);font-weight:700;margin-bottom:var(--space-2)}.sap-prompt{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;margin-bottom:var(--space-5)}.sap-field{margin-bottom:var(--space-4)}.sap-field-label{display:block;font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.sap-field-label-sm{font-size:var(--text-sm);color:var(--text-secondary)}.sap-input{width:100%;padding:var(--space-3) var(--page-px);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--text-primary);min-height:44px}.sap-input:focus{outline:none;border-color:var(--accent)}.sap-input::placeholder{color:var(--text-muted)}.sap-select{padding:var(--space-3) var(--page-px);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--text-primary);min-height:44px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}.sap-select:focus{outline:none;border-color:var(--accent)}.sap-textarea{width:100%;padding:var(--space-3) var(--page-px);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--text-primary);resize:vertical;min-height:80px;line-height:1.5}.sap-textarea:focus{outline:none;border-color:var(--accent)}.sap-textarea::placeholder{color:var(--text-muted)}.sap-budget-row{display:flex;gap:var(--space-2)}.sap-budget-input{flex:1}.sap-currency-select{width:90px;flex-shrink:0}.sap-mode-link{display:block;text-align:center;color:var(--text-muted);font-size:var(--text-sm);margin-top:var(--space-4);padding:var(--space-2);min-height:44px;display:flex;align-items:center;justify-content:center}.sap-mode-link:active{color:var(--accent)}.sap-mode-link-top{margin-top:0;margin-bottom:var(--space-3)}.sap-section{margin-bottom:var(--space-5)}.sap-section-title{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:var(--space-3)}.sap-pills{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-3)}.sap-pill-disabled{opacity:.4;cursor:default}.sap-pill-disabled:active{opacity:.4}.sap-coming-soon{font-size:var(--text-xs);color:var(--text-muted);margin-left:var(--space-1);font-weight:400}.sap-pressing-loading{font-size:var(--text-sm);color:var(--text-muted);padding:var(--space-3) 0}.sap-auction-row,.sap-rating-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) 0;min-height:44px}.sap-rating-input-wrap{display:flex;align-items:center;gap:var(--space-1)}.sap-rating-input{width:64px;text-align:center;padding:var(--space-2) var(--space-2);min-height:40px}.sap-rating-pct{font-size:var(--text-sm);color:var(--text-secondary)}.sap-save,.sap-actions{margin-top:var(--space-4)}.sap-cancel{display:flex;align-items:center;justify-content:center;width:100%;min-height:44px;color:var(--text-muted);font-size:var(--text-sm);margin-top:var(--space-2)}.sap-cancel:active{color:var(--text-secondary)}.sap-remove{display:flex;align-items:center;justify-content:center;width:100%;min-height:44px;color:#f87171;font-size:var(--text-sm);margin-top:var(--space-5);padding:var(--space-2)}.sap-remove:active{opacity:.7}.sap-panel-loading{display:flex;align-items:center;justify-content:center;min-height:120px}.sap-error{color:#f87171;font-size:var(--text-sm);margin-bottom:var(--space-3)}.sap-last-checked{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.sap-results-preview{background:var(--bg-surface);border-radius:var(--radius-md);padding:var(--space-3);margin-bottom:var(--space-4)}.sap-results-summary{display:flex;flex-direction:column;gap:2px;margin-bottom:var(--space-2)}.sap-results-match{font-size:var(--text-sm);font-weight:600;color:#34d399}.sap-results-none{font-size:var(--text-sm);color:var(--text-muted)}.sap-results-total{font-size:var(--text-xs);color:var(--text-muted)}.sap-results-link{display:block;text-align:center;color:var(--accent);font-size:var(--text-sm);font-weight:600;text-decoration:none;padding:var(--space-2) 0;margin-top:var(--space-2);border-top:1px solid var(--border)}.sap-results-link:active{opacity:.7}@media(prefers-reduced-motion:reduce){.sap-panel{animation:none}}.wsp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:var(--bg-page);display:flex;flex-direction:column;animation:wsp-fade-in .2s ease-out}@keyframes wsp-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.wsp-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--page-px);padding-top:calc(var(--space-3) + var(--safe-top, 0px));border-bottom:1px solid var(--border);flex-shrink:0}.wsp-back{color:var(--text-muted);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.wsp-back:active{color:var(--text-primary)}.wsp-search-input{flex:1;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);font-size:var(--text-base);color:var(--text-primary);min-height:44px}.wsp-search-input::placeholder{color:var(--text-muted)}.wsp-search-input:focus{border-color:var(--accent);outline:none}.wsp-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:var(--space-2) var(--page-px)}.wsp-hint{text-align:center;color:var(--text-muted);padding:var(--space-8) var(--page-px);font-size:var(--text-sm)}.wsp-loading{display:flex;align-items:center;justify-content:center;padding:var(--space-8)}.wsp-album{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--border);-webkit-tap-highlight-color:transparent;cursor:pointer}.wsp-album:active{opacity:.7}.wsp-album-thumb{width:52px;height:52px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.wsp-album-info{flex:1;min-width:0}.wsp-album-title{font-weight:600;font-size:var(--text-base);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wsp-album-artist{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wsp-album-meta{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.wsp-album-arrow{color:var(--text-muted);flex-shrink:0}.wsp-pressing-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) 0;border-bottom:1px solid var(--border);margin-bottom:var(--space-2)}.wsp-pressing-header h3{font-size:var(--text-base);font-weight:600;flex:1;margin:0}.wsp-pressing-subtitle{font-size:var(--text-sm);color:var(--text-muted)}.wsp-pressing{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md);margin-bottom:var(--space-2);-webkit-tap-highlight-color:transparent;cursor:pointer}.wsp-pressing:active{opacity:.7}.wsp-pressing-info{flex:1;min-width:0}.wsp-pressing-main{font-size:var(--text-sm);font-weight:500;display:flex;gap:var(--space-2);flex-wrap:wrap}.wsp-pressing-country{color:var(--accent)}.wsp-pressing-year{color:var(--text-secondary)}.wsp-pressing-detail{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wsp-pressing-stats{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.wsp-pressing-badges{display:flex;gap:var(--space-1);margin-top:var(--space-1)}.wsp-pressing-add{color:var(--accent);flex-shrink:0;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.wsp-pressing-add:active{opacity:.6}.wsp-pressing-added{color:var(--grade-a, #34d399)}.wsp-back-results{display:flex;align-items:center;gap:var(--space-1);color:var(--accent);font-size:var(--text-sm);font-weight:500;padding:var(--space-2) 0;cursor:pointer}.wsp-back-results:active{opacity:.7}.pcp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#0009;display:flex;align-items:flex-end;-webkit-tap-highlight-color:transparent}.pcp-panel{width:100%;max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--bg-page);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:var(--space-3) var(--page-px) calc(var(--space-8) + var(--safe-bottom));animation:pcp-slide-up .3s ease-out}@keyframes pcp-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pcp-handle{width:36px;height:4px;background:var(--border);border-radius:var(--radius-full);margin:0 auto var(--space-4)}.pcp-album-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.pcp-album-cover{width:56px;height:56px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.pcp-album-info{flex:1;min-width:0}.pcp-album-title{font-size:var(--text-base);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pcp-album-artist{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.pcp-album-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.pcp-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:120px;gap:var(--space-3)}.pcp-loading-text{font-size:var(--text-sm);color:var(--text-muted)}.pcp-error{text-align:center;padding:var(--space-4) 0;color:#f87171;font-size:var(--text-sm)}.pcp-retry{margin-top:var(--space-3);color:var(--accent);font-size:var(--text-sm);font-weight:600;min-height:44px;padding:var(--space-2) var(--space-4)}.pcp-summary{display:flex;gap:var(--space-4);padding:var(--space-4);background:var(--bg-surface);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.pcp-stat{display:flex;flex-direction:column;align-items:center;flex:1}.pcp-stat-value{font-size:var(--text-lg);font-weight:700;color:var(--text-primary)}.pcp-stat-price{color:var(--accent)}.pcp-stat-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.pcp-stat-match .pcp-stat-value{color:#34d399}.pcp-listings{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.pcp-listing{background:var(--bg-surface);border-radius:var(--radius-md);padding:var(--space-3)}.pcp-listing-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-1)}.pcp-source-pill{font-size:var(--text-xs);font-weight:600;color:var(--accent);background:#d4a8531f;padding:2px 8px;border-radius:var(--radius-full)}.pcp-price-total{font-size:var(--text-base);font-weight:700;color:var(--text-primary)}.pcp-listing-meta{display:flex;flex-wrap:wrap;gap:var(--space-1);font-size:var(--text-xs);color:var(--text-muted)}.pcp-listing-meta span:after{content:"·";margin-left:var(--space-1)}.pcp-listing-meta span:last-child:after{content:""}.pcp-listing-notes{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pcp-listing-link{display:inline-block;font-size:var(--text-xs);color:var(--accent);font-weight:600;text-decoration:none;margin-top:var(--space-1)}.pcp-listing-link:active{opacity:.7}.pcp-no-listings{text-align:center;padding:var(--space-4);background:var(--bg-surface);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.pcp-no-listings p{color:var(--text-secondary);font-size:var(--text-sm);margin:0 0 var(--space-1)}.pcp-no-listings-hint{color:var(--text-muted)!important;font-size:var(--text-xs)!important}.pcp-browse-btn{display:block;width:100%;text-align:center;padding:var(--space-3);background:var(--accent);color:#000;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:600;text-decoration:none;min-height:48px;line-height:48px;margin-bottom:var(--space-3)}.pcp-browse-btn:active{opacity:.85}.pcp-setup-agent{width:100%;padding:var(--space-3);background:var(--bg-surface);border:1px dashed var(--border);border-radius:var(--radius-md);color:var(--accent);font-size:var(--text-sm);font-weight:600;text-align:center;min-height:44px;margin-bottom:var(--space-3)}.pcp-setup-agent:active{background:var(--bg-elevated)}.pcp-close{display:flex;align-items:center;justify-content:center;width:100%;min-height:44px;color:var(--text-muted);font-size:var(--text-sm)}.pcp-close:active{color:var(--text-secondary)}@media(prefers-reduced-motion:reduce){.pcp-panel{animation:none}}.wld-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#0009;display:flex;align-items:flex-end;-webkit-tap-highlight-color:transparent}.wld-panel{width:100%;max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--bg-page);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:var(--space-3) var(--page-px) calc(var(--space-8) + var(--safe-bottom));animation:sap-slide-up .3s ease-out}.wld-title{font-size:var(--text-lg);font-weight:700;margin-bottom:var(--space-2)}.wld-desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;margin-bottom:var(--space-4)}.wld-features{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-5)}.wld-feature{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md)}.wld-feature-icon{font-size:var(--text-lg);flex-shrink:0;margin-top:1px}.wld-feature-text{display:flex;flex-direction:column;gap:2px;min-width:0}.wld-feature-label{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.wld-feature-desc{font-size:var(--text-xs);color:var(--text-muted);line-height:1.4}.wld-section{margin-bottom:var(--space-4)}.wld-section-label{display:block;font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.wld-freq-row{display:flex;gap:var(--space-2)}.wld-freq-btn{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:600;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-surface);color:var(--text-muted);min-height:38px}.wld-freq-active{color:var(--accent);border-color:var(--accent);background:#f59e0b14}.wld-freq-disabled{opacity:.5;cursor:default}.wld-coming-soon{font-size:var(--text-xs);font-weight:400;color:var(--text-muted);margin-left:var(--space-1)}.wld-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) 0;margin-bottom:var(--space-3)}.wld-toggle-label{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.wld-save{width:100%;margin-top:var(--space-2)}.wld-cancel{display:flex;align-items:center;justify-content:center;width:100%;min-height:44px;color:var(--text-muted);font-size:var(--text-sm);margin-top:var(--space-2)}.wld-cancel:active{color:var(--text-secondary)}.wld-error{color:#f87171;font-size:var(--text-sm);margin-bottom:var(--space-3)}.wld-success{color:#34d399;font-size:var(--text-sm);margin-bottom:var(--space-3)}@media(prefers-reduced-motion:reduce){.wld-panel{animation:none}}.wl-actions-row{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.wl-share-btn{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:600;color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);min-height:36px;-webkit-tap-highlight-color:transparent}.wl-share-btn:active{color:var(--accent)}.wl-share-btn:disabled{opacity:.5}.wl-share-btn--active{color:var(--accent);border-color:var(--accent);background:#f59e0b14}.wl-preview-link{display:block;text-align:center;font-size:var(--text-xs);font-weight:600;color:var(--accent);text-decoration:none;padding:var(--space-1) 0 var(--space-3)}.wl-preview-link:active{opacity:.7}.wl-loading{display:flex;align-items:center;justify-content:center;min-height:40vh}.wl-error{color:#f87171;text-align:center;padding:var(--space-8);font-size:var(--text-sm)}.wl-empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-8) var(--page-px);margin-top:10vh}.wl-empty-add{width:80px;height:80px;border-radius:50%;background:var(--bg-surface);border:2px dashed var(--accent);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4);transition:transform .15s,background .15s}.wl-empty-add:active{transform:scale(.95);background:var(--bg-elevated)}.wl-empty-title{margin:0 0 var(--space-2);font-size:var(--text-lg);font-weight:700;color:var(--text-primary)}.wl-empty-text{margin:0 0 var(--space-6);font-size:var(--text-sm);color:var(--text-muted);max-width:280px;line-height:1.5}.wl-empty-search-btn{width:100%;max-width:280px;padding:var(--space-3);background:var(--accent);color:#000;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:600;min-height:48px;margin-bottom:var(--space-3)}.wl-empty-search-btn:active{opacity:.85;transform:scale(.98)}.wl-empty-import-btn{width:100%;max-width:280px;padding:var(--space-3);background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;min-height:44px}.wl-empty-import-btn:active{background:var(--bg-elevated)}.wl-sync-card{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-muted)}.wl-sync-card span{flex:1}.wl-sync-card button{font-size:var(--text-xs);font-weight:600;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);border:none;background:var(--accent);color:#000;white-space:nowrap;min-height:32px}.wl-sync-card--action{background:#f59e0b14;border:1px solid rgba(245,158,11,.2);color:var(--text-secondary)}.wl-sync-card--success{background:#22c55e14;border:1px solid rgba(34,197,94,.2);color:#4ade80}.wl-fab{position:fixed;bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-3) + 56px);right:var(--page-px);width:48px;height:48px;border-radius:50%;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000004d;z-index:89;transition:transform .15s}.wl-fab:active{transform:scale(.9)}.wl-list{display:flex;flex-direction:column;gap:var(--space-3)}.wl-item{display:flex;flex-direction:column;gap:0;padding:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md);position:relative}.wl-purchased{opacity:.5}.wl-cover{width:112px;height:112px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.wl-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.wl-title{font-size:var(--text-base);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wl-artist{font-size:var(--text-sm);color:var(--text-secondary)}.wl-pressing-details{font-size:var(--text-xs);color:var(--text-muted)}.wl-format{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wl-badges{display:flex;flex-wrap:wrap;gap:var(--space-1);align-items:center;margin-top:var(--space-1)}.wl-badge-label{font-size:var(--text-xs);color:var(--text-muted)}.wl-note{font-size:var(--text-xs);color:var(--accent);font-style:italic}.wl-purchased-tag{font-size:var(--text-xs);color:var(--grade-a);font-weight:600;margin-top:var(--space-1)}.wl-verdict-row{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap}.wl-verdict{display:inline-flex;align-items:center;font-size:var(--text-2xs);font-weight:600;padding:2px 8px;border-radius:10px;white-space:nowrap}.wl-verdict--best{background:#22c55e1f;color:#4ade80;border:1px solid rgba(34,197,94,.25)}.wl-verdict--value{background:#3b82f61f;color:#60a5fa;border:1px solid rgba(59,130,246,.25)}.wl-verdict--better{background:#f59e0b1f;color:#fbbf24;border:1px solid rgba(245,158,11,.25)}.wl-link{display:flex;gap:var(--space-3);width:100%;min-width:0;color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}.wl-link:active{opacity:.8}.wl-remove{position:absolute;top:var(--space-2);right:var(--space-2);color:var(--text-muted);padding:var(--space-1);min-width:32px;min-height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);opacity:.5}.wl-remove:active{color:#f87171;opacity:1}.wl-bottom-actions{display:flex;flex-wrap:wrap;gap:var(--space-2);width:100%;margin-top:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--border)}.wl-action-btn{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:500;color:var(--text-muted);background:var(--bg-elevated);border-radius:var(--radius-full);white-space:nowrap;min-height:32px}.wl-action-btn:active{color:var(--accent)}.wl-bottom-actions .ask-ai-inline{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:600;color:#a78bfa;background:#8b5cf61a;border:1px solid rgba(139,92,246,.25);border-radius:var(--radius-full);white-space:nowrap;min-height:32px}.wl-bottom-actions .ask-ai-inline:active{background:#8b5cf638}.wl-action-btn--active{color:#34d399cc;background:#34d3991a}.wl-source-prices{display:flex;flex-wrap:wrap;gap:4px;margin-top:var(--space-1)}.wl-source-chip{display:inline-flex;align-items:center;gap:3px;font-size:var(--text-2xs);font-weight:600;padding:2px 7px;border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--text-secondary);white-space:nowrap}.wl-source-chip--best{background:#34d3991a;color:#34d399}.wl-source-name{font-weight:400;color:var(--text-muted)}.wl-alert-badge{display:inline-flex;align-items:center;gap:6px;font-size:var(--text-xs);color:#34d399;font-weight:500;margin-top:var(--space-1);-webkit-tap-highlight-color:transparent}.wl-alert-badge:active{opacity:.7}.wl-alert-dot{width:6px;height:6px;border-radius:50%;background:#34d399;display:inline-block;animation:alert-pulse 2s ease-in-out infinite}@keyframes alert-pulse{0%,to{opacity:1}50%{opacity:.4}}.album-detail{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--page-px))}.ad-loading{display:flex;align-items:center;justify-content:center;min-height:60vh}.ad-error{color:#f87171;text-align:center;padding:var(--space-8);font-size:var(--text-sm)}.ad-back{position:fixed;top:calc(var(--safe-top) + var(--space-2));left:var(--space-3);z-index:50;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#0c0c0eb3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:50%;color:var(--text-primary)}.ad-back:active{opacity:.7}.ad-hero{text-align:center;padding:var(--space-8) var(--page-px) var(--page-px)}.ad-cover{width:min(220px,55vw);height:min(220px,55vw);object-fit:cover;border-radius:var(--radius-lg);margin:0 auto var(--page-px);box-shadow:0 8px 32px #00000080}.ad-title-row{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}.ad-title{font-size:var(--text-lg);font-weight:700;line-height:1.3}.ad-spotify-icon-link{display:inline-flex;align-items:center;color:#1db954;opacity:.75;flex-shrink:0;-webkit-tap-highlight-color:transparent}.ad-spotify-icon-link:active{opacity:1}.ad-artist{font-size:var(--text-base);color:var(--text-secondary);margin-top:var(--space-1)}.ad-label{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1)}.ad-listener-count{display:inline-block;font-size:var(--text-xs);color:var(--text-muted);margin-left:var(--space-2);font-weight:400}.ad-tidbit-banner{display:flex;align-items:flex-start;gap:var(--space-2);margin:0 var(--page-px) var(--space-3);padding:var(--space-3);background:#f59e0b14;border-left:3px solid #f59e0b;border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary);line-height:1.45}.ad-tidbit-banner svg{flex-shrink:0;color:#f59e0b;margin-top:1px}.ad-tidbit-banner p{margin:0}.ad-rec-banner{margin:0 var(--page-px) var(--space-3);padding:var(--space-3);background:#a78bfa14;border-left:3px solid #a78bfa;border-radius:var(--radius-md)}.ad-rec-banner-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.ad-rec-badge{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:var(--radius-sm);background:#a78bfa33;color:#a78bfa}.ad-rec-match{font-size:var(--text-xs);font-weight:600;color:var(--text-muted)}.ad-rec-reason{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;margin:0 0 var(--space-2)}.ad-rec-source{font-size:var(--text-xs);font-weight:600;color:var(--accent);text-decoration:none}.ad-rec-source:active{opacity:.6}.ad-rec-score{margin-left:auto;font-size:var(--text-base);font-weight:700;color:#7dd3fc}.ad-rec-factors{display:flex;flex-wrap:wrap;gap:6px;margin-top:var(--space-2)}.ad-rec-chip{font-size:var(--text-xs);font-weight:600;padding:2px 8px;border-radius:999px;border:1px solid;background:#0003}.ad-badges-row{display:flex;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--page-px)}.ad-actions{display:flex;gap:var(--space-2);padding:var(--space-3) var(--page-px)}.ad-action-btn{flex:1;padding:var(--space-3);border-radius:var(--radius-md);font-weight:600;font-size:var(--text-sm);text-align:center;background:var(--accent);color:#000;min-height:48px;display:flex;align-items:center;justify-content:center}.ad-action-btn:active{transform:scale(.97)}.ad-action-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.ad-action-done{background:var(--grade-a)}.ad-section{padding:var(--space-3) var(--page-px)}.ad-section-title{font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-3)}.ad-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}.ad-detail-item{background:var(--bg-surface);padding:var(--space-3);border-radius:var(--radius-sm)}.ad-detail-label{display:block;font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.ad-detail-value{font-size:var(--text-sm);font-weight:600}.ad-story{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5}.ad-fact-card{background:var(--bg-surface);padding:var(--space-3);border-radius:var(--radius-md);border-left:3px solid var(--accent);margin-bottom:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5}.ad-discogs-link{display:flex;align-items:center;justify-content:center;text-align:center;padding:var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--accent);font-weight:600;font-size:var(--text-sm);min-height:48px}.ad-discogs-link:active{opacity:.8}.ad-prov-list{display:flex;flex-direction:column;gap:var(--space-2)}.ad-prov-card{background:var(--bg-surface);padding:var(--space-3);border-radius:var(--radius-md);border-left:3px solid var(--accent)}.ad-prov-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-2)}.ad-prov-info{display:flex;flex-direction:column;min-width:0}.ad-prov-label{font-size:var(--text-base);font-weight:600}.ad-prov-meta{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}.ad-prov-badges{display:flex;gap:6px;align-items:center;flex-shrink:0}.ad-prov-status{font-size:var(--text-2xs);font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.03em}.ad-prov-status-available{background:#166534;color:#86efac}.ad-prov-status-preorder{background:#713f12;color:#fde68a}.ad-prov-status-upcoming{background:#1e3a5f;color:#93c5fd}.ad-prov-detail{display:flex;flex-wrap:wrap;gap:var(--space-2);font-size:var(--text-sm);color:var(--accent);font-weight:500;margin-bottom:var(--space-2)}.ad-prov-notes{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;margin-bottom:var(--space-2)}.ad-prov-source-link{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:600;color:var(--accent);padding:var(--space-2) var(--space-3);background:#f59e0b14;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-md);min-height:40px;-webkit-tap-highlight-color:transparent}.ad-prov-source-link:active{opacity:.7}.ad-pressings-list{display:flex;flex-direction:column;gap:var(--space-2)}.ad-pressing-item{background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border);overflow:hidden;transition:border-color .15s}.ad-pressing-item:active{border-color:var(--border, #3a3a3e)}.ad-pressing-expanded{border-color:var(--accent)}.ad-pressing-header{display:flex;flex-direction:column;width:100%;padding:var(--space-3);background:none;border:none;text-align:left;color:var(--text-primary);font-family:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;position:relative}.ad-pressing-main{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1)}.ad-pressing-label{font-size:var(--text-base);font-weight:600}.ad-pressing-year,.ad-pressing-country{font-size:var(--text-sm);color:var(--text-muted)}.ad-pressing-meta{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-1)}.ad-pressing-format{font-size:var(--text-sm);color:var(--text-secondary)}.ad-pressing-eng,.ad-pressing-plant{font-size:var(--text-sm);color:var(--accent);font-weight:500}.ad-pressing-aaa{font-size:var(--text-xs);font-weight:700;padding:2px var(--space-2);background:#f59e0b33;color:var(--audio-aaa);border-radius:var(--radius-sm)}.ad-pressing-rating{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2)}.ad-pressing-stars{font-size:var(--text-sm);font-weight:600;color:var(--accent)}.ad-pressing-count{font-size:var(--text-xs);color:var(--text-muted)}.ad-pressing-expand{display:flex;align-items:center;gap:4px;margin-top:var(--space-2);font-size:var(--text-xs);font-weight:600;color:var(--accent);align-self:flex-end}.ad-pressing-expand svg{transition:transform .2s ease}.ad-pressing-expand-open{color:var(--text-muted)}.ad-pressing-inline-rating{padding:var(--space-2) var(--space-3);border-top:1px solid var(--border)}.ad-pressing-body{padding:var(--space-3);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:var(--space-3)}.ad-pressing-insight{font-size:var(--text-sm);line-height:1.5;color:var(--text-secondary);padding:var(--space-2) var(--space-3);background:#4a9eff0f;border-left:3px solid var(--accent);border-radius:0 4px 4px 0}.ad-pressing-insight p{margin:0}.ad-pressing-tldr{font-size:var(--text-sm);line-height:1.5;color:var(--text-muted);font-style:italic}.ad-pressing-tldr p{margin:0}.ad-pressing-detail{font-size:var(--text-sm);color:var(--text-muted)}.ad-pressing-price{font-size:var(--text-base);font-weight:700;color:var(--accent);margin:var(--space-1, 4px) 0}.ad-pressing-links{display:flex;flex-wrap:wrap;gap:8px;margin:var(--space-2, 8px) 0}.ad-pressing-store-link{font-size:var(--text-sm);color:var(--accent);text-decoration:none;padding:4px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg-elevated)}.ad-pressing-discogs-link{font-size:var(--text-sm);color:var(--accent);text-decoration:none}.pr-root{display:flex;flex-direction:column;gap:.5rem}.pr-quick-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.pr-label{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap}.pr-star-row{display:inline-flex;gap:.1rem}.pr-star{font-size:var(--text-xl);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;outline:none;line-height:1}.pr-star-filled{color:var(--accent)}.pr-star-empty{color:var(--text-muted, #475569)}.pr-quick-value{font-size:var(--text-sm);color:var(--accent);font-weight:600}.pr-toggle{font-size:var(--text-xs);padding:.2rem .5rem;border-radius:4px;border:1px solid var(--text-muted, #475569);background:none;color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;font-family:inherit}.pr-toggle-active{border-color:var(--accent);color:var(--accent)}.pr-detail-panel{display:flex;flex-direction:column;gap:.4rem;padding:.5rem .6rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px}.pr-detail-row{display:flex;align-items:center;gap:.4rem}.pr-detail-label{font-size:var(--text-xs);color:var(--text-secondary);width:85px;flex-shrink:0}.pr-detail-value{font-size:var(--text-2xs);color:var(--accent);font-weight:600}.pr-save-row{display:flex;justify-content:flex-end;margin-top:.25rem}.pr-save-btn{font-size:var(--text-sm);padding:.3rem .75rem;border-radius:5px;border:none;background:var(--accent);color:#0f172a;font-weight:700;cursor:pointer;font-family:inherit;-webkit-tap-highlight-color:transparent}.pr-save-btn:disabled{opacity:.4}.pr-saved-notice{font-size:var(--text-xs);color:#4ade80}.pcomment-root{display:flex;flex-direction:column;gap:.75rem}.pcomment-form{display:flex;flex-direction:column;gap:.3rem}.pcomment-textarea{width:100%;box-sizing:border-box;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:7px;padding:.5rem .65rem;font-size:var(--text-sm);font-family:inherit;resize:none;min-height:56px;outline:none}.pcomment-textarea::placeholder{color:var(--text-muted)}.pcomment-textarea:focus{border-color:var(--accent)}.pcomment-textarea:disabled{opacity:.5}.pcomment-form-footer{display:flex;align-items:center;justify-content:flex-end;gap:.5rem}.pcomment-charcount{font-size:var(--text-2xs);color:var(--text-muted)}.pcomment-charcount-max{color:#f87171}.pcomment-submit-btn{font-size:var(--text-sm);font-weight:700;padding:.3rem .85rem;border-radius:5px;border:none;background:var(--accent);color:#0f172a;cursor:pointer;font-family:inherit;-webkit-tap-highlight-color:transparent}.pcomment-submit-btn:disabled{opacity:.4}.pcomment-list{display:flex;flex-direction:column;gap:.5rem}.pcomment-item{background:var(--bg-elevated);border:1px solid var(--border);border-radius:7px;padding:.5rem .65rem;display:flex;flex-direction:column;gap:.25rem}.pcomment-meta{display:flex;align-items:baseline;gap:.4rem}.pcomment-username{font-size:var(--text-xs);font-weight:600;color:var(--accent)}.pcomment-time{font-size:var(--text-2xs);color:var(--text-muted)}.pcomment-body{margin:0;font-size:var(--text-sm);color:var(--text-primary);line-height:1.5;white-space:pre-wrap;word-break:break-word}.pcomment-empty{margin:0;font-size:var(--text-sm);color:var(--text-muted);text-align:center;padding:.5rem 0}.ad-community-card{background:var(--bg-surface);padding:var(--space-3);border-radius:var(--radius-md);border-left:3px solid var(--accent);margin-bottom:var(--space-2)}.ad-community-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.ad-community-stars{font-size:var(--text-sm);color:var(--accent);letter-spacing:1px}.ad-community-reviewer{font-size:var(--text-sm);font-weight:600;color:var(--text-muted)}.ad-community-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5}.ad-cb-avg{font-size:var(--text-sm);font-weight:600;color:var(--accent);background:#f59e0b1a;padding:4px 10px;border-radius:var(--radius-sm);margin-bottom:var(--space-2);display:inline-block}.ad-cb-user-badge{font-size:var(--text-2xs);font-weight:600;color:#a78bfa;background:#a78bfa1f;padding:2px 6px;border-radius:3px;text-transform:capitalize}.ad-cb-votes{font-size:var(--text-xs);color:#34d399;font-weight:500}.ad-allmusic-review{font-size:var(--text-sm);line-height:1.6;color:var(--text-secondary)}.ad-allmusic-review p{margin:0 0 var(--space-2)}.ad-allmusic-link{font-size:var(--text-xs);color:var(--accent);text-decoration:none}.ad-expert-card{background:var(--bg-surface);padding:var(--space-3);border-radius:var(--radius-md);border-left:3px solid #22c55e;margin-bottom:var(--space-2)}.ad-expert-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.ad-expert-name{font-size:var(--text-sm);font-weight:600;color:var(--text-muted)}.ad-expert-sentiment{font-size:var(--text-xs);font-weight:600;padding:3px 10px;border-radius:var(--radius-full);text-transform:capitalize}.ad-sentiment-positive{background:#22c55e26;color:#4ade80}.ad-sentiment-mixed{background:#f59e0b26;color:#fbbf24}.ad-sentiment-negative{background:#ef444426;color:#f87171}.ad-expert-summary{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5}.ad-expert-quote{font-size:var(--text-sm);color:var(--text-muted);font-style:italic;line-height:1.5;padding:var(--space-2) var(--space-3);margin-top:var(--space-2);background:var(--bg-elevated);border-radius:var(--radius-sm);border-left:2px solid var(--border)}.ad-expert-score{font-size:var(--text-xs);color:var(--text-muted);font-weight:600;margin-left:auto}.ad-expert-type{font-size:var(--text-xs);color:var(--text-muted);text-transform:capitalize}.ad-review-footer{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--border)}.ad-review-date{font-size:var(--text-xs);color:var(--text-muted)}.ad-source-link{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:600;color:var(--accent);margin-left:auto}.ad-source-link:active{opacity:.6}.ad-section-badge{font-size:var(--text-xs);font-weight:500;color:var(--text-muted);margin-left:var(--space-2);text-transform:none;letter-spacing:0}.ad-artist-bio{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-2)}.ad-artist-tags{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-bottom:var(--space-2)}.ad-artist-tag{font-size:var(--text-xs);padding:2px var(--space-2);background:var(--bg-elevated);border-radius:var(--radius-full);color:var(--text-muted)}.ad-price-loading{font-size:var(--text-sm);color:var(--accent)}.ad-price-ref{display:flex;align-items:baseline;gap:var(--space-2);padding:var(--space-3);background:#60a5fa14;border:1px solid rgba(96,165,250,.15);border-radius:var(--radius-md);margin-bottom:var(--space-3)}.ad-price-ref-val{font-size:var(--text-lg);font-weight:700;color:var(--text-primary)}.ad-price-ref-source{font-size:var(--text-xs);color:var(--text-muted)}.ad-price-group{margin-bottom:var(--space-3)}.ad-price-group-title{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);margin:0 0 var(--space-2);padding:0}.ad-price-group-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;padding:0;cursor:pointer;color:inherit;font:inherit}.ad-price-chevron{font-size:var(--text-xs);color:var(--text-muted)}.ad-price-note{font-size:var(--text-xs);color:var(--text-muted);font-style:italic;margin:0 0 var(--space-2)}.ad-price-listing{padding:var(--space-2) var(--space-3);background:var(--bg-elevated);border-radius:var(--radius-md);margin-top:var(--space-1);font-size:var(--text-sm)}.ad-price-listing-top{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.ad-price-listing-price{font-weight:700;color:var(--text-primary)}.ad-price-listing-source{color:var(--text-secondary)}.ad-price-listing-cond{font-size:var(--text-xs);color:var(--text-muted);padding:1px 6px;border-radius:3px;background:#ffffff0f}.ad-price-listing-notes{font-size:var(--text-xs);color:var(--text-muted)}.ad-price-listing-bottom{display:flex;gap:var(--space-2);flex-wrap:wrap;font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.ad-price-listing-bottom a{color:var(--accent);text-decoration:none}.ad-listing-exact{border-left:3px solid #4ade80}.ad-listing-likely{border-left:3px solid #facc15}.ad-link-search{color:#eab308!important;font-style:italic}.ad-shipping-free{color:#4ade80}.ad-value-pill{font-size:.65rem;font-weight:600;padding:1px 6px;border-radius:3px;margin-left:auto}.ad-value-below{color:#4ade80;background:#22c55e1f}.ad-value-around{color:var(--text-muted);background:#ffffff0f}.ad-value-above{color:#fbbf24;background:#eab3081f}.ad-price-sources{font-size:var(--text-2xs);color:var(--text-muted);text-align:center;margin-top:var(--space-2);margin-bottom:0}.ad-pressing-owned{border-left:3px solid #22c55e}.ad-owned-badge{font-size:var(--text-xs);font-weight:700;color:#22c55e;background:#22c55e1a;padding:1px 6px;border-radius:4px;margin-right:auto}.ad-taste-badge{font-size:.65rem;font-weight:600;color:#8b5cf6;background:#8b5cf61f;padding:1px 6px;border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.ad-taste-gold{color:#f59e0b;background:#f59e0b26;border:1px solid rgba(245,158,11,.3)}.ad-notes-list{display:flex;flex-direction:column;gap:var(--space-2)}.ad-note-card{background:var(--bg-surface);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius-md);padding:var(--space-3)}.ad-note-header{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-1)}.ad-note-rating{color:var(--accent);font-size:var(--text-sm);letter-spacing:.05em}.ad-note-session{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary)}.ad-note-mood{font-size:var(--text-2xs);background:var(--bg-elevated);color:var(--text-muted);padding:1px 6px;border-radius:4px;text-transform:capitalize}.ad-note-date{font-size:var(--text-2xs);color:var(--text-muted);margin-left:auto}.ad-note-track{font-size:var(--text-xs);color:#7dd3fc;margin-bottom:var(--space-1);font-style:italic}.ad-note-body{margin:0;font-size:var(--text-sm);line-height:1.5;color:var(--text-secondary)}.ad-review-summary{display:flex;align-items:center;justify-content:center;gap:4px;margin:var(--space-2) var(--page-px) 0;padding:6px 12px;background:#f59e0b14;border:1px solid rgba(245,158,11,.25);border-radius:8px;font-size:var(--text-sm);color:#f59e0b;font-weight:500;font-family:inherit}.ad-review-summary:active{background:#f59e0b26}.ad-your-pressing{margin:var(--space-3) var(--page-px) 0;padding:var(--space-3);background:#22c55e0f;border:1px solid rgba(34,197,94,.15);border-radius:var(--radius-md)}.ad-yp-title{font-size:var(--text-xs);font-weight:700;color:#22c55e;text-transform:uppercase;letter-spacing:.5px;margin:0 0 var(--space-2)}.ad-yp-main{display:flex;flex-wrap:wrap;align-items:baseline;gap:var(--space-2)}.ad-yp-label{font-weight:600;font-size:var(--text-base);color:var(--text-primary)}.ad-yp-detail{font-size:var(--text-sm);color:var(--text-secondary)}.ad-yp-signals{display:flex;flex-wrap:wrap;gap:4px;margin-top:var(--space-2)}.ad-yp-signal{font-size:.65rem;color:var(--text-muted);background:#ffffff0f;padding:1px 6px;border-radius:var(--radius-sm)}.ad-yp-taste{margin-top:var(--space-2)}.ad-yp-rating{font-size:var(--text-sm);color:#f59e0b;margin-top:var(--space-1)}.ad-yp-insight{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;margin:var(--space-2) 0 0}.ad-yp-matrix{font-size:var(--text-xs);color:var(--text-muted);font-family:monospace;margin-top:var(--space-1)}.ad-about-album{margin:var(--space-2) var(--page-px) 0;cursor:pointer;-webkit-tap-highlight-color:transparent}.ad-about-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.55;margin:0}.ad-about-truncated{max-height:4.65em;overflow:hidden;position:relative}.ad-about-truncated:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1.5em;background:linear-gradient(transparent,var(--bg-page))}.ad-about-truncated.ad-about-expanded{max-height:none}.ad-about-truncated.ad-about-expanded:after{display:none}.ad-about-toggle{display:inline-block;font-size:var(--text-xs);color:var(--accent);margin-top:var(--space-1)}.ad-about-expanded+.ad-about-toggle:after{content:" less"}.ad-ask-ai-card{margin:var(--space-3) var(--page-px) 0;padding:var(--space-3);background:var(--bg-surface);border:1px solid rgba(139,92,246,.18);border-radius:var(--radius-md)}.ad-intelligence{margin:var(--space-3) var(--page-px) 0;padding:var(--space-3);background:#60a5fa0f;border:1px solid rgba(96,165,250,.15);border-radius:var(--radius-md)}.ad-intelligence-summary{margin:0;font-size:var(--text-sm);color:var(--text-primary);line-height:1.5}.ad-intelligence-meta{display:flex;flex-wrap:wrap;gap:var(--space-1, 4px);margin-top:var(--space-2, 8px)}.ad-intel-chip{font-size:.65rem;color:var(--text-muted);background:#ffffff0f;padding:1px 6px;border-radius:var(--radius-sm)}.ad-intel-aaa{color:var(--audio-aaa);background:#f59e0b1f}.ad-intel-link{color:var(--accent);text-decoration:none;cursor:pointer}.ad-tabs{display:flex;gap:0;margin:var(--space-4) var(--page-px) var(--space-4);border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch}.ad-tab{flex:1;padding:10px 0;font-size:var(--text-sm);font-weight:600;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;font-family:inherit;white-space:nowrap;text-align:center;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;-webkit-tap-highlight-color:transparent;transition:color .15s,border-color .15s}.ad-tab:active{opacity:.7}.ad-tab-active{color:var(--accent);border-bottom-color:var(--accent)}.ad-muted{color:var(--text-muted);font-size:var(--text-sm);text-align:center;padding:var(--space-4) var(--page-px)}.ad-spotify-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .85rem;border-radius:20px;font-size:var(--text-sm);font-weight:600;text-decoration:none;margin:.5rem var(--page-px)}.ad-spotify-direct{background:#1db954;color:#fff}.ad-spotify-search{background:var(--bg-surface);color:#1db954;border:1px solid #1DB95444}.ad-tracks-list{margin:0 var(--page-px);background:var(--bg-surface);border-radius:var(--radius-md);overflow:hidden}.ad-track-row{display:flex;align-items:center;gap:.6rem;padding:.65rem .75rem;border-bottom:1px solid var(--border, #ffffff0d)}.ad-track-row:last-of-type{border-bottom:none}.ad-track-num{width:1.6rem;text-align:right;font-size:var(--text-xs);color:var(--text-muted);flex-shrink:0;font-variant-numeric:tabular-nums}.ad-track-name{flex:1;font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ad-track-dur{font-size:var(--text-xs);color:var(--text-muted);font-variant-numeric:tabular-nums;flex-shrink:0}.ad-track-play,.ad-track-search{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;-webkit-tap-highlight-color:transparent}.ad-track-play:active{background:#1db95422}.ad-track-search:active{background:#1db95418}.ad-tracks-total{padding:.5rem .75rem;font-size:var(--text-xs);color:var(--text-muted);text-align:right;border-top:1px solid var(--border, #ffffff0d)}.ad-tracks-empty{text-align:center;padding:2rem var(--page-px);color:var(--text-muted)}.ad-tracks-empty p{margin-bottom:.75rem;font-size:var(--text-sm)}.ad-verdict{background:var(--bg-elevated);border-radius:var(--radius-md);padding:var(--space-3);margin-bottom:var(--space-3)}.ad-verdict-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.ad-verdict-title{font-size:var(--text-sm);font-weight:700}.ad-verdict-ai-tag{font-size:var(--text-xs);padding:2px 6px;background:#f59e0b1f;border-radius:var(--radius-sm);color:var(--accent)}.ad-verdict-link{margin-left:auto;font-size:var(--text-xs);color:var(--accent);text-decoration:none}.ad-verdict-summary{font-size:var(--text-sm);line-height:1.5;margin:0 0 10px;color:var(--text-secondary)}.ad-verdict-tags{display:flex;flex-wrap:wrap;gap:6px}.ad-verdict-tag{font-size:var(--text-xs);padding:3px 8px;border-radius:var(--radius-sm)}.ad-verdict-tag-sound{background:#14532d;color:#4ade80}.ad-verdict-tag-value{background:#422006;color:#fbbf24}.ad-verdict-tag-collect{background:#1e1b4b;color:#a78bfa}.ad-discussion-item{display:block;text-decoration:none;color:inherit;padding:var(--space-3) 0;border-bottom:1px solid var(--border)}.ad-discussion-meta{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1)}.ad-discussion-source{font-size:var(--text-xs);padding:2px 6px;background:var(--bg-elevated);border-radius:var(--radius-sm)}.ad-discussion-relevance{font-size:var(--text-xs);color:var(--text-muted)}.ad-discussion-title{font-weight:600;font-size:var(--text-sm);margin-bottom:var(--space-1)}.ad-discussion-info{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-1)}.ad-discussion-excerpt{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.4}.ad-discussion-more{margin-top:var(--space-3);text-align:center}.ad-discussion-more a{color:var(--accent);font-size:var(--text-sm)}.ad-wl-pressing{border-bottom:1px solid var(--border);padding-bottom:var(--space-4);margin-bottom:var(--space-4)}.ad-wl-context{margin-bottom:var(--space-3)}.ad-wl-details{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.ad-wl-alert-row{margin-top:var(--space-2)}.ad-wl-alert{font-size:var(--text-xs);color:var(--text-muted);padding:2px 8px;border-radius:var(--radius-sm);background:#ffffff0d}.ad-wl-alert--active{color:#34d399;background:#34d3991a}.ad-wl-listings{display:flex;flex-direction:column;gap:var(--space-2)}.ad-wl-listing{background:var(--surface, rgba(255,255,255,.04));border-radius:var(--radius-md);padding:var(--space-3)}.ad-wl-listing-top{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.ad-wl-listing-price{font-weight:600;font-size:var(--text-base);color:var(--text-primary)}.ad-wl-listing-source{font-size:var(--text-sm);color:var(--text-secondary)}.ad-wl-listing-cond{font-size:var(--text-xs);color:var(--text-muted);padding:1px 6px;border-radius:var(--radius-sm);background:#ffffff0f}.ad-wl-listing-bottom{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;margin-top:var(--space-1);font-size:var(--text-xs);color:var(--text-muted)}.ad-wl-listing-bottom a{color:var(--accent);text-decoration:none}.expert-pick-page{padding:calc(var(--safe-top) + var(--space-6)) var(--page-px) calc(var(--tab-height) + var(--safe-bottom) + var(--page-px));max-width:600px;margin:0 auto}.ep-loading{display:flex;align-items:center;justify-content:center;min-height:60vh}.ep-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:ep-spin .7s linear infinite}@keyframes ep-spin{to{transform:rotate(360deg)}}.ep-error{color:#f87171;text-align:center;padding:var(--space-8);font-size:var(--text-sm)}.ep-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.ep-tag{display:inline-block;padding:.2rem .6rem;border-radius:999px;background:#22c55e26;color:#4ade80;border:1px solid rgba(34,197,94,.3);font-size:var(--text-xs);font-weight:600;letter-spacing:.02em}.ep-score{font-size:var(--text-sm);font-weight:700;color:var(--accent)}.ep-title{font-size:var(--text-xl);font-weight:700;line-height:1.3;color:var(--text-primary);margin:0 0 var(--space-1)}.ep-artist{font-size:var(--text-base);color:var(--text-secondary);margin:0 0 var(--space-3)}.ep-reviewer{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-4);font-size:var(--text-sm)}.ep-reviewer-name{font-weight:600;color:var(--text-primary)}.ep-tier{padding:.1rem .5rem;border-radius:999px;font-size:var(--text-xs);font-weight:600;background:#f59e0b1f;color:var(--accent);border:1px solid rgba(245,158,11,.3)}.ep-date{color:var(--text-muted);font-size:var(--text-xs)}.ep-video-wrap{position:relative;width:100%;padding-top:56.25%;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-3);background:#000}.ep-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:none}.ep-episode{margin-bottom:var(--space-4)}.ep-episode-title{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-2);line-height:1.4}.ep-youtube-link{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:600;color:#f87171;text-decoration:none}.ep-youtube-link:active{opacity:.7}.ep-quote{margin:0 0 var(--space-3);padding:var(--space-3);border-left:3px solid var(--accent);background:#f59e0b0f;border-radius:0 var(--radius-md) var(--radius-md) 0;font-size:var(--text-sm);color:var(--text-secondary);font-style:italic;line-height:1.5}.ep-summary{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;margin:0 0 var(--space-4)}.ep-album-link{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-base);font-weight:600;text-decoration:none;-webkit-tap-highlight-color:transparent}.ep-album-link:active{background:var(--bg-elevated)}.scan-page{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-6))}.scan-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) 0 var(--space-4)}.scan-title{font-size:var(--text-xl);font-weight:700}.scan-history-btn{position:fixed;top:calc(var(--safe-top, 0px) + var(--space-2) + var(--page-px));right:calc(var(--page-px) + 48px);z-index:80;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border);border-radius:50%;box-shadow:0 2px 8px #0003}.scan-history-btn:active{color:var(--accent);background:var(--bg-elevated)}.scan-mode-toggle{display:flex;gap:var(--space-1);background:var(--bg-elevated);border-radius:var(--radius-full);padding:3px;margin-bottom:var(--space-5)}.scan-mode-btn{flex:1;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-weight:600;border-radius:var(--radius-full);color:var(--text-muted);transition:all .2s}.scan-mode-btn.active{background:var(--accent);color:var(--bg-page)}.scan-camera-area{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-elevated);aspect-ratio:4/3;margin-bottom:var(--space-4)}.scan-video{width:100%;height:100%;object-fit:cover}.scan-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.scan-reticle{width:70%;height:40%;border:2px solid var(--accent);border-radius:var(--radius-md);opacity:.7;box-shadow:0 0 0 9999px #0006}.scan-hint{text-align:center;font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-3)}.scan-camera-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:var(--space-3);padding:var(--space-6)}.scan-camera-error{font-size:var(--text-sm);color:var(--text-muted);text-align:center;max-width:280px}.scan-switch-btn{background:var(--accent);color:var(--bg-page);font-weight:600;font-size:var(--text-sm);padding:var(--space-2) var(--space-5);border-radius:var(--radius-full)}.scan-manual-form{padding:var(--space-4) 0}.scan-manual-label{display:block;font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-2)}.scan-manual-row{display:flex;gap:var(--space-2)}.scan-manual-input{flex:1;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-base);color:var(--text-primary);outline:none;transition:border-color .15s}.scan-manual-input:focus{border-color:var(--accent)}.scan-manual-input::placeholder{color:var(--text-muted)}.scan-manual-go{background:var(--accent);color:var(--bg-page);font-weight:700;font-size:var(--text-sm);padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);white-space:nowrap;transition:opacity .15s}.scan-manual-go:disabled{opacity:.4}.scan-manual-hint{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-2)}.scan-location{padding:0 var(--page-px);margin-bottom:var(--space-3)}.scan-location-input{width:100%;padding:var(--space-2) var(--space-3);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-primary);min-height:40px}.scan-location-input:focus{outline:none;border-color:var(--accent)}.scan-location-input::placeholder{color:var(--text-muted)}.scan-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-8) 0}.scan-loading p{font-size:var(--text-sm);color:var(--text-muted)}.scan-camera-fallback-actions{display:flex;flex-direction:column;gap:var(--space-2);width:100%;max-width:280px}.scan-switch-btn-secondary{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border)}.scan-error{margin-top:var(--space-4);padding:var(--space-3) var(--space-4);background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-md);font-size:var(--text-sm);color:#f87171;text-align:center;display:flex;flex-direction:column;gap:var(--space-2)}.scan-error-search-link{background:none;border:none;color:var(--accent);font-size:var(--text-xs);font-weight:600;cursor:pointer;text-align:center;padding:0;text-decoration:underline;text-underline-offset:3px}.scan-search-panel{padding-top:var(--space-2)}.scan-search-input-row{display:flex;align-items:center;gap:var(--space-2);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-3)}.scan-search-icon{color:var(--text-muted);flex-shrink:0}.scan-search-input{flex:1;background:none;border:none;outline:none;font-size:var(--text-base);color:var(--text-primary);min-height:36px}.scan-search-input::placeholder{color:var(--text-muted)}.scan-search-clear{background:none;border:none;color:var(--text-muted);padding:4px;display:flex;align-items:center;flex-shrink:0}.scan-search-hint{font-size:var(--text-xs);color:var(--text-muted);line-height:1.5;margin-bottom:var(--space-4)}.scan-search-loading{display:flex;justify-content:center;padding:var(--space-5) 0}.scan-search-empty{font-size:var(--text-sm);color:var(--text-muted);text-align:center;padding:var(--space-5) 0}.scan-search-results{display:flex;flex-direction:column;gap:2px}.scan-search-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--border)}.scan-search-row:last-child{border-bottom:none}.scan-search-cover{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated);cursor:pointer}.scan-search-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;cursor:pointer}.scan-search-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scan-search-artist{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scan-search-year{font-size:var(--text-xs);color:var(--text-muted)}.scan-search-add-btn{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border);background:var(--bg-elevated);color:var(--text-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,border-color .15s}.scan-search-add-btn.added{background:#22c55e26;border-color:#22c55e66;color:#22c55e}.scan-search-add-btn:not(.added):not(:disabled):active{background:var(--accent);border-color:var(--accent);color:var(--bg-page)}.scan-search-add-btn:disabled:not(.added){opacity:.4}.scan-search-add-spinner{width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}.sr-page{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-6))}.sr-back{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:600;color:var(--text-muted);padding:var(--space-2) 0;margin-bottom:var(--space-3);transition:color .15s}.sr-back:active{color:var(--accent)}.sr-empty{display:flex;align-items:center;justify-content:center;padding:var(--space-8) 0;color:var(--text-muted);font-size:var(--text-sm)}.sr-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-5)}.sr-hero{display:flex;gap:var(--space-4);margin-bottom:var(--space-4)}.sr-cover{width:100px;height:100px;border-radius:var(--radius-md);object-fit:cover;background:var(--bg-elevated);flex-shrink:0}.sr-hero-info{flex:1;min-width:0}.sr-title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);line-height:1.3;margin-bottom:var(--space-1)}.sr-artist{font-size:var(--text-base);color:var(--text-secondary)}.sr-label{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1)}.sr-country{font-size:var(--text-sm);color:var(--text-muted)}.sr-badges{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-4)}.sr-format-badge{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-full);padding:2px var(--space-3)}.sr-status-badge{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius-full);padding:2px var(--space-3)}.sr-owned{background:#22c55e26;color:#22c55e}.sr-wished{background:#f59e0b26;color:var(--accent)}.sr-intel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:var(--space-3);margin-bottom:var(--space-4)}.sr-intel-item{display:flex;flex-direction:column;align-items:center;background:var(--bg-elevated);border-radius:var(--radius-md);padding:var(--space-3)}.sr-intel-label{font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--space-1)}.sr-intel-value{font-size:var(--text-lg);font-weight:700;color:var(--text-primary)}.sr-story{border-top:1px solid var(--border);padding-top:var(--space-3);margin-bottom:var(--space-4)}.sr-story-title{font-size:var(--text-sm);font-weight:700;color:var(--text-secondary);margin-bottom:var(--space-2)}.sr-story-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6}.sr-actions{display:flex;flex-direction:column;gap:var(--space-2)}.sr-action-btn{display:block;text-align:center;font-weight:700;font-size:var(--text-sm);padding:var(--space-3);border-radius:var(--radius-md);transition:opacity .15s}.sr-action-btn:active{opacity:.8}.sr-action-primary{background:var(--accent);color:var(--bg-page)}.sr-action-secondary{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary)}.sr-others{margin-bottom:var(--space-5)}.sr-others-title{font-size:var(--text-sm);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-3)}.sr-other-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-2);text-align:left}.sr-other-item:active{background:var(--bg-elevated)}.sr-other-cover{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-elevated);flex-shrink:0}.sr-other-info{flex:1;min-width:0;display:flex;flex-direction:column}.sr-other-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sr-other-artist{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sr-other-meta{font-size:var(--text-xs);color:var(--text-muted)}.sr-other-grade{font-size:var(--text-sm);font-weight:700;flex-shrink:0}.sr-action-add{background:var(--accent)!important;color:#000!important;font-weight:600}.sr-action-add:disabled{opacity:.6}.sr-action-added{background:#22c55e26!important;color:#4ade80!important;font-weight:600;text-align:center}.sr-action-master{background:var(--bg-elevated)!important;color:var(--text-muted)!important;border:1px solid var(--border)!important;font-size:var(--text-xs)!important;font-weight:500;padding:var(--space-2) var(--space-3)!important}.sr-action-master:disabled{opacity:.5}.sr-action-master:not(:disabled):active{background:var(--bg-surface)!important}.sr-enrich{border-top:1px solid var(--border);margin-top:var(--space-4);padding-top:var(--space-3);display:flex;flex-direction:column;gap:var(--space-3)}.sr-enrich-row{display:flex;flex-direction:column;gap:2px}.sr-enrich-label{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.sr-enrich-value{display:flex;flex-direction:column;gap:1px}.sr-enrich-primary{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.sr-enrich-secondary{font-size:var(--text-xs);color:var(--text-muted)}.sr-enrich-prices{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:baseline}.sr-price-item{font-size:var(--text-base);font-weight:700;color:var(--text-primary)}.sr-price-label{font-size:var(--text-xs);font-weight:500;color:var(--text-muted);margin-right:3px}.sr-enrich-tags{display:flex;flex-wrap:wrap;gap:var(--space-1)}.sr-enrich-tag{font-size:var(--text-xs);font-weight:600;padding:2px var(--space-2);background:#f59e0b1a;color:var(--accent);border-radius:var(--radius-full);border:1px solid rgba(245,158,11,.2)}.sr-enrich-source{font-size:var(--text-xs);font-weight:500;color:var(--text-muted);margin-left:var(--space-2)}.sr-enrich-reviews{display:flex;flex-direction:column;gap:var(--space-2)}.sr-enrich-review{display:flex;flex-wrap:wrap;align-items:baseline;gap:var(--space-1)}.sr-enrich-reviewer{font-size:var(--text-xs);font-weight:700;color:var(--text-primary)}.sr-enrich-sentiment{font-size:var(--text-2xs);font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:1px var(--space-2);border-radius:var(--radius-full)}.sr-sentiment-positive{background:#22c55e26;color:#22c55e}.sr-sentiment-mixed{background:#f59e0b26;color:#f59e0b}.sr-sentiment-negative{background:#ef444426;color:#ef4444}.sr-enrich-quote{font-size:var(--text-xs);color:var(--text-secondary);font-style:italic;line-height:1.5;width:100%}.sr-enrich-shimmer{height:16px;width:70%;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--bg-elevated) 25%,rgba(255,255,255,.06) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:sr-shimmer 1.5s infinite ease-in-out}@keyframes sr-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sr-enrich-top{border-top:none;margin-top:0;padding-top:0}.sr-have-want{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) 0;border-top:1px solid var(--border);margin-top:var(--space-3)}.sr-have-want-label{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.sr-have-want-stat{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary)}.sr-have-want-divider{font-size:var(--text-sm);color:var(--text-muted)}.sr-deep-actions{border-top:1px solid var(--border);margin-top:var(--space-4);padding-top:var(--space-3)}.sr-deep-actions-title{font-size:var(--text-sm);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-3)}.sr-deep-actions-grid{display:flex;flex-direction:column;gap:var(--space-3)}.sr-action-deep{display:flex;flex-direction:column;gap:var(--space-2)}.sr-action-deep-btn{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);text-align:left;transition:all .15s}.sr-action-deep-btn:active:not(:disabled){background:var(--bg-surface);border-color:var(--accent)}.sr-action-deep-btn:disabled{opacity:.5}.sr-action-deep-done{border-color:#22c55e4d;opacity:.6!important}.sr-action-deep-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:var(--text-base);font-weight:700;color:var(--accent);background:#f59e0b1a;border-radius:var(--radius-sm);flex-shrink:0}.sr-action-deep-spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:sr-spin .6s linear infinite;margin:3px;flex-shrink:0}@keyframes sr-spin{to{transform:rotate(360deg)}}.sr-action-deep-error{font-size:var(--text-xs);color:var(--text-muted);font-style:italic;padding:0 var(--space-2)}.sr-action-deep-result{padding:var(--space-3);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md)}.sr-deep-prices{display:flex;flex-direction:column;gap:var(--space-1)}.sr-deep-prices-row{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:baseline}.sr-deep-timestamp{font-size:var(--text-2xs);color:var(--text-muted);font-style:italic;margin-top:var(--space-1)}.sr-deep-reviews,.sr-deep-discussions{display:flex;flex-direction:column;gap:var(--space-3)}.sr-deep-section{display:flex;flex-direction:column;gap:var(--space-2)}.sr-deep-section-title{font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.sr-deep-forum-post{display:flex;flex-direction:column;gap:2px;padding:var(--space-2);background:var(--bg-surface);border-radius:var(--radius-sm)}.sr-deep-forum-header{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:baseline}.sr-deep-forum-source{font-size:var(--text-xs);font-weight:700;color:var(--accent);text-transform:uppercase}.sr-deep-forum-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);text-decoration:none}a.sr-deep-forum-title:active{color:var(--accent)}.sr-deep-forum-snippet{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.sr-deep-verdict{display:flex;flex-direction:column;gap:var(--space-2)}.sr-deep-verdict-confidence{font-size:var(--text-2xs);font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px var(--space-2);border-radius:var(--radius-full);width:fit-content}.sr-confidence-high{background:#22c55e26;color:#22c55e}.sr-confidence-medium{background:#f59e0b26;color:#f59e0b}.sr-confidence-low{background:#9ca3af26;color:#9ca3af}.sr-deep-verdict-text{font-size:var(--text-sm);color:var(--text-primary);line-height:1.6}.sr-deep-verdict-list{display:flex;flex-direction:column;gap:2px}.sr-deep-verdict-pro{font-size:var(--text-xs);color:#22c55e;line-height:1.5}.sr-deep-verdict-con{font-size:var(--text-xs);color:#ef4444;line-height:1.5}.sr-share-section{margin-top:var(--space-4);background:var(--bg-surface);border-radius:var(--radius-md);overflow:hidden}.sr-share-toggle{width:100%;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);background:none;border:none;color:inherit;text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent}.sr-share-toggle:active{opacity:.8}.sr-share-icon{font-size:24px;flex-shrink:0}.sr-share-text{flex:1;display:flex;flex-direction:column}.sr-share-text strong{font-size:var(--text-sm);color:var(--text-primary)}.sr-share-text span{font-size:var(--text-xs);color:var(--text-muted);line-height:1.4}.sr-share-match-badge{font-size:var(--text-xs);font-weight:600;color:#22c55e;background:#22c55e1a;padding:2px 8px;border-radius:10px;white-space:nowrap}.sr-share-chevron{flex-shrink:0;transition:transform .2s}.sr-share-chevron.open{transform:rotate(180deg)}.sr-share-form{padding:0 var(--space-3) var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.sr-share-input{width:100%;padding:10px 12px;background:#ffffff0f;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-sm)}.sr-share-input::placeholder{color:var(--text-muted)}.sr-share-row{display:flex;gap:var(--space-2)}.sr-share-price{flex:1}.sr-share-select{flex:1;-moz-appearance:none;appearance:none;-webkit-appearance:none}.sr-share-submit{padding:12px;background:var(--accent);color:#000;font-weight:600;font-size:var(--text-sm);border:none;border-radius:var(--radius-sm);cursor:pointer}.sr-share-submit:active{opacity:.8}.sr-share-submit:disabled{opacity:.5}.sr-share-done{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);color:#22c55e;font-size:var(--text-sm);font-weight:600}.sr-share-done-icon{font-size:20px}.sr-share-alerts{font-size:var(--text-xs);color:#22c55e;margin-left:auto}.sr-barcode-ref{font-size:var(--text-xs);color:var(--text-muted);text-align:center;padding:var(--space-3) 0}.sh-page{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-6))}.sh-loading{display:flex;align-items:center;justify-content:center;min-height:50vh}.sh-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0 var(--space-5)}.sh-back{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);border-radius:var(--radius-full)}.sh-back:active{color:var(--accent)}.sh-title{font-size:var(--text-xl);font-weight:700;flex:1}.sh-clear{font-size:var(--text-xs);font-weight:600;color:#ef4444;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:#ef44441a}.sh-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-8) 0;color:var(--text-muted)}.sh-empty p{font-size:var(--text-sm)}.sh-scan-btn{background:var(--accent);color:var(--bg-page);font-weight:700;font-size:var(--text-sm);padding:var(--space-2) var(--space-5);border-radius:var(--radius-full)}.sh-list{display:flex;flex-direction:column;gap:var(--space-2)}.sh-item{display:flex;align-items:center;gap:var(--space-1);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md)}.sh-item-main{flex:1;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);text-align:left;min-width:0}.sh-item-main:active{background:var(--bg-elevated);border-radius:var(--radius-md)}.sh-cover{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-elevated);flex-shrink:0}.sh-info{flex:1;min-width:0;display:flex;flex-direction:column}.sh-item-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sh-item-artist{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sh-item-meta{font-size:var(--text-xs);color:var(--text-muted)}.sh-right{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-1);flex-shrink:0}.sh-grade{font-size:var(--text-xs);font-weight:700;padding:1px var(--space-2);border-radius:var(--radius-full)}.sh-grade-aplus{color:var(--grade-aplus);background:#f59e0b26}.sh-grade-a{color:var(--grade-a);background:#22c55e26}.sh-grade-b{color:var(--grade-b);background:#3b82f626}.sh-grade-c{color:var(--grade-c);background:#94a3b826}.sh-grade-d{color:var(--grade-d);background:#ef444426}.sh-time{font-size:var(--text-xs);color:var(--text-muted)}.sh-delete{width:36px;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0;transition:color .15s}.sh-delete:active{color:#ef4444}.frc-page{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-6))}.frc-loading{display:flex;align-items:center;justify-content:center;min-height:30vh}.frc-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0 var(--space-4)}.frc-back{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);border-radius:var(--radius-full);flex-shrink:0}.frc-back:active{color:var(--accent)}.frc-header-info{flex:1;min-width:0}.frc-title{font-size:var(--text-lg);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.frc-count{font-size:var(--text-xs);color:var(--text-muted)}.frc-sync{font-size:var(--text-xs);font-weight:600;color:var(--accent);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:#f59e0b1a;flex-shrink:0}.frc-sync:disabled{opacity:.5}.frc-stats{margin-bottom:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.frc-stats-row{display:flex;gap:var(--space-2)}.frc-stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--space-3) var(--space-2);background:var(--bg-elevated);border-radius:var(--radius-md)}.frc-stat-val{font-size:var(--text-lg);font-weight:700;color:var(--accent)}.frc-stat-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}.frc-overlap{background:var(--bg-elevated);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4)}.frc-overlap-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.frc-overlap-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.frc-overlap-pct{font-size:var(--text-lg);font-weight:700;color:var(--accent)}.frc-overlap-bars{display:flex;flex-direction:column;gap:var(--space-2)}.frc-overlap-item{display:flex;align-items:center;gap:var(--space-2)}.frc-overlap-dot{width:10px;height:10px;border-radius:var(--radius-full);flex-shrink:0}.frc-overlap-dot.exact{background:#86efac}.frc-overlap-dot.fuzzy{background:#7dd3fc}.frc-overlap-label{flex:1;font-size:var(--text-sm);color:var(--text-secondary)}.frc-overlap-val{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.frc-search-form{margin-bottom:var(--space-4)}.frc-search{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-primary);outline:none}.frc-search:focus{border-color:var(--accent)}.frc-search::placeholder{color:var(--text-muted)}.frc-error{padding:var(--space-3);margin-bottom:var(--space-3);background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-md);font-size:var(--text-sm);color:#f87171}.frc-empty{text-align:center;padding:var(--space-8) 0;color:var(--text-muted);font-size:var(--text-sm)}.frc-list{display:flex;flex-direction:column;gap:var(--space-1)}.frc-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2) var(--space-3);text-align:left;border-radius:var(--radius-md);-webkit-tap-highlight-color:transparent}.frc-item:active{background:var(--bg-elevated)}.frc-cover{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-elevated);flex-shrink:0}.frc-info{flex:1;min-width:0;display:flex;flex-direction:column}.frc-item-title{font-size:var(--text-sm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.frc-item-artist{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.frc-item-meta{font-size:var(--text-xs);color:var(--text-muted)}.frc-rating{font-size:var(--text-sm);font-weight:600;color:var(--accent);flex-shrink:0}.frc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.frc-grid-item{display:flex;flex-direction:column;align-items:flex-start;text-align:left;border-radius:var(--radius-md);overflow:hidden;-webkit-tap-highlight-color:transparent}.frc-grid-item:active{opacity:.75}.frc-grid-cover{width:100%;aspect-ratio:1;object-fit:cover;background:var(--bg-elevated);border-radius:var(--radius-sm);margin-bottom:var(--space-1)}.frc-grid-title{font-size:var(--text-xs);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;padding:0 2px}.frc-grid-artist{font-size:var(--text-2xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;padding:0 2px}.onboarding-page{display:flex;flex-direction:column;align-items:center;padding:var(--space-6) var(--space-4);min-height:100dvh}.onboarding-hero{text-align:center;margin-bottom:var(--space-6);padding-top:var(--space-6)}.onboarding-title{font-size:var(--text-xl);font-weight:700;margin:var(--space-4) 0 var(--space-2)}.onboarding-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin:0}.onboarding-message{padding:var(--space-2) var(--space-4);background:#34d3991a;color:#34d399;border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--space-4);text-align:center;width:100%;max-width:400px}.onboarding-syncing{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:#f59e0b1a;color:var(--accent);border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--space-4);width:100%;max-width:400px}.onboarding-syncing .spinner{width:18px;height:18px;flex-shrink:0}.onboarding-card{width:100%;max-width:400px;padding:var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--space-3)}.onboarding-card.done{border-color:#22c55e4d;background:#22c55e0d}.onboarding-card-header{display:flex;gap:var(--space-3);align-items:flex-start;margin-bottom:var(--space-3)}.onboarding-step-num{width:28px;height:28px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:700;color:var(--accent);flex-shrink:0}.onboarding-card.done .onboarding-step-num{background:#22c55e26;border-color:#22c55e4d;color:#22c55e}.onboarding-card-title{font-size:var(--text-base);font-weight:600;margin:0 0 4px}.onboarding-card-desc{font-size:var(--text-sm);color:var(--text-muted);margin:0;line-height:1.4}.onboarding-btn{width:100%;padding:var(--space-3);border-radius:var(--radius-md);border:none;font-size:var(--text-sm);font-weight:600;cursor:pointer;min-height:44px}.onboarding-btn.primary{background:var(--accent);color:var(--bg-page)}.onboarding-btn.secondary{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary)}.onboarding-btn:active{opacity:.8}.onboarding-optional{font-size:var(--text-xs);color:var(--text-muted);text-align:center;margin:var(--space-2) 0 0}.onboarding-alt{width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center}.onboarding-alt-divider{display:flex;align-items:center;gap:var(--space-3);width:100%;margin:var(--space-2) 0 var(--space-4);color:var(--text-muted);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.07em}.onboarding-alt-divider:before,.onboarding-alt-divider:after{content:"";flex:1;height:1px;background:var(--border)}.onboarding-alt-card{width:100%;border-style:dashed;opacity:.9}.onboarding-alt-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0}.onboarding-skip{margin-top:var(--space-4);font-size:var(--text-xs);color:var(--text-muted);background:none;border:none;padding:var(--space-2);text-decoration:underline;text-underline-offset:3px;cursor:pointer}.onboarding-skip:active{opacity:.6}.digest-settings{padding-bottom:100px}.digest-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1.25rem}.digest-header h1{font-size:var(--text-lg);margin:0}.digest-back{background:none;border:none;color:var(--text-primary);padding:4px;cursor:pointer}.digest-error{background:#dc323226;color:#f87171;padding:.75rem;border-radius:8px;font-size:var(--text-sm);margin-bottom:1rem}.digest-success{background:#32b45026;color:#6fcc6f;padding:.75rem;border-radius:8px;font-size:var(--text-sm);margin-bottom:1rem}.digest-form{display:flex;flex-direction:column;gap:1rem}.digest-toggle-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-surface);border-radius:10px;font-size:var(--text-base);font-weight:500}.digest-toggle-row input[type=checkbox]{width:20px;height:20px;accent-color:var(--accent, #d4a853)}.digest-field{display:flex;flex-direction:column;gap:.35rem}.digest-field label{font-size:var(--text-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding-left:.25rem}.digest-field input,.digest-field select{padding:.7rem .85rem;background:var(--bg-surface);border:1px solid var(--border, #333);border-radius:10px;color:var(--text-primary);font-size:var(--text-base);-webkit-appearance:none}.digest-field select{background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.digest-sections{display:flex;flex-direction:column;gap:.35rem}.digest-sections-label{font-size:var(--text-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding-left:.25rem;margin-bottom:.25rem}.digest-section-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .85rem;background:var(--bg-surface);border-radius:10px;cursor:pointer;transition:background .15s}.digest-section-item.active{background:#f59e0b14}.digest-section-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent, #d4a853);flex-shrink:0}.digest-section-text{display:flex;flex-direction:column;min-width:0}.digest-section-name{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.digest-section-desc{font-size:var(--text-sm);color:var(--text-muted);margin-top:1px}.digest-actions{display:flex;gap:.75rem;margin-top:.5rem}.digest-save-btn{flex:1;padding:.75rem;background:var(--accent, #d4a853);color:#111;border:none;border-radius:10px;font-size:var(--text-base);font-weight:600;cursor:pointer}.digest-save-btn:disabled{opacity:.6}.digest-test-btn{flex:1;padding:.75rem;background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border, #333);border-radius:10px;font-size:var(--text-base);cursor:pointer}.pers-page{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-6))}.pers-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.pers-header .page-title{margin:0}.pers-back{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);padding:0}.pers-desc{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-5);line-height:1.5}.pers-loading{color:var(--text-muted);font-size:var(--text-sm)}.pers-group{margin-bottom:var(--space-5)}.pers-group-title{font-size:var(--text-base);font-weight:600;margin:0 0 var(--space-2)}.pers-count{font-weight:400;color:var(--accent);font-size:var(--text-sm)}.pers-empty{font-size:var(--text-sm);color:var(--text-muted)}.pers-tier{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;margin-bottom:var(--space-2)}.pers-tier-header{width:100%;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-surface);border:none;color:var(--text-primary);font-size:var(--text-sm);-webkit-tap-highlight-color:transparent}.pers-tier-badge{font-weight:600;font-size:var(--text-xs);padding:2px 8px;border-radius:4px}.tier-s{background:#f59e0b26;color:var(--accent)}.tier-a{background:#4ade8026;color:#4ade80}.tier-b{background:#38bdf826;color:#38bdf8}.tier-c{background:#a1a1aa26;color:#a1a1aa}.pers-tier-sel{font-size:var(--text-xs);color:var(--accent)}.pers-tier-arrow{margin-left:auto;color:var(--text-muted)}.pers-tier-items{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-2) var(--space-3) var(--space-3)}.pers-chip{font-size:var(--text-sm);padding:6px 14px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);-webkit-tap-highlight-color:transparent;transition:all .15s}.pers-chip.active{background:#f59e0b26;border-color:var(--accent);color:var(--accent);font-weight:600}.pers-pills{display:flex;gap:var(--space-2);flex-wrap:wrap}.pers-pill{font-size:var(--text-sm);padding:8px 18px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);-webkit-tap-highlight-color:transparent;min-height:40px}.pers-pill.active{background:#f59e0b26;border-color:var(--accent);color:var(--accent);font-weight:600}.pers-hint{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.pers-alert-toggle{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.pers-alert-toggle input[type=checkbox]{width:20px;height:20px;accent-color:var(--accent)}.pers-textarea{width:100%;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);padding:var(--space-3);font-size:var(--text-sm);font-family:inherit;resize:vertical}.pers-textarea::placeholder{color:var(--text-muted)}.pers-textarea:focus{outline:none;border-color:var(--accent)}.pers-actions{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-4)}.pers-save-btn{width:100%;padding:var(--space-3);background:var(--accent);color:var(--bg-page);border:none;border-radius:var(--radius-md);font-weight:600;font-size:var(--text-sm);min-height:48px}.pers-save-btn:disabled{opacity:.6}.pers-save-btn:active{opacity:.8}.pers-success{color:#22c55e;font-size:var(--text-sm)}.pers-error{color:#f87171;font-size:var(--text-sm)}.pers-alert-section{margin-bottom:var(--space-4)}.pers-alert-subtitle{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-2)}.pers-alert-criteria{display:flex;flex-direction:column;gap:var(--space-2)}.pers-alert-row{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);padding:var(--space-2) var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md, 8px)}.pers-alert-icon{font-size:var(--text-base);min-width:24px;text-align:center;color:var(--accent)}.pers-alert-count{margin-left:auto;font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap}.admin-hub{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-6))}.admin-hub-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4)}.admin-hub-header .page-title{margin:0;flex:1}.admin-env-badge{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);background:var(--bg-elevated);padding:2px 8px;border-radius:var(--radius-sm);text-transform:lowercase;letter-spacing:.03em;flex-shrink:0}.admin-back{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);padding:0}.admin-grid{display:flex;flex-direction:column;gap:var(--space-2)}.admin-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}.admin-card:active{background:var(--bg-elevated)}.admin-card-icon{font-size:var(--text-xl);flex-shrink:0;width:32px;text-align:center}.admin-card-body{flex:1;min-width:0}.admin-card-label{font-size:var(--text-base);font-weight:600}.admin-card-desc{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.admin-card svg{color:var(--text-muted);flex-shrink:0}.admin-hub-stats{display:flex;align-items:center;flex-wrap:wrap;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);gap:var(--space-1) 0}.admin-hub-stat{display:flex;flex-direction:column;align-items:center;gap:2px;padding:0 var(--space-3)}.admin-hub-stat:first-child{padding-left:0}.admin-hub-stat-val{font-size:var(--text-sm);font-weight:700}.admin-hub-stat-lbl{font-size:.62rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.admin-hub-stat-div{width:1px;height:28px;background:var(--border);flex-shrink:0}.admin-tiles{display:flex;flex-direction:column;gap:var(--space-2)}.admin-tile{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.admin-tile-head{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}.admin-tile-head:active{background:var(--bg-elevated)}.admin-tile-head svg{color:var(--text-muted);flex-shrink:0}.admin-tile-icon{font-size:var(--text-xl);flex-shrink:0;width:32px;text-align:center}.admin-tile-meta{flex:1;min-width:0}.admin-tile-title{font-size:var(--text-base);font-weight:700}.admin-tile-desc{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.admin-tile-sub{display:flex;flex-wrap:wrap;gap:var(--space-1);padding:var(--space-2) var(--space-4) var(--space-3);border-top:1px solid var(--border)}.admin-tile-pill{font-size:var(--text-xs);font-weight:500;color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px 10px;text-decoration:none;-webkit-tap-highlight-color:transparent}.admin-tile-pill:active{color:var(--accent);border-color:var(--accent)}.admin-sub{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-6))}.admin-sub-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4)}.admin-sub-header .page-title{margin:0;font-size:var(--text-lg)}.admin-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--space-2);margin-bottom:var(--space-4)}.admin-stat{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);text-align:center}.admin-stat-val{display:block;font-size:var(--text-lg);font-weight:700;color:var(--accent)}.admin-stat-lbl{font-size:var(--text-xs);color:var(--text-muted)}.admin-section{margin-bottom:var(--space-5)}.admin-section-title{font-size:var(--text-sm);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}.admin-list{display:flex;flex-direction:column;gap:var(--space-2)}.admin-list-item{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3)}.admin-list-row{display:flex;justify-content:space-between;align-items:center;gap:var(--space-2)}.admin-list-primary{font-size:var(--text-sm);font-weight:500}.admin-list-secondary{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.admin-list-badge{font-size:var(--text-xs);font-weight:600;padding:2px 8px;border-radius:var(--radius-full);flex-shrink:0}.admin-badge-success{background:#22c55e26;color:#4ade80}.admin-badge-error{background:#ef444426;color:#f87171}.admin-badge-warn{background:#f59e0b26;color:#fbbf24}.admin-badge-info{background:#38bdf826;color:#38bdf8}.admin-badge-muted{background:var(--bg-elevated);color:var(--text-muted)}.admin-btn{padding:var(--space-2) var(--space-4);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-surface);color:var(--text-primary);font-size:var(--text-sm);font-weight:500;min-height:40px;-webkit-tap-highlight-color:transparent}.admin-btn:active{background:var(--bg-elevated)}.admin-btn:disabled{opacity:.5}.admin-btn-accent{background:var(--accent);color:var(--bg-page);border-color:var(--accent)}.admin-search-row{display:flex;gap:var(--space-2);margin-bottom:var(--space-3)}.admin-search{flex:1;padding:var(--space-2) var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm)}.admin-search::placeholder{color:var(--text-muted)}.admin-filter-row{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-3)}.admin-filter{padding:6px 14px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);font-size:var(--text-xs);font-weight:500;-webkit-tap-highlight-color:transparent}.admin-filter.active{background:#f59e0b26;border-color:var(--accent);color:var(--accent)}.admin-empty{font-size:var(--text-sm);color:var(--text-muted);text-align:center;padding:var(--space-6)}.admin-error{font-size:var(--text-sm);color:#f87171;text-align:center;padding:var(--space-4)}.admin-loading{font-size:var(--text-sm);color:var(--text-muted);text-align:center;padding:var(--space-6)}.admin-detail{margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--border)}.admin-detail-row{display:flex;gap:var(--space-2);font-size:var(--text-xs);margin-bottom:4px}.admin-detail-label{color:var(--text-muted);min-width:60px;flex-shrink:0}.admin-detail-value{color:var(--text-secondary);word-break:break-all}.admin-toggle{width:44px;height:24px;border-radius:12px;border:none;background:var(--bg-elevated);position:relative;padding:0;-webkit-tap-highlight-color:transparent;transition:background .2s}.admin-toggle.on{background:#22c55e}.admin-toggle:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s}.admin-toggle.on:after{transform:translate(20px)}.admin-pagination{display:flex;justify-content:center;align-items:center;gap:var(--space-3);margin-top:var(--space-4)}.admin-page-info{font-size:var(--text-xs);color:var(--text-muted)}.flw-page{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-8))}.flw-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.flw-avatar--lg{width:44px;height:44px;font-size:18px}.flw-feed-list{display:flex;flex-direction:column;gap:var(--space-3)}.flw-feed-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.flw-feed-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-3) var(--space-2);gap:var(--space-2)}.flw-feed-actor{display:flex;align-items:center;gap:var(--space-2);background:none;border:none;padding:0;cursor:pointer;text-align:left;min-width:0;flex:1}.flw-feed-actor-body{display:flex;flex-direction:column;min-width:0}.flw-feed-name{font-size:var(--text-sm);font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.flw-feed-action{font-size:var(--text-xs);color:var(--text-muted)}.flw-feed-time{font-size:var(--text-xs);color:var(--text-muted);flex-shrink:0}.flw-feed-album{display:flex;align-items:center;gap:var(--space-3);width:100%;background:none;border:none;border-top:1px solid var(--border);padding:var(--space-2) var(--space-3);cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent}.flw-feed-album:disabled{cursor:default}.flw-feed-album:not(:disabled):active{background:#ffffff08}.flw-feed-cover{width:44px;height:44px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg)}.flw-feed-album-body{flex:1;min-width:0}.flw-feed-album-title{font-size:var(--text-sm);font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.flw-feed-album-sub{font-size:var(--text-xs);color:var(--text-muted);margin-top:1px}.flw-feed-album-arrow{color:var(--text-muted);flex-shrink:0}.flw-following-list,.flw-find-grid{display:flex;flex-direction:column;gap:var(--space-2)}.flw-collector-card{display:flex;align-items:center;gap:var(--space-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3);width:100%;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent}.flw-collector-card:active{opacity:.85}.flw-collector-body{flex:1;min-width:0}.flw-collector-name{font-size:var(--text-sm);font-weight:600;color:var(--text);margin-bottom:2px}.flw-collector-location{display:flex;align-items:center;gap:3px;font-size:var(--text-xs);color:var(--text-muted);margin-bottom:2px}.flw-collector-count{font-size:var(--text-xs);color:var(--text-muted)}.flw-collector-bio{font-size:var(--text-xs);color:var(--text-muted);margin:var(--space-1) 0 0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.flw-collector-arrow{color:var(--text-muted);flex-shrink:0}.flw-search-row{margin-bottom:var(--space-4)}.flw-search-input{width:100%;box-sizing:border-box;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:var(--text-sm);padding:var(--space-2) var(--space-3);outline:none}.flw-search-input:focus{border-color:var(--accent)}.flw-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-10) var(--space-4);color:var(--text-muted)}.flw-empty-icon{margin-bottom:var(--space-3);opacity:.5}.flw-empty-title{font-size:var(--text-base);font-weight:600;color:var(--text);margin:0 0 var(--space-1)}.flw-empty-sub{font-size:var(--text-sm);color:var(--text-muted);line-height:1.5;margin:0 0 var(--space-4);max-width:280px}.flw-empty-cta{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;padding:var(--space-2) var(--space-5);cursor:pointer}.flw-skeleton-list{display:flex;flex-direction:column;gap:var(--space-3)}.flw-skeleton-card{display:flex;align-items:center;gap:var(--space-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3)}.flw-skeleton-avatar{width:44px;height:44px;border-radius:50%;background:var(--bg);animation:flw-shimmer 1.4s ease-in-out infinite;flex-shrink:0}.flw-skeleton-body{flex:1;display:flex;flex-direction:column;gap:var(--space-1)}.flw-skeleton-bar{height:12px;border-radius:6px;background:var(--bg);animation:flw-shimmer 1.4s ease-in-out infinite;width:120px}.flw-skeleton-bar.wide{width:180px;height:14px}@keyframes flw-shimmer{0%,to{opacity:.4}50%{opacity:.8}}.pgd-page{padding-bottom:calc(var(--tab-height) + var(--space-4))}.pgd-back{display:inline-flex;align-items:center;gap:var(--space-1);color:var(--accent);font-size:var(--text-sm);text-decoration:none;margin-bottom:var(--space-3)}.pgd-hero{display:flex;gap:var(--space-4);margin-bottom:var(--space-4)}.pgd-hero-cover{width:96px;height:96px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0}.pgd-hero-info{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}.pgd-hero-title{font-size:var(--text-lg);font-weight:700;margin:0;line-height:1.2}.pgd-hero-artist{font-size:var(--text-base);color:var(--text-secondary);margin:var(--space-1) 0 0}.pgd-hero-year{font-size:var(--text-sm);color:var(--text-muted);margin:2px 0 0}.pgd-hero-actions{display:flex;gap:var(--space-2);margin-top:var(--space-2);align-items:center}.pgd-action-link{font-size:var(--text-sm);color:var(--accent);text-decoration:none;padding:var(--space-1) var(--space-2);border:1px solid var(--accent);border-radius:var(--radius-sm)}.pgd-stats{display:flex;gap:var(--space-4);padding:var(--space-2) 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:var(--space-4);flex-wrap:wrap}.pgd-stat{display:flex;flex-direction:column;align-items:center}.pgd-stat-val{font-size:var(--text-base);font-weight:700}.pgd-stat-label{font-size:var(--text-xs);color:var(--text-muted)}.pgd-stat-owned .pgd-stat-val{font-size:var(--text-xs);color:#4ade80;background:#14532d;padding:2px var(--space-2);border-radius:var(--radius-sm)}.pgd-verdict{background:var(--bg-elevated);border-radius:var(--radius-md);padding:var(--space-3);margin-bottom:var(--space-4)}.pgd-verdict-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.pgd-verdict-header h2{font-size:var(--text-base);margin:0}.pgd-ai-badge{font-size:var(--text-2xs);padding:2px var(--space-1);background:#f59e0b1f;border-radius:var(--radius-sm);color:var(--accent)}.pgd-verdict-summary{font-size:var(--text-sm);line-height:1.5;color:var(--text-secondary);margin:0 0 var(--space-3)}.pgd-verdict-picks{display:flex;flex-direction:column;gap:var(--space-2)}.pgd-pick{padding:var(--space-2) var(--space-2);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:2px}.pgd-pick-sound{background:#14532d}.pgd-pick-value{background:#422006}.pgd-pick-collect{background:#1e1b4b}.pgd-pick-label{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px}.pgd-pick-sound .pgd-pick-label{color:#4ade80}.pgd-pick-value .pgd-pick-label{color:#fbbf24}.pgd-pick-collect .pgd-pick-label{color:#a78bfa}.pgd-pick .pgd-pick-value{font-size:var(--text-sm);font-weight:600}.pgd-pick-reason{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.4}.pgd-verdict-loading{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-3)}.pgd-pressings{margin-bottom:var(--space-5)}.pgd-pressings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.pgd-add-comment-btn{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);font-weight:500;color:var(--accent);background:none;border:1px solid var(--accent);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-3);cursor:pointer;-webkit-tap-highlight-color:transparent}.pgd-add-comment-btn:active{opacity:.7}.pgd-inline-comment{margin-bottom:var(--space-4);padding:var(--space-3);background:var(--bg-elevated);border-radius:var(--radius-md)}.pgd-section-title{font-size:var(--text-base);margin:0;display:flex;align-items:center;gap:var(--space-2)}.pgd-count{font-size:var(--text-xs);padding:2px var(--space-1);background:var(--bg-elevated);border-radius:var(--radius-sm);color:var(--text-muted)}.pgd-pressing{border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-2);overflow:hidden}.pgd-pressing.expanded{border-color:var(--accent)}.pgd-pressing-owned{border-color:#4ade80;background:#22c55e0d}.pgd-pressing-owned .pgd-pressing-rank{color:#4ade80}.pgd-owned-badge{display:inline-block;font-size:var(--text-2xs);font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:1px var(--space-1);border-radius:var(--radius-sm);background:#14532d;color:#4ade80;margin-right:var(--space-1)}.pgd-pressing-main{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);cursor:pointer;-webkit-tap-highlight-color:transparent}.pgd-pressing-rank{font-size:var(--text-sm);font-weight:700;color:var(--text-muted);min-width:28px;text-align:center}.pgd-pressing-info{flex:1;min-width:0}.pgd-pressing-label-line{font-size:var(--text-sm);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pgd-pressing-catno{font-size:var(--text-xs);color:var(--text-muted)}.pgd-pressing-badges{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-1)}.pgd-heard-on{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-1);margin-top:var(--space-1)}.pgd-heard-on-label{font-size:var(--text-2xs);color:var(--text-muted);font-weight:500}.pgd-heard-on-pill{font-size:var(--text-2xs);padding:1px var(--space-1);border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--text-secondary)}.pgd-pressing-scores{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.pgd-score{text-align:right}.pgd-score-val{font-size:var(--text-sm);font-weight:700;color:var(--accent)}.pgd-score-user .pgd-score-val{color:#a78bfa}.pgd-score-label{font-size:var(--text-2xs);color:var(--text-muted);display:block}.pgd-chevron{flex-shrink:0;color:var(--text-muted);transition:transform .2s}.pgd-chevron.open{transform:rotate(180deg)}.pgd-pressing-detail{padding:var(--space-2) var(--space-2) var(--space-3) 48px;border-top:1px solid var(--border);padding-top:var(--space-2)}.pgd-detail-row{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-1);line-height:1.4}.pgd-detail-label{font-weight:600;color:var(--text-muted);margin-right:var(--space-1)}.pgd-tier{display:inline-block;font-size:var(--text-xs);font-weight:700;padding:1px var(--space-1);border-radius:var(--radius-sm)}.pgd-tier-s{background:#14532d;color:#4ade80}.pgd-tier-a{background:#1e1b4b;color:#a78bfa}.pgd-tier-b{background:#422006;color:#fbbf24}.pgd-tier-c{background:#3f1f1f;color:#f87171}.pgd-detail-actions{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center;margin:var(--space-2) 0}.pgd-discogs-link{display:inline-block;font-size:var(--text-sm);color:var(--accent);text-decoration:none}.pgd-show-all{display:block;width:100%;padding:var(--space-2);margin-top:var(--space-2);border:1px solid var(--border);border-radius:var(--radius-md);background:transparent;color:var(--accent);font-size:var(--text-sm);cursor:pointer}.pgd-pressing-comments{margin-top:var(--space-2);border-top:1px solid var(--border);padding-top:var(--space-2)}.pgd-pressing-comments h4{font-size:var(--text-xs);color:var(--text-muted);margin:0 0 var(--space-1)}.pgd-discussion{margin-bottom:var(--space-5)}.pgd-add-comment{margin-bottom:var(--space-4)}.pgd-comment-input{width:100%;padding:var(--space-2);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);font-size:var(--text-sm);font-family:inherit;resize:vertical;outline:none;box-sizing:border-box}.pgd-comment-input:focus{border-color:var(--accent)}.pgd-comment-submit{margin-top:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--accent);color:#000;border:none;border-radius:var(--radius-sm);font-size:var(--text-sm);cursor:pointer}.pgd-comment-submit:disabled{opacity:.5;cursor:default}.pgd-comment{padding:var(--space-2) 0;border-bottom:1px solid var(--border)}.pgd-comment-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1)}.pgd-comment-user{font-size:var(--text-sm);font-weight:600}.pgd-comment-type{font-size:var(--text-2xs);padding:1px 5px;background:#f59e0b1f;border-radius:var(--radius-sm);color:var(--accent)}.pgd-comment-date{font-size:var(--text-xs);color:var(--text-muted);margin-left:auto}.pgd-comment-upvotes{font-size:var(--text-xs);color:var(--accent)}.pgd-comment-upvotes:before{content:"▲"}.pgd-comment-body{font-size:var(--text-sm);line-height:1.5;color:var(--text-secondary);margin:0}.pgd-subsection-title{font-size:var(--text-sm);color:var(--text-muted);margin:var(--space-4) 0 var(--space-2)}.pgd-forum-link{display:block;padding:var(--space-2) 0;border-bottom:1px solid var(--border);text-decoration:none;color:inherit}.pgd-forum-source{font-size:var(--text-xs);padding:2px var(--space-1);background:var(--bg-elevated);border-radius:var(--radius-sm);display:inline-block;margin-bottom:var(--space-1)}.pgd-forum-title{font-weight:600;font-size:var(--text-sm);margin-bottom:var(--space-1)}.pgd-forum-meta{font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--space-1)}.pgd-forum-excerpt{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.4}.pgd-loading,.pgd-error{padding:var(--space-8) 0;text-align:center;color:var(--text-muted)}.pgd-back-link{display:inline-block;margin-top:var(--space-3);color:var(--accent);text-decoration:none}.pgd-muted{font-size:var(--text-sm);color:var(--text-muted)}.pgd-wishlist-btn{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);font-weight:500;color:#f87171;background:none;border:1px solid rgba(248,113,113,.3);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-3);cursor:pointer;-webkit-tap-highlight-color:transparent}.pgd-wishlist-btn:active{opacity:.7}.pgd-wishlist-btn:disabled{opacity:.5;cursor:default}.pgd-wishlisted{display:inline-flex;align-items:center;font-size:var(--text-sm);color:#4ade80;font-weight:500}.artist-page{padding:0!important}.artist-loading{display:flex;align-items:center;justify-content:center;min-height:60vh}.artist-error{color:var(--fomo-high);text-align:center;padding:var(--space-8)}.artist-back{position:fixed;top:calc(var(--safe-top) + var(--space-2));left:var(--space-3);z-index:50;width:36px;height:36px;border-radius:50%;border:none;background:#00000080;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.artist-hero{position:relative;width:100%;aspect-ratio:1.2;overflow:hidden;background:var(--bg-elevated)}.artist-hero-img{width:100%;height:100%;object-fit:cover}.artist-hero-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:linear-gradient(135deg,var(--bg-surface),var(--bg-elevated))}.artist-hero-overlay{position:absolute;bottom:0;left:0;right:0;padding:var(--space-6) var(--page-px) var(--space-4);background:linear-gradient(transparent,#0c0c0ed9 40%,#0c0c0e)}.artist-name{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin:0}.artist-meta{display:flex;gap:var(--space-2);margin-top:var(--space-1);font-size:var(--text-sm);color:var(--text-secondary)}.artist-meta span:not(:last-child):after{content:"·";margin-left:var(--space-2);color:var(--text-muted)}.artist-tags{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-3) var(--page-px)}.artist-tag{font-size:var(--text-xs);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border)}.artist-tag--notable{background:#f59e0b1a;color:var(--accent);border-color:#f59e0b33}.artist-bio{padding:0 var(--page-px) var(--space-4)}.artist-bio p{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;margin:0}.artist-albums{padding:0 var(--page-px)}.artist-section-title{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--space-3)}.artist-album-list{display:flex;flex-direction:column}.artist-album-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;border:none;background:none;cursor:pointer;text-align:left;color:inherit;border-bottom:1px solid var(--border);width:100%}.artist-album-card:last-child{border-bottom:none}.artist-album-card:active{opacity:.7}.artist-album-cover{width:56px;height:56px;border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-elevated);flex-shrink:0}.artist-album-cover-placeholder{width:56px;height:56px;border-radius:var(--radius-sm);background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-muted)}.artist-album-body{flex:1;min-width:0}.artist-album-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.artist-album-year{font-size:var(--text-xs);color:var(--text-muted)}.artist-album-meta{display:flex;align-items:center;gap:var(--space-2);margin-top:2px}.artist-album-pressings{font-size:var(--text-2xs);color:var(--text-secondary)}.artist-album-badge{font-size:var(--text-2xs);font-weight:600;padding:1px 6px;border-radius:var(--radius-full)}.artist-album-badge--aaa{background:#f59e0b26;color:var(--audio-aaa)}.artist-album-badge--owned{background:#22c55e26;color:var(--grade-a)}.artist-album-rating{font-size:var(--text-2xs);color:var(--text-secondary)}.artist-album-rating:before{content:"★ ";color:var(--accent)}.artist-album-chevron{flex-shrink:0;color:var(--text-muted)}.alerts-loading{display:flex;align-items:center;justify-content:center;min-height:40vh}.alerts-section{margin-bottom:var(--space-6)}.alerts-section-title{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:var(--space-3)}.alerts-summary-bar{display:flex;justify-content:space-between;font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--space-4)}.alerts-bundle-card{padding:var(--space-3);background:#d4a85314;border:1px solid rgba(212,168,83,.15);border-radius:var(--radius-md);margin-bottom:var(--space-2)}.alerts-bundle-title{font-size:var(--text-sm);font-weight:600;color:var(--accent)}.alerts-bundle-meta{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.alerts-item-card{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md);color:inherit;text-decoration:none;margin-bottom:var(--space-2);-webkit-tap-highlight-color:transparent}.alerts-item-card:active{opacity:.8}.alerts-item-cover{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.alerts-item-body{flex:1;min-width:0}.alerts-item-title{font-size:var(--text-sm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.alerts-item-sources{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-1)}.alerts-source-chip{font-size:var(--text-2xs);font-weight:600;padding:2px 6px;border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--text-secondary);white-space:nowrap}.alerts-tag{display:inline-block;font-size:var(--text-2xs);font-weight:700;padding:2px 6px;border-radius:4px;background:#d4a8531f;color:var(--accent);margin-right:4px;margin-top:var(--space-1)}.alerts-tag--green{background:#34d3991f;color:#34d399}.alerts-notif{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md);margin-bottom:var(--space-2)}.alerts-notif-cover{width:40px;height:40px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.alerts-notif-body{flex:1;min-width:0}.alerts-notif-title{font-size:var(--text-sm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.alerts-notif-detail{font-size:var(--text-xs);color:var(--accent);margin-top:2px}.alerts-notif-time{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.alerts-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-8) var(--page-px);margin-top:10vh;color:var(--text-muted)}.alerts-empty svg{margin-bottom:var(--space-4)}.alerts-empty h2{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin:0 0 var(--space-2)}.alerts-empty p{font-size:var(--text-sm);line-height:1.5;max-width:280px;margin:0 0 var(--space-5)}.alerts-empty-link{padding:var(--space-2) var(--space-5);background:var(--accent);color:#000;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;text-decoration:none;min-height:44px;display:flex;align-items:center}.alerts-empty-link:active{opacity:.85}.pw-page{min-height:100vh;background:var(--bg-base, #0c0c0e);color:var(--text-primary, #e5e5e5);padding-bottom:var(--space-8)}.pw-loading{display:flex;align-items:center;justify-content:center;min-height:60vh}.pw-error{text-align:center;padding:var(--space-8) var(--page-px)}.pw-error h2{font-size:var(--text-lg);margin-bottom:var(--space-2)}.pw-error p{color:var(--text-muted);font-size:var(--text-sm)}.pw-header{text-align:center;padding:var(--space-8) var(--page-px) var(--space-4)}.pw-gift-icon{font-size:48px;margin-bottom:var(--space-2)}.pw-title{font-size:var(--text-xl, 1.3rem);font-weight:700;margin:0}.pw-owner{font-size:var(--text-sm);color:var(--text-secondary);margin:var(--space-1) 0 0}.pw-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin:var(--space-2) 0 0}.pw-stats{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-2)}.pw-empty{text-align:center;color:var(--text-muted);padding:var(--space-8);font-size:var(--text-sm)}.pw-items{padding:0 var(--page-px);display:flex;flex-direction:column;gap:var(--space-3)}.pw-item{background:var(--bg-surface, #1a1a1e);border-radius:var(--radius-md, 12px);padding:var(--space-3);border:1px solid var(--border, #2a2a2e)}.pw-item-claimed{opacity:.6}.pw-item-mine{opacity:1;border-color:#22c55e4d}.pw-item-main{display:flex;gap:var(--space-3)}.pw-item-cover{width:80px;height:80px;border-radius:var(--radius-sm, 6px);object-fit:cover;flex-shrink:0;background:var(--bg-elevated, #222)}.pw-cover-claimed{filter:grayscale(.5)}.pw-item-info{flex:1;min-width:0}.pw-item-title{font-size:var(--text-base, .95rem);font-weight:600;line-height:1.3}.pw-item-artist{font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.pw-item-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.pw-item-signals{display:flex;flex-wrap:wrap;gap:4px;margin-top:var(--space-1)}.pw-signal{font-size:.65rem;color:var(--text-muted);background:#ffffff0f;padding:1px 6px;border-radius:4px}.pw-item-rating{font-size:var(--text-xs);color:#f59e0b;margin-top:4px}.pw-item-guide{margin-top:var(--space-2);padding:var(--space-2);background:#60a5fa0f;border-radius:var(--radius-sm, 6px)}.pw-guide-text{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.5;margin:0}.pw-guide-text strong{color:var(--text-primary)}.pw-item-note{margin-top:var(--space-2);font-size:var(--text-xs);color:var(--text-secondary);font-style:italic}.pw-note-label{font-style:normal;font-weight:600;color:var(--text-muted)}.pw-item-actions{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-3);align-items:center}.pw-buy-btn{display:inline-flex;align-items:center;gap:4px;padding:8px 14px;background:var(--accent, #60a5fa);color:#000;font-size:var(--text-xs);font-weight:600;border-radius:20px;text-decoration:none;-webkit-tap-highlight-color:transparent}.pw-buy-btn:active{opacity:.8}.pw-buy-secondary{background:#ffffff1a;color:var(--text-primary)}.pw-claim-btn{padding:8px 14px;background:#22c55e1f;border:1px solid rgba(34,197,94,.3);color:#22c55e;font-size:var(--text-xs);font-weight:600;border-radius:20px;cursor:pointer;-webkit-tap-highlight-color:transparent}.pw-claim-btn:active{opacity:.8}.pw-claim-btn:disabled{opacity:.5}.pw-claimed-mine{background:#22c55e33;border-color:#22c55e80}.pw-claimed-badge{font-size:var(--text-xs);color:var(--text-muted);font-style:italic}.pw-claimed-section{margin-top:var(--space-4)}.pw-claimed-title{font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-2)}.pw-availability{margin-top:var(--space-2);font-size:var(--text-xs);color:var(--text-muted)}.pw-availability-link{color:var(--accent);font-weight:600;text-decoration:none}.pw-availability-stat{color:var(--text-muted)}.pw-listings{margin-top:var(--space-2)}.pw-listings-title{font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-1)}.pw-listing{display:flex;align-items:center;gap:var(--space-2);padding:8px 10px;background:#ffffff08;border:1px solid var(--border);border-radius:var(--radius-sm, 6px);margin-bottom:4px;text-decoration:none;color:inherit;font-size:var(--text-xs);-webkit-tap-highlight-color:transparent}.pw-listing:active{background:#ffffff0f}.pw-listing-source{font-weight:700;color:var(--accent);min-width:70px}.pw-listing-price{font-weight:600;color:var(--text-primary)}.pw-listing-ship{color:var(--text-muted)}.pw-free-ship{color:#22c55e;font-weight:600}.pw-listing-cond{color:var(--text-secondary);background:#ffffff0f;padding:1px 5px;border-radius:3px}.pw-listing-loc{color:var(--text-muted);margin-left:auto}.pw-listing-go{color:var(--accent);font-weight:600;margin-left:auto}.pw-best-deal{font-size:var(--text-xs);font-weight:600;color:#22c55e;padding:var(--space-1) 0}.pw-checked-at{font-size:.65rem;color:var(--text-muted);margin-top:2px}.pw-footer{margin-top:var(--space-8);padding:var(--space-4) var(--page-px);border-top:1px solid var(--border)}.pw-footer-content{text-align:center}.pw-footer-title{font-size:var(--text-sm);font-weight:700;color:var(--text-primary);margin:0}.pw-footer-sub{font-size:var(--text-xs);color:var(--text-muted);margin:var(--space-1) 0;line-height:1.4}.pw-footer-link{font-size:var(--text-xs);font-weight:600;color:var(--accent);text-decoration:none}.spotted-page{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-4))}.spotted-tabs{display:flex;gap:0;margin-bottom:var(--space-4);border-bottom:1px solid var(--border)}.spotted-tab{flex:1;padding:var(--space-2) 0;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:var(--text-sm);font-weight:600;cursor:pointer;position:relative;-webkit-tap-highlight-color:transparent}.spotted-tab-active{color:var(--accent);border-bottom-color:var(--accent)}.spotted-alert-count{display:inline-block;min-width:18px;padding:1px 5px;background:#ef4444;color:#fff;font-size:.6rem;font-weight:700;border-radius:9px;text-align:center;margin-left:4px;vertical-align:middle}.spotted-loading{display:flex;justify-content:center;padding:var(--space-8) 0}.spotted-empty{text-align:center;padding:var(--space-8) 0}.spotted-empty-title{font-size:var(--text-base);font-weight:600;color:var(--text-secondary);margin:0}.spotted-empty-sub{font-size:var(--text-sm);color:var(--text-muted);margin:var(--space-1) 0 0}.spotted-filter-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);background:#60a5fa14;border-radius:var(--radius-sm);font-size:var(--text-xs);color:var(--text-secondary);margin-bottom:var(--space-3)}.spotted-clear-filter{background:none;border:none;color:var(--accent);font-weight:600;font-size:var(--text-xs);cursor:pointer}.spotted-feed{display:flex;flex-direction:column;gap:var(--space-3)}.spotted-card{background:var(--bg-surface);border-radius:var(--radius-md);overflow:hidden}.spotted-card-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border);font-size:var(--text-xs)}.spotted-store-link{background:none;border:none;color:var(--accent);font-weight:600;font-size:var(--text-xs);cursor:pointer;padding:0;-webkit-tap-highlight-color:transparent}.spotted-time{color:var(--text-muted);margin-left:auto}.spotted-user{color:var(--text-muted)}.spotted-card-main{display:flex;gap:var(--space-3);padding:var(--space-3)}.spotted-cover-link{flex-shrink:0;text-decoration:none}.spotted-cover{width:80px;height:80px;border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-elevated);flex-shrink:0}.spotted-info{flex:1;min-width:0}.spotted-title{font-size:var(--text-base);font-weight:600;line-height:1.3}.spotted-artist{font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.spotted-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.spotted-signals{display:flex;flex-wrap:wrap;gap:4px;margin-top:var(--space-1)}.spotted-signal{font-size:.65rem;color:var(--text-muted);background:#ffffff0f;padding:1px 6px;border-radius:4px}.spotted-meta-row{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-1)}.spotted-price{font-weight:700;color:var(--text-primary);font-size:var(--text-sm)}.spotted-condition{font-size:var(--text-xs);color:var(--text-secondary);background:#ffffff0f;padding:1px 5px;border-radius:3px}.spotted-grade{font-size:var(--text-xs);font-weight:700;color:#f59e0b}.spotted-note{font-size:var(--text-sm);color:var(--text-secondary);font-style:italic;padding:0 var(--space-3);margin:0 0 var(--space-2)}.spotted-card-actions{padding:0 var(--space-3) var(--space-2)}.spotted-action-link{font-size:var(--text-xs);font-weight:600;color:var(--accent);text-decoration:none}.spotted-stores{display:flex;flex-direction:column;gap:var(--space-2)}.spotted-store-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md);border:none;color:inherit;text-align:left;cursor:pointer;width:100%;-webkit-tap-highlight-color:transparent}.spotted-store-card:active{opacity:.8}.spotted-store-icon{font-size:28px;flex-shrink:0}.spotted-store-info{flex:1;min-width:0}.spotted-store-name{font-size:var(--text-base);font-weight:600}.spotted-store-loc{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.spotted-store-stats{font-size:var(--text-xs);color:var(--text-secondary);margin-top:2px}.spotted-alerts{display:flex;flex-direction:column;gap:var(--space-2)}.spotted-alert-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md);border-left:3px solid #22c55e}.spotted-alert-icon{font-size:24px;flex-shrink:0}.spotted-alert-info{flex:1;min-width:0}.spotted-alert-title{font-size:var(--text-sm);font-weight:600}.spotted-alert-detail{font-size:var(--text-xs);color:var(--text-secondary);margin-top:2px}.spotted-alert-time{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.spotted-alert-action{font-size:var(--text-xs);font-weight:600;color:var(--accent);text-decoration:none;flex-shrink:0}.prs-page{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-6))}.prs-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.prs-header .page-title{margin:0}.prs-back{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);padding:0;cursor:pointer}.prs-intro{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-5);line-height:1.5}.prs-loading{color:var(--text-muted);font-size:var(--text-sm)}.prs-section{border-top:1px solid var(--border);margin-top:var(--space-8);padding-top:var(--space-5);margin-bottom:var(--space-4)}.prs-section-title{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin:0 0 var(--space-4)}.prs-field{margin-bottom:var(--space-5)}.prs-label{display:flex;justify-content:space-between;align-items:baseline;font-size:var(--text-sm);font-weight:600;color:var(--text);margin-bottom:var(--space-2)}.prs-optional,.prs-char-count{font-weight:400;color:var(--text-muted);font-size:var(--text-xs)}.prs-input,.prs-textarea{width:100%;box-sizing:border-box;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);font-size:var(--text-sm);font-family:inherit;padding:var(--space-3) var(--space-3);outline:none;transition:border-color .15s;-webkit-appearance:none}.prs-input:focus,.prs-textarea:focus{border-color:var(--accent)}.prs-textarea{resize:vertical;min-height:72px;line-height:1.5}.prs-hint{font-size:var(--text-xs);color:var(--text-muted);margin:var(--space-1) 0 0;line-height:1.5}.prs-hint--muted{font-style:italic}.prs-hint-link{background:none;border:none;color:var(--accent);font-size:var(--text-xs);cursor:pointer;padding:0;text-decoration:underline}.prs-toggle-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-3)}.prs-toggle-info{flex:1}.prs-toggle-label{font-size:var(--text-sm);font-weight:600;color:var(--text);display:block;margin-bottom:var(--space-1)}.prs-toggle{flex-shrink:0;position:relative;width:48px;height:28px;background:var(--border);border:none;border-radius:14px;cursor:pointer;padding:0;transition:background .2s;margin-top:2px}.prs-toggle--on{background:var(--accent)}.prs-toggle-thumb{position:absolute;top:3px;left:3px;width:22px;height:22px;background:#fff;border-radius:50%;transition:transform .2s}.prs-toggle--on .prs-toggle-thumb{transform:translate(20px)}.prs-public-preview{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3);margin-top:var(--space-2)}.prs-url-row{display:flex;align-items:center;gap:var(--space-2)}.prs-url{font-size:var(--text-xs);color:var(--accent);word-break:break-all;flex:1}.prs-copy-btn{flex-shrink:0;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:var(--text-xs);padding:var(--space-1) var(--space-2);cursor:pointer;transition:color .15s,border-color .15s}.prs-copy-btn:hover{color:var(--accent);border-color:var(--accent)}.prs-actions{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-5);border-top:1px solid var(--border)}.prs-save-btn{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;padding:var(--space-3) var(--space-5);cursor:pointer;transition:opacity .15s}.prs-save-btn:disabled{opacity:.6;cursor:not-allowed}.prs-msg{font-size:var(--text-sm)}.prs-msg--success{color:var(--success, #4ade80)}.prs-msg--error{color:var(--error, #f87171)}.pp-page{padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-8))}.pp-back{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0;margin-bottom:var(--space-4)}.pp-hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-2) 0 var(--space-5)}.pp-avatar{width:72px;height:72px;border-radius:50%;background:var(--accent);color:#fff;font-size:28px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-3);flex-shrink:0}.pp-name{font-size:var(--text-xl);font-weight:700;color:var(--text);margin:0 0 var(--space-1);line-height:1.2}.pp-location{display:flex;align-items:center;justify-content:center;gap:4px;font-size:var(--text-xs);color:var(--text-muted);margin:0 0 var(--space-2)}.pp-bio{font-size:var(--text-sm);color:var(--text-muted);line-height:1.5;margin:0;max-width:320px}.pp-stats{display:flex;justify-content:center;gap:var(--space-4);padding:var(--space-4) 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:var(--space-4)}.pp-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.pp-stat-value{font-size:var(--text-lg);font-weight:700;color:var(--text);line-height:1}.pp-stat-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.pp-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-5)}.pp-badge{font-size:var(--text-xs);font-weight:600;padding:4px 10px;border-radius:20px;background:#6366f11f;color:var(--accent);letter-spacing:.02em}.pp-badge--genre{background:var(--surface);color:var(--text-muted);border:1px solid var(--border)}.pp-section{border-top:1px solid var(--border);margin-top:var(--space-6);padding-top:var(--space-5)}.pp-section-title{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin:0 0 var(--space-4)}.pp-section-sublabel{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:var(--space-3) 0 var(--space-2)}.pp-records-row{display:flex;gap:var(--space-3);overflow-x:auto;padding-bottom:var(--space-2);scrollbar-width:none;-ms-overflow-style:none}.pp-records-row::-webkit-scrollbar{display:none}.pp-record{flex-shrink:0;width:88px;background:none;border:none;padding:0;cursor:pointer;text-align:left}.pp-record:disabled{cursor:default}.pp-record-cover{width:88px;height:88px;object-fit:cover;border-radius:var(--radius-sm);display:block;background:var(--surface);margin-bottom:var(--space-1)}.pp-record-title{font-size:11px;font-weight:600;color:var(--text);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:88px}.pp-record-artist{font-size:10px;color:var(--text-muted);margin:1px 0 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:88px}.pp-record-pressing{font-size:9px;color:var(--accent);margin:2px 0 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:88px;font-weight:500}.pp-cta-row{margin-top:var(--space-4);display:flex;justify-content:center}.pp-follow-btn{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;padding:var(--space-2) var(--space-6);cursor:pointer;transition:opacity .15s;min-width:120px}.pp-follow-btn:active{opacity:.8}.pp-follow-btn:disabled{opacity:.6;cursor:default}.pp-follow-btn--following{background:var(--surface);color:var(--text);border:1px solid var(--border)}.pp-edit-btn{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;padding:var(--space-2) var(--space-6);cursor:pointer;min-width:120px}.pp-footer{border-top:1px solid var(--border);margin-top:var(--space-8);padding-top:var(--space-5);text-align:center}.pp-footer-text{font-size:var(--text-sm);color:var(--text-muted);margin:0 0 var(--space-1)}.pp-footer-sub{font-size:var(--text-xs);color:var(--text-muted);margin:0 0 var(--space-3);line-height:1.5}.pp-footer-cta{display:inline-block;background:var(--accent);color:#fff;font-size:var(--text-sm);font-weight:600;padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);text-decoration:none}.pp-loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding-top:var(--space-8)}.pp-skeleton-avatar{width:72px;height:72px;border-radius:50%;background:var(--surface);animation:pp-shimmer 1.4s ease-in-out infinite}.pp-skeleton-bar{height:14px;border-radius:6px;background:var(--surface);animation:pp-shimmer 1.4s ease-in-out infinite;width:160px}.pp-skeleton-bar.wide{width:220px;height:20px}@keyframes pp-shimmer{0%,to{opacity:.4}50%{opacity:.8}}.pp-taste-match{display:flex;flex-direction:column;gap:var(--space-3)}.pp-taste-score-row{display:flex;align-items:center;gap:var(--space-4)}.pp-taste-pct{font-size:40px;font-weight:800;color:var(--accent);line-height:1;min-width:72px}.pp-taste-desc{display:flex;flex-direction:column;gap:2px}.pp-taste-label{font-size:var(--text-sm);font-weight:600;color:var(--text)}.pp-taste-sub{font-size:var(--text-xs);color:var(--text-muted)}.pp-taste-artists{font-size:var(--text-sm);color:var(--text-muted);line-height:1.4}.pp-taste-artists-label{font-weight:600;color:var(--text)}.pp-taste-genres{display:flex;flex-wrap:wrap;gap:var(--space-2)}.pp-taste-genre-pill{font-size:var(--text-xs);padding:3px 8px;border-radius:12px;background:var(--surface);color:var(--text-muted);border:1px solid var(--border)}.pp-taste-they-have{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-1)}.pp-taste-they-label{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.pp-taste-loading{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3) 0}.pp-coll-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.pp-coll-browse-btn{background:none;border:1px solid var(--border);color:var(--accent);font-size:var(--text-sm);font-weight:600;padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);cursor:pointer}.pp-coll-search{width:100%;box-sizing:border-box;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:var(--text-sm);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-3);outline:none}.pp-coll-search:focus{border-color:var(--accent)}.pp-coll-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);margin-bottom:var(--space-4)}.pp-coll-item{background:none;border:none;padding:0;cursor:pointer;text-align:left;min-width:0}.pp-coll-item:disabled{cursor:default}.pp-coll-cover{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--radius-sm);display:block;background:var(--surface);margin-bottom:4px}.pp-coll-title{font-size:11px;font-weight:600;color:var(--text);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pp-coll-artist{font-size:10px;color:var(--text-muted);margin:1px 0 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pp-coll-year{font-size:9px;color:var(--accent);margin:1px 0 0;font-weight:500}.pp-coll-loading{display:flex;justify-content:center;padding:var(--space-6) 0}.pp-coll-empty{color:var(--text-muted);font-size:var(--text-sm);text-align:center;padding:var(--space-4) 0}.pp-coll-more-btn{width:100%;background:var(--surface);border:1px solid var(--border);color:var(--text-muted);font-size:var(--text-sm);padding:var(--space-2) 0;border-radius:var(--radius-sm);cursor:pointer;margin-top:var(--space-2)}.pp-coll-more-btn:active{opacity:.7}.pp-coll-more-btn:disabled{opacity:.5;cursor:default}.pp-error-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-10) var(--space-6);color:var(--text-muted)}.pp-error-title{font-size:var(--text-base);font-weight:600;color:var(--text);margin:var(--space-3) 0 var(--space-1)}.pp-error-sub{font-size:var(--text-sm);color:var(--text-muted);margin:0;line-height:1.5}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;padding:var(--space-8) var(--space-6)}.login-brand{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--space-8)}.login-brand h1{font-size:var(--text-2xl);font-weight:700;color:var(--accent)}.login-logo{height:48px;width:auto;margin-bottom:var(--space-2)}.login-brand p{color:var(--text-muted);margin-top:var(--space-2);font-size:var(--text-sm)}.login-form{width:100%;max-width:400px;display:flex;flex-direction:column;gap:var(--space-3)}.login-input{width:100%;padding:var(--space-3) var(--page-px);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--text-primary);min-height:48px}.login-input:focus{outline:none;border-color:var(--accent)}.login-btn{width:100%;padding:var(--space-3);background:var(--accent);color:#000;border-radius:var(--radius-md);font-weight:600;font-size:var(--text-base);margin-top:var(--space-2);min-height:48px}.login-btn:active:not(:disabled){opacity:.85;transform:scale(.98)}.login-btn:disabled{opacity:.6}.login-error{background:#ef444426;color:#f87171;padding:var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm)}.login-divider{display:flex;align-items:center;gap:var(--space-3);color:var(--text-muted);font-size:var(--text-sm);margin:var(--space-1) 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.login-google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-3);background:#fff;color:#333;border:1px solid var(--border);border-radius:var(--radius-md);font-weight:500;font-size:var(--text-base);min-height:48px}.login-google-btn:active{background:#f0f0f0;transform:scale(.98)}.shell{min-height:100dvh;display:flex;flex-direction:column}.shell-content{flex:1;padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--space-2))}.page{padding-top:calc(var(--safe-top, 0px) + var(--space-2))}.shell-loading{display:flex;align-items:center;justify-content:center;min-height:100dvh}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.shell-menu-btn{position:fixed;top:calc(var(--safe-top, 0px) + var(--space-2) + var(--page-px));right:var(--page-px);z-index:80;width:40px;height:40px;border-radius:50%;background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;text-decoration:none;-webkit-tap-highlight-color:transparent;box-shadow:0 2px 8px #0003}.shell-menu-btn:active{background:var(--bg-elevated);color:var(--accent)}.shell-menu-btn.active{color:var(--accent);border-color:var(--accent)}.impersonate-global-banner{position:sticky;top:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-4);background:#6366f126;border-bottom:1px solid rgba(99,102,241,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.impersonate-global-banner span{font-size:var(--text-sm);color:#a5b4fc}.impersonate-global-banner strong{color:#818cf8}.impersonate-global-banner button{padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:600;border-radius:var(--radius-md);border:1px solid rgba(239,68,68,.3);background:#ef44441f;color:#ef4444;cursor:pointer}.impersonate-global-banner button:disabled{opacity:.5}.fre-preview-global-banner{position:sticky;top:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-4);background:#f59e0b26;border-bottom:1px solid rgba(245,158,11,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.fre-preview-global-banner span{font-size:var(--text-sm);font-weight:600;color:var(--accent)}.fre-preview-global-banner button{padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:600;border-radius:var(--radius-md);border:1px solid rgba(239,68,68,.3);background:#ef44441f;color:#ef4444;cursor:pointer}.fre-preview-global-banner button:disabled{opacity:.5}:root{--bg-page: #0c0c0e;--bg-surface: #16161a;--bg-elevated: #1c1c21;--bg-input: #222226;--border: #2a2a2e;--border-hover: #3a3a3e;--accent: #f59e0b;--accent-hover: #d97706;--text-primary: #f0f0f2;--text-secondary: #94a3b8;--text-muted: #64748b;--grade-aplus: #f59e0b;--grade-a: #22c55e;--grade-b: #3b82f6;--grade-c: #94a3b8;--grade-d: #ef4444;--audio-aaa: #f59e0b;--fomo-high: #ef4444;--fomo-med: #f59e0b;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-full: 9999px;--text-2xs: .7rem;--text-xs: .8rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.5rem;--text-2xl: 1.75rem;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--tab-height: 56px;--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-top: env(safe-area-inset-top, 0px);--page-px: 16px;color-scheme:dark}[data-theme=vinyl]{--bg-page: #0f1117;--bg-surface: #151d2e;--bg-elevated: #1c2640;--bg-input: #202e4a;--border: #2a3d5a;--border-hover: #3a5278;--text-primary: #dde8f5;--text-secondary: #6888b0;--text-muted: #425570;--accent: #22c55e;--accent-hover: #16a34a;color-scheme:dark}[data-theme=light]{--bg-page: #f2f2f5;--bg-surface: #ffffff;--bg-elevated: #e8e8ee;--bg-input: #e2e2e8;--border: #d0d0d8;--border-hover: #b4b4be;--text-primary: #1a1a1e;--text-secondary: #4a5568;--text-muted: #8090a0;--accent: #d97706;--accent-hover: #b45309;color-scheme:light}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:calc(16px * var(--text-scale, 1));-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg-page);color:var(--text-primary);min-height:100dvh;-webkit-font-smoothing:antialiased;line-height:1.5;overscroll-behavior-y:none}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;border:none;background:none;color:inherit;-webkit-tap-highlight-color:transparent}img{display:block;max-width:100%}input,select,textarea{font:inherit;color:inherit}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.page{padding:var(--page-px) var(--page-px) var(--space-6);max-width:100vw;overflow-x:hidden;box-sizing:border-box}.page-title{font-size:var(--text-xl);font-weight:700;margin-bottom:var(--space-1)}.page-subtitle{color:var(--text-muted);font-size:var(--text-sm);margin-bottom:var(--page-px)}.section-title{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:var(--space-3)}.pill-row{display:flex;gap:var(--space-2);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.pill-row::-webkit-scrollbar{display:none}.pill{padding:var(--space-3) var(--page-px);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;white-space:nowrap;background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border);min-height:44px;display:inline-flex;align-items:center}.pill.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:600}.pill:active{opacity:.8}.card{background:var(--bg-surface);border-radius:var(--radius-md);padding:var(--page-px)}.card-accent{border-left:3px solid var(--accent)}.card-purple{border-left:3px solid #a78bfa}.card-green{border-left:3px solid #22c55e}.card-red{border-left:3px solid #ef4444}.card-blue{border-left:3px solid #3b82f6}.search-input{width:100%;padding:var(--space-3) var(--page-px);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-lg);font-size:var(--text-base);color:var(--text-primary);min-height:44px}.search-input:focus{outline:none;border-color:var(--accent)}.search-input::placeholder{color:var(--text-muted)}.sentiment-badge{font-size:var(--text-xs);font-weight:600;padding:3px 10px;border-radius:var(--radius-full);text-transform:capitalize}.sentiment-positive{background:#22c55e26;color:#4ade80}.sentiment-mixed{background:#f59e0b26;color:#fbbf24}.sentiment-negative{background:#ef444426;color:#f87171}.btn-primary{width:100%;padding:var(--space-3);background:var(--accent);color:#000;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:700;min-height:48px;display:flex;align-items:center;justify-content:center}.btn-primary:active:not(:disabled){opacity:.85;transform:scale(.98)}.btn-primary:disabled{opacity:.5}.btn-secondary{padding:var(--space-2) var(--space-4);background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;min-height:44px;display:inline-flex;align-items:center}.btn-secondary:active{opacity:.8}.list-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md)}.list-item-cover{width:72px;height:72px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}a.list-item{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}a.list-item:active{opacity:.8}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-accent{color:var(--accent)}.font-semibold{font-weight:600}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page-loading{display:flex;align-items:center;justify-content:center;min-height:40vh}.page-error{color:#f87171;text-align:center;padding:var(--space-8);font-size:var(--text-sm)}.page-empty{text-align:center;color:var(--text-muted);padding:var(--space-8) var(--page-px);font-size:var(--text-sm)}.skeleton{background:var(--bg-elevated);border-radius:var(--radius-sm);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-card{background:var(--bg-surface);border-radius:var(--radius-md);padding:var(--page-px);display:flex;gap:var(--space-3)}.skeleton-cover{width:120px;height:120px;border-radius:var(--radius-md);background:var(--bg-elevated);flex-shrink:0;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-lines{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.skeleton-line{height:14px;border-radius:var(--radius-sm);background:var(--bg-elevated);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-line:nth-child(1){width:70%}.skeleton-line:nth-child(2){width:50%}.skeleton-line:nth-child(3){width:40%;animation-delay:.15s}.skeleton-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.skeleton-tile{aspect-ratio:1;border-radius:var(--radius-sm);background:var(--bg-elevated);animation:skeleton-pulse 1.5s ease-in-out infinite}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:.7}}.scroll-x{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;will-change:transform}.scroll-x::-webkit-scrollbar{display:none}.card-list-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface);border-radius:var(--radius-md)}.card-standard{display:flex;gap:var(--space-3);padding:var(--space-4);background:var(--bg-surface);border-radius:var(--radius-md)}.card-detail{padding:var(--space-4);background:var(--bg-surface);border-radius:var(--radius-md)}.cover-mini{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}.cover-compact{width:72px;height:72px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0}.cover-standard{width:96px;height:96px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0}.badge{display:inline-flex;align-items:center;gap:4px;font-size:var(--text-xs);font-weight:600;padding:2px 8px;border-radius:var(--radius-sm);white-space:nowrap}.badge-pill{border-radius:var(--radius-full)}.badge-green{background:#22c55e26;color:#4ade80}.badge-red{background:#ef444426;color:#f87171}.badge-amber{background:#f59e0b26;color:#fbbf24}.badge-blue{background:#3b82f626;color:#7dd3fc}.badge-purple{background:#a78bfa26;color:#a78bfa}.badge-muted{background:var(--bg-elevated);color:var(--text-muted)}.status-pill{display:inline-flex;align-items:center;font-size:var(--text-xs);font-weight:700;padding:2px 8px;border-radius:var(--radius-full);white-space:nowrap}.status-available{background:#14532d;color:#4ade80}.status-coming-soon{background:#1e3a5f;color:#7dd3fc}.status-pre-order{background:#1e1b4b;color:#a78bfa}.status-upcoming{background:#1e3a5f;color:#7dd3fc}.status-out-of-stock{background:#3f1f1f;color:#f87171}.text-2xs{font-size:var(--text-2xs)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.disc-page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-3)}.disc-page-header>div:first-child{flex:1;min-width:0}.disc-page-header .page-title{margin:0!important}.disc-page-header .page-subtitle{margin:var(--space-1) 0 0!important}.primary-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:var(--space-4)}.primary-tabs+.secondary-band{margin-top:calc(-1 * var(--space-4))}.primary-tab{flex:1;padding:var(--space-3) 0;font-size:var(--text-base);font-weight:600;white-space:nowrap;background:transparent;color:var(--text-muted);border:none;border-bottom:2px solid transparent;min-height:44px;display:inline-flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;transition:all .15s}.primary-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.primary-tab:active{opacity:.8}.secondary-band{display:flex;width:calc(100% + 2 * var(--page-px));margin-left:calc(-1 * var(--page-px));margin-bottom:var(--space-4)}.secondary-tab{flex:1;padding:var(--space-2) 0;min-height:40px;display:inline-flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:500;white-space:nowrap;background:var(--bg-surface);color:var(--text-muted);border:none;border-bottom:1px solid var(--border);-webkit-tap-highlight-color:transparent;transition:color .15s,background .15s}.secondary-tab.active{color:var(--accent);font-weight:600;background:#f59e0b14;border-bottom-color:var(--accent)}.secondary-tab:active{opacity:.8}.filter-chips{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-3)}.filter-chip{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;white-space:nowrap;background:none;color:var(--text-muted);border:1px solid var(--border);display:inline-flex;align-items:center;min-height:32px;-webkit-tap-highlight-color:transparent;transition:all .15s}.filter-chip.active{background:#f59e0b1a;color:var(--accent);border-color:#f59e0b4d}.filter-chip:active{opacity:.8}.filter-dropdown{position:relative;display:flex}.filter-dropdown select{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:100%;padding:var(--space-1) 32px var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:600;color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);cursor:pointer;min-height:36px;-webkit-tap-highlight-color:transparent;font-family:inherit}.filter-dropdown:after{content:"";position:absolute;right:12px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--text-muted);pointer-events:none}.curate-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-3);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.curate-tabs::-webkit-scrollbar{display:none}.curate-tab{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;white-space:nowrap;background:none;color:var(--text-muted);border:1px solid var(--border);display:inline-flex;align-items:center;-webkit-tap-highlight-color:transparent;transition:all .15s}.curate-tab.active{background:#f59e0b1a;color:var(--accent);border-color:#f59e0b4d}.curate-tab:active{opacity:.8}.curate-panel{min-height:200px}.curate-list,.curate-loading{display:flex;flex-direction:column;gap:var(--space-3)}.curate-empty{text-align:center;color:var(--text-muted);padding:var(--space-8) 0;font-size:var(--text-sm)}.curate-error{color:#f87171;text-align:center;padding:var(--page-px);font-size:var(--text-base)}.curate-search-row{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.curate-search{flex:1;padding:var(--space-3) var(--page-px);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-lg);font-size:var(--text-base);color:var(--text-primary);min-height:44px}.curate-search:focus{outline:none;border-color:var(--accent)}.curate-search::placeholder{color:var(--text-muted)}.curate-search-btn{padding:var(--space-3) var(--space-4);background:var(--accent);color:#000;border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:700;min-height:44px;white-space:nowrap}.curate-search-btn:active:not(:disabled){opacity:.85;transform:scale(.98)}.curate-search-btn:disabled{opacity:.5}.rec-card{background:var(--bg-surface);border-radius:var(--radius-md);border-left:3px solid #a78bfa;overflow:hidden}.rec-card-lg{border-left-width:4px}.rec-main{display:flex;gap:var(--space-3);padding:var(--page-px);color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}.rec-main:active{background:var(--bg-elevated)}.rec-main-lg{gap:var(--space-4);padding:var(--space-4)}.rec-cover{width:112px;height:112px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--bg-elevated)}.rec-cover-lg{width:112px;height:112px;border-radius:var(--radius-sm)}.rec-body{min-width:0;flex:1;display:flex;flex-direction:column}.rec-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-1)}.rec-tag{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;background:#a78bfa33;color:#a78bfa;padding:2px var(--space-2);border-radius:var(--radius-sm)}.rec-match{font-size:var(--text-xs);font-weight:600;color:var(--text-muted)}.rec-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.rec-artist{font-size:var(--text-sm);color:var(--text-secondary)}.rec-found-date{color:var(--text-muted)}.rec-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:1px}.rec-pressing-info{display:flex;flex-wrap:wrap;gap:4px;margin-top:var(--space-1)}.rec-pressing-tag{font-size:var(--text-2xs);font-weight:600;padding:1px 6px;border-radius:var(--radius-sm);white-space:nowrap}.rec-pressing-eng{background:#fbbf2426;color:#fbbf24}.rec-pressing-plant{background:#22c55e26;color:#4ade80}.rec-pressing-aaa{background:#a78bfa26;color:#a78bfa}.rec-reason{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-top:var(--space-1)}.rec-bar-wrap{padding-top:var(--space-2);display:flex;align-items:center;gap:var(--space-2)}.rec-bar{height:4px;border-radius:2px;background:var(--bg-elevated);overflow:hidden;flex:1}.rec-bar-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,#a78bfa,#f59e0b);transition:width .4s ease}.rec-score-num{font-size:var(--text-xs);font-weight:700;color:var(--text-muted);min-width:24px;text-align:right}.rec-status{display:inline-block;padding:1px 6px;border-radius:4px;font-size:var(--text-xs);font-weight:600;white-space:nowrap}.rec-why-section{padding:var(--space-2) var(--space-4);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:var(--space-2)}.rec-why-factors{display:flex;flex-wrap:wrap;gap:4px}.rec-why-chip{font-size:var(--text-2xs);font-weight:700;padding:2px 8px;border-radius:var(--radius-full);border:1px solid;white-space:nowrap;background:none;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .15s}.rec-why-chip:active{opacity:.6}.rec-why-actions{display:flex;align-items:center;gap:var(--space-3)}.rec-source-link{font-size:var(--text-xs);color:var(--accent);font-weight:500;text-decoration:none;-webkit-tap-highlight-color:transparent}.rec-source-link:active{opacity:.6}.rec-breakdown-toggle{display:flex;align-items:center;gap:4px;font-size:var(--text-xs);font-weight:600;color:var(--text-muted);-webkit-tap-highlight-color:transparent}.rec-breakdown-toggle:active{color:var(--text-primary)}.rec-breakdown{padding:0 var(--page-px) var(--page-px)}.rec-breakdown-title{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--space-2)}.rec-factor{margin-bottom:var(--space-2)}.rec-factor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.rec-factor-name{font-size:var(--text-xs);font-weight:600}.rec-factor-points{font-size:var(--text-xs);font-weight:700;color:var(--text-muted)}.rec-factor-bar{height:3px;border-radius:2px;background:var(--bg-elevated);overflow:hidden}.rec-factor-bar-fill{height:100%;border-radius:2px;transition:width .3s ease}.rec-factor-detail{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px;line-height:1.4}.card-link{color:inherit;text-decoration:none;display:block;-webkit-tap-highlight-color:transparent}.load-more-btn{display:block;width:100%;padding:var(--space-3);margin-top:var(--space-4);background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;cursor:pointer;text-align:center}.load-more-btn:disabled{opacity:.5}
