:root{
  --blue:#1a73e8; --blue2:#29a3ec; --bg:#0b1220; --bg2:#0f1830; --card:#141f38;
  --card2:#18233f; --line:#22304f; --ink:#eaf1ff; --mut:#9fb0cf; --gold:#fbbf24;
  --live:#22c55e; --pl-h:82px;
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;background:
  radial-gradient(1100px 480px at 80% -8%,#13224a,transparent),
  radial-gradient(900px 420px at -5% 0%,#102038,transparent),var(--bg);
  color:var(--ink);min-height:100vh;padding-bottom:calc(var(--pl-h) + env(safe-area-inset-bottom));-webkit-text-size-adjust:100%}
a{color:var(--blue2);text-decoration:none}
[hidden]{display:none!important}

/* header */
.top{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:14px;padding:11px 16px;
  background:rgba(11,18,32,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.logo{display:block;line-height:0}
.logo svg{border-radius:8px;display:block}
.bname{font-size:19px;font-weight:800;letter-spacing:.2px;color:#fff}
.bname b{color:var(--blue2);font-weight:800}
.search{flex:1;display:flex;justify-content:flex-end}
.search input{width:min(420px,100%);background:var(--card);border:1px solid var(--line);color:var(--ink);
  border-radius:12px;padding:11px 14px;font:inherit;outline:none}
.search input:focus{border-color:var(--blue2);box-shadow:0 0 0 3px rgba(41,163,236,.18)}
.search input::placeholder{color:#73849f}

/* filters */
.filters{position:sticky;top:60px;z-index:15;padding:11px 16px 6px;background:linear-gradient(var(--bg),rgba(11,18,32,.4));backdrop-filter:blur(6px)}
.ctry{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.ctry::-webkit-scrollbar{display:none}
.cf{flex:0 0 auto;border:1px solid var(--line);background:var(--card);color:var(--mut);border-radius:999px;
  padding:8px 15px;font:inherit;font-weight:700;font-size:13.5px;cursor:pointer;white-space:nowrap;transition:.15s}
.cf:hover{color:#fff;border-color:#2c3e63}
.cf.on{background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;border-color:transparent}
.cf.fav.on{background:linear-gradient(135deg,#d97706,#fbbf24);color:#1a1300}
.genres{display:flex;gap:7px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.genres::-webkit-scrollbar{display:none}
.gchip{flex:0 0 auto;border:1px solid var(--line);background:transparent;color:var(--mut);border-radius:8px;
  padding:5px 11px;font:inherit;font-size:12.5px;font-weight:600;cursor:pointer;white-space:nowrap}
.gchip.on{background:var(--card2);color:#fff;border-color:#2c3e63}

#main{max-width:1180px;margin:0 auto;padding:6px 16px 30px}
.status{color:var(--mut);padding:30px 6px;text-align:center;font-size:14px}

/* grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:13px;margin-top:8px}
.st{position:relative;background:linear-gradient(180deg,var(--card),var(--card2));border:1px solid var(--line);
  border-radius:16px;padding:13px;cursor:pointer;transition:.16s;overflow:hidden}
.st:hover{border-color:#33486f;transform:translateY(-2px);box-shadow:0 10px 26px rgba(0,0,0,.32)}
.st.playing{border-color:var(--blue2);box-shadow:0 0 0 1px var(--blue2),0 10px 26px rgba(26,115,232,.28)}
.st-logo{width:100%;aspect-ratio:1/1;border-radius:12px;background:#0c1730;display:flex;align-items:center;justify-content:center;
  overflow:hidden;margin-bottom:10px;position:relative}
.st-logo img{width:100%;height:100%;object-fit:contain;padding:8px}
.st-logo .ltr{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:44px;font-weight:800;color:#fff}
.st-flag{position:absolute;top:7px;left:7px;font-size:15px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5));z-index:2}
.st-play{position:absolute;right:8px;bottom:8px;width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:15px;box-shadow:0 4px 12px rgba(26,115,232,.5);opacity:0;transform:translateY(6px);transition:.16s}
.st:hover .st-play,.st.playing .st-play{opacity:1;transform:none}
.st-fav{position:absolute;top:6px;right:6px;background:rgba(8,14,28,.6);border:0;color:#cdd9f0;font-size:16px;
  width:30px;height:30px;border-radius:50%;cursor:pointer;line-height:1;z-index:3}
.st-fav.on{color:var(--gold)}
.st-name{font-size:14px;font-weight:700;line-height:1.25;color:#fff;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:35px}
.st-sub{display:flex;flex-wrap:wrap;gap:5px;align-items:center;margin-top:6px;font-size:11.5px;color:var(--mut)}
.st-freq{background:rgba(41,163,236,.16);color:#bfe0ff;border-radius:6px;padding:1px 7px;font-weight:700;font-variant-numeric:tabular-nums}
.st-city{opacity:.85}
.st-lic{background:rgba(148,163,184,.14);color:#aebfd8;border-radius:6px;padding:1px 7px;font-weight:700;font-size:10.5px;letter-spacing:.02em}
.st.noair{opacity:.66}
.st.noair:hover{transform:none;border-color:var(--line);box-shadow:none}
.st-off{position:absolute;right:8px;bottom:8px;width:34px;height:34px;border-radius:50%;background:rgba(8,14,28,.8);display:flex;align-items:center;justify-content:center;font-size:15px}
.st-noband{margin-top:8px;background:rgba(248,113,113,.13);color:#fca5a5;border:1px solid rgba(248,113,113,.32);border-radius:8px;padding:5px 8px;font-size:11px;font-weight:800;text-align:center;letter-spacing:.02em}
.eq{display:inline-flex;gap:2px;align-items:flex-end;height:12px;margin-left:2px}
.eq i{width:3px;background:var(--blue2);border-radius:2px;animation:eq .9s ease-in-out infinite}
.eq i:nth-child(2){animation-delay:.25s}.eq i:nth-child(3){animation-delay:.5s}
@keyframes eq{0%,100%{height:3px}50%{height:12px}}

/* player */
.player{position:fixed;left:0;right:0;bottom:0;z-index:40;height:calc(var(--pl-h) + env(safe-area-inset-bottom));
  padding:0 16px env(safe-area-inset-bottom);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;
  background:rgba(13,20,38,.92);backdrop-filter:blur(16px);border-top:1px solid var(--line)}
.pl-info{display:flex;align-items:center;gap:11px;min-width:0}
.pl-logo{width:50px;height:50px;border-radius:11px;background:#0c1730;flex:0 0 auto;overflow:hidden;display:flex;align-items:center;justify-content:center}
.pl-logo img{width:100%;height:100%;object-fit:contain;padding:5px}
.pl-logo .ltr{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;color:#fff}
.pl-meta{min-width:0}
.pl-name{font-size:15px;font-weight:800;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pl-sub{font-size:12px;color:var(--mut);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;gap:7px;align-items:center}
.live{color:var(--live);font-weight:800;font-size:11px}
.live.buffering{color:var(--gold)}
.live.err{color:#f87171}
.pl-ctl{display:flex;align-items:center;gap:8px}
.pbtn{border:0;background:var(--card);color:#fff;width:42px;height:42px;border-radius:50%;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.14s}
.pbtn:hover{background:var(--card2)}
.pbtn.play{width:50px;height:50px;background:linear-gradient(135deg,var(--blue),var(--blue2));font-size:18px;box-shadow:0 5px 16px rgba(26,115,232,.45)}
.pbtn.ghost{background:transparent}
.pbtn.ghost:hover{background:var(--card)}
.pl-right{display:flex;align-items:center;justify-content:flex-end;gap:10px}
.pl-fav.on,#plFav.on{color:var(--gold)}
.vol{display:flex;align-items:center;gap:7px}
.vico{color:var(--mut)}
#vol{width:110px;accent-color:var(--blue2)}

.foot{max-width:1180px;margin:0 auto;padding:18px 16px 8px;color:var(--mut);font-size:12.5px;line-height:1.6}
.foot b{color:#cfdcf4}.fl{margin-top:6px;display:flex;gap:10px;flex-wrap:wrap}

@media(max-width:640px){
  .bname{font-size:17px}
  .top{gap:10px;padding:10px 13px}
  .search input{padding:9px 12px}
  .grid{grid-template-columns:repeat(2,1fr);gap:11px}
  #main{padding:4px 13px 24px}
  .player{grid-template-columns:1fr auto;gap:9px;padding:0 12px env(safe-area-inset-bottom)}
  .pl-right{display:none}
  .pbtn.ghost{display:none}
  .pbtn.play{display:flex}
  .pl-ctl{gap:0}
}
