:root{--bg-base: #121212;--bg-highlight: #1a1a1a;--bg-elevated: #242424;--bg-elevated-hover: #2a2a2a;--bg-card: #181818;--bg-card-hover: #282828;--bg-tracks: #121212;--bg-header: rgba(18, 18, 18, .6);--text-primary: #fff;--text-secondary: #b3b3b3;--text-subdued: #6a6a6a;--text-tag: #7a7a7a;--accent: #1db954;--accent-hover: #1ed760;--accent-active: #169c46;--player-height: 90px;--sidebar-width: 240px;--sidebar-bg: #000;--border: #333;--card-radius: 6px}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{border:none;background:none;cursor:pointer;color:inherit;font:inherit}input{font:inherit;color:inherit}ul{list-style:none}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#555;border:3px solid var(--bg-base);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#777}.app-layout{display:flex;height:100%;padding-bottom:var(--player-height)}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;padding:0;position:relative}.sidebar-logo{padding:24px 24px 18px}.sidebar-close{display:none;position:absolute;top:12px;right:12px;width:28px;height:28px;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-secondary);font-size:18px;cursor:pointer;border-radius:50%}.sidebar-close:hover{background:#ffffff1a;color:var(--text-primary)}.sidebar-logo svg{width:130px;height:40px}.sidebar-nav{display:flex;flex-direction:column;padding:0 8px;gap:2px;margin-bottom:18px}.sidebar-nav a,.sidebar-nav button{display:flex;align-items:center;gap:16px;padding:10px 16px;border-radius:4px;font-size:14px;font-weight:600;color:var(--text-secondary);transition:all .2s;width:100%;text-align:left;height:40px}.sidebar-nav a:hover,.sidebar-nav button:hover{color:var(--text-primary)}.sidebar-nav a.active,.sidebar-nav button.active{color:var(--text-primary);background:var(--bg-elevated)}.sidebar-nav .nav-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-nav .nav-icon svg{width:24px;height:24px;fill:currentColor;opacity:.7}.sidebar-nav a:hover .nav-icon svg,.sidebar-nav button:hover .nav-icon svg,.sidebar-nav a.active .nav-icon svg{opacity:1}.sidebar-divider{height:1px;background:var(--bg-elevated);margin:0 24px 18px}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;padding:8px 24px 8px 16px}.sidebar-section-header span{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-secondary)}.sidebar-section-header button{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:18px;transition:all .2s}.sidebar-section-header button:hover{color:var(--text-primary);background:var(--bg-elevated)}.sidebar-playlists{padding:0 8px;display:flex;flex-direction:column;gap:2px;flex:1;min-height:0;overflow-y:auto}.sidebar-playlists a{display:block;padding:10px 16px;font-size:14px;font-weight:400;color:var(--text-secondary);border-radius:4px;transition:all .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-playlists a:hover{color:var(--text-primary)}.main-content{flex:1;display:flex;flex-direction:column;overflow-y:auto;background:linear-gradient(180deg,var(--page-bg, #121212) 0%,var(--bg-base) 420px);position:relative}.main-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:transparent;transition:background .3s}.main-header.scrolled{background:#12121299;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-left{display:flex;align-items:center;gap:16px}.header-nav-buttons{display:flex;gap:8px}.nav-arrow-btn{width:32px;height:32px;border-radius:50%;background:#0006;display:flex;align-items:center;justify-content:center;color:var(--text-primary);font-size:14px;transition:all .2s}.nav-arrow-btn:hover{background:#0009}.header-search{position:relative;width:364px}.header-search .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-secondary);pointer-events:none}.header-search .search-icon svg{width:16px;height:16px;fill:currentColor}.header-search input{width:100%;height:40px;padding:6px 12px 6px 40px;border-radius:20px;border:none;background:var(--bg-elevated);color:var(--text-primary);font-size:14px;outline:none}.header-search input::placeholder{color:var(--text-secondary)}.header-search input:focus{background:var(--bg-elevated-hover);outline:2px solid var(--text-primary);outline-offset:-2px}.header-right{display:flex;align-items:center;gap:8px}.header-user-btn{height:32px;padding:0 16px;border-radius:16px;background:#0006;font-size:13px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px;transition:all .2s}.header-user-btn:hover{background:#0009}.header-user-btn .avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:14px;color:#000;font-weight:700}.sidebar-brand{font-size:22px;font-weight:800;color:var(--text-primary);letter-spacing:-.5px}.content-area{padding:0 32px 98px;flex:1;position:relative;z-index:1}.page-title{font-size:32px;font-weight:700;margin-bottom:24px;letter-spacing:-.5px}.page-subtitle{font-size:14px;color:var(--text-secondary);margin-bottom:24px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.section-header h2{font-size:24px;font-weight:700}.section-header a{font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;transition:all .2s}.section-header a:hover{color:var(--text-primary)}.albums-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:24px}.album-card{background:var(--bg-card);border-radius:var(--card-radius);padding:16px;transition:background .3s;cursor:pointer;position:relative}.album-card:hover{background:var(--bg-card-hover)}.album-card:hover .card-play-btn{opacity:1;transform:translateY(0)}.album-cover-wrap{position:relative;margin-bottom:16px;aspect-ratio:1;border-radius:4px;overflow:hidden;background:var(--bg-elevated);box-shadow:0 0 12px #0000004d}.album-cover-wrap img{width:100%;height:100%;object-fit:cover;display:block}.album-cover-wrap .placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;color:var(--text-tag);background:var(--bg-elevated)}.card-play-btn{position:absolute;bottom:8px;right:8px;width:48px;height:48px;border-radius:50%;background:var(--accent);color:#000;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(8px);transition:all .3s ease;box-shadow:0 4px 12px #00000080}.card-play-btn:hover{background:var(--accent-hover);transform:scale(1.06)}.card-play-btn svg{width:20px;height:20px;fill:#000;margin-left:2px}.album-card-title{font-size:14px;font-weight:700;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.album-card-desc{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.album-page{position:relative;margin:0 -32px;padding:0 32px}.album-gradient{position:absolute;top:0;left:0;right:0;height:420px;pointer-events:none;z-index:0}.album-detail{position:relative;z-index:1;display:flex;gap:32px;align-items:flex-end;padding:40px 0 32px}.album-detail-cover{width:232px;height:232px;flex-shrink:0;border-radius:4px;overflow:hidden;box-shadow:0 8px 32px #0009}.album-detail-cover img{width:100%;height:100%;object-fit:cover;display:block}.album-detail-cover .placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:80px;background:var(--bg-elevated);color:var(--text-tag)}.album-detail-info{display:flex;flex-direction:column;gap:8px;padding-bottom:8px;min-width:0}.album-detail-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px}.album-detail-title{font-size:clamp(28px,5vw,72px);font-weight:800;line-height:1.1;letter-spacing:-1px;word-break:break-word}.album-detail-meta-row{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:14px;color:var(--text-secondary);flex-wrap:wrap}.album-detail-meta-row .album-artist-link{font-weight:700;color:var(--text-primary);transition:all .2s}.album-detail-meta-row .album-artist-link:hover{text-decoration:underline;color:var(--text-primary)}.album-detail-meta-row .dot{font-size:4px;color:var(--text-secondary)}.album-actions-row{display:flex;align-items:center;gap:24px;padding:16px 0;position:relative;z-index:1}.play-circle-btn{width:56px;height:56px;border-radius:50%;background:var(--accent);color:#000;display:flex;align-items:center;justify-content:center;transition:all .2s}.play-circle-btn:hover{background:var(--accent-hover);transform:scale(1.04)}.play-circle-btn svg{width:24px;height:24px;fill:#000;margin-left:2px}.action-icon-btn{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s}.action-icon-btn:hover{color:var(--text-primary)}.action-icon-btn.liked{color:var(--accent)}.action-icon-btn.liked:hover{color:var(--accent-hover)}.action-icon-btn svg{width:24px;height:24px;fill:currentColor}.more-btn svg{width:20px;height:20px;fill:currentColor}.tracklist-container{padding:0;position:relative;z-index:1}.tracklist-header{display:grid;grid-template-columns:16px 4fr 3fr 2fr minmax(80px,1fr);padding:0 16px 8px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1.2px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:4px;align-items:center;height:36px}.track-item--album,.tracklist-header.tracklist-header--album{grid-template-columns:16px 4fr 3fr minmax(80px,1fr)}.tracklist-header span:last-child{text-align:right;justify-self:end}.track-item--album .track-cell-album{display:none}.track-item{display:grid;grid-template-columns:16px 4fr 3fr 2fr minmax(80px,1fr);padding:8px 16px;border-radius:4px;font-size:14px;cursor:pointer;transition:background .2s;align-items:center;height:56px;gap:8px}.track-item:hover{background:#ffffff0f}.track-item.active{background:#ffffff14}.track-item.active .track-cell-number .number,.track-item:hover .track-cell-number .number{display:none}.track-item.active .track-cell-number .play-icon,.track-item:hover .track-cell-number .play-icon{display:flex}.track-cell-number{position:relative;display:flex;align-items:center;justify-content:center}.track-cell-number .number{font-size:14px;color:var(--text-secondary)}.track-cell-number .play-icon{display:none;align-items:center;justify-content:center}.track-cell-number .play-icon svg{width:14px;height:14px;fill:var(--text-primary)}.track-item.active .track-cell-number .play-icon svg{width:14px;height:14px}.track-cell-title{display:flex;flex-direction:column;gap:2px;min-width:0}.track-cell-title .title-text{font-size:14px;font-weight:400;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-item.active .track-cell-title .title-text{color:var(--accent)}.track-cell-title .title-sub{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-item.active .track-cell-title .title-sub{color:var(--accent);opacity:.7}.track-cell-artist{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-item:hover .track-cell-artist{color:var(--text-primary)}.track-cell-album{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-cell-duration{font-size:13px;color:var(--text-secondary);text-align:right;white-space:nowrap}.track-item:hover .track-cell-duration .duration-text{display:none}.track-item:hover .track-cell-duration .duration-actions{display:flex}.duration-text{display:block}.duration-actions{display:none;align-items:center;gap:8px;justify-content:flex-end}.duration-actions button{width:16px;height:16px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s}.duration-actions button:hover{color:var(--text-primary)}.duration-actions button svg{width:14px;height:14px;fill:currentColor}.player-bar{position:fixed;bottom:0;left:0;right:0;height:var(--player-height);background:#181818;border-top:1px solid #282828;display:grid;grid-template-columns:1fr 2fr 1fr;align-items:center;padding:0 16px;z-index:200;gap:16px}.player-left{display:flex;align-items:center;gap:14px;min-width:0}.player-cover{width:56px;height:56px;border-radius:4px;overflow:hidden;flex-shrink:0;background:var(--bg-elevated)}.player-cover img{width:100%;height:100%;object-fit:cover;display:block}.player-cover .player-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--text-tag)}.player-track-meta{display:flex;flex-direction:column;gap:2px;min-width:0}.player-track-name{font-size:13px;font-weight:400;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.player-track-name:hover{text-decoration:underline;cursor:pointer}.player-track-artist{font-size:11px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.player-track-artist:hover{color:var(--text-primary);text-decoration:underline;cursor:pointer}.player-track-actions{display:flex;align-items:center;gap:8px;margin-left:4px}.player-icon-btn{background:none;border:none;color:#b3b3b3;cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:color .2s}.player-icon-btn:hover{color:#fff}.player-icon-btn.active{color:#1db954}.player-icon-btn:hover{color:var(--text-primary)}.player-icon-btn svg{width:16px;height:16px;fill:currentColor}.player-icon-btn.like-btn svg{width:14px;height:14px}.player-icon-btn.picture-in-picture svg{width:16px;height:16px}.player-center{display:flex;flex-direction:column;align-items:center;gap:4px;max-width:600px;margin:0 auto;width:100%}.player-controls-row{display:flex;align-items:center;gap:16px}.player-control-btn{display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s}.player-control-btn:hover{color:var(--text-primary)}.player-control-btn svg{fill:currentColor}.player-control-btn.shuffle-btn svg{width:16px;height:16px}.player-control-btn.prev-btn svg{width:16px;height:16px}.player-control-btn.play-pause-btn{width:32px;height:32px;border-radius:50%;background:var(--text-primary);color:#000;transition:all .2s}.player-control-btn.play-pause-btn:hover{transform:scale(1.06)}.player-control-btn.play-pause-btn svg{width:16px;height:16px;fill:#000}.player-control-btn.next-btn svg{width:16px;height:16px}.player-control-btn.repeat-btn{position:relative}.player-control-btn.repeat-btn svg{width:16px;height:16px}.player-control-btn.active{color:var(--accent)!important}.repeat-one-indicator{position:absolute;top:-2px;right:-4px;font-size:8px;font-weight:700;color:var(--accent)}.player-progress-row{display:flex;align-items:center;gap:8px;width:100%}.progress-time{font-size:11px;font-weight:400;color:var(--text-secondary);min-width:40px;text-align:center;font-variant-numeric:tabular-nums}.progress-bar-track{flex:1;height:4px;background:#ffffff26;border-radius:2px;cursor:pointer;position:relative;transition:height .1s}.progress-bar-track:hover{height:6px}.progress-bar-fill{height:100%;background:var(--text-primary);border-radius:2px;position:relative;transition:background .1s;max-width:100%}.progress-bar-track:hover .progress-bar-fill{background:var(--accent)}.progress-bar-thumb{position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:50%;background:var(--text-primary);opacity:0;transition:opacity .15s;box-shadow:0 2px 4px #00000080}.progress-bar-track:hover .progress-bar-thumb{opacity:1}.player-right{display:flex;align-items:center;justify-content:flex-end;gap:4px}.player-right .player-icon-btn svg{width:16px;height:16px}.volume-control{display:flex;align-items:center;gap:4px;width:140px}.volume-bar-track{flex:1;height:4px;background:#ffffff26;border-radius:2px;cursor:pointer;transition:height .1s}.volume-bar-track:hover{height:6px}.volume-bar-fill{position:relative;height:100%;background:var(--text-primary);border-radius:2px;transition:background .1s,width .1s;max-width:100%;cursor:pointer}.volume-bar-track:hover .volume-bar-fill{background:var(--accent)}.volume-bar-thumb{position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:50%;background:var(--text-primary);opacity:0;transition:opacity .15s;box-shadow:0 0 4px #0006;cursor:grab}.volume-bar-track:hover .volume-bar-thumb,.volume-bar-track:active .volume-bar-thumb{opacity:1}.lyrics-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;flex-direction:column;animation:lyricsFadeIn .3s ease-out}@keyframes lyricsFadeIn{0%{opacity:0}to{opacity:1}}.lyrics-visualizer{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:1;opacity:1;pointer-events:none}.lyrics-overlay-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;background:radial-gradient(ellipse at center top,#0a0a14d9,#000000f2);cursor:pointer}.lyrics-fullscreen-close{position:absolute;top:20px;left:20px;z-index:10;background:#00000080;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;width:36px;height:36px}.lyrics-fullscreen-close:hover{background:#ffffff26;transform:scale(1.05)}.lyrics-track-info{position:absolute;top:20px;left:68px;z-index:10;display:flex;flex-direction:column;gap:2px}.lyrics-track-name{color:#fff;font-size:14px;font-weight:600}.lyrics-track-artist{color:#b3b3b3;font-size:12px}.lyrics-fullscreen-body{position:relative;z-index:5;flex:1;overflow-y:auto;scroll-behavior:smooth;scroll-padding:45vh 0;padding:10px 0 calc(45vh + var(--player-height))}.lyrics-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#727272;font-size:16px}.lyrics-fullscreen-body::-webkit-scrollbar{width:8px}.lyrics-fullscreen-body::-webkit-scrollbar-thumb{background:#535353;border-radius:4px}.lyrics-fullscreen-body::-webkit-scrollbar-track{background:transparent}.lyrics-empty{text-align:center;color:#727272;font-size:16px}.lyrics-fullscreen-text{color:#b3b3b3;font-size:18px;line-height:2;white-space:pre-wrap;font-family:inherit;text-align:center;max-width:700px;margin:0 auto}.lyrics-fullscreen-timed{display:flex;flex-direction:column;align-items:center;gap:16px;padding:60px 0;max-width:700px;width:100%;margin:0 auto}.lyrics-fullscreen-line{font-size:32px;font-weight:500;color:#404040;transition:color .4s ease;line-height:1.6;padding:6px 0;text-align:center;width:100%;-webkit-user-select:none;user-select:none}.lyrics-fullscreen-line:hover{color:gray}.lyrics-fullscreen-line.past{color:#606060}.lyrics-fullscreen-line.active{color:#fff;font-weight:700}.admin-page{max-width:800px}.admin-section{background:var(--bg-elevated);border-radius:8px;padding:24px;margin-bottom:24px}.admin-section h2{font-size:18px;font-weight:600;margin-bottom:16px}.admin-input-group{display:flex;gap:8px;margin-bottom:12px}.admin-input{flex:1;background:var(--bg-highlight);border:1px solid var(--border);border-radius:4px;padding:10px 14px;font-size:14px;color:var(--text-primary);outline:none;width:100%}.admin-input:focus{border-color:var(--text-primary)}select.admin-input{cursor:pointer;-moz-appearance:auto;appearance:auto;-webkit-appearance:auto}select.admin-input option{background:var(--bg-highlight);color:var(--text-primary);padding:8px}.admin-btn{padding:10px 24px;background:var(--accent);color:#000;border-radius:20px;font-weight:600;font-size:14px;transition:all .2s;white-space:nowrap;height:40px}.admin-btn:hover{background:var(--accent-hover)}.admin-btn.danger{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.admin-btn.danger:hover{color:var(--text-primary);border-color:var(--text-primary)}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-status{padding:12px 16px;background:var(--bg-highlight);border-radius:4px;margin-top:8px;font-size:14px;color:var(--text-secondary)}.folder-list-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.06)}.folder-list-item:last-child{border-bottom:none}.folder-list-name{font-weight:500;font-size:14px}.folder-list-path{font-size:12px;color:var(--text-secondary);margin-top:2px}.section-title{font-size:24px;font-weight:700;margin-bottom:20px;letter-spacing:-.3px}.schedule-gate{display:flex;align-items:center;justify-content:center;min-height:300px;padding:60px 24px}.schedule-gate-content{text-align:center}.schedule-gate-label{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--text-secondary);margin-bottom:32px}.schedule-gate-timer{display:flex;align-items:center;gap:12px}.schedule-gate-unit{display:flex;flex-direction:column;align-items:center;gap:4px}.schedule-gate-unit-label{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-secondary)}.schedule-gate-sep{font-size:40px;font-weight:800;color:var(--text-secondary);margin-top:-20px}.flip-digit-group{display:flex;gap:4px}.flip-digit{position:relative;width:40px;height:56px;perspective:120px}.flip-digit-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d}.flip-digit-front,.flip-digit-back{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:42px;font-weight:800;color:var(--text-primary);background:var(--bg-elevated);border-radius:6px;backface-visibility:hidden;-webkit-backface-visibility:hidden;line-height:1;font-variant-numeric:tabular-nums;overflow:hidden}.flip-digit-back{transform:rotateX(180deg)}.flip-digit.flipping .flip-digit-inner{animation:flipDigit .35s ease-in-out;transform-origin:center center}@keyframes flipDigit{0%{transform:rotateX(0)}50%{transform:rotateX(-90deg)}to{transform:rotateX(-180deg)}}.flip-digit.flipping .flip-digit-front{animation:flipFront .35s ease-in-out}.flip-digit.flipping .flip-digit-back{animation:flipBack .35s ease-in-out}@keyframes flipFront{0%{opacity:1}49%{opacity:1}50%{opacity:0}to{opacity:0}}@keyframes flipBack{0%{opacity:0}49%{opacity:0}50%{opacity:1}to{opacity:1}}.link-like{cursor:pointer;transition:all .2s}.link-like:hover{text-decoration:underline;color:var(--text-primary)}.card-row{display:flex;gap:24px;overflow-x:auto;padding-bottom:8px}.card-row::-webkit-scrollbar{height:6px}.card{min-width:180px;max-width:200px;background:var(--bg-card);border-radius:var(--card-radius);padding:16px;cursor:pointer;transition:background .3s;flex-shrink:0}.card:hover{background:var(--bg-card-hover)}.card-img{width:100%;aspect-ratio:1;border-radius:4px;overflow:hidden;margin-bottom:14px;box-shadow:0 4px 16px #0006;position:relative}.card-img img{width:100%;height:100%;object-fit:cover;display:block}.card-img .placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;background:var(--bg-elevated);color:var(--text-tag);position:absolute;top:0;right:0;bottom:0;left:0}.card-title{font-size:14px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.card-sub{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.release-badge{display:inline-block;padding:1px 6px;border-radius:3px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:#ffffff1a;color:var(--text-secondary);margin-right:2px}.release-badge.single{background:#1db95426;color:var(--accent)}.artist-page{position:relative}.artist-header{display:flex;align-items:flex-end;gap:32px;padding:40px 0 32px}.artist-header-main{display:flex;align-items:flex-end;gap:32px;min-width:0}.artist-cover{width:232px;height:232px;flex-shrink:0;border-radius:50%;overflow:hidden;box-shadow:0 8px 32px #0009}.artist-cover img{width:100%;height:100%;object-fit:cover;display:block}.artist-cover .placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:64px;background:var(--bg-elevated);color:var(--text-tag)}.artist-info{display:flex;flex-direction:column;gap:8px;padding-bottom:8px;min-width:0}.artist-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px}.artist-title{font-size:clamp(28px,5vw,72px);font-weight:800;line-height:1.1;letter-spacing:-1px;word-break:break-word}.artist-meta{font-size:14px;color:var(--text-secondary);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.artist-meta .dot{font-size:4px;color:var(--text-secondary)}.artist-actions{display:flex;align-items:center;gap:24px;padding:16px 0}.artist-section{margin-top:40px}.artist-tracks-layout{display:grid;grid-template-columns:1fr 280px;gap:40px;align-items:start}.artist-tracks-list{min-width:0}.artist-tracks-sidebar{position:sticky;top:100px}.upcoming-card{width:100%;background:linear-gradient(180deg,var(--bg-card-hover) 0%,var(--bg-card) 100%);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;border:1px solid rgba(255,255,255,.04)}.upcoming-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px #0006}.upcoming-cover{width:100%;aspect-ratio:1;overflow:hidden;position:relative}.upcoming-cover img{width:100%;height:100%;object-fit:cover;display:block}.upcoming-cover .placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;background:var(--bg-elevated);color:var(--text-tag)}.upcoming-body{padding:16px}.upcoming-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent);margin-bottom:4px}.upcoming-title{font-size:16px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:14px}.upcoming-timer{display:flex;align-items:center;justify-content:center;gap:0;background:#0003;border-radius:8px;padding:10px 12px;font-variant-numeric:tabular-nums}.upcoming-timer .timer-block{display:flex;flex-direction:column;align-items:center;min-width:36px}.upcoming-timer .timer-num{font-size:22px;font-weight:800;color:var(--text-primary);line-height:1.1}.upcoming-timer .timer-unit{font-size:8px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-subdued);margin-top:2px}.upcoming-timer .timer-sep{font-size:18px;font-weight:800;color:var(--text-subdued);margin:0 4px;padding-top:0}.home-canvas-bg{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;pointer-events:none;overflow:hidden;background:var(--bg-base)}.home-blob{position:absolute;border-radius:50%;filter:blur(100px);animation-name:blobFloat;animation-timing-function:ease-in-out;animation-iteration-count:infinite;will-change:transform}@keyframes blobFloat{0%,to{transform:translate(0) scale(1)}20%{transform:translate(calc(var(--tx, 50px) * .5),calc(var(--ty, -30px) * .5)) scale(var(--sx, 1))}40%{transform:translate(calc(var(--tx, -30px) * 1.2),calc(var(--ty, 40px) * .8)) scale(var(--sy, 1))}60%{transform:translate(calc(var(--tx, 40px) * .7),calc(var(--ty, -20px) * 1.3)) scale(var(--sx, 1) * .95)}80%{transform:translate(calc(var(--tx, -20px) * .9),calc(var(--ty, 30px) * .6)) scale(var(--sy, 1) * 1.05)}to{transform:translate(0) scale(1)}}.home-greeting{font-size:42px;font-weight:800;margin-bottom:4px;letter-spacing:-1px;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:greetingFadeIn .8s ease-out}@keyframes greetingFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.home-greeting-sub{font-size:16px;color:var(--text-secondary);margin-bottom:32px;animation:greetingFadeIn .8s ease-out .15s both}.home-section-glass{background:#1818188c;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:24px;transition:all .3s ease;position:relative;overflow:hidden}.home-section-glass:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(29,185,84,.3),transparent)}.home-track-list{background:transparent!important;border-radius:0!important;padding:0!important}.home-track-list .track-item{border-radius:8px;margin-bottom:2px;position:relative;overflow:hidden}.home-track-list .track-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent);transform:scaleY(0);transition:transform .2s ease}.home-track-list .track-item:hover:before{transform:scaleY(1)}.home-track-list .track-item:hover{background:#1db9540f}.home-track-list .track-item.active{background:#1db9541a}.home-track-list .track-item.active:before{transform:scaleY(1)}@keyframes cardFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.album-card-home{background:#1818188c;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:16px;transition:all .3s ease;cursor:pointer;position:relative;overflow:hidden;animation:cardFloat 4s ease-in-out infinite}.album-card-home:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:16px;padding:1px;background:linear-gradient(135deg,var(--card-glow, transparent),transparent 60%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:0;transition:opacity .4s ease}.album-card-home:hover:before{opacity:1}.album-card-home:hover{background:#1e1e1eb3;border-color:#1db95433;transform:translateY(-4px);box-shadow:0 12px 40px #0000004d}.album-card-home .album-cover-wrap{border-radius:12px;box-shadow:0 4px 16px #0000004d}.album-card-home .card-play-btn{bottom:12px;right:12px}.upcoming-banner-glass{background:#1818188c;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.05);border-radius:20px;overflow:hidden;cursor:pointer;transition:all .3s ease;display:flex;gap:24px;margin-bottom:32px;position:relative}.upcoming-banner-glass:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:20px;padding:1px;background:linear-gradient(135deg,rgba(29,185,84,.2),transparent 50%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.upcoming-banner-glass:hover{transform:translateY(-4px);box-shadow:0 16px 48px #0006;border-color:#1db95426}.home-section-glass .section-header h2{font-size:20px}.home-section-glass .tracklist-container{max-height:360px;overflow-y:auto;scrollbar-width:thin}.home-section-glass .tracklist-container::-webkit-scrollbar{width:4px}.home-section-glass .tracklist-container::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.home-accent-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);margin-left:8px;animation:accentPulse 2s ease-in-out infinite}@keyframes accentPulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.home-sections-row{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:40px}.section-playlist-card{position:relative;border-radius:14px;overflow:hidden;cursor:pointer;aspect-ratio:1;display:flex;flex-direction:column;justify-content:flex-end;padding:20px;transition:transform .25s ease,box-shadow .25s ease}.section-playlist-card:hover{transform:translateY(-3px);box-shadow:0 12px 36px #00000080}.section-card-img-wrap{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-elevated)}.section-card-img-wrap img{width:100%;height:100%;object-fit:cover;display:block}.section-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.section-card-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;color:#fffc;width:88px;height:88px;display:flex;align-items:center;justify-content:center;background:#00000026;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border-radius:50%}.section-card-title{position:relative;z-index:2;font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:2px;text-shadow:0 2px 10px rgba(0,0,0,.6)}.section-card-count{position:relative;z-index:2;font-size:12px;font-weight:500;color:#ffffff80;text-shadow:0 1px 6px rgba(0,0,0,.4)}@media (max-width: 1100px){.home-sections-row{grid-template-columns:repeat(2,1fr)}}.home-quick-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:40px}@media (max-width: 800px){.home-quick-row{grid-template-columns:1fr}}.home-quick-row .track-item{height:44px!important;padding:4px 12px!important;font-size:12px!important}.home-quick-row .track-item .title-text{font-size:12px!important}.home-quick-row .track-item .title-sub{font-size:11px!important}.upcoming-banner{display:flex;gap:24px;background:linear-gradient(135deg,var(--bg-card-hover) 0%,var(--bg-elevated) 100%);border-radius:16px;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;border:1px solid rgba(255,255,255,.05);margin-bottom:32px}.upcoming-banner:hover{transform:translateY(-2px);box-shadow:0 8px 32px #0006}.upcoming-banner-cover{width:180px;min-height:180px;flex-shrink:0;overflow:hidden;position:relative}.upcoming-banner-cover img{width:100%;height:100%;object-fit:cover;display:block}.upcoming-banner-cover .placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;background:var(--bg-elevated);color:var(--text-tag)}.upcoming-banner-body{flex:1;padding:28px 28px 28px 0;display:flex;flex-direction:column;justify-content:center;gap:6px}.upcoming-banner-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent);margin-bottom:2px}.upcoming-banner-title{font-size:28px;font-weight:800;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upcoming-banner-artist{font-size:14px;color:var(--text-secondary);margin-bottom:10px}.upcoming-banner-timer{display:inline-flex;align-items:center;gap:0;background:#0000004d;border-radius:8px;padding:10px 14px;font-variant-numeric:tabular-nums;align-self:flex-start}.upcoming-banner-timer .timer-block{display:flex;flex-direction:column;align-items:center;min-width:36px}.upcoming-banner-timer .timer-num{font-size:24px;font-weight:800;color:var(--text-primary);line-height:1.1}.upcoming-banner-timer .timer-unit{font-size:8px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-subdued);margin-top:2px}.upcoming-banner-timer .timer-sep{font-size:18px;font-weight:800;color:var(--text-subdued);margin:0 4px;padding-top:0}.track-page{position:relative}.track-page-hero{display:flex;gap:32px;align-items:flex-end;padding:40px 0 32px}.track-page-cover{width:232px;height:232px;flex-shrink:0;border-radius:4px;overflow:hidden;box-shadow:0 8px 32px #0009}.track-page-cover img{width:100%;height:100%;object-fit:cover;display:block}.track-page-cover .placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:64px;background:var(--bg-elevated);color:var(--text-tag)}.track-page-info{display:flex;flex-direction:column;gap:8px;padding-bottom:8px;min-width:0}.track-page-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px}.track-page-title{font-size:clamp(28px,5vw,72px);font-weight:800;line-height:1.1;letter-spacing:-1px;word-break:break-word}.track-page-artist-row{display:flex;align-items:center;gap:8px;margin-top:4px;font-size:14px;color:var(--text-secondary)}.track-page-artist-row .link-like{font-weight:700;font-size:14px;color:var(--text-primary)}.track-page-meta{font-size:14px;color:var(--text-secondary);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.track-page-meta .link-like{color:var(--text-secondary);font-weight:500}.track-page-meta .dot{font-size:4px;color:var(--text-secondary)}.track-page-actions{display:flex;align-items:center;gap:24px;margin-top:8px}.track-page-section{margin-top:40px}.track-page-lyrics{max-width:600px;line-height:1.8;font-size:15px;color:var(--text-secondary)}.track-page-lyrics p{margin-bottom:4px}.empty-state{text-align:center;padding:48px 24px;color:var(--text-secondary)}.empty-state .empty-icon{font-size:48px;margin-bottom:16px;opacity:.6}.empty-state h3{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.empty-state p{font-size:14px;max-width:400px;margin:0 auto;line-height:1.5}.admin-input[type=file]{padding:6px;font-size:13px}.admin-input select,.admin-input option{color:var(--text-primary);background:var(--bg-highlight)}textarea.admin-input{font-family:inherit;line-height:1.5}input[type=file]{color:var(--text-secondary);font-size:13px}input[type=file]::file-selector-button{padding:6px 14px;border:1px solid var(--border);border-radius:4px;background:var(--bg-elevated);color:var(--text-primary);font-size:12px;cursor:pointer;margin-right:8px;transition:all .2s}input[type=file]::file-selector-button:hover{background:var(--bg-card-hover);border-color:var(--text-secondary)}input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.glass-panel{background:#18181880;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.05);border-radius:12px;transition:all .3s ease}.glass-panel:hover{background:#1e1e1e8c;border-color:#ffffff14}.glass-panel-light{background:#18181859;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.04);border-radius:12px}.particles-container{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;pointer-events:none;overflow:hidden}.particle{position:absolute;border-radius:50%;background:var(--accent);animation:particleDrift linear infinite}@keyframes particleDrift{0%{transform:translate(0) scale(1);opacity:0}10%{opacity:1}85%{opacity:1}to{transform:translate(var(--dx),var(--dy)) scale(.3);opacity:0}}.player-bar{background:#181818bf!important;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid rgba(255,255,255,.04)!important}@keyframes glowPulse{0%,to{box-shadow:0 0 20px #1db9541a}50%{box-shadow:0 0 40px #1db95433}}.glow-hover{transition:box-shadow .3s ease}.glow-hover:hover{box-shadow:0 0 30px #1db95426}.album-detail{background:linear-gradient(180deg,rgba(0,0,0,.3) 0%,transparent 100%);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:12px;padding:32px;margin:0 -32px}.album-actions-row{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border-radius:12px;padding:16px 8px;margin:0 -8px}.tracklist-container{backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.artist-header,.track-page-hero{background:linear-gradient(180deg,rgba(0,0,0,.2) 0%,transparent 100%);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:12px;padding:32px;margin:0 -32px}.favorites-page-tracks{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.hamburger-btn{display:none;position:fixed;top:12px;left:12px;z-index:110;width:36px;height:36px;border:none;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:4px}.hamburger-btn span{display:block;width:18px;height:2px;background:#fff;border-radius:2px}.sidebar-backdrop{display:none}@media (max-width: 768px){:root{--sidebar-width: 0px;--player-height: 56px}.hamburger-btn{display:flex}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:90}.sidebar{position:fixed;left:-280px;top:0;bottom:0;width:260px;z-index:100;transition:left .25s ease;height:100%}.sidebar.open{left:0}.sidebar-close{display:flex}.app-layout{padding-bottom:var(--player-height)}.main-content{margin-left:0}.main-header{padding:8px 12px 8px 56px!important}.header-nav-buttons{display:none!important}.header-search{width:100%!important;max-width:none!important}.header-search input{font-size:13px!important}.content-area{padding:0 12px 80px!important}.page-title{font-size:24px!important}.home-greeting{font-size:26px!important}.home-greeting-sub{font-size:14px!important}.home-sections-row{grid-template-columns:repeat(2,1fr)!important;gap:12px!important}.section-playlist-card{aspect-ratio:auto!important;min-height:120px}.section-card-icon{width:52px!important;height:52px!important}.section-card-icon svg{width:22px!important;height:22px!important}.section-card-title{font-size:13px!important}.home-quick-row{grid-template-columns:1fr!important;gap:12px!important}.home-section-glass{padding:16px!important}.albums-grid,.card-row{grid-template-columns:repeat(2,1fr)!important;gap:12px!important}.card-row{display:grid!important;overflow-x:visible!important}.card{min-width:0!important}.card-img{aspect-ratio:1}.card-title{font-size:13px!important}.card-sub{font-size:11px!important}.tracklist-header{display:none!important}.track-item{padding:8px 4px!important;gap:8px!important}.track-item--album,.track-item{grid-template-columns:28px 1fr auto!important}.track-cell-artist,.track-cell-album{display:none!important}.track-cell-title{min-width:0!important}.title-text{font-size:13px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.artist-header{flex-direction:column!important;align-items:center!important;padding:20px 12px!important;margin:0 -12px!important;text-align:center;gap:16px!important}.artist-header-main{flex-direction:column!important;align-items:center!important;gap:16px!important}.artist-cover{width:140px!important;height:140px!important}.artist-cover .placeholder{font-size:40px!important}.artist-info{align-items:center!important}.artist-title{font-size:24px!important;text-align:center!important}.artist-meta,.artist-actions{justify-content:center!important}.artist-section{margin-top:24px!important}.artist-tracks-layout{grid-template-columns:1fr!important;gap:20px!important}.artist-tracks-sidebar{position:static!important;width:100%!important}.upcoming-card{display:flex!important;flex-direction:row!important;align-items:center!important;gap:12px!important;padding:12px!important}.upcoming-cover{width:60px!important;height:60px!important;flex-shrink:0!important}.upcoming-body{flex:1!important;min-width:0!important}.upcoming-timer{flex-wrap:wrap!important;gap:4px!important}.timer-num{font-size:18px!important}.timer-unit{font-size:9px!important}.album-page{margin:0 -12px!important;padding:0 12px!important}.album-detail{flex-direction:column!important;align-items:center!important;text-align:center;padding:20px 12px!important;gap:16px!important}.album-detail-cover{width:160px!important;height:160px!important}.album-detail-title{font-size:24px!important;text-align:center!important}.album-detail-info{align-items:center!important}.album-detail-meta-row{justify-content:center!important;font-size:12px!important}.album-actions-row{justify-content:center!important;gap:16px!important}.schedule-gate{min-height:200px!important;padding:32px 12px!important}.schedule-gate-timer{gap:8px!important}.schedule-gate-sep{font-size:32px!important;margin-top:-16px!important}.schedule-gate-unit-label{font-size:10px!important}.flip-digit{width:34px!important;height:48px!important}.flip-digit-front,.flip-digit-back{font-size:28px!important;line-height:48px!important}.flip-digit-group{gap:3px!important}.track-page-hero{flex-direction:column!important;align-items:center!important;text-align:center;padding:20px 12px!important;margin:0 -12px!important;gap:16px!important}.track-page-cover{width:160px!important;height:160px!important}.track-page-info{align-items:center!important}.track-page-title{font-size:24px!important;text-align:center!important}.track-page-artist-row{justify-content:center!important}.track-page-meta{justify-content:center!important;font-size:12px!important}.track-page-actions{justify-content:center!important}.track-page-section{margin-top:24px!important}.track-page-lyrics{font-size:14px!important;padding:0 4px!important}.edit-album-form{grid-template-columns:1fr!important}.admin-page{padding:0!important}.admin-section{padding:12px!important}.player-bar{display:flex!important;flex-wrap:wrap!important;align-items:center!important;height:auto!important;min-height:56px!important;padding:6px 8px!important;gap:2px!important}.player-left{flex:0 1 auto!important;min-width:0!important;max-width:65%!important;gap:8px!important}.player-left .player-cover{width:36px!important;height:36px!important}.player-left .player-track-meta{min-width:0!important}.player-left .player-track-name{font-size:12px!important;max-width:80px!important}.player-left .player-track-artist{font-size:10px!important}.player-left .like-btn{display:none!important}.player-center{flex:1 1 auto!important;min-width:0!important;max-width:none!important;margin:0!important;display:flex!important;align-items:center!important;flex-wrap:wrap!important;gap:2px!important}.player-center .player-controls-row{flex:0 0 auto!important;gap:6px!important;margin-left:auto!important}.player-center .player-controls-row .shuffle-btn,.player-center .player-controls-row .repeat-btn{display:none!important}.player-center .player-controls-row button{width:28px!important;height:28px!important}.player-center .player-controls-row .play-pause-btn{width:32px!important;height:32px!important}.player-center .player-controls-row .play-pause-btn svg{width:28px!important;height:28px!important}.player-center .player-progress-row{flex-basis:100%!important;width:100%!important;gap:4px!important}.player-time{font-size:10px!important;min-width:24px!important}.player-right{display:none!important}}@media (max-width: 480px){.home-sections-row{grid-template-columns:1fr!important}.albums-grid,.card-row{grid-template-columns:1fr 1fr!important;gap:8px!important}.card-row{display:grid!important;overflow-x:visible!important}.page-title{font-size:20px!important}.home-greeting{font-size:22px!important}.main-header{padding:8px 8px 8px 52px!important}.content-area{padding:0 8px 70px!important}.sidebar{width:240px}.album-detail-cover{width:130px!important;height:130px!important}.album-detail-title{font-size:20px!important}.schedule-gate{min-height:180px!important;padding:24px 8px!important}.schedule-gate-timer{gap:6px!important}.schedule-gate-sep{font-size:24px!important;margin-top:-12px!important}.flip-digit{width:28px!important;height:40px!important}.flip-digit-front,.flip-digit-back{font-size:22px!important;line-height:40px!important}}.mini-player{position:fixed;bottom:0;left:0;right:0;height:56px;background:#282828;display:flex;align-items:center;padding:0 12px;gap:8px;z-index:150;border-top:1px solid rgba(255,255,255,.06);cursor:pointer}.mini-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.mini-cover{width:40px;height:40px;border-radius:4px;overflow:hidden;flex-shrink:0}.mini-cover img,.mini-cover .placeholder{width:100%;height:100%;object-fit:cover;display:block}.mini-cover .placeholder{display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);color:var(--text-tag)}.mini-info{min-width:0}.mini-title{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.mini-artist{font-size:11px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.mini-right{display:flex;align-items:center;gap:4px;flex-shrink:0}.mini-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-primary);cursor:pointer;border-radius:50%}.mini-btn:active{background:#ffffff1a}.mini-play-btn{background:var(--text-primary);color:#000;border-radius:50%;width:36px;height:36px}.mini-play-btn:active{transform:scale(.95)}.full-player-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:linear-gradient(180deg,#1a1a1a,#0a0a0a);display:flex;align-items:center;justify-content:center;animation:fp-fade-in .2s ease}@keyframes fp-fade-in{0%{opacity:0}to{opacity:1}}.full-player-content{display:flex;flex-direction:column;align-items:center;gap:20px;padding:24px;width:100%;max-width:420px;max-height:100vh;overflow-y:auto}.full-player-content.lyrics-mode{height:100%;padding:48px 16px 16px;gap:12px}.full-player-close{position:absolute;top:12px;left:12px;width:40px;height:40px;border:none;background:transparent;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;z-index:10}.full-player-close:active{background:#ffffff1a}.full-player-cover-wrap{width:280px;height:280px;max-width:80vw;max-height:50vh;border-radius:12px;overflow:hidden;box-shadow:0 8px 40px #00000080}.full-player-cover-wrap img,.full-player-cover-wrap .placeholder{width:100%;height:100%;object-fit:cover;display:block}.full-player-cover-wrap .placeholder{display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);color:var(--text-tag);font-size:64px}.full-player-info{text-align:center;width:100%}.full-player-title{font-size:20px;font-weight:700;color:var(--text-primary);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.full-player-artist{font-size:14px;color:var(--text-secondary);cursor:pointer}.full-player-artist:active{color:var(--text-primary)}.full-player-progress{display:flex;align-items:center;gap:8px;width:100%}.full-player-progress .progress-bar-track{flex:1}.full-player-controls{display:flex;align-items:center;justify-content:center;gap:24px;width:100%}.fp-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:50%}.fp-btn:active{color:var(--text-primary)}.fp-btn.active{color:var(--accent)}.fp-play-btn{width:64px;height:64px;background:var(--accent);color:#000!important;border-radius:50%}.fp-play-btn:active{transform:scale(.95);background:var(--accent-hover)}.full-player-extras{display:flex;align-items:center;gap:24px}.fp-icon-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:50%}.fp-icon-btn:active{color:var(--text-primary)}.fp-icon-btn.active{color:var(--accent)}.full-player-volume{display:flex;align-items:center;gap:8px;width:100%;max-width:280px}.full-player-volume .volume-bar-track{flex:1}@media (max-width: 768px){.full-player-cover-wrap{width:220px;height:220px}.full-player-content{gap:16px;padding:16px}.full-player-title{font-size:18px}}.fp-lyrics-body{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%;height:100%;flex:1;min-height:0}.fp-lyrics-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0 4px}.fp-lyrics-title{font-size:14px;font-weight:600;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center;flex:1;margin:0 8px}.fp-lyrics-scroll{flex:1;width:100%;overflow-y:auto;display:flex;flex-direction:column;justify-content:flex-start;min-height:0;padding:16px 0;-webkit-overflow-scrolling:touch}.fp-lyrics-line{font-size:18px;font-weight:500;color:#ffffff4d;padding:8px 16px;text-align:center;line-height:1.5;transition:color .2s,font-size .2s;cursor:default}.fp-lyrics-line:not(.no-time){cursor:pointer}.fp-lyrics-line.active{color:var(--text-primary);font-size:20px;font-weight:700}.fp-lyrics-line.no-time{color:#ffffff80;font-size:14px;font-weight:400}.fp-lyrics-plain{font-size:15px;color:var(--text-primary);line-height:1.7;white-space:pre-wrap;text-align:center;padding:16px;max-height:60vh;overflow-y:auto}.fp-lyrics-progress{display:flex;align-items:center;gap:8px;width:100%;padding:0 4px}.fp-lyrics-progress .progress-bar-track{flex:1}.fp-lyrics-controls{display:flex;align-items:center;justify-content:center;gap:24px;width:100%}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 12px #1db9544d;transform:scale(1)}50%{box-shadow:0 0 24px #1db95499;transform:scale(1.05)}}@keyframes itemFadeSlide{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes cardEntrance{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.sidebar-backdrop{animation:fadeIn .2s ease}.sidebar.open .sidebar-nav a{animation:fadeInUp .3s ease both}.sidebar.open .sidebar-nav a:nth-child(1){animation-delay:.02s}.sidebar.open .sidebar-nav a:nth-child(2){animation-delay:.06s}.sidebar.open .sidebar-nav a:nth-child(3){animation-delay:.1s}.sidebar.open .sidebar-nav a:nth-child(4){animation-delay:.14s}.sidebar.open .sidebar-nav a:nth-child(5){animation-delay:.18s}.content-area>*{animation:fadeInUp .35s ease both}.mini-player{animation:slideUp .25s ease}.full-player-modal{animation:slideUp .3s ease}.play-circle-btn{animation:pulseGlow 2.5s ease-in-out infinite}.track-item--album{animation:itemFadeSlide .25s ease both}.track-item--album:nth-child(2){animation-delay:.02s}.track-item--album:nth-child(3){animation-delay:.04s}.track-item--album:nth-child(4){animation-delay:.06s}.track-item--album:nth-child(5){animation-delay:.08s}.track-item--album:nth-child(6){animation-delay:.1s}.track-item--album:nth-child(7){animation-delay:.12s}.track-item--album:nth-child(8){animation-delay:.14s}.track-item--album:nth-child(9){animation-delay:.16s}.track-item--album:nth-child(10){animation-delay:.18s}.track-item--album:nth-child(11){animation-delay:.2s}.track-item--album:nth-child(12){animation-delay:.22s}.track-item--album:nth-child(13){animation-delay:.24s}.track-item--album:nth-child(14){animation-delay:.26s}.track-item--album:nth-child(15){animation-delay:.28s}.track-item--album:nth-child(16){animation-delay:.3s}.track-item--album:nth-child(17){animation-delay:.32s}.track-item--album:nth-child(18){animation-delay:.34s}.track-item--album:nth-child(19){animation-delay:.36s}.track-item--album:nth-child(20){animation-delay:.38s}.track-item--album:nth-child(21){animation-delay:.4s}.track-item--album:nth-child(22){animation-delay:.42s}.track-item--album:nth-child(23){animation-delay:.44s}.track-item--album:nth-child(24){animation-delay:.46s}.track-item--album:nth-child(25){animation-delay:.48s}.card{animation:cardEntrance .35s ease both}.card:nth-child(1){animation-delay:.02s}.card:nth-child(2){animation-delay:.06s}.card:nth-child(3){animation-delay:.1s}.card:nth-child(4){animation-delay:.14s}.card:nth-child(5){animation-delay:.18s}.card:nth-child(6){animation-delay:.22s}.card:nth-child(7){animation-delay:.26s}.card:nth-child(8){animation-delay:.3s}.section-playlist-card{animation:cardEntrance .4s ease both}.section-playlist-card:nth-child(1){animation-delay:.05s}.section-playlist-card:nth-child(2){animation-delay:.1s}.section-playlist-card:nth-child(3){animation-delay:.15s}.section-playlist-card:nth-child(4){animation-delay:.2s}@media (max-width: 768px){.track-item--album:nth-child(n){animation-delay:0s!important}.card:nth-child(n){animation-delay:0s!important}.section-playlist-card:nth-child(n){animation-delay:0s!important}.sidebar.open .sidebar-nav a:nth-child(n){animation-delay:0s!important}.sidebar-backdrop{animation:fadeIn .15s ease!important}.mini-player{animation:slideUp .2s ease!important}.full-player-modal{animation:slideUp .25s ease!important}.content-area>*{animation:fadeInUp .25s ease!important}}
