:root{--bg: #0b0910;--bg-2: #14111d;--panel: #181425;--panel-2: #211b30;--line: #2a2438;--text: #f4f1fb;--muted: #a39bb8;--muted-2: #6f6783;--accent: #b15cff;--accent-2: #7b2cbf;--accent-gl: rgba(177, 92, 255, .35);--sql: #4a8fe7;--doc: #57c785;--kv: #f0705f;--graph: #29c5d6;--radius: 12px;--sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--display: "Space Grotesk", var(--sans)}*{box-sizing:border-box}html,body{height:100%;margin:0}body{font-family:var(--sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}input,select,button{font-family:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#2c2540;border-radius:6px}::-webkit-scrollbar-track{background:transparent}.app{display:grid;grid-template-columns:248px 1fr;grid-template-rows:1fr auto;height:100vh}.sidebar{grid-row:1 / 2}.main{grid-row:1 / 2;min-height:0}.player{grid-column:1 / 3}.sidebar{background:linear-gradient(180deg,#100d18,#0a0810);border-right:1px solid var(--line);padding:18px 14px;display:flex;flex-direction:column;gap:18px;overflow:hidden}.brand{display:flex;align-items:center;gap:11px;padding:4px 6px}.brand__name{font-family:var(--display);font-weight:700;font-size:22px;letter-spacing:-.5px}.brand__mark{display:inline-grid;grid-template-columns:repeat(2,7px);gap:3px}.brand__mark span{width:7px;height:7px;border-radius:2px;display:block}.brand__mark span:nth-child(1){background:var(--sql)}.brand__mark span:nth-child(2){background:var(--doc)}.brand__mark span:nth-child(3){background:var(--kv)}.brand__mark span:nth-child(4){background:var(--graph)}.nav{display:flex;flex-direction:column;gap:2px}.nav__item{display:flex;align-items:center;gap:12px;background:none;border:0;color:var(--muted);font-size:14.5px;font-weight:600;padding:10px 12px;border-radius:9px;text-align:left;transition:color .15s,background .15s}.nav__item:hover{color:var(--text);background:var(--panel)}.nav__item.is-active{color:var(--text);background:var(--panel-2)}.nav__ico{font-size:16px;width:18px;text-align:center;opacity:.9}.side-section{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:12px 10px;flex:1;min-height:0;display:flex;flex-direction:column}.side-section__head{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-2);padding:2px 6px 10px}.iconbtn{background:var(--panel-2);border:0;color:var(--muted);width:24px;height:24px;border-radius:7px;font-size:16px;line-height:1}.iconbtn:hover{color:var(--text);background:var(--accent-2)}.playlist-list{overflow-y:auto;display:flex;flex-direction:column;gap:1px}.pl-item{background:none;border:0;color:var(--muted);text-align:left;padding:8px;border-radius:7px;font-size:13.5px;display:flex;flex-direction:column;gap:1px}.pl-item:hover{background:var(--panel);color:var(--text)}.pl-item.is-active{background:var(--panel-2);color:var(--text)}.pl-item small{color:var(--muted-2);font-size:11px}.dbstatus{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:8px 6px 2px;border-top:1px solid var(--line)}.dbstatus__title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2);margin-right:2px}.dbdot{font-size:9.5px;font-weight:700;letter-spacing:.04em;padding:2px 6px;border-radius:5px;color:#0b0910;opacity:.35;position:relative;transition:opacity .3s}.dbdot.is-up{opacity:1}.dbdot.is-down{opacity:1;outline:1px solid #ff5470;filter:grayscale(.6)}.dbdot--sql{background:var(--sql)}.dbdot--doc{background:var(--doc)}.dbdot--kv{background:var(--kv)}.dbdot--graph{background:var(--graph)}.prov{font-size:10px;font-weight:700;letter-spacing:.05em;padding:2px 7px;border-radius:6px;color:#0b0910;vertical-align:middle}.prov--sql{background:var(--sql)}.prov--doc{background:var(--doc)}.prov--kv{background:var(--kv)}.prov--graph{background:var(--graph)}.main{background:radial-gradient(1200px 380px at 20% -8%,rgba(123,44,191,.28),transparent 60%),var(--bg);overflow-y:auto;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:16px;padding:14px 28px;background:linear-gradient(180deg,#0b0910eb,#0b09108c);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.topbar__search{flex:1;max-width:460px}.topbar__search input{width:100%;background:var(--panel);border:1px solid var(--line);color:var(--text);padding:10px 16px;border-radius:999px;font-size:14px;outline:none}.topbar__search input:focus{border-color:var(--accent)}.topbar__user{margin-left:auto;display:flex;align-items:center;gap:10px}.topbar__label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2)}.user-select{background:var(--panel);color:var(--text);border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-size:13.5px;font-weight:500;outline:none}.user-select:focus{border-color:var(--accent)}.view{padding:8px 28px 40px}.sec{margin-top:30px}.sec__head{display:flex;align-items:baseline;gap:11px;margin-bottom:14px}.sec__head h2{font-family:var(--display);font-size:21px;font-weight:600;letter-spacing:-.4px;margin:0}.sec__head .hint{font-size:12.5px;color:var(--muted-2);margin-left:auto}.hero{display:flex;align-items:flex-end;gap:22px;padding:30px 0 6px}.hero__cover{width:168px;height:168px;border-radius:16px;flex-shrink:0;box-shadow:0 18px 50px #00000080;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:46px;color:#fff}.hero__kind{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.hero h1{font-family:var(--display);font-size:40px;line-height:1.05;margin:8px 0 10px;letter-spacing:-1px}.hero__sub{color:var(--muted);font-size:14px}.hero__sub b{color:var(--text)}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:16px}.card{background:var(--panel);border:1px solid transparent;border-radius:var(--radius);padding:14px;text-align:left;transition:background .15s,border-color .15s,transform .15s;display:flex;flex-direction:column;gap:10px;color:inherit}.card:hover{background:var(--panel-2);border-color:var(--line)}.card__cover{width:100%;aspect-ratio:1;border-radius:9px;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:26px;color:#fff;position:relative;overflow:hidden}.card__rank{position:absolute;left:8px;bottom:8px;font-family:var(--display);font-size:30px;font-weight:700;color:#ffffffd9;text-shadow:0 2px 12px rgba(0,0,0,.5)}.card__title{font-weight:600;font-size:14px;line-height:1.25}.card__sub{color:var(--muted);font-size:12.5px}.card__play{position:absolute;right:8px;bottom:8px;width:38px;height:38px;border-radius:50%;border:0;background:var(--accent);color:#18091f;font-size:15px;display:grid;place-items:center;opacity:0;transform:translateY(6px);transition:.15s;box-shadow:0 8px 20px var(--accent-gl)}.card:hover .card__play{opacity:1;transform:translateY(0)}.tracklist{display:flex;flex-direction:column}.trow{display:grid;grid-template-columns:28px 1fr 1.1fr 88px 120px;align-items:center;gap:12px;padding:9px 10px;border-radius:8px;color:var(--muted);font-size:13.5px}.trow:hover{background:var(--panel);color:var(--text)}.trow__head{color:var(--muted-2);font-size:11px;text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--line);border-radius:0;padding-bottom:8px}.trow__head:hover{background:none;color:var(--muted-2)}.trow__idx{text-align:right;color:var(--muted-2)}.trow__main{display:flex;align-items:center;gap:11px;min-width:0;cursor:pointer}.trow__cover{width:38px;height:38px;border-radius:6px;flex-shrink:0;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:13px;color:#fff}.trow__t{min-width:0}.trow__name{color:var(--text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trow__artist{color:var(--muted);font-size:12px}.trow__album{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trow__plays{display:flex;align-items:center;gap:6px;color:var(--muted)}.trow__actions{display:flex;gap:6px;justify-content:flex-end}.trow__actions button{background:none;border:0;color:var(--muted-2);font-size:15px;width:30px;height:30px;border-radius:7px}.trow__actions button:hover{color:var(--text);background:var(--panel-2)}.trow__actions .heart.is-on{color:var(--accent)}.artist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.acard{text-align:center}.empty{color:var(--muted);font-size:14px;padding:40px 0;text-align:center}.empty b{color:var(--text)}.player{display:grid;grid-template-columns:1fr 1.4fr 1fr;align-items:center;gap:16px;padding:12px 22px;background:linear-gradient(180deg,#15111f,#0e0b15);border-top:1px solid var(--line)}.player__track{display:flex;align-items:center;gap:12px;min-width:0}.player__cover{width:50px;height:50px;border-radius:8px;flex-shrink:0;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:16px;color:#fff}.player__meta{min-width:0}.player__title{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player__artist{color:var(--muted);font-size:12.5px}.heart{background:none;border:0;color:var(--muted);font-size:18px;padding:4px}.heart:hover,.heart.is-on{color:var(--accent)}.player__center{display:flex;flex-direction:column;align-items:center;gap:8px}.play-toggle{width:42px;height:42px;border-radius:50%;border:0;background:var(--text);color:#14101f;font-size:13px;display:grid;place-items:center}.play-toggle:hover{transform:scale(1.05)}.progress{width:min(420px,38vw);height:4px;background:#2a2438;border-radius:3px;overflow:hidden}.progress__bar{height:100%;width:0%;background:linear-gradient(90deg,var(--accent-2),var(--accent))}.player__right{display:flex;align-items:center;gap:8px;justify-content:flex-end}.plays{font-family:var(--display);font-weight:700;font-size:15px}.plays__label{font-size:11px;color:var(--muted-2);text-transform:uppercase;letter-spacing:.06em}.drawer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.drawer__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#04030899;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.drawer__panel{position:absolute;right:0;top:0;bottom:0;width:min(440px,92vw);background:var(--bg-2);border-left:1px solid var(--line);padding:26px;overflow-y:auto;animation:slideIn .22s ease}@keyframes slideIn{0%{transform:translate(20px);opacity:.6}to{transform:none;opacity:1}}.dr-cover{width:100%;aspect-ratio:1;border-radius:14px;margin-bottom:16px;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:44px;color:#fff}.dr-title{font-family:var(--display);font-size:24px;margin:0 0 2px;letter-spacing:-.3px}.dr-artist{color:var(--muted);margin-bottom:16px}.dr-block{margin-top:18px}.dr-block__head{display:flex;align-items:center;gap:8px;margin-bottom:9px;font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted-2)}.chips{display:flex;flex-wrap:wrap;gap:7px}.chip{background:var(--panel-2);color:var(--text);font-size:12px;padding:5px 11px;border-radius:999px}.feat{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.feat div{background:var(--panel);border-radius:9px;padding:9px 11px}.feat span{display:block;font-size:11px;color:var(--muted-2)}.feat b{font-family:var(--display);font-size:16px}.credits{display:flex;flex-direction:column;gap:6px}.credits div{display:flex;justify-content:space-between;font-size:13px}.credits span{color:var(--muted)}.statline{display:flex;gap:18px;margin:6px 0 2px}.statline div b{font-family:var(--display);font-size:19px;display:block}.statline div span{font-size:11px;color:var(--muted-2)}.lyrics{font-size:13px;color:var(--muted);line-height:1.7;white-space:pre-line;max-height:200px;overflow-y:auto}.closebtn{position:absolute;top:18px;right:18px;width:32px;height:32px;border-radius:50%;border:0;background:var(--panel-2);color:var(--text);font-size:16px}.popmenu{position:fixed;z-index:60;min-width:200px;max-height:280px;overflow-y:auto;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:6px;box-shadow:0 18px 50px #00000080}.popmenu__head{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted-2);padding:6px 8px}.popmenu button{display:block;width:100%;text-align:left;background:none;border:0;color:var(--text);padding:8px 9px;border-radius:7px;font-size:13px}.popmenu button:hover{background:var(--accent-2)}.toasts{position:fixed;bottom:96px;left:50%;transform:translate(-50%);z-index:80;display:flex;flex-direction:column;gap:8px;align-items:center}.toast{background:var(--panel-2);border:1px solid var(--line);color:var(--text);padding:10px 16px;border-radius:10px;font-size:13.5px;box-shadow:0 12px 34px #00000080;animation:pop .25s ease;display:flex;align-items:center;gap:9px}@keyframes pop{0%{transform:translateY(10px);opacity:0}to{transform:none;opacity:1}}.spinner{padding:60px 0;text-align:center;color:var(--muted-2)}@media (max-width: 920px){.app{grid-template-columns:208px 1fr}}@media (max-width: 760px){.app{display:block;height:auto;min-height:100vh}.main{min-height:0}.view{padding:16px 16px 176px}.topbar{padding:12px 16px;gap:10px;flex-wrap:wrap}.topbar__search{flex:1 1 100%}.sidebar{position:fixed;left:0;right:0;bottom:0;top:auto;z-index:60;flex-direction:row;gap:0;height:60px;padding:0;border-right:0;border-top:1px solid var(--line);background:#0d0a14}.sidebar .brand,.side-section,.dbstatus{display:none}.nav{flex-direction:row;width:100%;gap:0}.nav__item{flex:1;flex-direction:column;gap:3px;align-items:center;font-size:10.5px;padding:9px 4px;border-radius:0}.nav__item .ic{width:23px;height:23px}.player{position:fixed;left:0;right:0;bottom:60px;top:auto;z-index:59;grid-template-columns:1fr auto;grid-template-areas:"center center" "track right";gap:4px 12px;padding:9px 14px}.player__track{grid-area:track}.player__center{grid-area:center}.player__right{grid-area:right;gap:8px}.plays,.plays__label{display:none}.player__cover{width:42px;height:42px}.yt-link{margin-right:0}.trow{grid-template-columns:26px 1fr auto;gap:8px}.trow__album,.trow__plays{display:none}.drawer__panel{width:100vw;padding:22px 18px}.hero{flex-direction:column;align-items:flex-start;gap:14px;padding:18px 0 4px}.hero__cover{width:120px;height:120px;font-size:34px}.hero h1{font-size:30px}.cards{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}.brand{position:relative}.info{display:inline-grid;place-items:center;width:17px;height:17px;margin-left:7px;border-radius:50%;border:1px solid var(--muted-2);color:var(--muted);font-size:11px;font-style:italic;font-weight:700;cursor:help;outline:none;flex-shrink:0}.info:hover,.info:focus{color:var(--text);border-color:var(--accent)}.info__tip{position:absolute;left:0;top:calc(100% + 8px);z-index:50;background:var(--panel-2);color:var(--text);border:1px solid var(--line);border-radius:9px;padding:9px 12px;font-size:12.5px;font-style:normal;font-weight:500;white-space:nowrap;box-shadow:0 14px 36px #00000080;opacity:0;transform:translateY(-4px);pointer-events:none;transition:opacity .15s,transform .15s}.info:hover .info__tip,.info:focus .info__tip{opacity:1;transform:translateY(0)}.pl-lock{font-size:10px;opacity:.8}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;display:grid;place-items:center}.modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#04030899;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal__panel{position:relative;width:min(420px,92vw);background:var(--bg-2);border:1px solid var(--line);border-radius:14px;padding:24px;box-shadow:0 24px 60px #0009;animation:pop .2s ease}.modal__title{font-family:var(--display);font-size:20px;margin:0 0 16px}.modal__input{width:100%;background:var(--panel);border:1px solid var(--line);color:var(--text);padding:11px 14px;border-radius:9px;font-size:14px;outline:none}.modal__input:focus{border-color:var(--accent)}.modal__label{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted-2);margin:16px 0 8px}.seg{display:flex;gap:8px}.seg__btn{flex:1;background:var(--panel);border:1px solid var(--line);color:var(--muted);padding:10px;border-radius:9px;font-size:13.5px;font-weight:600}.seg__btn.is-on{color:var(--text);border-color:var(--accent);background:var(--panel-2)}.modal__hint{font-size:12px;color:var(--muted-2);margin-top:8px}.modal__actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.btn-ghost{background:none;border:0;color:var(--muted);padding:10px 16px;border-radius:9px;font-weight:600}.btn-ghost:hover{color:var(--text);background:var(--panel)}.btn-accent{background:var(--accent);border:0;color:#18091f;padding:10px 20px;border-radius:9px;font-weight:700}.btn-accent:hover{filter:brightness(1.08)}.sub-badge{margin-left:10px;padding:4px 10px;border-radius:999px;font-size:11.5px;font-weight:600;white-space:nowrap;border:1px solid var(--line)}.sub-badge--ok{color:#57c785;border-color:#57c78580;background:#57c78514}.sub-badge--off{color:#f0705f;border-color:#f0705f80;background:#f0705f14}.ptime{font-size:11px;color:var(--muted-2);font-variant-numeric:tabular-nums;min-width:34px}#t-cur{text-align:right}#t-dur{text-align:left}.player__center{display:flex;align-items:center;gap:10px}.yt-link{font-size:11.5px;font-weight:600;color:var(--muted);text-decoration:none;padding:5px 10px;border:1px solid var(--line);border-radius:999px;margin-right:10px;white-space:nowrap}.yt-link:hover{color:#ff4d4d;border-color:#ff4d4d80}#yt-host{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;overflow:hidden}.ic{width:20px;height:20px;display:block;flex-shrink:0}.ic--fill{fill:currentColor;stroke:none}.nav__item .ic{width:21px;height:21px;opacity:.92}.iconbtn{display:grid;place-items:center}.iconbtn .ic{width:15px;height:15px}.is-on .ic-heart{fill:var(--accent);stroke:var(--accent)}.player__center{flex-direction:row;gap:10px}.player__center .progress{flex:1}.progress{height:5px}.progress__bar{transition:none}.play-toggle{font-size:0}.play-toggle .ic{width:19px;height:19px}.heart{display:inline-grid;place-items:center;width:36px;height:36px;padding:0;border-radius:8px}.heart .ic{width:20px;height:20px}.icon-act{display:inline-grid;place-items:center;width:34px;height:34px;background:none;border:1px solid var(--line);border-radius:9px;color:var(--muted)}.icon-act:hover{color:var(--text);border-color:var(--accent)}.trow__actions button{display:grid;place-items:center}.trow__actions .ic{width:18px;height:18px}.trow__actions .play{color:var(--text)}.act-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.act-play,.act-add{display:inline-flex;align-items:center;gap:7px;white-space:nowrap;border:0;border-radius:999px;font-weight:600;font-size:14px;padding:10px 18px}.act-play{background:var(--accent);color:#18091f}.act-play:hover{filter:brightness(1.08)}.act-add{background:var(--panel-2);color:var(--text)}.act-add:hover{background:var(--panel)}.act-play .ic,.act-add .ic{width:18px;height:18px}.act-icon{display:inline-grid;place-items:center;width:42px;height:42px;background:var(--panel-2);border:0;border-radius:50%;color:var(--muted);padding:0}.act-icon:hover{color:var(--text)}.act-icon.is-on .ic-heart{fill:var(--accent);stroke:var(--accent)}.act-icon .ic{width:20px;height:20px}.play-all{margin-top:12px}.skip{display:inline-grid;place-items:center;width:32px;height:32px;background:none;border:0;color:var(--muted);border-radius:8px}.skip:hover{color:var(--text)}.skip:disabled{opacity:.3;cursor:default}.skip .ic{width:18px;height:18px}.vol-wrap{display:inline-flex;align-items:center;gap:7px;color:var(--muted)}.vol-wrap .ic{width:18px;height:18px}.vol{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:84px;height:4px;background:var(--line);border-radius:999px;outline:none;cursor:pointer}.vol::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:13px;height:13px;border-radius:50%;background:var(--accent);border:0;cursor:pointer}.vol::-moz-range-thumb{width:13px;height:13px;border-radius:50%;background:var(--accent);border:0;cursor:pointer}@media (max-width: 760px){.vol-wrap{display:none}.skip{width:30px;height:30px}}.progress{cursor:pointer;position:relative}.progress__bar{position:relative}.progress__bar:after{content:"";position:absolute;right:-6px;top:50%;width:12px;height:12px;border-radius:50%;background:#fff;transform:translateY(-50%) scale(0);transition:transform .12s}.progress:hover .progress__bar:after{transform:translateY(-50%) scale(1)}.vol-ic{display:inline-grid;place-items:center;width:28px;height:28px;background:none;border:0;color:var(--muted);padding:0;cursor:pointer}.vol-ic:hover{color:var(--text)}.vol-ic .ic{width:18px;height:18px}.repeat-btn.is-on,.loop-btn.is-on{color:var(--accent);border-color:var(--accent)}.pl-controls{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:12px}.play-all{margin-top:0}.follow-btn{background:var(--accent);color:#18091f;border:0;border-radius:999px;font-weight:700;font-size:14px;padding:9px 22px}.follow-btn:hover{filter:brightness(1.08)}.follow-btn.is-following{background:transparent;color:var(--text);border:1px solid var(--line)}.follow-btn.is-following:hover{border-color:#f0705f;color:#f0705f}.me-avatar{width:30px;height:30px;border-radius:50%;border:0;color:#fff;font-weight:700;font-size:12px;display:grid;place-items:center;cursor:pointer;font-family:var(--display);flex-shrink:0}.me-avatar:hover{outline:2px solid var(--accent);outline-offset:1px}.trow.is-playing{background:linear-gradient(90deg,rgba(177,92,255,.16),transparent 70%);border-radius:8px}.trow.is-playing .trow__name{color:var(--accent);font-weight:600}.trow.is-playing .trow__idx{color:var(--accent)}.pl-hero{position:relative}.pl-menu-btn{position:absolute;top:4px;right:0;width:38px;height:38px;display:grid;place-items:center;background:var(--panel-2);border:1px solid var(--line);color:var(--text);border-radius:10px;font-size:22px;line-height:1;cursor:pointer}.pl-menu-btn:hover{border-color:var(--accent)}.pl-menu{position:fixed;z-index:80;min-width:190px;padding:6px;background:var(--panel-2);border:1px solid var(--line);border-radius:12px;box-shadow:0 18px 50px #00000080}.pl-menu button{display:block;width:100%;text-align:left;padding:10px 12px;background:none;border:0;color:var(--text);border-radius:8px;font-size:14px;cursor:pointer}.pl-menu button:hover{background:var(--panel)}.filters{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.f-sel,.f-num{background:var(--panel-2);color:var(--text);border:1px solid var(--line);border-radius:9px;padding:9px 12px;font-size:14px;font-family:inherit;outline:none}.f-sel:focus,.f-num:focus{border-color:var(--accent)}.f-num{width:110px}.f-reset{background:none;border:1px solid var(--line);color:var(--muted);border-radius:9px;padding:9px 14px;font-size:13px;cursor:pointer}.f-reset:hover{color:var(--text);border-color:var(--accent)}.filters__hint{color:var(--muted);font-size:12px;display:inline-flex;align-items:center;gap:7px}.prof-lang{display:inline-flex;flex-direction:column;gap:7px;color:var(--muted);font-size:13px}.prof-lang .f-sel{color:var(--text);min-width:200px}.settings-btn{display:inline-flex;align-items:center;gap:8px;background:var(--panel-2);color:var(--text);border:1px solid var(--line);border-radius:999px;font-weight:600;font-size:14px;padding:9px 18px;cursor:pointer}.settings-btn:hover{border-color:var(--accent)}.settings-btn .ic{width:17px;height:17px}.settings-menu{max-height:320px;overflow:auto}.settings-menu__head{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);padding:6px 12px 4px}.pl-menu button.is-sel{color:var(--accent);font-weight:700}.pl-menu button.is-sel:after{content:" ✓"}.artist-link{color:var(--text);cursor:pointer;text-decoration:none}.artist-link:hover{color:var(--accent);text-decoration:underline}.card--static{cursor:default}.card--static:hover{transform:none}.acard .card__cover{border-radius:50%}.bio{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px 20px}.bio h3{margin:0 0 8px;font-size:17px}.bio p{margin:0;color:var(--muted);line-height:1.55}.bio__src{margin-top:12px;font-size:12px;color:var(--muted-2)}.potw{display:flex;gap:16px;align-items:center;width:100%;text-align:left;background:linear-gradient(120deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:16px;padding:16px;cursor:pointer}.potw:hover{border-color:var(--accent)}.potw__cover{width:96px;height:96px;border-radius:12px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:24px;color:#fff}.potw__title{font-size:19px;font-weight:700}.potw__sub{color:var(--muted);margin:4px 0}.potw__meta{font-size:12px;color:var(--muted-2)}.charts-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}.seg button{background:var(--panel-2);border:1px solid var(--line);color:var(--muted);padding:6px 14px;border-radius:999px;cursor:pointer;font-size:13px}.seg button.is-on{color:#fff;border-color:var(--accent);background:var(--accent-2)}.chart-list{display:flex;flex-direction:column;gap:2px}.chart-row{display:grid;grid-template-columns:34px 1fr auto;align-items:center;gap:14px;background:none;border:0;border-radius:10px;padding:9px 12px;cursor:pointer;text-align:left;color:var(--text)}.chart-row:hover{background:var(--panel)}.chart-rank{font-weight:700;color:var(--muted-2);text-align:center}.chart-title{font-weight:600}.chart-artist{font-size:12px;color:var(--muted);margin-bottom:5px}.chart-bar{height:5px;background:var(--line);border-radius:4px;overflow:hidden}.chart-bar__fill{height:100%;background:linear-gradient(90deg,var(--accent-2),var(--accent));border-radius:4px}.chart-plays{font-variant-numeric:tabular-nums;color:var(--muted);font-size:13px}.stat-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:8px}.stat-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px;text-align:center}.stat-card__v{font-size:30px;font-weight:800;color:var(--accent)}.stat-card__l{color:var(--muted);font-size:13px;margin-top:2px}.bar-row{display:grid;grid-template-columns:150px 1fr 60px;align-items:center;gap:12px;padding:7px 0}.bar-row__lab{font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-row__track{height:10px;background:var(--line);border-radius:6px;overflow:hidden}.bar-row__fill{height:100%;background:linear-gradient(90deg,var(--accent-2),var(--accent))}.bar-row__fill--alt{background:linear-gradient(90deg,#2a6ed0,var(--sql))}.bar-row__val{text-align:right;color:var(--muted);font-size:13px;font-variant-numeric:tabular-nums}.gauges{display:flex;gap:26px;flex-wrap:wrap}.gauge{text-align:center}.gauge__ring{width:92px;height:92px;border-radius:50%;background:conic-gradient(var(--accent) calc(var(--v) * 1%),var(--line) 0);display:flex;align-items:center;justify-content:center;position:relative}.gauge__ring:before{content:"";position:absolute;top:9px;right:9px;bottom:9px;left:9px;background:var(--bg);border-radius:50%}.gauge__ring span{position:relative;font-weight:700;font-size:19px}.gauge__ring small{font-size:11px;color:var(--muted)}.gauge__lab{margin-top:8px;font-size:13px;color:var(--muted)}.plan-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.plan-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:20px;text-align:center}.plan-card.is-current{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-gl)}.plan-card__name{font-size:18px;font-weight:700}.plan-card__price{font-size:26px;font-weight:800;margin:10px 0;color:var(--accent)}.plan-card__price span{font-size:13px;color:var(--muted);font-weight:500}.plan-card__btn{width:100%;padding:9px;border-radius:10px;border:0;cursor:pointer;background:var(--accent);color:#fff;font-weight:600}.plan-card__btn:disabled{background:var(--panel-2);color:var(--muted-2);cursor:default}.inv-table{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:12px;overflow:hidden}.inv-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:8px;padding:11px 16px;border-top:1px solid var(--line);font-size:14px}.inv-row:first-child{border-top:0}.inv-row--head{background:var(--panel);color:var(--muted);font-size:12px;text-transform:uppercase}.inv-status--paid{color:var(--doc)}.inv-status--pending{color:var(--kv)}.inv-status--failed{color:#e0556a}.prof-actions{display:flex;gap:10px;flex-wrap:wrap}.queue-panel{position:fixed;right:18px;bottom:92px;width:340px;max-height:60vh;background:var(--panel);border:1px solid var(--line);border-radius:16px;z-index:60;display:flex;flex-direction:column;box-shadow:0 16px 50px #00000080;overflow:hidden}.queue-panel__head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line);font-weight:600}.queue-panel__body{overflow-y:auto;padding:8px}.qrow{display:grid;grid-template-columns:40px 1fr auto;align-items:center;gap:10px;padding:6px;border-radius:10px}.qrow:hover,.qrow.is-current{background:var(--panel-2)}.qrow__cover{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;cursor:pointer}.qrow__cover .ic{width:16px;height:16px}.qrow.is-current .qrow__title{color:var(--accent)}.qrow__meta{overflow:hidden;cursor:pointer}.qrow__title{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qrow__artist{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qrow__acts{display:flex;gap:2px}.qbtn{background:none;border:0;color:var(--muted-2);cursor:pointer;padding:4px;border-radius:6px}.qbtn:hover:not(:disabled){color:var(--text);background:var(--line)}.qbtn:disabled{opacity:.3;cursor:default}.qbtn .ic{width:16px;height:16px}.pl-collab{display:flex;align-items:center;flex-wrap:wrap;gap:7px;margin-top:12px}.pl-collab__lab{font-size:12px;color:var(--muted-2);margin-right:4px}.chip--add{background:none;border:1px dashed var(--line);color:var(--muted);cursor:pointer}.chip--add:hover{border-color:var(--accent);color:var(--accent)}.chip__x{background:none;border:0;color:var(--muted-2);cursor:pointer;font-size:14px;padding:0 0 0 4px}.chip__x:hover{color:#e0556a}.collab-menu{max-height:280px;overflow-y:auto}.discover{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:12px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px 14px}.disco-q{flex:1 1 280px;min-width:220px;background:var(--bg-2);border:1px solid var(--line);color:var(--text);border-radius:9px;padding:9px 12px;font-size:14px}.disco-q:focus{outline:none;border-color:var(--accent)}.disco-go{background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#fff;border:0;border-radius:9px;padding:9px 16px;font-weight:600;cursor:pointer;white-space:nowrap}.disco-go:disabled{opacity:.6;cursor:default}.queue-panel__head-acts{display:flex;gap:4px}.queue-panel.is-collapsed{max-height:none}.queue-panel.is-collapsed .queue-panel__body{display:none}.queue-panel.is-collapsed #queue-collapse .ic{transform:rotate(180deg)}.potw__title{color:#fff}.potw__sub{color:#e7def5}.potw__meta{color:#b9aed3}.potw__cover{color:#fff}.queue-panel[hidden]{display:none!important}.queue-panel{animation:qSlide .26s cubic-bezier(.2,.8,.2,1)}@keyframes qSlide{0%{transform:translateY(16px);opacity:0}to{transform:none;opacity:1}}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.hero{animation:fadeUp .45s ease both}.sec{animation:fadeUp .5s ease both}.sec:nth-of-type(2){animation-delay:.05s}.sec:nth-of-type(3){animation-delay:.1s}.sec:nth-of-type(4){animation-delay:.15s}.card{animation:pop .4s ease both}.qrow{animation:fadeUp .25s ease both}.card:hover{transform:translateY(-4px);box-shadow:0 12px 28px #00000059}.trow{transition:background .15s,color .15s,transform .12s}.trow:hover{transform:translate(2px)}.chart-bar__fill,.bar-row__fill{transition:width .6s cubic-bezier(.2,.8,.2,1)}.act-play,.act-add,.act-icon,.seg button,.plan-card__btn,.disco-go,.follow-btn,.settings-btn,.chip--add,.qbtn,.icon-act{transition:transform .12s ease,background .15s,color .15s,border-color .15s,filter .15s}.act-play:hover,.disco-go:hover,.plan-card__btn:enabled:hover,.follow-btn:hover{transform:translateY(-2px);filter:brightness(1.08)}.act-play:active,.disco-go:active,.play-toggle:active{transform:scale(.94)}.seg button:hover,.chip--add:hover,.settings-btn:hover{transform:translateY(-1px)}.qbtn:hover:not(:disabled),.icon-act:hover{transform:scale(1.12)}.gauge__ring{transition:filter .2s}.gauge:hover .gauge__ring{filter:brightness(1.12)}.potw{transition:border-color .18s,transform .18s,box-shadow .18s}.potw:hover{transform:translateY(-3px);box-shadow:0 14px 32px #0006}.prov{transition:transform .15s}.trow:hover .prov{transform:scale(1.06)}@media (max-width: 760px){.queue-panel{left:10px;right:10px;width:auto;bottom:132px;max-height:46vh}.stat-cards{grid-template-columns:repeat(3,1fr);gap:8px}.stat-card{padding:12px 8px}.stat-card__v{font-size:22px}.plan-cards{grid-template-columns:1fr}.bar-row{grid-template-columns:92px 1fr 42px;gap:8px}.bar-row__lab{font-size:12px}.gauges{justify-content:space-around;gap:14px;width:100%}.gauge__ring{width:78px;height:78px}.inv-row{grid-template-columns:1.1fr 1.1fr .8fr .8fr;gap:5px;padding:9px 10px;font-size:11.5px}.charts-head{flex-direction:column;align-items:stretch;gap:10px}.seg{display:flex}.seg button{flex:1}.chart-row{grid-template-columns:26px 1fr auto;gap:10px}.discover{padding:10px}.disco-q,.disco-go{flex:1 1 100%}.potw{gap:12px;padding:12px}.potw__cover{width:72px;height:72px;font-size:18px}.prof-actions{width:100%}.prof-actions .settings-btn{flex:1 1 auto;justify-content:center}.pl-controls{flex-wrap:wrap}.pl-collab{gap:6px}.pl-menu,.collab-menu,.settings-menu,.add-menu{max-width:calc(100vw - 24px)}}@media (max-width: 480px){.cards{grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:10px}.stat-cards{grid-template-columns:1fr 1fr}.hero h1{font-size:25px}.hero__cover{width:96px;height:96px;font-size:28px}.inv-row{grid-template-columns:1fr 1fr;gap:4px 10px}.gauge__ring{width:70px;height:70px}}.queue-panel{transition:right .25s ease,left .25s ease,bottom .2s ease}body.drawer-open .queue-panel{right:calc(min(440px,92vw) + 26px)}@media (max-width: 860px){body.drawer-open .queue-panel{right:10px;left:10px;z-index:30}}:root{--admin: #f5a524;--admin-ink: #1a1205}body.admin-mode{--accent: var(--admin);--accent-2: #c47f12;--accent-gl: rgba(245,165,36,.3)}body.admin-mode .brand__name:after{content:" · admin";color:var(--admin)}body.admin-mode .main{box-shadow:inset 0 3px 0 var(--admin)}.admin-hero{background:linear-gradient(120deg,#f5a5242e,#f5a5240a);border:1px solid rgba(245,165,36,.25)}.admin-tabs{display:flex;gap:8px;margin:12px 0 16px;flex-wrap:wrap}.admin-tab{padding:8px 16px;border-radius:999px;border:1px solid var(--line);background:var(--panel);color:var(--muted);cursor:pointer;font-weight:600;font-size:13px;transition:background .15s,color .15s}.admin-tab:hover{color:var(--text)}.admin-tab.is-on{background:var(--admin);color:var(--admin-ink);border-color:var(--admin)}.admin-body{display:grid;grid-template-columns:244px 1fr;gap:16px;align-items:start}.admin-list{display:flex;flex-direction:column;gap:6px;max-height:64vh;overflow:auto;padding-right:4px}.admin-item{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:9px 12px;background:var(--panel);border:1px solid var(--line);border-radius:10px;color:var(--text);cursor:pointer;text-align:left;font-size:13px;transition:border-color .15s,background .15s}.admin-item:hover{border-color:var(--admin)}.admin-item span{color:var(--muted);font-size:12px}.admin-item.is-on{border-color:var(--admin);background:var(--panel-2)}.admin-data{min-width:0}.admin-grid-wrap{overflow:auto;border:1px solid var(--line);border-radius:12px;max-height:60vh}.admin-grid{border-collapse:collapse;width:100%;font-size:12.5px}.admin-grid th{text-align:left;padding:8px 10px;background:var(--panel-2);position:sticky;top:0;white-space:nowrap;z-index:1}.admin-grid td{padding:4px 6px;border-top:1px solid var(--line)}.admin-grid input{width:100%;min-width:90px;background:var(--bg);border:1px solid transparent;border-radius:6px;padding:5px 7px;color:var(--text);font-size:12.5px}.admin-grid input:focus{border-color:var(--admin);outline:none}.admin-rowacts{white-space:nowrap}.admin-save,.admin-del,.admin-add__btn{border:0;border-radius:8px;padding:6px 11px;font-size:12px;cursor:pointer;font-weight:600;transition:filter .15s,transform .1s}.admin-save:hover,.admin-del:hover,.admin-add__btn:hover{filter:brightness(1.08)}.admin-save:active,.admin-add__btn:active{transform:scale(.96)}.admin-save,.admin-add__btn{background:var(--admin);color:var(--admin-ink)}.admin-del{background:#f0705f29;color:#f0705f;margin-left:6px}.admin-add{margin-top:14px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px}.admin-add__title{font-weight:600;margin-bottom:8px}.admin-add__fields{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;margin-bottom:10px}.admin-add__fields label{display:flex;flex-direction:column;gap:3px;font-size:11px;color:var(--muted)}.admin-add__fields input{background:var(--bg);border:1px solid var(--line);border-radius:7px;padding:6px 8px;color:var(--text);font-size:13px}.admin-doc{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:10px}.admin-json{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:8px;color:var(--text);font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:12.5px;padding:10px;resize:vertical;box-sizing:border-box}.admin-json:focus{border-color:var(--admin);outline:none}.admin-readonly{white-space:pre-wrap;max-height:52vh;overflow:auto}.admin-node-id{font-size:11px;color:var(--admin);margin-bottom:6px;font-weight:600}.admin-redis-col{display:flex;flex-direction:column}.admin-redis-bar{display:flex;gap:8px;margin-bottom:10px}.admin-redis-bar input{flex:1;min-width:0;background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:8px 10px;color:var(--text)}.admin-redis-type{display:inline-block;font-size:10px;text-transform:uppercase;background:var(--panel-2);color:var(--muted);border-radius:5px;padding:1px 5px;margin-right:6px}.admin-kv-edit{display:flex;gap:8px;align-items:center;margin-top:10px;flex-wrap:wrap}.admin-kv-edit input{flex:1;min-width:160px;background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:8px 10px;color:var(--text)}.admin-cypher{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px}.admin-cypher textarea{margin:8px 0}@media (max-width: 860px){.admin-body{grid-template-columns:1fr}.admin-list{flex-direction:row;flex-wrap:wrap;max-height:none}.admin-list .admin-item{flex:1 1 auto}}body.admin-mode #player,body.admin-mode .queue-panel{display:none!important}.auth{position:relative;min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(1200px 600px at 50% -10%,rgba(123,44,191,.18),transparent 60%),linear-gradient(180deg,var(--bg-2),var(--bg));overflow:hidden}.auth__aura{position:absolute;width:520px;height:520px;top:-140px;right:-120px;background:radial-gradient(circle,var(--accent-gl),transparent 65%);filter:blur(20px);pointer-events:none;animation:authFloat 14s ease-in-out infinite alternate}@keyframes authFloat{0%{transform:translate(0) scale(1)}to{transform:translate(-40px,30px) scale(1.12)}}.auth__card{position:relative;width:100%;max-width:400px;padding:36px 34px 30px;display:flex;flex-direction:column;background:linear-gradient(180deg,#211b30eb,#181425eb);border:1px solid var(--line);border-radius:20px;box-shadow:0 24px 70px #0000008c,inset 0 1px #ffffff0a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.auth__brand{display:flex;align-items:center;gap:11px;margin-bottom:22px}.auth__brandname{font-family:var(--display);font-weight:700;font-size:22px;letter-spacing:-.5px}.auth .brand__mark{display:inline-grid;grid-template-columns:repeat(2,9px);gap:4px}.auth .brand__mark span{width:9px;height:9px;border-radius:2px;display:block}.auth__title{font-family:var(--display);font-size:26px;font-weight:700;margin:0 0 4px;letter-spacing:-.4px}.auth__sub{margin:0 0 24px;color:var(--muted);font-size:13.5px}.auth__label{font-size:12px;font-weight:600;color:var(--muted);margin:14px 0 6px;text-transform:uppercase;letter-spacing:.4px}.auth__input{height:44px;padding:0 14px;border-radius:11px;border:1px solid var(--line);background:#0b091099;color:var(--text);font-size:14.5px;outline:none;transition:border-color .15s,box-shadow .15s}.auth__input::placeholder{color:var(--muted-2)}.auth__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-gl)}.auth__error{margin-top:16px;padding:10px 12px;border-radius:10px;background:#f0705f1f;border:1px solid rgba(240,112,95,.4);color:#ffb4a8;font-size:13px}.auth__submit{margin-top:22px;height:46px;border:none;border-radius:12px;font-size:15px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 10px 26px var(--accent-gl);transition:transform .1s,box-shadow .15s,opacity .15s}.auth__submit:hover{transform:translateY(-1px);box-shadow:0 14px 32px var(--accent-gl)}.auth__submit:active{transform:translateY(0)}.auth__submit:disabled{opacity:.6;cursor:progress;transform:none}.auth__hint{margin-top:20px;text-align:center;font-size:12px;color:var(--muted-2);line-height:1.7}.auth__hint code{background:#b15cff24;color:var(--accent);padding:1px 6px;border-radius:5px;font-size:11.5px}.topbar__who{font-size:13.5px;font-weight:600;color:var(--text);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 13px;border-radius:999px;border:1px solid var(--line);background:var(--panel-2);color:var(--muted);font-size:13px;font-weight:500;transition:color .15s,border-color .15s,background .15s}.logout-btn:hover{color:var(--text);border-color:var(--kv);background:#f0705f1a}.logout-btn svg{flex:none}.friends-live{min-height:0;display:flex;flex-direction:column}.friends-live__count{font-size:11px;font-weight:700;color:var(--graph);background:#29c5d624;border-radius:999px;padding:1px 8px}.friends-list{display:flex;flex-direction:column;gap:4px;overflow-y:auto;max-height:260px;padding-right:2px}.friends-empty{font-size:12px;color:var(--muted-2);padding:6px 4px}.friend-row{display:grid;grid-template-columns:34px 1fr auto;align-items:center;gap:9px;padding:6px 5px;border-radius:10px;transition:background .15s}.friend-row:hover{background:var(--panel-2)}.friend-av{position:relative;width:34px;height:34px;border-radius:50%;border:none;color:#fff;font-size:11px;font-weight:700;display:grid;place-items:center;flex:none}.friend-dot{position:absolute;right:-1px;bottom:-1px;width:11px;height:11px;border-radius:50%;border:2px solid var(--bg)}.friend-dot.is-playing{background:#34d27b;animation:friendPulse 1.6s ease-in-out infinite}.friend-dot.is-paused{background:var(--muted-2)}@keyframes friendPulse{0%{box-shadow:0 0 #34d27b8c}70%{box-shadow:0 0 0 6px #34d27b00}to{box-shadow:0 0 #34d27b00}}.friend-info{min-width:0}.friend-name{font-size:12.5px;font-weight:600;color:var(--text);cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-name:hover{text-decoration:underline}.friend-track{font-size:11px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:1px}.friend-track__title{color:var(--muted)}.friend-track__artist{color:var(--muted-2)}.friend-bar{height:3px;background:var(--line);border-radius:2px;overflow:hidden;margin:5px 0 2px}.friend-bar__fill{height:100%;background:linear-gradient(90deg,var(--graph),#5fe0ec);border-radius:2px;transition:width 1s linear}.friend-time{font-size:10px;color:var(--muted-2);letter-spacing:.2px}.friend-join{width:30px;height:30px;flex:none;border-radius:50%;border:1px solid var(--line);background:var(--panel);color:var(--accent);font-size:14px;display:grid;place-items:center;transition:background .15s,color .15s,transform .1s}.friend-join:hover{background:var(--accent);color:#fff;transform:scale(1.06)}.party-launch{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 12px;border-radius:999px;border:1px solid var(--line);background:var(--panel-2);color:var(--muted);font-size:13px;font-weight:600;position:relative;transition:color .15s,border-color .15s,background .15s}.party-launch:hover{color:var(--text);border-color:var(--accent);background:#b15cff1a}.party-launch.is-active{color:#fff;border-color:var(--accent);background:linear-gradient(135deg,var(--accent),var(--accent-2))}.party-launch__ic{font-size:15px;line-height:1}.party-launch__badge{min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#34d27b;color:#052012;font-size:11px;font-weight:800;display:inline-grid;place-items:center}.party-code{font-family:var(--display);letter-spacing:2px;font-weight:700;background:#b15cff29;color:var(--accent);padding:1px 8px;border-radius:6px}.party-create-btn{width:100%;height:46px;margin-top:6px;border:none;border-radius:12px;color:#fff;font-size:15px;font-weight:600;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 10px 26px var(--accent-gl);transition:transform .1s}.party-create-btn:hover{transform:translateY(-1px)}.party-or{display:flex;align-items:center;gap:10px;margin:16px 0 12px;color:var(--muted-2);font-size:12px}.party-or:before,.party-or:after{content:"";flex:1;height:1px;background:var(--line)}.party-join-row{display:flex;gap:8px}.party-join-input{flex:1;text-transform:uppercase;letter-spacing:3px;font-weight:700;text-align:center}.party-banner{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:0 0 12px;padding:9px 14px;border:1px solid rgba(177,92,255,.4);background:linear-gradient(90deg,#7b2cbf2e,#b15cff0f);border-radius:12px}.party-banner__live{font-size:11px;font-weight:800;letter-spacing:1px;color:#ff6b6b;animation:friendPulse 1.6s ease-in-out infinite}.party-banner__code{border:none;background:transparent;color:var(--text);font-size:13.5px;cursor:pointer}.party-banner__code strong{font-family:var(--display);letter-spacing:2px;color:var(--accent)}.party-banner__role{font-size:12.5px;color:var(--muted)}.party-banner__members{display:flex;align-items:center;margin-left:auto}.party-mem{width:28px;height:28px;border-radius:50%;margin-left:-8px;border:2px solid var(--bg);color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center}.party-mem.is-host{box-shadow:0 0 0 2px #34d27b}.party-mem--more{background:var(--panel-2);color:var(--muted)}.party-banner__leave{height:30px;padding:0 12px;border-radius:999px;border:1px solid var(--line);background:var(--panel);color:var(--muted);font-size:12.5px}.party-banner__leave:hover{color:var(--text);border-color:var(--kv);background:#f0705f1a}.friends-fab,.friends-sheet{display:none}.friends-fab{position:fixed;right:16px;bottom:140px;z-index:62;width:50px;height:50px;border-radius:50%;border:none;font-size:21px;background:linear-gradient(135deg,var(--graph),#1f9fb0);color:#fff;box-shadow:0 10px 26px #29c5d666}.friends-fab__badge{position:absolute;top:-3px;right:-3px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:#34d27b;color:#052012;font-size:11px;font-weight:800;display:grid;place-items:center;border:2px solid var(--bg)}.friends-sheet{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80}.friends-sheet__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080}.friends-sheet__panel{position:absolute;left:0;right:0;bottom:0;max-height:72vh;display:flex;flex-direction:column;background:var(--panel);border-top:1px solid var(--line);border-radius:18px 18px 0 0;padding:14px 14px calc(14px + env(safe-area-inset-bottom));animation:sheetUp .22s ease}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.friends-sheet__head{display:flex;align-items:center;justify-content:space-between;font-family:var(--display);font-weight:700;font-size:15px;margin-bottom:8px}.friends-sheet__close{width:30px;height:30px;border-radius:50%;border:1px solid var(--line);background:var(--panel-2);color:var(--muted);font-size:14px}.friends-sheet .friends-list{max-height:none;overflow-y:auto}@media (max-width: 760px){.friends-fab{display:grid;place-items:center}.friends-sheet{display:block}.party-launch__lbl{display:none}.party-launch{padding:0 10px}.party-banner{margin:10px 0}.party-banner__role{display:none}}.party-status{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;margin:4px 0 14px;padding:7px 11px;border-radius:9px;border:1px solid var(--line)}.party-status__dot{width:9px;height:9px;border-radius:50%;flex:none}.party-status--ok{color:#34d27b;background:#34d27b14;border-color:#34d27b4d}.party-status--ok .party-status__dot{background:#34d27b;box-shadow:0 0 0 3px #34d27b2e}.party-status--off{color:var(--muted);background:var(--panel-2)}.party-status--off .party-status__dot{background:var(--muted-2);animation:friendPulse 1.4s ease-in-out infinite}.party-status__hint{margin-top:12px;font-size:11.5px;color:var(--muted-2);line-height:1.6}.party-status__hint code{background:#b15cff24;color:var(--accent);padding:1px 5px;border-radius:5px;font-size:11px}.play-toggle--activate{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;animation:friendPulse 1.6s ease-in-out infinite}.party-banner__activate{height:30px;padding:0 14px;border-radius:999px;border:none;font-size:12.5px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 6px 18px var(--accent-gl);animation:friendPulse 1.8s ease-in-out infinite}.party-banner__activate:hover{filter:brightness(1.08)}
