:root,[data-theme=light]{--bg: #ececef;--panel: #ffffff;--text: #1b1b1f;--muted: #6a6a73;--muted-2: #a0a0aa;--line: rgba(0, 0, 0, .08);--accent: #6b4ef0;--row-hover: #f4f4f6;--chip-hover: #e8e8ec;--cover-fallback: #e2e2e6;--promo-bg: #1c1c24;--promo-text: #ffffff;--btn-bg: #111111;--btn-text: #ffffff;--shadow: 0 1px 2px rgba(0,0,0,.04), 0 4px 16px rgba(0,0,0,.05);--radius: 16px}[data-theme=dark]{--bg: #0d0d11;--panel: #17171c;--text: #f1f1f4;--muted: #9a9aa6;--muted-2: #66666f;--line: rgba(255, 255, 255, .09);--accent: #8a6dff;--row-hover: rgba(255, 255, 255, .06);--chip-hover: rgba(255, 255, 255, .1);--cover-fallback: #2a2a31;--promo-bg: #26262e;--promo-text: #ffffff;--btn-bg: #f1f1f4;--btn-text: #111111;--shadow: 0 1px 2px rgba(0,0,0,.5)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input{font-family:inherit}a{color:inherit;text-decoration:none}.pl-cover,.t-cover,.artist-avatar,.now-cover,.avatar,.hero-art{background-size:cover;background-position:center;background-repeat:no-repeat;background-color:var(--cover-fallback)}.app{height:100vh;padding:14px;display:flex;flex-direction:column;gap:12px}.topbar{display:flex;align-items:center;gap:16px;padding:2px 6px}.brand{width:38px;height:38px;border-radius:10px;overflow:hidden;flex-shrink:0}.brand img{width:100%;height:100%;object-fit:cover;display:block}.topnav{display:flex;align-items:center;gap:4px}.navbtn{display:inline-flex;align-items:center}.navbtn{padding:8px 16px;border-radius:10px;font-size:15px;font-weight:500;color:var(--muted)}.navbtn:hover{color:var(--text)}.navbtn.active{background:var(--panel);color:var(--text);font-weight:600;box-shadow:var(--shadow)}.searchbar{margin-left:auto;display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--line);padding:10px 16px;border-radius:12px;width:420px;max-width:38vw;color:var(--muted-2)}.searchbar input{border:none;outline:none;background:none;width:100%;font-size:14px;color:var(--text)}.searchbar input::placeholder{color:var(--muted-2)}.icon-btn{display:grid;place-items:center;width:40px;height:40px;border-radius:10px;color:var(--text)}.icon-btn.sm{width:32px;height:32px;color:var(--muted)}.icon-btn:hover{background:var(--row-hover)}.icon-btn.ghost{background:#ffffff29;color:#fff;width:36px;height:36px}.icon-btn.ghost:hover{background:#ffffff47}.icon-btn.badge{position:relative}.icon-btn.badge:after{content:"";position:absolute;top:9px;right:10px;width:7px;height:7px;border-radius:50%;background:#ff4d6d;border:1.5px solid var(--bg)}.avatar{width:40px;height:40px;border-radius:10px;background-image:url(https://picsum.photos/seed/me/80/80)}.body{flex:1;min-height:0;display:flex}.tab-panel{flex:1;min-height:0}.home-grid{flex:1;display:grid;grid-template-columns:280px 1fr 320px;gap:12px;min-height:0}.page{flex:1;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);min-height:0;overflow:hidden}.page.scroll{overflow-y:auto;padding-bottom:28px}.page-head{display:flex;align-items:center;justify-content:space-between;padding:28px 28px 8px}.page-head h1{margin:0;font-size:30px;font-weight:800;letter-spacing:-.5px}.block{padding:18px 28px 6px}.block-title{font-size:22px;font-weight:700;margin:0 0 12px}.sub-block{margin-bottom:14px}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-head h2{margin:0;font-size:19px;font-weight:700}.see-all{font-size:13px;font-weight:600;color:var(--muted)}.see-all:hover{color:var(--text)}.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:11px;background:var(--accent);color:#fff;font-weight:600;font-size:14px}.btn-primary:hover{filter:brightness(1.08)}.row-list{display:flex;flex-direction:column}.load-more-wrap{display:flex;justify-content:center;padding:18px 0 6px}.load-more{padding:10px 24px;border-radius:22px;border:1px solid var(--line);background:var(--panel);color:var(--text);font-weight:600;font-size:14px}.load-more:hover{border-color:var(--text)}.load-more:disabled{opacity:.6;cursor:default}.lrow{display:grid;grid-template-columns:36px 48px 1fr 36px 56px 36px;align-items:center;gap:12px;height:64px;border-radius:10px;padding:0 8px}.lrow:hover,.lrow.current{background:var(--row-hover)}.lrow.current .lrow-title{color:var(--accent)}.lrow-index{position:relative;display:flex;align-items:center;justify-content:center;color:var(--muted)}.lrow-num{font-size:14px}.lrow-play{position:absolute;display:none;color:var(--text)}.lrow:hover .lrow-num{opacity:0}.lrow:hover .lrow-play{display:block}.lrow-cover{width:48px;height:48px;border-radius:8px;position:relative;background-size:cover;background-position:center;background-repeat:no-repeat;background-color:var(--cover-fallback)}.lrow-meta{min-width:0}.lrow-title{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lrow-sub{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dot-sep{color:var(--muted-2)}.badge-pill{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--accent);background:#6b4ef01a;padding:2px 7px;border-radius:6px}.lrow-time{color:var(--muted);font-size:14px;text-align:right;font-variant-numeric:tabular-nums}.carousel{display:flex;gap:16px;overflow-x:auto;padding-bottom:8px}.carousel::-webkit-scrollbar{height:8px}.artist-card{width:130px;flex-shrink:0;cursor:pointer;text-align:center}.artist-card-cover{width:130px;height:130px;border-radius:50%;position:relative;margin-bottom:10px}.artist-card-name{font-weight:600;font-size:14px;display:flex;align-items:center;justify-content:center;gap:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.artist-card-sub{font-size:12px;color:var(--muted);margin-top:2px}.artist-card-cover.ph,.artist-tile-cover.ph,.artist-avatar.ph{display:flex;align-items:center;justify-content:center}.ph>span:not(.rank-badge){font-weight:700;color:var(--muted)}.artist-card-cover.ph>span:not(.rank-badge),.artist-tile-cover.ph>span:not(.rank-badge){font-size:40px}.artist-avatar.ph>span{font-size:17px}.rank-badge{position:absolute;top:-4px;left:-4px;width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:13px;color:#fff;border:2px solid var(--panel)}.rank-1{background:#e8b923}.rank-2{background:#b6bdc6}.rank-3{background:#cd7f44}.pl-card{width:180px;flex-shrink:0;text-align:left}.pl-card-cover{width:180px;height:180px;border-radius:12px;position:relative;margin-bottom:10px;background-size:cover;background-position:center;background-color:var(--cover-fallback)}.pl-card-play{position:absolute;right:10px;bottom:10px;width:42px;height:42px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;opacity:0;transform:translateY(6px);transition:.18s;box-shadow:0 6px 16px #0003}.pl-card:hover .pl-card-play{opacity:1;transform:translateY(0)}.pl-card-name{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pl-card-sub{font-size:13px;color:var(--muted)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:22px;padding:8px 28px}.card-grid .pl-card,.card-grid .pl-card-cover{width:100%}.card-grid .pl-card-cover{aspect-ratio:1;height:auto}.follow-btn{padding:7px 18px;border-radius:20px;border:1px solid var(--line);font-weight:600;font-size:13px;background:var(--panel);color:var(--text)}.follow-btn:hover{border-color:var(--text)}.follow-btn.following{background:var(--accent);color:#fff;border-color:var(--accent)}.artists-block{padding:12px 28px}.creator-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.feat-carousel{position:relative;padding:0 44px}.feat-stage{position:relative;height:220px;border-radius:18px;background-size:cover;background-position:center top;background-color:var(--cover-fallback);overflow:hidden;cursor:pointer;display:flex;align-items:center}.feat-stage:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#000000b3,#00000059 55%,#00000026)}.feat-stage-body{position:relative;z-index:1;padding:0 36px;color:#fff;max-width:70%}.feat-name{font-size:34px;font-weight:800;letter-spacing:-.5px;display:flex;align-items:center;gap:8px}.feat-sub{font-size:15px;color:#ffffffd9;margin-top:2px}.feat-meta{font-size:13px;color:#ffffffb3;margin:8px 0 16px}.feat-explore{background:#fff;color:#111;font-weight:700;font-size:14px;padding:10px 22px;border-radius:22px}.feat-explore:hover{transform:scale(1.04)}.feat-arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:var(--row-hover);border:1px solid var(--line);display:grid;place-items:center;color:var(--text);z-index:2}.feat-arrow:hover{background:var(--chip-hover)}.feat-arrow.left{left:0}.feat-arrow.right{right:0}.feat-dots{display:flex;justify-content:center;gap:7px;margin-top:14px}.feat-dot{width:7px;height:7px;border-radius:50%;background:var(--line);cursor:pointer;transition:width .2s}.feat-dot.on{width:22px;border-radius:4px;background:var(--accent)}.creator-card{background:var(--row-hover);border:1px solid var(--line);border-radius:14px;padding:12px;text-align:center;cursor:pointer;transition:transform .15s ease}.creator-card:hover{transform:translateY(-3px)}.creator-cover{width:100%;aspect-ratio:1;border-radius:10px;background-size:cover;background-position:center;background-color:var(--cover-fallback);margin-bottom:10px;display:grid;place-items:center}.creator-ph{font-weight:700;font-size:34px;color:var(--muted-2)}.creator-name{font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;gap:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.creator-genre{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.creator-stats{font-size:11px;color:var(--muted-2);margin:2px 0 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.artist-hero{position:relative;height:200px;border-radius:0;background-size:cover;background-position:center;background-color:var(--cover-fallback);display:flex;align-items:flex-end}.artist-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0003,#0009)}.back-btn.floating{position:absolute;top:18px;left:18px;z-index:2;background:#0006;color:#fff;border:none}.back-btn.floating:hover{background:#0009}.artist-hero-body{position:relative;z-index:1;display:flex;align-items:center;gap:16px;padding:24px 28px}.artist-hero-avatar{width:84px;height:84px;border-radius:50%;border:3px solid var(--panel);background-size:cover;background-position:center;background-color:var(--cover-fallback);display:grid;place-items:center}.artist-hero-name{font-size:26px;font-weight:800;color:#fff;display:flex;align-items:center;gap:6px}.artist-hero-meta{font-size:13px;color:#fffc;margin-top:2px}.explore-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:24px;padding:22px 28px 28px;align-items:start}.explore-main{min-width:0}.explore-main .block{padding:14px 0 6px}.greeting{margin:0 0 4px;font-size:30px;font-weight:800;letter-spacing:-.6px}.greeting .wave{display:inline-block}.explore-rail{display:flex;flex-direction:column;gap:16px;position:sticky;top:0}.allsongs-card{background:var(--row-hover);border:1px solid var(--line);border-radius:16px;padding:16px}.allsongs-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.allsongs-head h2{margin:0;font-size:18px;font-weight:700}.allsongs-tools{display:flex;align-items:center;gap:6px}.mini-pill{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:600;color:var(--muted);background:var(--panel);border:1px solid var(--line);padding:5px 9px;border-radius:8px}.mini-pill:hover{color:var(--text)}.dropdown{position:relative}.dropdown-menu{position:absolute;right:0;top:calc(100% + 4px);z-index:20;background:var(--panel);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);padding:4px;min-width:140px}.dropdown-menu button{display:block;width:100%;text-align:left;padding:8px 10px;border-radius:7px;font-size:13px;color:var(--text)}.dropdown-menu button:hover{background:var(--row-hover)}.dropdown-menu button.active{color:var(--accent);font-weight:600}.menu{position:absolute;right:0;top:calc(100% + 4px);z-index:40;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:0 8px 28px #00000040;padding:6px;min-width:184px}.menu button{display:block;width:100%;text-align:left;padding:9px 12px;border-radius:8px;font-size:14px;color:var(--text);white-space:nowrap}.menu button:hover{background:var(--row-hover)}.menu button.danger{color:#e0567a}.nr-menu{position:absolute;top:6px;right:6px;z-index:3}.nr-menu .icon-btn{background:#00000073;color:#fff;width:30px;height:30px}.nr-menu .icon-btn:hover{background:#000000a6}.toast{position:fixed;bottom:96px;left:50%;transform:translate(-50%);z-index:200;background:#1c1c24;color:#fff;padding:10px 18px;border-radius:22px;font-size:14px;font-weight:600;box-shadow:0 8px 28px #00000059}.modal.sm{width:340px}.pl-pick{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:10px;border-radius:10px}.pl-pick:hover{background:var(--row-hover)}.pl-pick.new{color:var(--accent);font-weight:600;margin-bottom:4px}.pl-pick-icon{width:34px;height:34px;border-radius:8px;background:var(--row-hover);display:grid;place-items:center;flex-shrink:0}.pl-pick.new .pl-pick-icon{background:#6b4ef01f}.pl-pick-name{flex:1;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pl-pick-count{font-size:12px;color:var(--muted)}.pl-pick-list{max-height:320px;overflow-y:auto}.pl-card-cover{display:grid;place-items:center}.pl-card-fallback{color:var(--muted-2)}.allsongs-list{display:flex;flex-direction:column}.as-row{display:grid;grid-template-columns:40px 1fr auto;align-items:center;gap:10px;padding:6px;border-radius:9px;cursor:pointer}.as-row:hover{background:var(--panel)}.as-row.current .as-title{color:var(--accent)}.as-cover{width:40px;height:40px;border-radius:7px;background-size:cover;background-position:center;background-color:var(--cover-fallback);position:relative}.as-eq{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#00000059;border-radius:7px;color:#fff}.as-meta{min-width:0}.as-title{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.as-artist{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.as-time{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}.allsongs-foot{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid var(--line);font-size:12px;color:var(--muted)}.pager{display:flex;align-items:center;gap:4px}.pager-now{min-width:22px;text-align:center;font-weight:700;color:var(--text)}.icon-btn.sm:disabled{opacity:.35;cursor:default}.icon-btn.on{color:var(--accent)}.premium{background:#1c1c24;border-radius:16px;padding:20px;color:#fff}.premium-gem{width:44px;height:44px;border-radius:12px;background:#6b4ef040;color:#b9a6ff;display:grid;place-items:center;margin-bottom:12px}.premium h3{margin:0 0 6px;font-size:19px;font-weight:700}.premium p{margin:0 0 16px;font-size:13px;color:#fff9}.premium-btn{width:100%;padding:11px;border-radius:10px;background:var(--accent);color:#fff;font-weight:600}.premium-btn:hover{filter:brightness(1.08)}@media (max-width: 1180px){.explore-grid{grid-template-columns:1fr}.explore-rail{display:none}}.rank-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}.rank-card{background:var(--row-hover);border:1px solid var(--line);border-radius:16px;padding:16px}.rank-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.rank-tag{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:800;letter-spacing:.6px;padding:5px 10px;border-radius:8px;color:#fff}.rank-tag.week{background:#6b4ef0}.rank-tag.today{background:#e0567a}.rank-card-body{display:grid;grid-template-columns:120px 1fr;gap:16px}.rank-cover{aspect-ratio:1;border-radius:12px;background-size:cover;background-position:center;background-color:var(--cover-fallback);position:relative}.rank-play{position:absolute;left:8px;bottom:8px;width:38px;height:38px;border-radius:50%;background:#fff;color:#111;display:grid;place-items:center;box-shadow:0 4px 12px #0000004d}.rank-play:hover{transform:scale(1.06)}.rank-ol{list-style:none;margin:0;padding:0}.rank-ol li{display:grid;grid-template-columns:18px 1fr auto;align-items:center;gap:10px;padding:6px 4px;border-radius:8px;cursor:pointer}.rank-ol li:hover{background:var(--panel)}.rk-num{font-weight:700;color:var(--muted-2);font-size:13px;text-align:center}.rk-title{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rk-time{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}.cover-ph{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:var(--muted-2)}.cat-head{display:flex;align-items:center;gap:14px;padding:24px 28px 4px}.back-btn{width:40px;height:40px;border-radius:50%;background:var(--row-hover);display:grid;place-items:center;color:var(--text);flex-shrink:0}.back-btn:hover{background:var(--chip-hover)}.cat-kind{font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.cat-head h1{margin:2px 0 0;font-size:30px;font-weight:800;letter-spacing:-.5px}.browse-2col{display:grid;grid-template-columns:1fr 1fr;gap:28px}.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.cat-tile{display:flex;align-items:center;gap:12px;padding:10px;border-radius:12px;background:var(--row-hover);text-align:left;transition:background .15s ease}.cat-tile:hover{background:var(--chip-hover)}.cat-ico{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;color:#fff;flex-shrink:0}.cat-label{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nr-row{display:flex;gap:18px;overflow-x:auto;padding-bottom:8px}.nr-card{width:160px;flex-shrink:0;cursor:pointer}.nr-cover{width:160px;height:160px;border-radius:12px;background-size:cover;background-position:center;background-color:var(--cover-fallback);position:relative;margin-bottom:10px}.nr-badge{position:absolute;top:8px;left:8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#fff;background:#0000008c;padding:3px 8px;border-radius:6px}.nr-play{position:absolute;right:10px;bottom:10px;width:42px;height:42px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;opacity:0;transform:translateY(6px);transition:.18s;box-shadow:0 6px 16px #00000040}.nr-card:hover .nr-play{opacity:1;transform:translateY(0)}.nr-title{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nr-artist{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width: 1000px){.rank-cards,.browse-2col{grid-template-columns:1fr}}.collection-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.collection-card{display:flex;align-items:center;gap:14px;padding:16px;border-radius:12px;background:var(--row-hover);text-align:left}.collection-card:hover{background:var(--chip-hover)}.collection-icon{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;color:#fff}.collection-card.liked .collection-icon{background:#e0567a}.collection-card.saved .collection-icon{background:var(--accent)}.collection-name{font-weight:700;font-size:16px}.collection-count{font-size:13px;color:var(--muted)}.profile{padding-bottom:28px}.profile-hero{height:240px;position:relative;background-size:cover;background-position:center;background-color:var(--cover-fallback)}.profile-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#00000026,#00000073)}.profile-hero-actions{position:absolute;top:18px;right:18px;display:flex;gap:10px;z-index:2}.profile-avatar{position:absolute;left:36px;bottom:-44px;width:110px;height:110px;border-radius:50%;border:4px solid var(--panel);background-size:cover;background-position:center;background-color:var(--cover-fallback);z-index:2}.profile-body{padding:56px 36px 0}.profile-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.profile-name{font-size:26px;font-weight:800;display:flex;align-items:center;gap:6px}.profile-handle{color:var(--muted);font-size:14px}.profile-bio{margin:10px 0 18px;font-size:14px;max-width:560px;line-height:1.5}.profile-stats{display:flex;gap:28px;padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.stat{text-align:left;padding:0;background:none}.stat.clickable{cursor:pointer;border-radius:8px}.stat.clickable:hover .stat-value{color:var(--accent)}.stat-value{display:flex;align-items:center;gap:5px;font-size:18px;font-weight:700;color:var(--text)}.stat-label{font-size:12px;color:var(--muted);margin-top:2px}.social-row{display:flex;flex-wrap:wrap;gap:10px;margin:16px 0 4px}.social-icon{width:38px;height:38px;border-radius:10px;background:var(--row-hover);display:grid;place-items:center;transition:transform .15s ease}.social-icon:hover{transform:translateY(-2px);background:var(--chip-hover)}.social-icon img{width:20px;height:20px;object-fit:contain}.follow-list{display:flex;flex-direction:column}.follow-row{display:grid;grid-template-columns:48px 1fr auto;align-items:center;gap:12px;padding:8px;border-radius:10px}.follow-row:hover{background:var(--row-hover)}.follow-avatar{width:48px;height:48px;border-radius:50%;background-size:cover;background-position:center;background-color:var(--cover-fallback);display:grid;place-items:center}.creator-ph.sm{font-size:17px}.follow-name{font-weight:600;font-size:15px;display:flex;align-items:center;gap:5px}.follow-handle{font-size:13px;color:var(--muted)}.profile-body .block{padding:18px 0 6px}.gift-list{display:flex;flex-direction:column;gap:4px}.gift-row{display:grid;grid-template-columns:46px 1fr auto;align-items:center;gap:12px;padding:8px;border-radius:10px}.gift-row:hover{background:var(--row-hover)}.gift-avatar{width:46px;height:46px;border-radius:50%;background-size:cover;background-position:center;background-color:var(--cover-fallback)}.gift-line{font-size:14px}.gift-amount{color:#d39a00;font-weight:700;display:inline-flex;align-items:center;gap:3px}.gift-msg{font-size:13px;color:var(--muted)}.gift-time{font-size:12px;color:var(--muted-2)}.sidebar,.main,.rail-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.sidebar{padding:14px 10px;display:flex;flex-direction:column;min-height:0}.sidebar-head{display:flex;align-items:center;justify-content:space-between;padding:4px 8px 12px}.sort{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--muted);font-size:14px}.sidebar-head-actions{display:flex;gap:2px}.playlist-list{overflow-y:auto;display:flex;flex-direction:column;gap:2px;padding-right:2px}.playlist-row{display:flex;align-items:center;gap:12px;padding:8px;border-radius:10px;text-align:left;width:100%}.playlist-row:hover,.playlist-row.active{background:var(--row-hover)}.pl-cover{width:48px;height:48px;border-radius:8px;flex-shrink:0;position:relative;display:flex;align-items:flex-end;padding:4px}.pl-cover:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:8px;background:#0000002e}.pl-count{position:relative;z-index:1;font-size:10px;color:#fff;font-weight:600}.pl-meta{min-width:0}.pl-name{display:flex;align-items:center;gap:6px;font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pl-name svg{color:var(--accent);flex-shrink:0}.pl-sub{font-size:12px;color:var(--muted)}.main{overflow:hidden;display:flex;flex-direction:column;min-height:0}.hero{position:relative;height:260px;flex-shrink:0;margin:8px;border-radius:12px;overflow:hidden}.hero-art{position:absolute;top:0;right:0;bottom:0;left:0}.hero-art:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#120c1c6b}.hero-overlay{position:absolute;left:28px;bottom:22px;right:28px;z-index:2}.hero-title{margin:0;font-size:60px;font-weight:800;color:#fff;letter-spacing:-1.5px;line-height:1}.hero-sub{margin:12px 0 14px;color:#ffffffd9;font-size:14px}.hero-actions{display:flex;gap:10px}.hero-play{position:absolute;right:28px;bottom:90px;z-index:2;width:60px;height:60px;border-radius:50%;background:#fff;color:#111;display:grid;place-items:center;box-shadow:0 6px 20px #00000040}.hero-play:hover{transform:scale(1.05)}.track-table{flex:1;display:flex;flex-direction:column;min-height:0;padding:0 8px 8px}.track-head,.track-row{display:grid;grid-template-columns:56px 1fr 120px 90px;align-items:center;gap:8px;padding:0 16px}.track-head{color:var(--muted);font-size:13px;font-weight:500;padding-top:8px;padding-bottom:8px;border-bottom:1px solid var(--line)}.track-rows{overflow-y:auto;flex:1}.track-row{height:60px;border-radius:10px}.track-row:hover,.track-row.current{background:var(--row-hover)}.track-row.current .t-name{color:var(--accent)}.t-index{position:relative;display:flex;align-items:center;color:var(--muted)}.t-num{font-size:14px}.t-play{position:absolute;display:none;color:var(--text)}.track-row:hover .t-num{opacity:0}.track-row:hover .t-play{display:block}.track-row.current .t-num{opacity:0}.track-row.current .t-play{display:block;color:var(--accent)}.t-title{display:flex;align-items:center;gap:12px;min-width:0}.t-cover{width:40px;height:40px;border-radius:6px;flex-shrink:0;position:relative}.t-title-text{display:flex;flex-direction:column;min-width:0}.t-name{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.t-artist{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.t-album{color:var(--muted);font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.t-added{color:var(--muted);font-size:14px}.t-time{display:flex;align-items:center;justify-content:flex-end;gap:6px;color:var(--muted);font-size:14px}.t-dots{color:var(--muted-2);display:grid;place-items:center;opacity:0}.track-row:hover .t-dots{opacity:1}.rail{display:flex;flex-direction:column;gap:12px;min-height:0}.rail-card{padding:18px 16px;flex:1;min-height:0;display:flex;flex-direction:column}.rail-head{display:flex;align-items:center;justify-content:space-between;font-size:18px;font-weight:700;margin-bottom:12px}.artist-list{overflow-y:auto;display:flex;flex-direction:column;gap:2px}.artist-row{display:flex;align-items:center;gap:12px;padding:6px;border-radius:10px}.artist-row:hover{background:var(--row-hover)}.artist-avatar{width:46px;height:46px;border-radius:10px;flex-shrink:0}.artist-name{font-weight:600;font-size:15px}.artist-sub{font-size:12px;color:var(--muted)}.promo{background:var(--promo-bg);border-radius:var(--radius);padding:20px;flex-shrink:0;color:var(--promo-text)}.promo h3{margin:0 0 6px;font-size:19px;font-weight:700}.promo p{margin:0 0 16px;font-size:13px;color:#fff9}.promo-btn{width:100%;padding:12px;border-radius:10px;background:#fff;color:#111;font-weight:600}.promo-btn:hover{background:#ededf0}.player{height:76px;flex-shrink:0;background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:var(--radius);display:grid;grid-template-columns:280px 1fr 320px;align-items:center;padding:0 18px;gap:12px}.player-now{display:flex;align-items:center;gap:12px;min-width:0}.player-now .clickable{cursor:pointer}.player-now .now-meta.clickable:hover .now-title{color:var(--accent)}.fullplayer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;background:var(--bg);display:flex;flex-direction:column}.fp-top{display:flex;align-items:center;justify-content:space-between;padding:16px 22px}.fp-eyebrow{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}.fp-body{flex:1;min-height:0;display:grid;grid-template-columns:1fr 380px;gap:24px;padding:8px 28px 36px}.fp-main{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;min-width:0}.fp-cover{width:320px;height:320px;max-width:60vh;aspect-ratio:1;border-radius:18px;background-size:cover;background-position:center;background-color:var(--cover-fallback);box-shadow:0 20px 60px #0006}.fp-info{text-align:center}.fp-title{font-size:26px;font-weight:800;letter-spacing:-.5px}.fp-artist{font-size:15px;color:var(--muted);margin-top:4px}.fp-seek{display:flex;align-items:center;gap:12px;width:100%;max-width:560px}.fp-controls{display:flex;align-items:center;gap:22px}.fp-play{width:64px;height:64px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center}.fp-play:hover{transform:scale(1.05)}.fp-volume{display:flex;align-items:center;gap:10px;color:var(--muted);width:100%;max-width:220px}.fp-volume input{flex:1;accent-color:var(--accent)}.fp-side{background:var(--row-hover);border:1px solid var(--line);border-radius:16px;padding:16px 18px;overflow-y:auto;display:flex;flex-direction:column}.fp-tabs{display:flex;gap:18px;margin-bottom:14px;border-bottom:1px solid var(--line)}.fp-tabs button{padding:4px 0 10px;font-size:16px;font-weight:700;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px}.fp-tabs button.active{color:var(--text);border-bottom-color:var(--accent)}.fp-lyrics-text{white-space:pre-wrap;font-family:inherit;font-size:15px;line-height:1.9;color:var(--muted);margin:0}.fp-queue{display:flex;flex-direction:column}.fp-q-row{display:grid;grid-template-columns:44px 1fr auto;align-items:center;gap:12px;padding:8px;border-radius:10px;cursor:pointer}.fp-q-row:hover,.fp-q-row.current{background:var(--panel)}.fp-q-row.current .fp-q-title{color:var(--accent)}.fp-q-cover{width:44px;height:44px;border-radius:8px;background-size:cover;background-position:center;background-color:var(--cover-fallback)}.fp-q-meta{min-width:0}.fp-q-title{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fp-q-artist{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fp-q-time{font-size:12px;color:var(--muted)}@media (max-width: 900px){.fp-body{grid-template-columns:1fr}.fp-side{display:none}}.now-cover{width:48px;height:48px;border-radius:8px;flex-shrink:0}.now-meta{min-width:0}.now-title{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.now-artist{font-size:12px;color:var(--muted)}.player-center{display:flex;flex-direction:column;align-items:center;gap:6px}.transport{display:flex;align-items:center;gap:14px}.play-main{width:44px;height:44px;border-radius:50%;background:var(--btn-bg);color:var(--btn-text);display:grid;place-items:center}.play-main:hover{transform:scale(1.05)}.seek{display:flex;align-items:center;gap:12px;width:100%;max-width:620px}.seek-time{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}.seek-bar{flex:1;height:4px;border-radius:2px;background:var(--chip-hover);position:relative}.seek-bar{cursor:pointer}.seek-fill{width:0;height:100%;border-radius:2px;background:var(--btn-bg);position:relative}.seek-fill:after{content:"";position:absolute;right:-5px;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:50%;background:var(--btn-bg)}.player-right{display:flex;align-items:center;justify-content:flex-end;gap:8px}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-thumb{background:var(--chip-hover);border-radius:4px}::-webkit-scrollbar-track{background:transparent}.avatar{cursor:pointer}.avatar.active{outline:2px solid var(--accent);outline-offset:2px}.loading{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:14px;padding:24px 4px}.spinner{width:16px;height:16px;border-radius:50%;border:2px solid var(--line);border-top-color:var(--accent);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty{color:var(--muted);font-size:14px;padding:20px 4px}.auth-gate{display:flex;flex-direction:column;align-items:center;gap:14px;padding:64px 24px;color:var(--muted);text-align:center}.auth-gate p{margin:0;font-size:15px}.app-splash{height:100vh;display:grid;place-items:center;background:var(--bg)}.app-splash .spinner{width:28px;height:28px;border-width:3px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;z-index:100}.modal-overlay.gate{background:var(--bg);-webkit-backdrop-filter:none;backdrop-filter:none}.modal{width:380px;max-width:90vw;background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:28px;box-shadow:0 20px 60px #0000004d}.modal-brand{width:44px;height:44px;border-radius:12px;overflow:hidden;margin-bottom:16px}.modal-brand img{width:100%;height:100%;object-fit:cover;display:block}.modal h2{margin:0 0 6px;font-size:24px;font-weight:800}.modal-sub{margin:0 0 20px;color:var(--muted);font-size:14px}.google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px;border-radius:11px;border:1px solid var(--line);background:var(--panel);color:var(--text);font-weight:600;font-size:14px}.google-btn:hover{background:var(--row-hover);border-color:var(--text)}.auth-divider{display:flex;align-items:center;gap:12px;margin:14px 0;color:var(--muted-2);font-size:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--line)}.auth-form{display:flex;flex-direction:column;gap:10px}.auth-form input{padding:12px 14px;border-radius:11px;border:1px solid var(--line);background:var(--bg);color:var(--text);font-size:14px;outline:none}.auth-form input:focus{border-color:var(--accent)}.auth-submit{justify-content:center;margin-top:6px}.auth-submit:disabled{opacity:.6;cursor:default}.auth-error{color:#e0567a;font-size:13px}.auth-notice{color:var(--muted);font-size:13px}.auth-toggle{margin-top:16px;width:100%;text-align:center;font-size:13px;color:var(--muted);font-weight:600}.auth-toggle:hover{color:var(--text)}.auth-link{display:block;width:100%;text-align:center;margin-top:8px;font-size:13px;color:var(--muted)}.auth-link:hover{color:var(--accent)}.otp-input{text-align:center;letter-spacing:7px;font-size:20px;font-weight:700}@media (max-width: 1100px){.home-grid,.player{grid-template-columns:240px 1fr}.rail,.player-right{display:none}}
