.BottomPlayer-module-scss-module__YTmOta__player{-webkit-backdrop-filter:blur(20px);z-index:1000;background:#0c0c0cf5;border-top:1px solid #ffffff14;justify-content:space-between;align-items:center;height:80px;padding:0 24px;animation:.3s cubic-bezier(.16,1,.3,1) BottomPlayer-module-scss-module__YTmOta__slideUp;display:flex;position:fixed;bottom:0;left:0;right:0}@keyframes BottomPlayer-module-scss-module__YTmOta__slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.BottomPlayer-module-scss-module__YTmOta__miniProgress{cursor:pointer;z-index:1;background:#ffffff14;height:3px;transition:height .15s;position:absolute;top:-2px;left:0;right:0}.BottomPlayer-module-scss-module__YTmOta__miniProgress:hover{height:5px}.BottomPlayer-module-scss-module__YTmOta__miniProgressFill{background:#fff;border-radius:0 1px 1px 0;height:100%;transition:width .15s linear}.BottomPlayer-module-scss-module__YTmOta__trackInfo{align-items:center;gap:14px;min-width:220px;max-width:30%;display:flex}.BottomPlayer-module-scss-module__YTmOta__cover{object-fit:cover;border-radius:6px;width:48px;height:48px;box-shadow:0 4px 12px #00000080}.BottomPlayer-module-scss-module__YTmOta__coverPlaceholder{color:#ffffff4d;background:#ffffff0f;border-radius:6px;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;display:flex}.BottomPlayer-module-scss-module__YTmOta__meta{flex-direction:column;gap:2px;display:flex;overflow:hidden}.BottomPlayer-module-scss-module__YTmOta__title{color:#e8e4e0;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.BottomPlayer-module-scss-module__YTmOta__artist{color:#e8e4e073;white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.BottomPlayer-module-scss-module__YTmOta__controls{flex-direction:column;flex:1;align-items:center;gap:6px;max-width:600px;display:flex}.BottomPlayer-module-scss-module__YTmOta__buttons{align-items:center;gap:20px;display:flex}.BottomPlayer-module-scss-module__YTmOta__btn{color:#e8e4e080;cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;transition:color .15s,transform .15s;display:flex}.BottomPlayer-module-scss-module__YTmOta__btn:hover{color:#e8e4e0;transform:scale(1.1)}.BottomPlayer-module-scss-module__YTmOta__playBtn{color:#0a0a0a;cursor:pointer;background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:transform .15s,box-shadow .15s;display:flex}.BottomPlayer-module-scss-module__YTmOta__playBtn:hover{transform:scale(1.06);box-shadow:0 4px 20px #ffffff26}.BottomPlayer-module-scss-module__YTmOta__playBtn:active{transform:scale(.96)}.BottomPlayer-module-scss-module__YTmOta__progressRow{align-items:center;gap:10px;width:100%;display:flex}.BottomPlayer-module-scss-module__YTmOta__time{color:#e8e4e059;font-variant-numeric:tabular-nums;text-align:center;-webkit-user-select:none;user-select:none;min-width:38px;font-size:11px}.BottomPlayer-module-scss-module__YTmOta__progressBar{cursor:pointer;background:#ffffff14;border-radius:2px;flex:1;height:4px;transition:height .1s;position:relative}.BottomPlayer-module-scss-module__YTmOta__progressBar:hover{height:6px}.BottomPlayer-module-scss-module__YTmOta__progressBar:hover .BottomPlayer-module-scss-module__YTmOta__progressFill:after{opacity:1;transform:scale(1)}.BottomPlayer-module-scss-module__YTmOta__progressFill{background:#fff;border-radius:2px;height:100%;transition:width .1s linear;position:relative}.BottomPlayer-module-scss-module__YTmOta__progressFill:after{content:"";opacity:0;background:#e8e4e0;border-radius:50%;width:12px;height:12px;transition:opacity .15s,transform .15s;position:absolute;top:50%;right:-5px;transform:translateY(-50%)scale(0);box-shadow:0 2px 4px #0006}.BottomPlayer-module-scss-module__YTmOta__volumeControl{justify-content:flex-end;align-items:center;gap:8px;min-width:160px;display:flex}.BottomPlayer-module-scss-module__YTmOta__volumeIcon{color:#fff9;flex-shrink:0}.BottomPlayer-module-scss-module__YTmOta__volumeSlider{appearance:none;cursor:pointer;background:#ffffff1f;border-radius:2px;outline:none;width:100px;height:4px}.BottomPlayer-module-scss-module__YTmOta__volumeSlider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#fff;border-radius:50%;width:12px;height:12px;transition:transform .1s;box-shadow:0 1px 4px #0000004d}.BottomPlayer-module-scss-module__YTmOta__volumeSlider::-webkit-slider-thumb:hover{transform:scale(1.2)}@media (max-width:768px){.BottomPlayer-module-scss-module__YTmOta__player{height:64px;padding:0 16px;padding-bottom:env(safe-area-inset-bottom,0)}.BottomPlayer-module-scss-module__YTmOta__trackInfo{flex:1;min-width:auto;max-width:none;overflow:hidden}.BottomPlayer-module-scss-module__YTmOta__cover,.BottomPlayer-module-scss-module__YTmOta__coverPlaceholder{border-radius:4px;width:40px;height:40px}.BottomPlayer-module-scss-module__YTmOta__volumeControl,.BottomPlayer-module-scss-module__YTmOta__progressRow{display:none}.BottomPlayer-module-scss-module__YTmOta__controls{flex:none;max-width:none}.BottomPlayer-module-scss-module__YTmOta__buttons{gap:12px}.BottomPlayer-module-scss-module__YTmOta__btnSkip{display:flex}.BottomPlayer-module-scss-module__YTmOta__playBtn{width:44px;height:44px}.BottomPlayer-module-scss-module__YTmOta__miniProgress,.BottomPlayer-module-scss-module__YTmOta__miniProgress:hover{height:3px}}
*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{overflow-x:clip}:root{--bg-primary:#0a0a0a;--bg-secondary:#0f0f0f;--bg-elevated:#161616;--bg-hover:#1c1c1c;--text-primary:#e8e4e0;--text-secondary:#e8e4e08c;--text-muted:#e8e4e04d;--accent:#fff;--accent-hover:#ccc;--accent-glow:#ffffff26;--accent-subtle:#ffffff0d;--border:#ffffff0f;--border-accent:#ffffff26;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--font-body:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-display:"Cinzel", "Times New Roman", serif}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;position:relative;overflow-x:hidden}body:after{content:"";pointer-events:none;z-index:9999;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px;position:fixed;inset:0}a{color:inherit;text-decoration:none;transition:color .2s}a:hover{color:var(--accent-hover)}.nav{z-index:100;-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);background:#0a0a0aeb;justify-content:space-between;align-items:center;padding:16px 32px;display:flex;position:sticky;top:0}.nav-logo{font-family:var(--font-display);letter-spacing:2px;text-transform:uppercase;color:var(--text-primary);font-size:22px;font-weight:700}.nav-year{color:var(--accent);margin-left:6px;font-size:16px;font-weight:400}.nav-links{align-items:center;gap:28px;display:flex}.nav-links a{color:var(--text-secondary);letter-spacing:.5px;text-transform:uppercase;font-size:13px;font-weight:500;transition:color .2s,text-shadow .2s}.nav-links a:hover{color:var(--accent-hover);text-shadow:0 0 20px var(--accent-glow)}.nav-search{flex:0 320px;position:relative}.search-input-wrap{align-items:center;display:flex;position:relative}.search-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:12px}.search-input{border:1px solid var(--border);width:100%;color:var(--text-primary);background:#ffffff0a;border-radius:20px;outline:none;padding:8px 12px 8px 36px;font-family:inherit;font-size:14px;transition:background .2s,border-color .2s,box-shadow .2s}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{border-color:var(--border-accent);box-shadow:0 0 0 3px var(--accent-subtle);background:#ffffff12}.search-spinner{border:2px solid #ffffff1a;border-top-color:var(--accent);border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin;position:absolute;right:12px}@keyframes spin{to{transform:rotate(360deg)}}.search-dropdown{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);z-index:200;max-height:420px;position:absolute;top:calc(100% + 8px);left:0;right:0;overflow:hidden auto;box-shadow:0 16px 48px #000000b3,0 0 40px #ffffff08}.search-empty{text-align:center;color:var(--text-muted);padding:24px;font-size:14px}.search-section{padding:8px 0}.search-section+.search-section{border-top:1px solid var(--border)}.search-section-title{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);padding:6px 16px;font-size:11px;font-weight:600}.search-item{color:var(--text-primary);align-items:center;gap:12px;padding:8px 16px;font-size:14px;transition:background .15s;display:flex}.search-item:hover{background:var(--accent-subtle);color:var(--text-primary)}.search-item-icon{text-align:center;flex-shrink:0;width:24px;font-size:18px}.search-item-sub{color:var(--text-muted);margin-top:1px;font-size:12px}.main-content{max-width:1400px;margin:0 auto;padding:32px 32px 120px;overflow-x:hidden}.hero{text-align:center;padding:100px 0 70px;position:relative}.hero:before{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff0a 0%,#0000 70%);width:600px;height:600px;position:absolute;top:-100px;left:50%;transform:translate(-50%)}.hero h1{font-family:var(--font-display);letter-spacing:4px;text-transform:uppercase;background:linear-gradient(#fff 0%,#666 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:20px;font-size:clamp(40px,6vw,72px);font-weight:800;position:relative}.hero p{color:var(--text-secondary);letter-spacing:.5px;max-width:440px;margin:0 auto 36px;font-size:16px}.hero-cta{color:#0a0a0a;letter-spacing:1px;text-transform:uppercase;background:#fff;border-radius:50px;align-items:center;gap:8px;padding:14px 36px;font-size:14px;font-weight:600;transition:all .3s;display:inline-flex;box-shadow:0 4px 20px #ffffff1a}.hero-cta:hover{color:#0a0a0a;background:#ccc;transform:scale(1.03);box-shadow:0 6px 30px #ffffff26}.section-header{justify-content:space-between;align-items:baseline;margin-bottom:24px;display:flex}.section-header h2{font-family:var(--font-display);letter-spacing:2px;text-transform:uppercase;font-size:22px;font-weight:600}.section-header a{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-size:12px;font-weight:600;transition:color .2s}.section-header a:hover{color:var(--accent)}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:24px;display:grid}.card{background:var(--bg-secondary);border-radius:var(--radius-md);cursor:pointer;border:1px solid #0000;min-width:0;padding:16px;transition:background .25s,transform .25s,box-shadow .25s;overflow:hidden}.card:hover{background:var(--bg-hover);border-color:var(--border-accent);transform:translateY(-3px);box-shadow:0 8px 32px #ffffff08}.card-image{aspect-ratio:1;border-radius:var(--radius-sm);object-fit:cover;width:100%;margin-bottom:14px;box-shadow:0 8px 24px #0006}.card-image-placeholder{aspect-ratio:1;border-radius:var(--radius-sm);background:var(--bg-elevated);width:100%;color:var(--text-muted);justify-content:center;align-items:center;margin-bottom:14px;font-size:40px;display:flex}.card-artist .card-image,.card-artist .card-image-placeholder{border-radius:50%}.card h3{white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:15px;font-weight:600;overflow:hidden}.card p{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.artist-header{align-items:flex-end;gap:32px;margin-bottom:48px;padding:40px 0 0;display:flex}.artist-photo{object-fit:cover;border-radius:50%;width:200px;height:200px;box-shadow:0 8px 32px #0009,0 0 40px #ffffff0a}.artist-photo-placeholder{background:var(--bg-elevated);width:200px;height:200px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:64px;display:flex;box-shadow:0 8px 32px #0009}.artist-info h1{font-family:var(--font-display);letter-spacing:2px;text-transform:uppercase;margin-bottom:8px;font-size:clamp(32px,4vw,56px);font-weight:800}.artist-info p{color:var(--text-secondary);max-width:600px;font-size:15px}.album-header{gap:32px;margin-bottom:40px;padding:24px 0 0;display:flex}.album-cover{border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;width:232px;height:232px;box-shadow:0 8px 32px #0009}.album-cover-placeholder{border-radius:var(--radius-sm);background:var(--bg-elevated);width:232px;height:232px;color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;font-size:64px;display:flex;box-shadow:0 8px 32px #0009}.album-meta{flex-direction:column;justify-content:flex-end;display:flex}.album-type{text-transform:uppercase;letter-spacing:1.5px;color:var(--accent);margin-bottom:8px;font-size:12px;font-weight:600}.album-meta h1{font-family:var(--font-display);letter-spacing:1px;text-transform:uppercase;margin-bottom:10px;font-size:clamp(28px,3vw,48px);font-weight:800}.album-details{color:var(--text-secondary);align-items:center;gap:6px;font-size:14px;display:flex}.album-details a{color:var(--text-primary);font-weight:500}.album-details a:hover{color:var(--accent)}.album-dot{opacity:.3}.tracklist{list-style:none}.track-row{border-radius:var(--radius-sm);cursor:pointer;grid-template-columns:40px 1fr 32px 60px;align-items:center;padding:10px 16px;transition:background .15s;display:grid}.track-row:hover{background:#ffffff0a}.track-row.is-playing{background:var(--accent-subtle)}.track-number{color:var(--text-muted);font-variant-numeric:tabular-nums;text-align:center;font-size:14px}.track-row:hover .track-number{color:var(--text-primary)}.track-row.is-playing .track-number{color:var(--accent)}.track-title{font-size:15px;font-weight:400}.track-row.is-playing .track-title{color:var(--accent);font-weight:500}.track-duration{color:var(--text-muted);text-align:right;font-variant-numeric:tabular-nums;font-size:14px}.favorite-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:color .2s,transform .2s;display:flex}.favorite-btn:hover{color:var(--accent);transform:scale(1.15)}.favorite-btn.is-favorited{color:var(--accent)}.favorite-btn.is-favorited:hover{color:var(--accent-hover)}.access-tooltip{display:inline-block;position:relative}.access-tooltip-content{background:var(--bg-elevated);border:1px solid var(--border-accent);border-radius:var(--radius-sm);color:var(--accent);white-space:nowrap;cursor:pointer;z-index:10;padding:8px 14px;font-size:13px;transition:background .2s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 8px 24px #00000080}.access-tooltip-content:hover{background:var(--accent-subtle)}.access-tooltip-content:after{content:"";border:6px solid #0000;border-top-color:var(--border-accent);position:absolute;top:100%;left:50%;transform:translate(-50%)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000c;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg-elevated);border:1px solid var(--border-accent);border-radius:var(--radius-lg);width:100%;max-width:440px;padding:36px;animation:.3s slideUp;box-shadow:0 24px 80px #000000b3,0 0 60px #ffffff08}.modal-card h2{font-family:var(--font-display);letter-spacing:1px;text-transform:uppercase;color:var(--text-primary);margin-bottom:8px;font-size:22px;font-weight:700}.modal-card p{color:var(--text-secondary);margin-bottom:24px;font-size:14px;line-height:1.5}.modal-field{margin-bottom:16px}.modal-label{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:6px;font-size:12px;font-weight:600;display:block}.modal-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);background:#ffffff0a;outline:none;padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .2s,box-shadow .2s}.modal-input:focus{border-color:var(--border-accent);box-shadow:0 0 0 3px var(--accent-subtle)}.modal-textarea{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);resize:vertical;background:#ffffff0a;outline:none;min-height:80px;padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .2s,box-shadow .2s}.modal-textarea:focus{border-color:var(--border-accent);box-shadow:0 0 0 3px var(--accent-subtle)}.modal-actions{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.btn-primary{color:#0a0a0a;border-radius:var(--radius-sm);cursor:pointer;letter-spacing:.5px;background:#fff;border:none;padding:10px 24px;font-size:14px;font-weight:600;transition:all .2s}.btn-primary:hover{background:#ccc;box-shadow:0 4px 16px #ffffff1a}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:10px 24px;font-size:14px;font-weight:500;transition:all .2s}.btn-secondary:hover{color:var(--text-primary);background:#ffffff0a}.modal-success{text-align:center;padding:12px 0}.modal-success-icon{margin-bottom:12px;font-size:48px}.favorites-header{margin-bottom:32px}.favorites-header h1{font-family:var(--font-display);letter-spacing:2px;text-transform:uppercase;margin-bottom:8px;font-size:clamp(28px,3vw,44px);font-weight:700}.favorites-header p{color:var(--text-secondary);font-size:15px}.upload-container{max-width:800px;margin:0 auto;padding:40px 0}.upload-title{font-family:var(--font-display);letter-spacing:2px;text-transform:uppercase;margin-bottom:8px;font-size:28px;font-weight:700}.upload-subtitle{color:var(--text-secondary);margin-bottom:32px;font-size:15px}.upload-dropzone{border-radius:var(--radius-lg);text-align:center;cursor:pointer;background:#ffffff03;border:2px dashed #ffffff26;padding:60px 40px;transition:all .3s}.upload-dropzone:hover,.upload-dropzone.is-dragging{border-color:var(--accent);background:#ffffff0a;box-shadow:0 0 40px #ffffff0a}.upload-dropzone-icon{margin-bottom:16px;font-size:48px}.upload-dropzone-text{color:var(--text-primary);margin-bottom:8px;font-size:18px;font-weight:600}.upload-dropzone-hint{color:var(--text-muted);font-size:14px}.upload-album-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:24px;padding:24px}.upload-album-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:20px;display:grid}.upload-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:12px;font-weight:600}.upload-value{color:var(--text-primary);font-size:16px;font-weight:500}.upload-track-list{border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:24px;overflow:hidden}.upload-track-header{background:var(--bg-secondary);color:var(--text-muted);text-transform:uppercase;grid-template-columns:40px 1fr 60px;padding:10px 16px;font-size:12px;font-weight:600;display:grid}.upload-track-row{border-top:1px solid var(--border);grid-template-columns:40px 1fr 60px;align-items:center;padding:12px 16px;font-size:14px;display:grid}.upload-track-num{color:var(--text-muted);text-align:center}.upload-track-title{font-weight:500}.upload-track-dur{color:var(--text-muted);text-align:right;font-variant-numeric:tabular-nums}.upload-actions{justify-content:flex-end;gap:12px;display:flex}.upload-loading{text-align:center;color:var(--text-secondary);padding:60px 20px}.upload-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;margin:0 auto 16px;animation:.8s linear infinite spin}.upload-done{text-align:center;background:var(--accent-subtle);border:1px solid var(--border-accent);border-radius:var(--radius-lg);padding:48px 32px}.upload-done-icon{margin-bottom:16px;font-size:48px}.upload-done h2{font-family:var(--font-display);letter-spacing:1px;text-transform:uppercase;margin-bottom:8px;font-size:24px;font-weight:700}.upload-error{color:var(--text-primary);border-radius:var(--radius-sm);background:#ffffff0d;border:1px solid #ffffff26;margin-bottom:16px;padding:12px 16px;font-size:14px}.upload-progress{border:1px solid var(--border-accent);color:var(--text-primary);border-radius:var(--radius-sm);background:#ffffff08;margin-bottom:16px;padding:12px 16px;font-size:14px}.private-badge{color:var(--accent);letter-spacing:.5px;text-transform:uppercase;background:#ffffff0f;border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.empty-state{text-align:center;color:var(--text-secondary);padding:80px 20px}.empty-state h2{font-family:var(--font-display);color:var(--text-primary);letter-spacing:1px;text-transform:uppercase;margin-bottom:8px;font-size:24px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.nav-mobile-actions{align-items:center;gap:4px;display:none}.nav-mobile-btn{color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:10px;transition:color .2s,background .2s;display:flex}.nav-mobile-btn:hover{color:var(--text-primary);background:#ffffff0f}.nav-hamburger{flex-direction:column;gap:5px;width:44px;height:44px}.hamburger-line{background:var(--text-secondary);border-radius:1px;width:20px;height:2px;transition:transform .3s cubic-bezier(.16,1,.3,1),opacity .2s;display:block}.hamburger-line.open:first-child{transform:translateY(7px)rotate(45deg)}.hamburger-line.open:nth-child(2){opacity:0}.hamburger-line.open:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-search-overlay,.mobile-menu-overlay{display:none}@media (max-width:768px){.nav-links--desktop,.nav-search--desktop{display:none!important}.nav-mobile-actions{display:flex}.nav{gap:8px;padding:8px 12px}.nav-logo{font-size:18px}.nav-year{font-size:13px}.main-content{padding:16px 16px 140px}.mobile-search-overlay{z-index:200;background:var(--bg-primary);flex-direction:column;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.mobile-search-bar{border-bottom:1px solid var(--border);background:var(--bg-secondary);align-items:center;gap:10px;padding:12px 16px;display:flex}.mobile-search-bar .search-icon{color:var(--text-muted);flex-shrink:0;position:static}.mobile-search-bar .search-input{border-radius:10px;flex:1;padding:10px 12px;font-size:16px}.mobile-search-cancel{color:var(--accent);cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;background:0 0;border:none;padding:8px;font-family:inherit;font-size:14px;font-weight:500}.mobile-search-results{-webkit-overflow-scrolling:touch;flex:1;overflow-y:auto}.mobile-search-results .search-item{min-height:48px;padding:14px 16px}.mobile-menu-overlay{z-index:150;-webkit-backdrop-filter:blur(4px);background:#0009;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.mobile-menu{background:var(--bg-elevated);border-top:1px solid var(--border-accent);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;padding:0 0 env(safe-area-inset-bottom,20px);max-height:80vh;animation:.3s cubic-bezier(.16,1,.3,1) slideMenuUp;overflow-y:auto}@keyframes slideMenuUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.mobile-menu-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 20px 12px;display:flex}.mobile-menu-title{font-family:var(--font-display);letter-spacing:1px;text-transform:uppercase;color:var(--text-secondary);font-size:16px;font-weight:600}.mobile-menu-close{color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;padding:8px;font-size:18px;line-height:1}.mobile-menu-links{padding:8px 0}.mobile-menu-link{color:var(--text-primary);-webkit-tap-highlight-color:transparent;align-items:center;gap:16px;min-height:52px;padding:16px 24px;font-size:16px;font-weight:500;transition:background .15s;display:flex}.mobile-menu-link:hover,.mobile-menu-link:active{color:var(--text-primary);background:#ffffff0a}.mobile-menu-icon{text-align:center;flex-shrink:0;width:28px;font-size:20px}.mobile-menu-footer{border-top:1px solid var(--border);padding:16px 24px}.mobile-menu-logout{border:1px solid var(--border);width:100%;color:var(--text-secondary);letter-spacing:.5px;text-transform:uppercase;border-radius:var(--radius-sm);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;padding:14px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s}.mobile-menu-logout:hover{border-color:var(--border-accent);color:var(--text-primary)}.mobile-menu-login{text-align:center;color:#0a0a0a;letter-spacing:1px;text-transform:uppercase;border-radius:var(--radius-sm);-webkit-tap-highlight-color:transparent;background:#fff;width:100%;padding:14px;font-size:14px;font-weight:700;transition:all .2s;display:block}.mobile-menu-login:hover{color:#0a0a0a;background:#e0e0e0}.hero{padding:48px 0 36px}.hero h1{letter-spacing:2px}.hero p{margin-bottom:28px;padding:0 20px;font-size:14px}.hero-cta{justify-content:center;width:calc(100% - 32px);padding:16px 24px}.cards-grid{grid-template-columns:repeat(2,1fr);gap:12px}.card{padding:12px}.card h3{font-size:13px}.card p{font-size:11px}.card-image{margin-bottom:10px}.section-header h2{letter-spacing:1.5px;font-size:18px}.artist-header{text-align:center;flex-direction:column;align-items:center;gap:16px;margin-bottom:32px;padding:16px 0 0}.artist-photo,.artist-photo-placeholder{width:120px;height:120px}.artist-info h1{font-size:clamp(24px,6vw,32px)}.artist-info p{font-size:14px}.album-header{text-align:center;flex-direction:column;align-items:center;gap:16px;margin-bottom:28px;padding:16px 0 0}.album-cover,.album-cover-placeholder{width:180px;height:180px}.album-meta h1{font-size:clamp(22px,5vw,32px)}.album-details{flex-wrap:wrap;justify-content:center;font-size:13px}.track-row{grid-template-columns:1fr 32px 48px;min-height:48px;padding:14px 12px}.track-number{display:none}.track-title{font-size:14px}.track-duration{font-size:13px}.modal-overlay{align-items:flex-end}.modal-card{padding:28px 20px env(safe-area-inset-bottom,20px);border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-width:none;max-height:90vh;margin:0;animation:.3s cubic-bezier(.16,1,.3,1) slideMenuUp;overflow-y:auto}.modal-card h2{font-size:20px}.modal-actions{flex-direction:column-reverse}.modal-actions .btn-primary,.modal-actions .btn-secondary{text-align:center;width:100%;padding:14px}.login-form{border-radius:var(--radius-md);margin:16px;padding:32px 20px}.login-title{letter-spacing:2px;font-size:26px}.login-button{padding:16px}.favorites-header h1{font-size:clamp(22px,5vw,32px)}.upload-dropzone{padding:40px 20px}.upload-album-card{padding:16px}}@media (max-width:374px){.cards-grid{grid-template-columns:1fr;gap:10px}.hero h1{font-size:28px}.album-cover,.album-cover-placeholder{width:150px;height:150px}.artist-photo,.artist-photo-placeholder{width:100px;height:100px}}.nav-logout{border:1px solid var(--border);color:var(--text-secondary);letter-spacing:.5px;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:20px;padding:6px 16px;font-family:inherit;font-size:12px;font-weight:500;transition:all .2s}.nav-logout:hover{border-color:var(--border-accent);color:var(--text-primary);background:#ffffff0a}.nav-login{border:1px solid var(--accent);letter-spacing:.5px;text-transform:uppercase;border-radius:20px;padding:6px 20px;font-size:12px;font-weight:600;transition:all .2s;color:var(--accent)!important}.nav-login:hover{background:var(--accent);box-shadow:0 0 20px var(--accent-glow);color:var(--bg-primary)!important}.login-container{justify-content:center;align-items:center;min-height:calc(100vh - 200px);padding:40px 20px;display:flex}.login-form{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:400px;padding:48px 40px;position:relative;box-shadow:0 24px 80px #00000080,0 0 60px #ffffff05}.login-form:before{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff08 0%,#0000 70%);width:400px;height:400px;position:absolute;top:-80px;left:50%;transform:translate(-50%)}.login-title{font-family:var(--font-display);letter-spacing:3px;text-transform:uppercase;text-align:center;background:linear-gradient(#fff 0%,#888 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:6px;font-size:32px;font-weight:700}.login-subtitle{text-align:center;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:36px;font-size:13px}.login-error{border-radius:var(--radius-sm);color:#ff6b6b;text-align:center;background:#ff3c3c14;border:1px solid #ff3c3c33;margin-bottom:20px;padding:10px 14px;font-size:13px}.login-field{margin-bottom:20px}.login-field label{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:8px;font-size:11px;font-weight:600;display:block}.login-field input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);background:#ffffff0a;outline:none;padding:12px 16px;font-family:inherit;font-size:16px;transition:border-color .2s,box-shadow .2s,background .2s}.login-field input::placeholder{color:var(--text-muted)}.login-field input:focus{border-color:var(--border-accent);box-shadow:0 0 0 3px var(--accent-subtle);background:#ffffff12}.login-button{color:#0a0a0a;border-radius:var(--radius-sm);letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fff;border:none;width:100%;margin-top:8px;padding:14px;font-family:inherit;font-size:14px;font-weight:700;transition:all .3s;box-shadow:0 4px 20px #ffffff14}.login-button:hover{background:#e0e0e0;transform:translateY(-1px);box-shadow:0 6px 30px #ffffff1f}.login-button:active{transform:translateY(0)}.login-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.enrich-button-wrapper{margin-top:12px}.enrich-btn{border:1px solid var(--border);color:var(--text-secondary);letter-spacing:.5px;cursor:pointer;background:#ffffff0f;border-radius:20px;align-items:center;gap:6px;padding:6px 16px;font-family:inherit;font-size:12px;font-weight:500;transition:all .2s;display:inline-flex}.enrich-btn:hover{border-color:var(--border-accent);color:var(--text-primary);box-shadow:0 0 12px var(--accent-glow);background:#ffffff1a}.enrich-btn--loading{opacity:.7;cursor:wait}.enrich-btn--force{margin-left:8px;padding:4px 12px;font-size:11px}.enrich-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin;display:inline-block}.enrich-msg{border-radius:var(--radius-sm);flex-wrap:wrap;align-items:center;gap:8px;padding:8px 14px;font-size:13px;display:flex}.enrich-msg--success{color:var(--accent);background:#ffffff0d}.enrich-msg--warn{color:#ffc832;background:#ffc8320f}.enrich-msg--not-found{color:var(--text-muted)}.enrich-msg--error{color:#ff6b6b;background:#ff3c3c0f}.tags{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.tag{border:1px solid var(--border);color:var(--text-secondary);letter-spacing:.5px;text-transform:lowercase;background:#ffffff0f;border-radius:12px;padding:3px 10px;font-size:11px;font-weight:500}
