/* ── RESPONSIVE ─────────────────────────────────────────────────── */
@media (max-width: 768px) {
  body {
    grid-template-columns: 1fr;
    grid-template-areas: "main" "pl";
    --ph: 70px;
  }
  .sb   { display: none; }
  .mnav { display: grid; }
  .main { padding-bottom: var(--nh); }

  .topbar  { padding: 10px 14px; }
  .content { padding: 14px; }

  .hero   { padding: 20px; margin-bottom: 20px; }
  .hero-t { font-size: 26px; }
  .sec    { margin-bottom: 28px; }

  .sg  { grid-template-columns: repeat(2,1fr); gap: 10px; }
  .sc  { width: auto; }

  .pl  { grid-template-columns: 1fr auto; padding: 0 14px; gap: 10px; }
  .prgt{ display: none; }
  .pctrl { gap: 4px; }
  .pbtns { gap: 14px; }
  .ppb   { width: 34px; height: 34px; }
  .pexp  { display: none; }

  .fs-body { grid-template-columns: 1fr; padding: 0 20px 20px; overflow-y: auto; align-items: flex-start; }
  .fs-r    { display: none; }
  .fs-ly-btn { display: flex; }
  .fs-hdr  { padding: 14px 18px; }
  .fs-cov  { width: min(240px,100%); }
  .fs-t    { font-size: 22px; }

  .art-hdr  { min-height: 200px; padding: 20px; }
  .art-name { font-size: 26px; }

  .alb-hdr { flex-direction: column; align-items: flex-start; gap: 16px; }
  .alb-cov { width: 120px; height: 120px; }
  .alb-t   { font-size: 22px; }
}

@media (max-width: 400px) {
  .sg { grid-template-columns: 1fr 1fr; }
  .hrow .sc { width: 140px; }
}
