:root{color-scheme:dark;--bg: #0f0f0f;--fg: #f1f1f1;--muted: #a0a0a0;--accent: #ff3a3a;--card: #1a1a1a;--border: #2a2a2a}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;background:var(--bg);color:var(--fg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;-webkit-font-smoothing:antialiased}.app{max-width:480px;margin:0 auto;padding:max(1rem,env(safe-area-inset-top)) 1rem env(safe-area-inset-bottom)}h1{font-size:1.25rem;font-weight:600;margin:0 0 1rem}.form{display:flex;gap:.5rem;margin-bottom:1rem}.form input{flex:1;padding:.65rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--card);color:var(--fg);font-size:1rem}.form button{padding:.65rem 1rem;border-radius:8px;border:none;background:var(--accent);color:#fff;font-size:1rem;font-weight:600;cursor:pointer}.form button:disabled{opacity:.5}.error{background:#3a1a1a;color:#ffb4b4;padding:.6rem .75rem;border-radius:8px;font-size:.9rem;margin-bottom:1rem}.player{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.player .art{width:100%;border-radius:8px;aspect-ratio:16 / 9;object-fit:cover;background:#000}.player .title{font-weight:600;line-height:1.3}.player .uploader{color:var(--muted);font-size:.9rem;margin-top:.15rem}.player audio{width:100%}.player .hint{color:var(--muted);font-size:.8rem}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.primary{padding:.5rem .8rem;border-radius:8px;border:none;background:var(--accent);color:#fff;font-weight:600;cursor:pointer}.link{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:.9rem}.back-btn{display:inline-flex;align-items:center;gap:.4rem;background:transparent;border:1px solid var(--border);border-radius:999px;color:var(--fg);cursor:pointer;font-size:1rem;font-weight:600;padding:.4rem .8rem}.back-btn:hover{background:var(--border)}.back-btn span{font-size:1.2rem;line-height:1}.hint{color:var(--muted);font-size:.9rem;padding:.5rem 0}.list{list-style:none;padding:0;margin:1rem 0;display:flex;flex-direction:column;gap:.5rem}.row{width:100%;display:flex;gap:.75rem;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:.5rem;cursor:pointer;text-align:left;color:var(--fg)}.row:hover{background:#222}.thumb{width:64px;height:64px;object-fit:cover;border-radius:6px;background:#000;flex-shrink:0}.row-text{min-width:0;flex:1}.row-title{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-sub{color:var(--muted);font-size:.85rem;margin-top:.15rem}.detail h2{font-size:1.05rem;margin:.5rem 0}.back{background:transparent;border:none;color:var(--muted);cursor:pointer;padding:.25rem 0;font-size:.9rem;margin-top:.5rem}.row-wrap{display:flex;align-items:stretch;gap:.4rem}.row-wrap .row{flex:1}.row-action{background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:8px;padding:0 .7rem;font-size:.85rem;cursor:pointer}.row-action:hover{color:var(--fg);border-color:#444}.thumb-placeholder{display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:1.2rem}.player-controls{display:flex;align-items:center;gap:.5rem;margin-top:.25rem}.player-controls button{background:transparent;color:var(--fg);border:1px solid var(--border);border-radius:8px;padding:.35rem .7rem;font-size:.9rem;cursor:pointer}.player-controls button:disabled{opacity:.4;cursor:not-allowed}.shuffle{margin-left:auto;color:var(--muted);font-size:.9rem;display:flex;align-items:center;gap:.35rem}.queue{list-style:none;padding:0;margin:0;flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.queue li+li{border-top:1px solid #1c1c1c}.queue-row{width:100%;display:flex;align-items:center;gap:.6rem;background:transparent;border:none;padding:.45rem .25rem;cursor:pointer;color:var(--fg);text-align:left}.queue-row:hover{background:#161616}.queue-row--current{background:#ff3a3a14}.queue-row--current .queue-title{color:var(--accent);font-weight:600}.queue-num{width:1.6rem;text-align:center;color:var(--muted);font-size:.85rem;flex-shrink:0}.queue-row--current .queue-num{color:var(--accent)}.queue-thumb{width:36px;height:36px;border-radius:4px;object-fit:cover;background:#000;flex-shrink:0}.queue-text{display:flex;flex-direction:column;min-width:0;flex:1}.queue-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.95rem}.queue-sub{color:var(--muted);font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nowplaying{position:fixed;top:0;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;display:flex;flex-direction:column;background:var(--bg);z-index:10;padding:max(.75rem,env(safe-area-inset-top)) 1rem env(safe-area-inset-bottom);gap:.5rem}.nowplaying-top{display:flex;justify-content:flex-start;margin-bottom:.25rem}.player-panel{flex:0 0 auto;background:var(--bg);padding-bottom:.5rem;border-bottom:1px solid #1a1a1a}.queue-row--current{scroll-margin-top:.25rem}.shuffle-btn{margin-left:auto}.now-playing-bar{display:flex;align-items:center;gap:.6rem;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:.5rem;margin-bottom:.75rem;width:100%;cursor:pointer;color:var(--fg);text-align:left}.now-playing-bar img{width:40px;height:40px;object-fit:cover;border-radius:4px}.np-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.95rem;font-weight:500}.np-sub{color:var(--muted);font-size:.8rem;flex-shrink:0}.signin-panel{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem 1rem;text-align:center;min-height:60vh}.signin-panel .hint{max-width:18rem}.signin-btn{padding:.8rem 1.5rem;font-size:1rem}.toast{background:#2a1a1a;color:#ffd0d0;border:1px solid #4a2a2a;border-radius:8px;padding:.55rem .75rem;font-size:.9rem;margin-bottom:.5rem;animation:toast-in .2s ease-out}@keyframes toast-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
