:root{--bg: #0d0d0f;--surface: #16161a;--surface-2: #1f1f24;--surface-3: #2a2a31;--text: #f2f2f5;--muted: #8a8a92;--accent: #e02438;--accent-press: #b81d2e;--accent-soft: rgba(224, 36, 56, .15);--radius: 14px;--radius-sm: 10px;--nav-h: 58px;--mini-h: 60px;--safe-b: env(safe-area-inset-bottom, 0px);--safe-t: env(safe-area-inset-top, 0px)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0}body{background:#000;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,system-ui,sans-serif;overscroll-behavior-y:none}:root{--app-max: 480px}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}img{display:block}input{font-family:inherit}.app{min-height:100%;padding-top:var(--safe-t);max-width:var(--app-max);margin:0 auto;position:relative;background:var(--bg)}.screen{padding:16px 16px calc(var(--nav-h) + var(--mini-h) + var(--safe-b) + 24px) 16px}.screen-title{font-size:26px;font-weight:800;margin:8px 0 18px;letter-spacing:-.02em}.section-title{font-size:18px;font-weight:700;margin:22px 0 12px}.btn-accent{background:var(--accent);color:#fff;font-weight:700;border-radius:var(--radius);padding:14px 18px;font-size:16px;width:100%;transition:background .15s,transform .05s}.btn-accent:active{background:var(--accent-press);transform:scale(.99)}.btn-accent:disabled{opacity:.5}.input{width:100%;background:var(--surface-2);border:1px solid transparent;border-radius:var(--radius);padding:14px 16px;font-size:16px;color:var(--text);outline:none;transition:border-color .15s}.input:focus{border-color:var(--accent)}.input::placeholder{color:var(--muted)}.error-text{color:var(--accent);font-size:14px;margin-top:4px}.spinner{width:28px;height:28px;border:3px solid var(--surface-3);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin:40px auto}@keyframes spin{to{transform:rotate(360deg)}}.muted{color:var(--muted)}.h-scroll{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:4px}.h-scroll::-webkit-scrollbar{display:none}.bottom-nav{position:fixed;left:50%;transform:translate(-50%);width:100%;max-width:var(--app-max);bottom:0;height:calc(var(--nav-h) + var(--safe-b));padding-bottom:var(--safe-b);display:flex;background:#0d0d0feb;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-top:1px solid var(--surface-2);z-index:30}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);font-size:11px;font-weight:600}.bottom-nav a.active{color:var(--accent)}.bottom-nav svg{width:24px;height:24px}.mini-player{position:fixed;left:50%;transform:translate(-50%);width:min(calc(100% - 16px),calc(var(--app-max) - 16px));bottom:calc(var(--nav-h) + var(--safe-b) + 6px);height:var(--mini-h);background:var(--surface-2);border-radius:var(--radius);display:flex;align-items:center;gap:12px;padding:0 10px 0 8px;z-index:25;box-shadow:0 8px 24px #0006;overflow:hidden}.mini-player .cover{width:44px;height:44px;border-radius:8px;object-fit:cover;background:var(--surface-3);flex-shrink:0}.mini-player .meta{flex:1;min-width:0}.mini-player .title{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-player .artist{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-player .progress{position:absolute;bottom:0;left:0;height:2px;background:var(--accent)}.play-btn{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.play-btn:active{background:var(--accent-press)}.play-btn svg{width:20px;height:20px}.track-row{display:flex;align-items:center;gap:12px;padding:8px 0;width:100%;text-align:left}.track-row .cover{width:48px;height:48px;border-radius:8px;object-fit:cover;background:var(--surface-3);flex-shrink:0}.track-row .meta{flex:1;min-width:0}.track-row .t{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-row .a{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-row.playing .t{color:var(--accent)}.track-row .dur{font-size:12px;color:var(--muted)}.explicit{display:inline-block;font-size:9px;background:var(--surface-3);color:var(--muted);border-radius:3px;padding:1px 3px;margin-left:6px;vertical-align:middle}.pl-card{width:150px;flex-shrink:0;scroll-snap-align:start}.pl-card .cover{width:150px;height:150px;border-radius:var(--radius);object-fit:cover;background:var(--surface-3)}.pl-card .t{font-size:14px;font-weight:600;margin-top:8px;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.pl-card .s{font-size:12px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.artist-chip{width:110px;flex-shrink:0;text-align:center;scroll-snap-align:start}.artist-chip .cover{width:110px;height:110px;border-radius:50%;object-fit:cover;background:var(--surface-3)}.artist-chip .n{font-size:13px;font-weight:600;margin-top:8px}.full-player{position:fixed;top:0;bottom:0;left:50%;width:100%;max-width:var(--app-max);z-index:50;background:linear-gradient(180deg,#1a1216 0%,var(--bg) 55%);display:flex;flex-direction:column;padding:calc(var(--safe-t) + 14px) 24px calc(var(--safe-b) + 28px);transform:translate(-50%);transition:transform .28s cubic-bezier(.2,.8,.2,1)}.full-player.hidden{transform:translate(-50%,100%);pointer-events:none}.fp-top{display:flex;align-items:center;justify-content:center;position:relative;height:40px}.fp-chevron{position:absolute;left:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.fp-cover{width:min(78vw,340px);aspect-ratio:1;border-radius:20px;object-fit:cover;background:var(--surface-2);margin:auto;box-shadow:0 20px 60px #00000080}.fp-info{margin:24px 0 12px}.fp-title{font-size:22px;font-weight:800}.fp-artist{font-size:16px;color:var(--muted);margin-top:4px}.seek{width:100%}.seek-bar{position:relative;height:4px;background:var(--surface-3);border-radius:2px;margin:8px 0 4px}.seek-fill{position:absolute;left:0;top:0;height:100%;background:var(--accent);border-radius:2px}.seek-times{display:flex;justify-content:space-between;font-size:12px;color:var(--muted)}.fp-controls{display:flex;align-items:center;justify-content:space-between;margin-top:22px}.fp-controls button{color:var(--text);display:flex;align-items:center;justify-content:center}.fp-controls .icon{width:30px;height:30px}.fp-controls .secondary{color:var(--muted)}.fp-controls .secondary.on{color:var(--accent)}.fp-play{width:68px;height:68px;border-radius:50%;background:var(--accent);color:#fff}.fp-play:active{background:var(--accent-press)}.fp-play svg{width:30px;height:30px}.empty{text-align:center;color:var(--muted);padding:60px 20px}
