/* Shen Radio — one-page cyberpunk */
:root{
  --bg0:#05060a;
  --bg1:#0b1020;
  --ink:#d9e0ff;
  --muted:rgba(217,224,255,.7);
  --c1:#00f5ff;
  --c2:#ff2fd6;
  --c3:#00ff7a;
  --card:rgba(10,14,24,.72);
  --stroke:rgba(255,255,255,.10);
  --shadow:0 18px 60px rgba(0,0,0,.55);
  --radius:18px;
  --app-vh: 1vh;
  --mobile-top-size: 108px;
  --font-body: ui-monospace, "SFMono-Regular", Menlo, Consolas, "Liberation Mono", monospace;
  --font-display: "Segoe UI", Roboto, Arial, sans-serif;
  --font-sans: "Segoe UI", Roboto, Arial, sans-serif;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:var(--ink);
  background:
    radial-gradient(900px 500px at 70% 10%, rgba(255,47,214,.16), transparent 55%),
    radial-gradient(900px 520px at 20% 20%, rgba(0,245,255,.12), transparent 60%),
    linear-gradient(180deg, var(--bg1), var(--bg0));
  font-family:var(--font-body);
  overflow-x:hidden;
}
body.legal-open{overflow:hidden}
.bg-grid{
  position:fixed; inset:0; pointer-events:none; opacity:.24;
  background-image:
    linear-gradient(to right, rgba(0,245,255,.12) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,47,214,.10) 1px, transparent 1px);
  background-size:80px 80px;
  transform: perspective(800px) rotateX(62deg) translateY(120px);
  filter: drop-shadow(0 0 24px rgba(0,245,255,.25));
}
.bg-noise{
  position:fixed; inset:-20%; pointer-events:none; opacity:.10;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
  animation:drift 10s linear infinite;
}
.bg-scan{
  position:fixed; inset:0; pointer-events:none; opacity:.07;
  background:repeating-linear-gradient(
    180deg,
    rgba(255,255,255,.06) 0px,
    rgba(255,255,255,.06) 1px,
    transparent 2px,
    transparent 8px
  );
  mix-blend-mode:screen;
  animation:scanDrift 14s linear infinite;
}
.history-backdrop{
  position:fixed;
  inset:0;
  background:rgba(2,5,12,.72);
  backdrop-filter:blur(4px);
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease;
  z-index:25;
}
.history-backdrop.open{
  opacity:1;
  pointer-events:auto;
}
@keyframes drift{to{transform:translate3d(-4%,2%,0)}}
@keyframes scanDrift{0%{transform:translateY(-10px)}100%{transform:translateY(10px)}}
@keyframes pulseLive{
  0%{box-shadow:0 0 0 0 rgba(0,255,122,.38)}
  70%{box-shadow:0 0 0 9px rgba(0,255,122,0)}
  100%{box-shadow:0 0 0 0 rgba(0,255,122,0)}
}

.top{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  padding:22px 20px 10px;
  max-width:1100px;
  margin:0 auto;
}
.brand{display:flex;align-items:center;gap:14px;min-width:0}
.mark{
  width:44px;height:44px;border-radius:14px;
  background:
    radial-gradient(circle at 25% 30%, rgba(0,245,255,.9), transparent 55%),
    radial-gradient(circle at 75% 70%, rgba(255,47,214,.85), transparent 55%),
    linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,0));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 0 0 2px rgba(0,245,255,.08), 0 0 26px rgba(255,47,214,.18);
  flex:0 0 auto;
}
.title{
  margin:0;
  font-family:var(--font-display);
  font-weight:800;
  letter-spacing:.08em;
  font-size:34px;
  line-height:1;
  text-transform:uppercase;
  text-shadow:0 0 18px rgba(0,245,255,.25), 0 0 22px rgba(255,47,214,.18);
}
.subtitle{margin:6px 0 0;color:var(--muted);font-size:18px;line-height:1.1}
.status{text-align:right;padding-bottom:6px;display:flex;flex-direction:column;gap:6px;align-items:flex-end}
.status-meta{display:flex;align-items:center;gap:12px;justify-content:flex-end}
.pill{
  display:inline-flex;align-items:center;gap:8px;padding:6px 11px;border-radius:999px;
  background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.12);
  box-shadow:0 0 0 2px rgba(255,47,214,.06);font-size:18px;
}
.pill::before{
  content:"";
  width:9px;height:9px;border-radius:999px;
  background:rgba(255,255,255,.65);
  box-shadow:0 0 0 0 rgba(255,255,255,.15);
  flex:0 0 auto;
}
.pill.ok{border-color:rgba(0,255,122,.25);box-shadow:0 0 0 2px rgba(0,255,122,.10)}
.pill.ok::before{background:rgba(0,255,122,.95);box-shadow:0 0 0 0 rgba(0,255,122,.32);animation:pulseLive 1.7s ease infinite}
.pill.bad{border-color:rgba(255,47,214,.25);box-shadow:0 0 0 2px rgba(255,47,214,.10)}
.pill.bad::before{background:rgba(255,47,214,.95)}
.small{font-size:16px;color:rgba(217,224,255,.72)}
.dim{opacity:.78}

.wrap{
  max-width:1100px;
  margin:0 auto;
  padding:14px 20px 34px;
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:16px;
}
.card{
  background:var(--card);
  border:1px solid var(--stroke);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  backdrop-filter:blur(10px);
  overflow:hidden;
  position:relative;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.card:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(600px 120px at 20% 0%, rgba(0,245,255,.10), transparent 60%),
    radial-gradient(600px 160px at 70% 0%, rgba(255,47,214,.10), transparent 65%);
  pointer-events:none;
}
.card-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 16px 10px;
  gap:12px;
  position:relative;
  z-index:1;
}
.card-title h2{
  margin:0;
  font-family:var(--font-display);
  font-size:16px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.player{grid-column:1/2}
.history{grid-column:2/3}
.links{grid-column:1/3}

.player-head{display:flex;gap:14px;padding:18px 16px 12px;position:relative;z-index:1}
.np-art{
  width:92px;height:92px;border-radius:16px;border:1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(circle at 30% 30%, rgba(0,245,255,.30), transparent 55%),
    radial-gradient(circle at 70% 70%, rgba(255,47,214,.28), transparent 55%),
    linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,0));
  box-shadow:0 0 0 2px rgba(0,245,255,.06), 0 0 30px rgba(0,245,255,.10);
  background-size:cover;
  background-position:center;
  flex:0 0 auto;
}
.np-meta{flex:1;min-width:0}
.kicker{color:rgba(217,224,255,.68);letter-spacing:.14em;text-transform:uppercase;font-family:var(--font-display);font-size:11px}
.np-title{font-size:30px;margin-top:6px;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.np-artist{margin-top:4px;color:rgba(217,224,255,.82);font-size:20px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.np-extra{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.chip{display:inline-flex;align-items:center;gap:8px;padding:5px 8px;background:rgba(0,0,0,.30);border:1px solid rgba(255,255,255,.10);border-radius:999px;font-size:16px}

.progress{padding:0 16px 12px;position:relative;z-index:1}
.bar{height:10px;border-radius:999px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.28);overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg, rgba(0,245,255,.85), rgba(255,47,214,.85), rgba(0,255,122,.80));box-shadow:0 0 22px rgba(0,245,255,.15)}
.bar-meta{display:flex;justify-content:space-between;margin-top:6px;color:rgba(217,224,255,.75);font-size:16px}

.controls{padding:6px 16px 12px;display:flex;gap:10px;flex-wrap:wrap;align-items:center;position:relative;z-index:1}
.btn{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.22);
  color:var(--ink);
  border-radius:14px;
  padding:10px 12px;
  font-size:18px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:10px;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease, opacity .12s ease;
  user-select:none;
}
.btn:hover{transform:translateY(-1px);border-color:rgba(0,245,255,.28);box-shadow:0 0 0 2px rgba(0,245,255,.12), 0 0 18px rgba(0,245,255,.08)}
.btn:active{transform:translateY(0)}
.btn[disabled]{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}
.btn.primary{background:linear-gradient(135deg, rgba(0,245,255,.18), rgba(255,47,214,.14));border-color:rgba(255,255,255,.18);box-shadow:0 0 0 2px rgba(255,47,214,.08)}
.btn.icon{padding:10px 12px}
.btn.tiny{padding:7px 10px;font-size:16px;border-radius:12px}
.vol{display:flex;align-items:center;gap:10px;margin-left:auto;min-width:240px}
.vol input[type="range"]{width:140px}
.hint{padding:0 16px 8px;color:rgba(217,224,255,.72);font-size:16px;position:relative;z-index:1;line-height:1.2}
.about-inline{padding:10px 16px 14px;color:rgba(217,224,255,.84);font-size:18px;line-height:1.18;position:relative;z-index:1;max-width:62ch}
.about-inline::before{content:"";display:block;width:64px;height:2px;margin-bottom:10px;border-radius:999px;background:linear-gradient(90deg, rgba(0,245,255,.95), rgba(255,47,214,.55));box-shadow:0 0 16px rgba(0,245,255,.18)}
.about-inline::after{content:"";position:absolute;left:16px;right:16px;bottom:0;height:1px;background:linear-gradient(90deg, rgba(0,245,255,.28), rgba(255,47,214,.12), transparent 88%)}
.mini-actions{display:flex;gap:10px;flex-wrap:wrap;padding:12px 16px 14px;position:relative;z-index:1}
.mobile-quick-links{display:none}
.quick-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:0;
  padding:9px 12px;
  border-radius:12px;
  text-decoration:none;
  color:var(--ink);
  border:1px solid rgba(255,255,255,.1);
  background:rgba(0,0,0,.18);
}
.quick-link:hover{border-color:rgba(255,47,214,.28);box-shadow:0 0 0 2px rgba(255,47,214,.08), 0 0 18px rgba(255,47,214,.06)}
.quick-link.small-action{font-size:16px;padding:8px 11px;background:rgba(0,245,255,.06)}
.quick-link.small-action[hidden]{display:none!important}

.history-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.history-body[hidden]{display:none}
.mobile-history-close,.mobile-menu-btn{display:none}

.list{padding:0 16px 16px;position:relative;z-index:1}
.row{display:flex;gap:10px;padding:10px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.22);margin-bottom:10px}
.row:last-child{margin-bottom:0}
.dot{width:10px;height:10px;border-radius:999px;background:rgba(0,245,255,.75);box-shadow:0 0 14px rgba(0,245,255,.25);margin-top:8px;flex:0 0 auto}
.lines{min-width:0}
.r-title{font-size:20px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.r-sub{font-size:16px;color:rgba(217,224,255,.70);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.r-time{margin-left:auto;font-size:16px;color:rgba(217,224,255,.65);flex:0 0 auto;align-self:center}
.skeleton{opacity:.65}
.skeleton .dot{background:rgba(255,47,214,.55)}
.skeleton .l1,.skeleton .l2{height:10px;border-radius:999px;background:rgba(255,255,255,.10);margin:6px 0}
.skeleton .l1{width:220px}
.skeleton .l2{width:170px}
.footnote{padding:0 16px 16px;font-size:16px;color:rgba(217,224,255,.62);position:relative;z-index:1}

.link-grid{padding:0 16px 18px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;position:relative;z-index:1}
.linkbtn{
  display:flex;
  gap:12px;
  align-items:center;
  padding:12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
  color:var(--ink);
  text-decoration:none;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.linkbtn:hover{transform:translateY(-2px);border-color:rgba(255,47,214,.30);box-shadow:0 0 0 2px rgba(255,47,214,.10), 0 0 22px rgba(255,47,214,.08)}
.lb-ico{font-size:22px}
.lb-title{display:block;font-size:18px}
.lb-sub{display:block;font-size:16px;color:rgba(217,224,255,.68);margin-top:2px}


.bottom{max-width:1100px;margin:0 auto;padding:0 20px 26px}
.bottom-row{display:flex;align-items:center;justify-content:space-between;gap:14px 18px;flex-wrap:wrap}
.footer-links{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.footer-link{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.18);
  color:var(--ink);
  border-radius:999px;
  padding:8px 12px;
  font:inherit;
  font-size:16px;
  cursor:pointer;
  transition:transform .12s ease, border-color .12s ease, box-shadow .12s ease;
}
.footer-link:hover{transform:translateY(-1px);border-color:rgba(0,245,255,.24);box-shadow:0 0 0 2px rgba(0,245,255,.08), 0 0 18px rgba(0,245,255,.06)}

.legal-backdrop{z-index:42}
.legal-panel{
  position:fixed;
  top:0;
  right:0;
  width:min(520px, 96vw);
  height:100dvh;
  background:rgba(8,12,22,.96);
  border-left:1px solid rgba(255,255,255,.10);
  box-shadow:-22px 0 46px rgba(0,0,0,.46), 0 0 0 1px rgba(0,245,255,.06);
  transform:translateX(105%);
  transition:transform .28s cubic-bezier(.22,.9,.22,1);
  z-index:46;
  display:flex;
  flex-direction:column;
  backdrop-filter:blur(18px);
}
.legal-panel.open{transform:translateX(0)}
.legal-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:20px 18px 12px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:
    linear-gradient(180deg, rgba(12,18,31,.98), rgba(8,12,22,.92)),
    radial-gradient(520px 180px at 12% 0%, rgba(0,245,255,.12), transparent 60%),
    radial-gradient(520px 220px at 88% 0%, rgba(255,47,214,.12), transparent 65%);
}
.legal-head-copy{min-width:0}
.legal-kicker{
  font-family:var(--font-display);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(217,224,255,.60);
  margin-bottom:6px;
}
.legal-head h2{
  margin:0;
  font-family:var(--font-display);
  font-size:22px;
  line-height:1.08;
  text-transform:uppercase;
}
.legal-scroll{
  flex:1 1 auto;
  overflow:auto;
  padding:16px 18px 20px;
  display:flex;
  flex-direction:column;
  gap:14px;
  scrollbar-width:thin;
}
.legal-doc{display:flex;flex-direction:column;gap:14px}
.legal-callout{
  padding:13px 14px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(135deg, rgba(0,245,255,.10), rgba(255,47,214,.08));
  box-shadow:0 0 0 1px rgba(0,245,255,.04) inset;
}
.legal-callout strong{display:block;font-family:var(--font-display);font-size:13px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}
.legal-callout p{margin:0;font-size:18px;line-height:1.24;color:rgba(217,224,255,.88)}
.legal-meta{
  font-size:15px;
  color:rgba(217,224,255,.60);
  padding:0 2px;
}
.legal-section{
  padding:14px 15px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.18);
  box-shadow:0 0 0 1px rgba(255,255,255,.02) inset;
}
.legal-section h3{
  margin:0 0 8px;
  font-family:var(--font-display);
  font-size:14px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.legal-section p{
  margin:0 0 10px;
  font-size:18px;
  line-height:1.26;
  color:rgba(217,224,255,.88);
}
.legal-section p:last-child{margin-bottom:0}
.legal-section ul{margin:0;padding-left:18px;display:grid;gap:8px}
.legal-section li{font-size:18px;line-height:1.24;color:rgba(217,224,255,.86)}
.legal-section a{color:var(--ink)}
.legal-menu{display:none}
.legal-toggle{display:none}


.glitch{position:relative}
.glitch::before,.glitch::after{
  content:attr(data-text);position:absolute;left:0;top:0;width:100%;opacity:.55;pointer-events:none;
}
.glitch::before{
  transform:translate(1px,0); color:rgba(0,245,255,.85); mix-blend-mode:screen;
  animation:glitchA 2.3s infinite linear alternate-reverse;
}
.glitch::after{
  transform:translate(-1px,0); color:rgba(255,47,214,.85); mix-blend-mode:screen;
  animation:glitchB 1.8s infinite linear alternate-reverse;
}
@keyframes glitchA{
  0%{clip-path:inset(0 0 92% 0)} 20%{clip-path:inset(10% 0 55% 0)}
  40%{clip-path:inset(55% 0 25% 0)} 60%{clip-path:inset(30% 0 55% 0)}
  80%{clip-path:inset(80% 0 5% 0)} 100%{clip-path:inset(0 0 92% 0)}
}
@keyframes glitchB{
  0%{clip-path:inset(85% 0 5% 0)} 25%{clip-path:inset(25% 0 55% 0)}
  50%{clip-path:inset(55% 0 25% 0)} 75%{clip-path:inset(10% 0 70% 0)}
  100%{clip-path:inset(85% 0 5% 0)}
}

@media (max-width:980px){
  .wrap{grid-template-columns:1fr}
  .player,.history,.links{grid-column:1/2}
  .vol{margin-left:0;width:100%;min-width:0}
  .link-grid{grid-template-columns:1fr 1fr}
  .history-actions{width:100%;justify-content:flex-end}
}

@media (max-width:520px){
  body.mobile-history-open{overflow:hidden}
  .top{
    display:grid;
    grid-template-columns:1fr auto;
    grid-template-areas:
      "brand button"
      "status status";
    align-items:center;
    gap:10px 12px;
    padding:calc(14px + env(safe-area-inset-top)) 14px 10px;
  }
  .brand{grid-area:brand;gap:10px;min-width:0}
  .status{grid-area:status;gap:6px;align-items:flex-start;padding-bottom:0}
  .status-meta{width:100%;justify-content:space-between;gap:10px}
  .mobile-menu-btn{
    grid-area:button;
    justify-self:end;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:44px;
    height:44px;
    padding:0;
    z-index:30;
    font-size:19px;
  }
  .mark{width:36px;height:36px;border-radius:12px}
  .title{font-size:23px;line-height:1}
  .subtitle{font-size:13px;margin-top:2px}
  .pill{font-size:14px;padding:5px 8px}
  .small{font-size:13px}

  .wrap{
    padding:10px 14px calc(12px + env(safe-area-inset-bottom));
    display:flex;
    flex-direction:column;
    min-height:calc(var(--app-vh, 1vh) * 100 - var(--mobile-top-size));
  }
  .player{
    margin-bottom:0;
    min-height:100%;
    display:flex;
    flex-direction:column;
  }
  .player-head{padding:15px 14px 11px;gap:12px}
  .np-art{width:70px;height:70px;border-radius:14px}
  .kicker{font-size:10px}
  .np-title{font-size:21px;white-space:normal;line-height:1.02}
  .np-artist{font-size:17px;white-space:normal;line-height:1.06}
  .np-extra{margin-top:7px;gap:7px}
  .chip{font-size:13px;padding:4px 7px}
  .progress{padding:0 14px 10px}
  .bar{height:8px}
  .bar-meta{font-size:13px;margin-top:4px}
  .controls{padding:6px 14px 10px;gap:10px}
  .btn{padding:10px 11px;font-size:15px;border-radius:12px}
  .btn.tiny{font-size:14px;padding:8px 10px}
  .vol{width:100%;gap:9px;min-width:0}
  .vol input[type="range"]{width:100%}
  .hint{padding:0 14px 8px;font-size:13px;line-height:1.22}
  .about-inline{padding:11px 14px 12px;font-size:15px;line-height:1.24}
  .about-inline::before{width:52px;margin-bottom:8px}
  .about-inline::after{left:14px;right:14px}
  .mini-actions{padding:11px 14px 10px;gap:9px}
  .bg-scan{opacity:.04}
  .mobile-quick-links{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
    padding:0 14px 14px;
    position:relative;
    z-index:1;
    margin-top:auto;
  }
  .quick-link{padding:10px 12px;font-size:15px}

  .desktop-links-card{display:none}
  .bottom{display:none}
  .legal-toggle{display:inline-flex}

  .legal-panel{
    top:auto;
    bottom:0;
    left:0;
    right:0;
    width:100%;
    height:min(82dvh, 760px);
    border-left:none;
    border-top:1px solid rgba(255,255,255,.10);
    border-radius:20px 20px 0 0;
    transform:translateY(105%);
    box-shadow:0 -24px 48px rgba(0,0,0,.46), 0 0 0 1px rgba(0,245,255,.05);
  }
  .legal-panel.open{transform:translateY(0)}
  .legal-head{padding:14px 14px 10px}
  .legal-head h2{font-size:18px}
  .legal-scroll{padding:14px 14px calc(18px + env(safe-area-inset-bottom))}
  .legal-callout p,
  .legal-section p,
  .legal-section li{font-size:15px}
  .legal-meta{font-size:13px}

  .history{
    position:fixed;
    top:0;
    right:0;
    left:auto;
    width:min(86vw, 360px);
    height:100dvh;
    margin:0;
    border-radius:18px 0 0 18px;
    transform:translateX(105%);
    transition:transform .28s cubic-bezier(.22,.9,.22,1);
    z-index:30;
    display:block;
    overflow:auto;
    box-shadow:-24px 0 48px rgba(0,0,0,.45);
  }
  .history.drawer-open{transform:translateX(0)}
  .history .card-title{
    position:sticky;
    top:0;
    background:rgba(9,13,23,.96);
    backdrop-filter:blur(10px);
    padding:calc(14px + env(safe-area-inset-top)) 14px 10px;
    border-bottom:1px solid rgba(255,255,255,.08);
  }
  .history .card-title h2{font-size:15px}
  .history-actions{width:auto;justify-content:flex-end;gap:6px}
  .mobile-history-close{display:inline-flex}
  .history-body{display:block !important}
  .list{padding:14px}
  .row{padding:9px}
  .r-title{font-size:18px}
  .r-sub,.r-time{font-size:14px}
  .footnote{padding:0 14px calc(14px + env(safe-area-inset-bottom));font-size:14px}
}

@media (max-width:520px) and (max-height:820px){
  .top{padding:calc(12px + env(safe-area-inset-top)) 12px 8px}
  .wrap{padding:8px 12px calc(10px + env(safe-area-inset-bottom)); min-height:calc(var(--app-vh, 1vh) * 100 - 100px)}
  .mark{width:34px;height:34px}
  .title{font-size:22px}
  .subtitle{font-size:12px}
  .status{gap:4px}
  .pill{font-size:13px;padding:4px 8px}
  .small{font-size:12px}
  .player-head{padding:13px 12px 9px;gap:10px}
  .np-art{width:62px;height:62px;border-radius:13px}
  .np-title{font-size:18px;line-height:1}
  .np-artist{font-size:15px;line-height:1.02}
  .chip{font-size:12px;padding:4px 6px}
  .progress{padding:0 12px 8px}
  .bar{height:7px}
  .bar-meta{font-size:12px}
  .controls{padding:3px 12px 8px;gap:8px}
  .btn{padding:9px 10px;font-size:14px}
  .btn.tiny{padding:7px 9px;font-size:13px}
  .hint{padding:0 12px 6px;font-size:12px;line-height:1.16}
  .about-inline{padding:9px 12px 10px;font-size:14px;line-height:1.18}
  .about-inline::before{width:44px;margin-bottom:7px}
  .about-inline::after{left:12px;right:12px}
  .mini-actions{padding:9px 12px 8px;gap:8px}
  .mobile-quick-links{padding:0 12px 12px;gap:8px}
  .quick-link{padding:9px 10px;font-size:14px}
}

@media (max-width:520px) and (min-height:900px){
  .wrap{min-height:calc(var(--app-vh, 1vh) * 100 - 118px)}
  .player-head{padding-top:18px}
  .hint{padding-bottom:10px}
  .about-inline{padding-top:13px; padding-bottom:14px}
  .mini-actions{padding-top:12px; padding-bottom:12px}
  .mobile-quick-links{padding-bottom:18px}
}

@media (hover:hover) and (pointer:fine){
  .card:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.14);box-shadow:0 22px 72px rgba(0,0,0,.58)}
}


/* locale selector */
.locale-fab{
  position:fixed;
  right:16px;
  bottom:calc(16px + env(safe-area-inset-bottom));
  z-index:40;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:8px;
}
.locale-toggle{
  min-width:72px;
  justify-content:center;
  gap:8px;
  backdrop-filter:blur(10px);
}
.locale-menu{
  min-width:196px;
  max-height:min(62vh, 420px);
  overflow:auto;
  padding:8px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(8,12,22,.94);
  box-shadow:0 18px 48px rgba(0,0,0,.48), 0 0 0 1px rgba(0,245,255,.06);
  backdrop-filter:blur(16px);
}
.locale-menu[hidden]{display:none}
.locale-item{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  border:1px solid transparent;
  border-radius:12px;
  background:transparent;
  color:var(--ink);
  padding:10px 12px;
  font:inherit;
  font-size:18px;
  cursor:pointer;
  text-align:left;
}
.locale-item:hover{
  border-color:rgba(0,245,255,.22);
  background:linear-gradient(135deg, rgba(0,245,255,.10), rgba(255,47,214,.08));
}
.locale-item.active{
  border-color:rgba(255,47,214,.26);
  box-shadow:0 0 0 1px rgba(255,47,214,.10) inset;
}
.locale-copy{display:flex;flex-direction:column;min-width:0;gap:2px}
.locale-name{font-size:1em;line-height:1.05}
.locale-note{font-size:14px;line-height:1.05;color:rgba(217,224,255,.58)}
.locale-code{
  color:rgba(217,224,255,.78);
  font-size:13px;
  letter-spacing:.08em;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  flex:0 0 auto;
}

[dir="rtl"] body{direction:rtl}
[dir="rtl"] .status{text-align:left;align-items:flex-start}
[dir="rtl"] .status-meta,
[dir="rtl"] .brand,
[dir="rtl"] .player-head,
[dir="rtl"] .np-extra,
[dir="rtl"] .controls,
[dir="rtl"] .bar-meta,
[dir="rtl"] .card-title,
[dir="rtl"] .row,
[dir="rtl"] .mini-actions,
[dir="rtl"] .mobile-quick-links,
[dir="rtl"] .vol,
[dir="rtl"] .history-actions{direction:rtl}
[dir="rtl"] .r-time{margin-left:0;margin-right:auto}
[dir="rtl"] .about-inline::before{margin-right:0;margin-left:auto}
[dir="rtl"] .locale-fab{left:16px;right:auto;align-items:flex-start}

@media (max-width:520px){
  .locale-fab{
    right:12px;
    bottom:calc(12px + env(safe-area-inset-bottom));
  }
  .locale-toggle{min-width:64px;padding:8px 10px}
  .locale-menu{min-width:176px;max-width:calc(100vw - 24px)}
  .legal-menu{display:block}
  .locale-item{font-size:17px;padding:9px 10px}
  [dir="rtl"] .locale-fab{left:12px;right:auto}
  [dir="rtl"] .legal-panel{left:0;right:0;transform:translateY(105%);border-right:none}
  [dir="rtl"] .legal-panel.open{transform:translateY(0)}
}
@media (max-width:520px) and (max-height:820px){
  .locale-fab{bottom:calc(10px + env(safe-area-inset-bottom))}
  .locale-menu{max-height:min(54vh, 320px)}
}

html:lang(zh) body{
  font-family:var(--font-sans), "PingFang SC", "Microsoft YaHei", sans-serif;
}
html:lang(zh) .title{
  font-family:var(--font-display), "PingFang SC", "Microsoft YaHei", sans-serif;
}
html:lang(zh) .subtitle,
html:lang(zh) .kicker,
html:lang(zh) .card-title h2,
html:lang(zh) .pill,
html:lang(zh) .chip,
html:lang(zh) .small,
html:lang(zh) .btn,
html:lang(zh) .hint,
html:lang(zh) .about-inline,
html:lang(zh) .r-title,
html:lang(zh) .r-sub,
html:lang(zh) .np-title,
html:lang(zh) .np-artist{
  font-family:var(--font-sans), "PingFang SC", "Microsoft YaHei", sans-serif;
  letter-spacing:normal;
}


.mini-actions .quick-link{white-space:nowrap}
@media (max-width:520px){
  .mini-actions{display:grid;grid-template-columns:1fr 1fr;}
  .mini-actions .quick-link,.mini-actions .small-action{width:100%}
}
