*{box-sizing:border-box}
[hidden]{display:none!important}
:root{
  --bg:#0e1116;--bg-sunken:#0a0d12;--panel:#161b22;--panel-2:#1b212b;--line:#222c38;
  --fg:#d8dee9;--mut:#8b98a9;--faint:#5b6675;
  --accent:#FF8A00;--accent-soft:rgba(255,138,0,.15);--accent-line:rgba(255,138,0,.55);--air:#00C8C8;
  --ok:#3fb950;--like:#ff6b9d;--hh:56px;
  --mono:ui-monospace,"SFMono-Regular","Cascadia Code","JetBrains Mono",Menlo,Consolas,monospace;
}
body{margin:0;font:14px/1.5 system-ui,-apple-system,"Segoe UI",sans-serif;background:var(--bg);color:var(--fg)}
/* баннер «нас где-то забанили» — поверх всего, заметный */
#ban-banner{position:sticky;top:0;z-index:50;padding:9px 16px;font-size:13px;text-align:center;
  border-bottom:1px solid rgba(0,0,0,.3)}
#ban-banner .es{color:rgba(255,255,255,.75);font-weight:400;margin-left:8px}
#ban-banner.ban-high{background:#7d1f1f;color:#ffe2e2}
#ban-banner.ban-low{background:#7d671f;color:#fff4d6}
a{color:inherit;text-decoration:none}
a:hover{color:var(--accent)}

/* ---- header ---- */
header{display:flex;gap:10px;align-items:center;flex-wrap:wrap;padding:9px 16px;
  background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}
.brand{display:inline-flex;align-items:center}
.brand-logo{display:block;height:37px;width:auto}
.brand-fn{margin-left:9px;font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--mut);font-weight:600}
#q{flex:1;min-width:200px;padding:8px 12px;border-radius:9px;border:1px solid var(--line);
  background:var(--bg-sunken);color:var(--fg);font-size:14px}
#q:focus{outline:none;border-color:var(--accent)}
select{background:var(--bg-sunken);color:var(--fg);border:1px solid var(--line);border-radius:9px;padding:7px 10px;font-size:13px}
.tabs{display:flex;gap:4px}
.tab{background:transparent;border:1px solid var(--line);color:var(--mut);border-radius:20px;
  padding:6px 14px;cursor:pointer;font-size:13px}
.tab.on{background:var(--accent);color:#0E1116;border-color:var(--accent)}
.btn{background:var(--panel-2);border:1px solid var(--line);color:var(--fg);border-radius:9px;
  padding:7px 12px;cursor:pointer;font-size:13px;display:inline-flex;align-items:center;gap:6px}
.btn:hover{border-color:var(--accent)}
.ftgl{display:none}
.ftgl b{background:var(--accent);color:#0E1116;border-radius:9px;padding:0 6px;font-size:11px;font-weight:700}
#acct b{color:var(--like)}

/* ---- app shell: left rail + main ---- */
.app{display:grid;grid-template-columns:286px minmax(0,1fr);align-items:start}
.rail{position:sticky;top:var(--hh);align-self:start;height:calc(100vh - var(--hh));overflow-y:auto;
  background:var(--bg-sunken);border-right:1px solid var(--line);scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.rail::-webkit-scrollbar{width:9px}.rail::-webkit-scrollbar-thumb{background:var(--line);border-radius:6px;border:3px solid var(--bg-sunken)}
.rail-head{display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;
  background:var(--bg-sunken);padding:12px 14px 8px;border-bottom:1px solid var(--line);z-index:2}
.rail-head .ttl{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--fg)}
.rail-head .clr{background:none;border:none;color:var(--faint);cursor:pointer;font-size:12px;padding:2px 4px}
.rail-head .clr:hover{color:var(--like)}
.rail-head .clr[disabled]{opacity:.35;cursor:default}
.rail-close{display:none}

/* ---- facet section ---- */
.facet{border-bottom:1px solid var(--line);padding:11px 12px 12px}
.facet-h{display:flex;align-items:center;justify-content:space-between;margin:0 2px 7px;
  font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--mut)}
.facet-h .fcount{font-family:var(--mono);font-weight:500;color:var(--faint);font-size:10px}
.facet-find{width:100%;margin-bottom:6px;padding:5px 9px;border-radius:7px;border:1px solid var(--line);
  background:var(--bg);color:var(--fg);font-size:12px}
.facet-find:focus{outline:none;border-color:var(--accent)}
.facet-rows{display:flex;flex-direction:column;gap:1px}
.frow{display:flex;align-items:center;gap:8px;padding:4px 7px;border-radius:7px;cursor:pointer;
  font-size:13px;border-left:2px solid transparent;transition:background .1s,border-color .1s}
.frow:hover{background:var(--panel)}
.frow:hover .fexc{opacity:.55}
.frow.sel{background:var(--accent-soft);border-left-color:var(--accent)}
.frow.exc{background:rgba(255,107,157,.12);border-left-color:var(--like)}
.frow input{margin:0;accent-color:var(--accent);flex:none;width:14px;height:14px;cursor:pointer}
.frow-l{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--fg);cursor:pointer}
.frow.sel .frow-l{font-weight:600}
.frow.exc .frow-l{color:var(--like);text-decoration:line-through;text-decoration-color:rgba(255,107,157,.5)}
.fexc{flex:none;background:none;border:1px solid transparent;border-radius:6px;color:var(--faint);
  cursor:pointer;font-size:13px;line-height:1;width:20px;height:20px;padding:0;opacity:0;transition:opacity .1s,color .1s}
.fexc:hover{color:var(--like);border-color:var(--like)}
.frow.exc .fexc{opacity:1;color:var(--like);border-color:var(--like)}
.frow-c{font-family:var(--mono);font-size:11px;color:var(--mut);font-variant-numeric:tabular-nums;
  letter-spacing:-.03em;flex:none;min-width:34px;text-align:right}
.frow.zero{opacity:.38}
.frow.zero .frow-c{color:var(--faint)}
.frow-c.tick{animation:tick .65s ease-out}
@keyframes tick{0%{color:var(--ok);transform:translateX(-2px)}100%{color:var(--mut);transform:none}}
.facet-more{margin-top:3px;background:none;border:none;color:var(--accent);cursor:pointer;
  font-size:12px;padding:4px 7px;text-align:left}
.facet-more:hover{text-decoration:underline}
.facet-empty{color:var(--faint);font-size:12px;padding:3px 7px}

/* ---- active-filter pills ---- */
.resbar{display:flex;align-items:flex-start;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.pills{display:flex;flex-wrap:wrap;gap:6px;flex:1;min-width:0}
.pill{display:inline-flex;align-items:center;gap:7px;background:var(--accent-soft);
  border:1px solid var(--accent-line);border-radius:6px;padding:3px 5px 3px 9px;font-size:12px;color:#FFD7A8}
.pill .k{color:var(--mut);font-size:10.5px;text-transform:uppercase;letter-spacing:.04em}
.pill .v{font-weight:600;color:#fff}
.pill .x{cursor:pointer;border:none;background:none;color:#FFD7A8;font-size:14px;line-height:1;
  padding:0 2px;border-radius:4px}
.pill .x:hover{background:rgba(255,255,255,.12);color:#fff}
.pill.exc{background:rgba(255,107,157,.14);border-color:rgba(255,107,157,.55);color:#ffc2d6}
.pill.exc .v{color:#fff}
.pill.exc .x{color:#ffc2d6}
.pill.clear{background:none;border-color:var(--line);color:var(--mut);cursor:pointer;padding:3px 10px}
.pill.clear:hover{border-color:var(--like);color:var(--like)}
.stat{color:var(--mut);font-size:12px;font-family:var(--mono);white-space:nowrap;padding-top:4px}

/* ---- stats strip ---- */
.statsbar{display:flex;flex-wrap:wrap;gap:8px 18px;align-items:center;margin-bottom:12px;
  padding:10px 14px;background:var(--bg-sunken);border:1px solid var(--line);border-radius:10px;
  font-size:13px;color:var(--mut)}
.statsbar:empty{display:none}
.s-item b{color:var(--fg);font-family:var(--mono);font-variant-numeric:tabular-nums;font-weight:600}
.s-link{cursor:pointer;border-radius:6px;padding:1px 6px;margin:-1px -2px;transition:background .1s}
.s-link:hover{background:var(--panel)}
.s-link.on{background:var(--accent-soft);box-shadow:inset 0 0 0 1px var(--accent-line)}
.s-link.on b{color:#FFC078}

/* ---- main / grid ---- */
main{padding:16px;min-width:0}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:12px;transition:opacity .12s}
.grid.is-loading{opacity:.45;pointer-events:none}
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px;
  display:flex;gap:11px;cursor:pointer;transition:border-color .12s,transform .12s}
.card:hover{border-color:var(--accent)}
.card.playing{border-color:var(--ok);box-shadow:0 0 0 1px var(--ok) inset}
.card img{width:54px;height:54px;border-radius:9px;object-fit:cover;background:var(--bg-sunken);flex:none}
.card .cb{flex:1;min-width:0}
.card .cn{font-weight:600;margin-bottom:2px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card .cm{color:var(--mut);font-size:11px}
.card .now{font-size:12px;margin-top:5px;color:#cdd6e3;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card .now b{color:#7ee2a0;font-weight:600}
.card .tags{margin-top:5px;color:var(--mut);font-size:10.5px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.card .cn,.card .now,.card .tags{overflow-wrap:anywhere}
.badge{font-size:9px;padding:1px 5px;border-radius:6px;background:#30363d;color:var(--mut)}
.badge.px{background:#3a2d12;color:#ffd479}
.badge.var{background:var(--accent-soft);color:#FFC078;border:1px solid var(--accent-line)}
.vars{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.vars .vbtn{padding:4px 9px;font-size:12px}
.card-actions{display:flex;flex-direction:column;gap:6px;align-items:center;flex:none}
.iconbtn{background:var(--panel-2);border:1px solid var(--line);color:var(--mut);border-radius:8px;
  width:34px;height:30px;cursor:pointer;font-size:15px;line-height:1;padding:0}
.iconbtn:hover{border-color:var(--accent);color:var(--fg)}
.iconbtn.play{color:var(--ok)}
.iconbtn.play.pausing{color:#ffb454;border-color:#ffb454;background:rgba(255,180,84,.12)}
.iconbtn.play.pausing:hover{color:#ffc878;border-color:#ffc878}
.iconbtn.liked{color:var(--like);border-color:var(--like)}

/* ---- skeleton ---- */
.skel{background:var(--panel);border:1px solid var(--line);border-radius:12px;height:84px;
  position:relative;overflow:hidden}
.skel::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.045),transparent);
  transform:translateX(-100%);animation:sweep 1.25s infinite}
@keyframes sweep{to{transform:translateX(100%)}}

/* ---- misc ---- */
.more{text-align:center;margin:18px 0}
.empty{color:var(--mut);text-align:center;padding:48px}
.efir-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px}
h2{font-size:13px;text-transform:uppercase;letter-spacing:.07em;color:var(--mut)}
h2 small{text-transform:none;letter-spacing:0}
.efir-list{display:flex;flex-direction:column;gap:6px}
.erow{display:flex;gap:10px;align-items:center;background:var(--panel);border:1px solid var(--line);
  border-radius:9px;padding:8px 11px}
.erow img{width:34px;height:34px;border-radius:6px;object-fit:cover;flex:none;background:var(--bg-sunken)}
.erow .et{font-size:13px}.erow .es{color:var(--mut);font-size:11px}
.erow.clk{cursor:pointer}.erow.clk:hover{border-color:var(--accent)}
.erow .cnt{margin-left:auto;color:var(--accent);font-weight:700;font-family:var(--mono)}
.trackpanel{margin-bottom:14px;display:flex;flex-direction:column;gap:6px}
.trackpanel h2{margin:6px 0 2px}
.trk-ic{width:34px;height:34px;border-radius:6px;flex:none;display:flex;align-items:center;
  justify-content:center;font-size:17px;background:var(--panel-2)}

/* ---- player ---- */
.player{position:sticky;bottom:0;display:flex;gap:12px;align-items:center;padding:10px 16px;
  background:var(--bg-sunken);border-top:1px solid var(--accent);z-index:30}
.player img{width:46px;height:46px;border-radius:8px;object-fit:cover;background:var(--panel)}
.p-meta{min-width:0}.p-name{font-weight:600}.p-now{color:#7ee2a0;font-size:12px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60vw}
.player audio{height:34px}.player .btn{margin-left:auto}
#p-like.liked{color:var(--like);border-color:var(--like)}

/* ---- modal ---- */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;
  justify-content:center;z-index:40;padding:20px}
.modal-box{background:var(--panel);border:1px solid var(--line);border-radius:14px;
  max-width:560px;width:100%;max-height:80vh;overflow:auto;padding:18px}
.es{color:var(--mut);font-size:12px}
.np-now{background:#16361f;border:1px solid #2a5a3a;border-radius:9px;padding:9px 12px;margin:6px 0}
.np-now>div{font-weight:600;color:#7ee2a0;margin-top:2px}
.rep{display:flex;gap:9px;align-items:center;padding:5px 0;border-bottom:1px solid var(--line)}
.rep img{width:38px;height:38px;border-radius:6px;object-fit:cover;background:var(--bg-sunken);flex:none}
.loginrow{display:flex;gap:8px;margin:8px 0}
.loginrow input{flex:1;min-width:0;padding:8px 10px;border-radius:8px;border:1px solid var(--line);
  background:var(--bg-sunken);color:var(--fg);font-size:14px}
.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:#3a1a1a;
  color:#ff8a8a;border:1px solid #5a2a2a;border-radius:9px;padding:9px 16px;z-index:50}
.backdrop{display:none}

/* ---- mobile: rail becomes a drawer ---- */
@media(max-width:900px){
  .app{grid-template-columns:1fr}
  .ftgl{display:inline-flex}
  .rail{position:fixed;top:0;left:0;height:100vh;width:290px;z-index:60;transform:translateX(-102%);
    transition:transform .18s ease;border-right:1px solid var(--line);box-shadow:2px 0 24px rgba(0,0,0,.5)}
  .rail.open{transform:none}
  .rail-close{display:inline-block;background:none;border:none;color:var(--mut);font-size:16px;cursor:pointer}
  .backdrop{display:block;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:55}
  .efir-cols{grid-template-columns:1fr}.p-now{max-width:40vw}
}
