/* ==========================================================
   AUDIOHUB — STYLE.CSS
   Responsive: 1280 | 1024 | 768 | 480 | 360
   ========================================================== */

/* ── Variables ─────────────────────────────────────────── */
:root {
  --bg:        #09090f;
  --bg-card:   #111120;
  --bg-surf:   #16162a;
  --border:    rgba(255,255,255,0.07);
  --primary:   #f59e0b;
  --pri-d:     #d97706;
  --pri-glow:  rgba(245,158,11,0.25);
  --accent:    #06b6d4;
  --acc-glow:  rgba(6,182,212,0.2);
  --green:     #10b981;
  --red:       #ef4444;
  --t1: #f1f5f9;
  --t2: #94a3b8;
  --t3: #64748b;
  --r1: 6px;  --r2: 12px;  --r3: 18px;  --r4: 24px;
  --font-d: 'Baloo 2', cursive;
  --font-b: 'Nunito', sans-serif;
  --ease: 0.22s cubic-bezier(0.4,0,0.2,1);
  /* fluid type scale */
  --fs-xs:   clamp(10px, 1.2vw, 11px);
  --fs-sm:   clamp(12px, 1.4vw, 13px);
  --fs-base: clamp(13px, 1.5vw, 15px);
  --fs-md:   clamp(16px, 2vw,   21px);
  --fs-lg:   clamp(22px, 3.5vw, 38px);
  --fs-xl:   clamp(28px, 5vw,   50px);
}

/* ── Reset ──────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; text-size-adjust:100%; }
body {
  font-family: var(--font-b);
  background: var(--bg);
  color: var(--t1);
  font-size: var(--fs-base);
  line-height: 1.65;
  overflow-x: hidden;
}
a { text-decoration:none; color:inherit; }
img { display:block; max-width:100%; }
select,input,button { font-family:var(--font-b); }
body.no-scroll { overflow:hidden; }

/* ── Container ──────────────────────────────────────────── */
.container { max-width:1200px; margin:0 auto; padding:0 clamp(14px,3vw,28px); }

/* ── Buttons ────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:7px;
  padding:0 20px; height:44px; border-radius:var(--r1);
  font-weight:700; font-size:var(--fs-sm); cursor:pointer; border:none;
  transition:var(--ease); white-space:nowrap; flex-shrink:0;
}
.btn--primary { background:linear-gradient(135deg,var(--primary),#f97316); color:#000; box-shadow:0 4px 16px var(--pri-glow); }
.btn--primary:hover { filter:brightness(1.12); transform:translateY(-1px); }
.btn--outline  { background:transparent; border:1.5px solid var(--border); color:var(--t2); }
.btn--outline:hover { border-color:var(--primary); color:var(--primary); }
.btn--glow     { background:linear-gradient(135deg,var(--primary),#f97316); color:#000; height:50px; padding:0 32px; border-radius:var(--r2); font-size:var(--fs-base); font-weight:800; box-shadow:0 0 32px var(--pri-glow); }
.btn--glow:hover { transform:scale(1.04); box-shadow:0 0 48px rgba(245,158,11,.5); }
.btn--blk  { width:100%; }

/* ── HEADER ─────────────────────────────────────────────── */
.header {
  position:sticky; top:0; z-index:100;
  background:rgba(9,9,15,.93);
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);
}
.header__in {
  display:flex; align-items:center; gap:20px;
  height:clamp(56px,8vw,64px);
}
.logo {
  display:flex; align-items:center; gap:9px; flex-shrink:0;
  font-family:var(--font-d); font-size:clamp(17px,2.2vw,21px); font-weight:800;
}
.logo i { color:var(--primary); font-size:1.15em; filter:drop-shadow(0 0 8px var(--pri-glow)); }
.logo em { color:var(--primary); font-style:normal; }

/* Desktop nav */
.nav { display:flex; align-items:center; gap:2px; margin-left:auto; }
.nav__close { display:none; }
.nav__mbtns { display:none; }
.nav__link {
  display:flex; align-items:center; gap:7px;
  padding:8px 13px; border-radius:var(--r1);
  font-weight:600; font-size:var(--fs-sm); color:var(--t2); transition:var(--ease);
}
.nav__link i { display:none; } /* icons hidden on desktop */
.nav__link:hover,.nav__link.active { color:var(--primary); background:var(--pri-glow); }

/* Dropdown menu */
.nav__dropdown { position:relative; }
.nav__submenu {
  position:absolute; top:100%; left:0;
  display:grid; grid-template-columns:repeat(2,minmax(130px,1fr)); gap:8px;
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r2);
  min-width:260px; padding:12px; margin-top:4px;
  opacity:0; visibility:hidden; transform:translateY(-10px);
  transition:var(--ease); z-index:101;
}
.nav__dropdown:hover .nav__submenu {
  opacity:1; visibility:visible; transform:translateY(0);
}
.nav__submenu li {
  list-style:none;
}
.nav__submenu a {
  display:flex; align-items:center; justify-content:center;
  padding:10px 14px; border-radius:var(--r1);
  color:var(--t2); font-size:var(--fs-sm); font-weight:600;
  background:rgba(255,255,255,.04); transition:var(--ease);
}
.nav__submenu a:hover {
  color:var(--primary); background:rgba(245,158,11,.14);
}
.nav__submenu__all {
  grid-column:1/-1;
}
.nav__submenu__all a {
  background:rgba(245,158,11,.12); color:var(--primary); font-weight:700;
}
.nav__submenu__all a:hover {
  background:var(--pri-glow); color:#000;
}

.header__acts { display:flex; gap:8px; flex-shrink:0; }
.hamburger {
  display:none; align-items:center; justify-content:center;
  width:44px; height:44px; background:none; border:none;
  color:var(--t1); font-size:20px; cursor:pointer;
  border-radius:var(--r1); flex-shrink:0;
}

/* Nav overlay */
.nav-ov { display:none; position:fixed; inset:0; background:rgba(0,0,0,.65); z-index:90; backdrop-filter:blur(3px); }
.nav-ov.show { display:block; }

/* ── HERO ───────────────────────────────────────────────── */
.hero { position:relative; padding:clamp(48px,8vw,88px) 0 clamp(40px,6vw,72px); overflow:visible; }
.hero__glow {
  position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(ellipse 700px 500px at 72% 50%,rgba(245,158,11,.07) 0%,transparent 70%),
    radial-gradient(ellipse 450px 400px at 8%  80%,rgba(6,182,212,.06) 0%,transparent 60%);
}
.hero__in { display:grid; grid-template-columns:1fr 360px; gap:clamp(24px,4vw,56px); align-items:center; }

.eyebrow {
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(245,158,11,.1); border:1px solid rgba(245,158,11,.25);
  color:var(--primary); padding:5px 14px; border-radius:99px;
  font-size:var(--fs-sm); font-weight:700; margin-bottom:14px;
}
.eyebrow--lt { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.15); color:rgba(255,255,255,.65); }
.grad { background:linear-gradient(135deg,var(--primary),#f97316,#ef4444); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

.hero__title { font-family:var(--font-d); font-size:var(--fs-xl); font-weight:800; line-height:1.15; margin-bottom:14px; }
.hero__sub   { color:var(--t2); font-size:var(--fs-base); max-width:480px; margin-bottom:24px; }

/* Search */
.search-wrap { margin-bottom:20px; }
.sbox {
  display:flex; align-items:center; gap:10px;
  background:var(--bg-card); border:1.5px solid var(--border);
  border-radius:var(--r2); padding:6px 6px 6px 16px; margin-bottom:12px;
  transition:var(--ease);
}
.sbox:focus-within { border-color:var(--primary); box-shadow:0 0 0 3px var(--pri-glow); }
.sbox i    { color:var(--t3); flex-shrink:0; }
.sbox input {
  flex:1; background:none; border:none; outline:none;
  color:var(--t1); font-size:var(--fs-base); min-width:0;
}
.sbox input::placeholder { color:var(--t3); }
.sbox button {
  background:linear-gradient(135deg,var(--primary),#f97316); color:#000;
  border:none; padding:0 18px; height:38px; border-radius:var(--r1);
  font-weight:700; font-size:var(--fs-sm); cursor:pointer; white-space:nowrap; transition:var(--ease);
}
.sbox button:hover { filter:brightness(1.1); }

.filters { display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.filters select {
  background:var(--bg-card); border:1.5px solid var(--border); color:var(--t2);
  padding:0 14px; height:44px; border-radius:var(--r1);
  font-size:var(--fs-sm); cursor:pointer; outline:none; transition:var(--ease); flex:1; min-width:120px;
  color-scheme: dark;
}
.filters select option {
  background: var(--bg-card);
  color: var(--t1);
}
.filters select:focus { border-color:var(--primary); }

.genre-dd { position:relative; flex:1; min-width:120px; }
.genre-dd__trigger {
  width:100%; height:44px; border-radius:var(--r1);
  border:1.5px solid var(--border); background:var(--bg-card); color:var(--t2);
  font-size:var(--fs-sm); padding:0 14px; display:flex; align-items:center; justify-content:space-between;
}
.genre-dd__trigger i { font-size:12px; }
.genre-dd__menu {
  position:absolute; top:calc(100% + 6px); left:0; right:0; z-index:120;
  max-height:460px; overflow:auto;
  border:1px solid var(--border); border-radius:var(--r1);
  background:var(--bg-card); box-shadow:0 16px 30px rgba(0,0,0,.28);
  padding:6px;
}
.genre-dd__menu.is-hidden { display:none; }
.genre-dd__item {
  width:100%; text-align:left; border:0; background:transparent; color:var(--t1);
  border-radius:8px; padding:8px 10px; font-size:var(--fs-sm);
}
.genre-dd__item:hover, .genre-dd__item.is-active { background:rgba(245,158,11,.14); color:var(--primary); }

/* Stats */
.hstats { display:flex; align-items:center; gap:18px; margin-top:24px; }
.hs { text-align:center; }
.hs strong { display:block; font-family:var(--font-d); font-size:clamp(18px,2.5vw,24px); font-weight:800; color:var(--primary); }
.hs span   { font-size:var(--fs-xs); color:var(--t3); text-transform:uppercase; letter-spacing:.06em; }
.hs-div    { width:1px; height:32px; background:var(--border); }

/* Hero art */
.hero__art { position:relative; display:flex; justify-content:center; align-items:center; }
.vinyl { position:relative; width:clamp(180px,22vw,240px); height:clamp(180px,22vw,240px); }
.vinyl__disc {
  width:100%; height:100%; border-radius:50%;
  background:conic-gradient(#1a1a1a 0deg,#2a2a2a 30deg,#1a1a1a 60deg,#2a2a2a 90deg,#1a1a1a 120deg,#2a2a2a 150deg,#1a1a1a 180deg,#2a2a2a 210deg,#1a1a1a 240deg,#2a2a2a 270deg,#1a1a1a 300deg,#2a2a2a 330deg,#1a1a1a 360deg);
  border:3px solid #2a2a2a; animation:spin 8s linear infinite;
  box-shadow:0 0 40px rgba(0,0,0,.8),0 0 70px rgba(245,158,11,.12);
}
.vinyl__dot {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:56px; height:56px; border-radius:50%;
  background:radial-gradient(circle,var(--primary) 0%,var(--pri-d) 50%,#111 70%);
  border:3px solid #333; box-shadow:0 0 18px var(--pri-glow);
}
.vinyl__glow {
  position:absolute; inset:-16px; border-radius:50%;
  background:radial-gradient(circle,var(--pri-glow) 0%,transparent 70%);
  animation:pulse 3s ease-in-out infinite;
}
.hcard {
  position:absolute; display:flex; align-items:center; gap:10px;
  background:rgba(15,15,30,.92); border:1px solid var(--border);
  backdrop-filter:blur(12px); border-radius:var(--r2); padding:9px 14px; white-space:nowrap;
}
.hcard i { font-size:17px; }
.hcard b  { display:block; font-size:11px; font-weight:700; }
.hcard small { font-size:10px; color:var(--t3); }
.hcard--a { bottom:18px; left:-28px; }
.hcard--a i { color:var(--green); }
.hcard--b { top:16px; right:-18px; }
.hcard--b i { color:var(--red); }

/* ── SECTIONS ───────────────────────────────────────────── */
.sec { padding:clamp(28px,5vw,52px) 0; }
.sec__hd { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; gap:12px; }
.sec__ttl { font-family:var(--font-d); font-size:var(--fs-md); font-weight:800; display:flex; align-items:center; gap:10px; }
.dot { display:inline-block; width:11px; height:11px; border-radius:50%; flex-shrink:0; }
.dot-c { background:var(--accent); box-shadow:0 0 8px var(--acc-glow); }
.dot-o { background:#f97316;  box-shadow:0 0 8px rgba(249,115,22,.5); }
.dot-y { background:var(--primary); box-shadow:0 0 8px var(--pri-glow); }
.dot-g { background:var(--green);  box-shadow:0 0 8px rgba(16,185,129,.4); }
.sec__more { font-size:var(--fs-sm); font-weight:700; color:var(--primary); display:flex; align-items:center; gap:5px; transition:var(--ease); flex-shrink:0; }
.sec__more:hover { gap:9px; }

/* ── CARD GRID ──────────────────────────────────────────── */
.cgrid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)) !important; gap:clamp(12px,1.8vw,18px); }

.sc { cursor:pointer; transition:var(--ease); }
.sc:hover { transform:translateY(-4px); }
.sc__th {
  position:relative; aspect-ratio:16/9;
  background:linear-gradient(145deg,var(--c,#333),color-mix(in srgb,var(--c,#333) 55%,#000));
  border-radius:var(--r2); display:flex; align-items:center; justify-content:center;
  overflow:hidden; margin-bottom:8px;
}
.si { font-family:var(--font-d); font-size:clamp(18px,3vw,28px); font-weight:800; color:rgba(255,255,255,.28); }
.bx {
  position:absolute; top:7px; left:7px;
  padding:2px 7px; border-radius:4px; font-size:10px; font-weight:800; letter-spacing:.04em;
}
.bn { background:var(--accent); color:#fff; }
.bh { background:var(--red);    color:#fff; }
.bf { background:var(--green);  color:#fff; }
.pov {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,.5); opacity:0; transition:var(--ease); font-size:26px; color:#fff;
}
.sc:hover .pov { opacity:1; }
.sc__genre { font-size:11px; color:var(--accent); margin-bottom:4px; font-weight:700; }
.sc__nm { font-size:clamp(14px,1.6vw,18px); font-weight:800; color:var(--t1); line-height:1.35; margin-bottom:4px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sc__author { font-size:11px; color:var(--t3); display:flex; gap:6px; align-items:center; }
.sc__author i { color:var(--t2); }
.sc__mt { font-size:11px; color:var(--t3); display:flex; gap:6px; align-items:center; }
.sc__mt i { color:var(--primary); }

/* ── LEADERBOARD ────────────────────────────────────────── */
.lb-box {
  background:linear-gradient(135deg,#0d0d22 0%,#1a0a2e 50%,#0d1a2e 100%);
  border:1px solid var(--border); border-radius:var(--r4); padding:clamp(24px,4vw,48px);
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(24px,4vw,48px); align-items:center;
  position:relative; overflow:hidden;
}
.lb-box::before {
  content:''; position:absolute; inset:0; border-radius:var(--r4); pointer-events:none;
  background:
    radial-gradient(ellipse 500px 300px at 0% 50%,rgba(99,102,241,.08) 0%,transparent 60%),
    radial-gradient(ellipse 400px 400px at 100% 50%,rgba(245,158,11,.08) 0%,transparent 60%);
}
.lb-ttl { font-family:var(--font-d); font-size:clamp(22px,3.5vw,38px); font-weight:800; margin:8px 0 10px; }
.lb-desc { color:var(--t2); font-size:var(--fs-base); max-width:360px; }

/* Podium */
.podium { display:flex; align-items:flex-end; justify-content:center; gap:12px; }
.pod { display:flex; flex-direction:column; align-items:center; gap:5px; position:relative; z-index:1; }
.pcrn { font-size:20px; color:var(--primary); filter:drop-shadow(0 0 8px var(--pri-glow)); }
.pav {
  width:50px; height:50px; border-radius:50%;
  background:linear-gradient(135deg,var(--ac,#555),color-mix(in srgb,var(--ac,#555) 55%,#000));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-d); font-size:20px; font-weight:800; color:#fff;
  border:2px solid rgba(255,255,255,.12);
}
.pod1 .pav { width:62px; height:62px; font-size:24px; border-color:var(--primary); box-shadow:0 0 18px var(--pri-glow); }
.prk {
  width:22px; height:22px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:10px; font-weight:800; background:var(--bg-surf); border:1.5px solid var(--border); color:var(--t2);
}
.prk1 { background:var(--primary); color:#000; border-color:var(--primary); }
.pod p    { font-size:11.5px; font-weight:700; text-align:center; }
.pod small { font-size:10.5px; color:var(--primary); font-weight:700; }
.pbar {
  width:72px; border-radius:6px 6px 0 0;
  background:linear-gradient(to top,var(--primary),rgba(245,158,11,.35));
}
.pod2 .pbar { background:linear-gradient(to top,#94a3b8,rgba(148,163,184,.3)); }
.pod3 .pbar { background:linear-gradient(to top,#cd7f32,rgba(205,127,50,.3)); }

/* ── GENRE GRID ─────────────────────────────────────────── */
.ggrid { display:grid; grid-template-columns:repeat(8,1fr); gap:clamp(8px,1.2vw,12px); }
.gi {
  display:flex; flex-direction:column; align-items:center; gap:7px;
  padding:clamp(10px,1.4vw,14px) 8px;
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r2);
  font-size:clamp(10px,1.1vw,12px); font-weight:700; color:var(--t2);
  transition:var(--ease); text-align:center;
}
.gi:hover {
  background:color-mix(in srgb,var(--gc,#333) 12%,transparent);
  border-color:var(--gc,#333); color:#fff; transform:translateY(-3px);
  box-shadow:0 8px 22px color-mix(in srgb,var(--gc,#333) 18%,transparent);
}
.gi i { font-size:clamp(16px,2vw,20px); color:var(--gc,var(--primary)); }

/* ── TRENDING ───────────────────────────────────────────── */
.tlist { display:grid; gap:9px; }
.ti {
  display:flex; align-items:center; gap:14px;
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r2);
  padding:12px 16px; transition:var(--ease); cursor:pointer;
}
.ti:hover { border-color:rgba(245,158,11,.3); transform:translateX(4px); }
.trk { font-family:var(--font-d); font-size:18px; font-weight:800; color:var(--t3); width:28px; text-align:center; flex-shrink:0; }
.gold   { color:var(--primary); text-shadow:0 0 12px rgba(245,158,11,.6); }
.silver { color:#94a3b8; }
.bronze { color:#cd7f32; }
.tth {
  width:44px; height:44px; border-radius:var(--r1); flex-shrink:0;
  background:linear-gradient(135deg,var(--c,#333),color-mix(in srgb,var(--c,#333) 55%,#000));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-d); font-size:13px; font-weight:800; color:rgba(255,255,255,.35);
}
.tin { flex:1; min-width:0; }
.tnm { font-size:clamp(15px,1.5vw,18px); font-weight:800; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.tmt { font-size:var(--fs-xs); color:var(--t3); margin-top:2px; }
.tbar { width:120px; height:4px; background:var(--bg-surf); border-radius:99px; overflow:hidden; flex-shrink:0; }
.tfill { height:100%; background:linear-gradient(90deg,var(--primary),#f97316); border-radius:99px; }

/* ── AFFILIATE BANNER ───────────────────────────────────── */
.aff-box {
  background:linear-gradient(135deg,#064e3b 0%,#065f46 60%,#047857 100%);
  border:1px solid rgba(16,185,129,.25); border-radius:var(--r4);
  padding:clamp(24px,4vw,44px) clamp(20px,4vw,48px);
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  position:relative; overflow:hidden;
}
.aff-box::before {
  content:''; position:absolute; inset:0; border-radius:var(--r4); pointer-events:none;
  background:radial-gradient(ellipse 600px 400px at 30% 50%,rgba(16,185,129,.15) 0%,transparent 60%);
}
.aff-ttl { font-family:var(--font-d); font-size:clamp(17px,2.5vw,26px); font-weight:800; color:#fff; margin:6px 0 8px; line-height:1.3; }
.aff-ttl span { color:var(--primary); }
.aff-desc { color:rgba(255,255,255,.7); font-size:var(--fs-base); }

/* ── FOOTER ─────────────────────────────────────────────── */
.footer { background:#06060f; border-top:1px solid var(--border); padding:clamp(40px,6vw,60px) 0 clamp(16px,3vw,24px); }
.ft-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:clamp(20px,3vw,40px); margin-bottom:clamp(24px,3vw,36px); }
.ft-brand p { color:var(--t3); font-size:var(--fs-sm); margin-top:10px; max-width:260px; line-height:1.7; }
.socials { display:flex; gap:9px; margin-top:14px; }
.socials a {
  width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background:var(--bg-card); border:1px solid var(--border); color:var(--t3); font-size:14px; transition:var(--ease);
}
.socials a:hover { border-color:var(--primary); color:var(--primary); background:var(--pri-glow); }
.ft-col h4 { font-family:var(--font-d); font-size:var(--fs-sm); font-weight:800; color:var(--t1); margin-bottom:12px; }
.ft-col { display:flex; flex-direction:column; gap:9px; }
.ft-col a { color:var(--t3); font-size:var(--fs-sm); display:flex; align-items:center; gap:7px; transition:var(--ease); }
.ft-col a:hover { color:var(--primary); }
.ft-btm { border-top:1px solid var(--border); padding-top:18px; display:flex; justify-content:space-between; gap:12px; font-size:var(--fs-xs); color:var(--t3); }

/* ── BOTTOM NAV ─────────────────────────────────────────── */
.bnav { display:none; }

/* ── ANIMATIONS ─────────────────────────────────────────── */
@keyframes spin  { to { transform:rotate(360deg); } }
@keyframes pulse { 0%,100%{opacity:.5;transform:scale(.96)} 50%{opacity:1;transform:scale(1.04)} }

/* ==========================================================
   RESPONSIVE BREAKPOINTS
   ========================================================== */

/* ── Large tablet / small desktop  ≤ 1100px ── */
@media (max-width:1100px) {
  .hero__in   { grid-template-columns:1fr; }
  .hero__art  { display:none; }
  .cgrid      { grid-template-columns:repeat(4,1fr); }
  .ggrid      { grid-template-columns:repeat(6,1fr); }
  .lb-box     { grid-template-columns:1fr; }
  .lb-desc    { max-width:100%; }
  .podium     { justify-content:center; }
  .ft-grid    { grid-template-columns:1.6fr 1fr 1fr 1fr; }
}

/* ── Tablet  ≤ 900px ── */
@media (max-width:900px) {
  .cgrid  { grid-template-columns:repeat(4,1fr) !important; }
  .ggrid  { grid-template-columns:repeat(5,1fr); }
  .tbar   { display:none; }
  .ft-grid { grid-template-columns:1fr 1fr 1fr; }
  .ft-brand { grid-column:1 / -1; }
  .ft-brand p { max-width:100%; }
}

/* ── Mobile  ≤ 768px ── */
@media (max-width:768px) {
  /* body padding for bottom nav */
  body { padding-bottom:66px; }

  /* Container tighter */
  .container { padding:0 16px; }

  /* Header — show hamburger, hide desktop nav & actions */
  .header__acts { display:none; }
  .hamburger    { display:flex; margin-left:auto; }

  /* ─ Drawer nav ─ */
  .nav {
    position:fixed; top:0; right:-100%; bottom:0;
    width:min(290px, 82vw);
    height:100dvh;
    min-height:100vh;
    background:#0d0d1e;
    border-left:1px solid var(--border);
    flex-direction:column; align-items:flex-start; gap:3px;
    padding:72px 18px calc(28px + env(safe-area-inset-bottom));
    transition:right .3s cubic-bezier(.4,0,.2,1);
    z-index:200; overflow-y:auto; margin-left:0;
  }
  .nav.open     { right:0; }
  .nav__close   { display:flex; position:absolute; top:16px; right:16px; width:36px; height:36px; border-radius:50%; background:var(--bg-surf); border:1px solid var(--border); color:var(--t1); font-size:15px; align-items:center; justify-content:center; cursor:pointer; }
  .nav__link    { width:100%; padding:11px 14px; border-radius:var(--r2); font-size:15px; }
  .nav__link i  { display:inline-block; width:18px; }
  .nav__mbtns   { display:flex; flex-direction:column; gap:9px; width:100%; margin-top:auto; padding-top:14px; border-top:1px solid var(--border); }
  .nav__dropdown { width:100%; }
  .nav__submenu {
    position:static;
    display:grid;
    grid-template-columns:1fr;
    gap:6px;
    min-width:0;
    width:100%;
    margin-top:8px;
    padding:8px;
    opacity:1;
    visibility:visible;
    transform:none;
  }
  .nav__submenu a {
    justify-content:flex-start;
  }

  /* Hero */
  .hero__body { text-align:center; }
  .eyebrow    { margin-bottom:12px; }
  .hero__sub  { margin:0 auto 22px; }
  .filters    { justify-content:center; }
  .hstats     { justify-content:center; }
  .genre-dd__trigger,
  .filters select {
    height:46px !important;
    min-height:46px !important;
    line-height:46px;
    box-sizing:border-box;
  }
  .filters select {
    -webkit-appearance:none;
    appearance:none;
  }
  .filters .btn--primary {
    height:46px;
  }
  .filters select[data-home-status-select] {
    height:46px !important;
    min-height:46px !important;
  }

  /* Sections */
  .cgrid { grid-template-columns:repeat(4,1fr) !important; gap:10px; }
  .ggrid { grid-template-columns:repeat(4,1fr); gap:9px; }

  /* Leaderboard */
  .lb-box { padding:26px 22px; border-radius:var(--r3); gap:22px; }

  /* Affiliate */
  .aff-box { flex-direction:column; text-align:center; padding:28px 22px; border-radius:var(--r3); gap:18px; }
  .btn--glow { width:100%; }

  /* Trending */
  .ti { padding:10px 12px; gap:10px; }

  /* Footer */
  .ft-grid { grid-template-columns:1fr 1fr; gap:20px; }
  .ft-brand { grid-column:1 / -1; }
  .ft-btm   { flex-direction:column; text-align:center; }

  /* ─ Bottom nav ─ */
  .bnav {
    display:grid; grid-template-columns:repeat(5,1fr);
    position:fixed; bottom:0; left:0; right:0; z-index:150;
    background:rgba(10,10,20,.97);
    backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
    border-top:1px solid var(--border);
    padding-bottom:max(8px, env(safe-area-inset-bottom));
  }
  .bnav__item {
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    gap:3px; padding:8px 4px; color:var(--t3);
    font-size:10px; font-weight:700; transition:var(--ease); min-height:52px;
  }
  .bnav__item i   { font-size:19px; transition:var(--ease); }
  .bnav__item.active     { color:var(--primary); }
  .bnav__item.active i   { filter:drop-shadow(0 0 6px var(--pri-glow)); }
  .bnav__fab-wrap  { position:relative; top:-12px; }
  .bnav__fab {
    width:50px; height:50px; border-radius:50%;
    background:linear-gradient(135deg,var(--primary),#f97316);
    display:flex; align-items:center; justify-content:center;
    font-size:21px; color:#000; box-shadow:0 4px 20px var(--pri-glow);
  }
}

/* ── Phone  ≤ 480px ── */
@media (max-width:480px) {
  .container { padding:0 12px; }

  /* Cards 2 col */
  .cgrid { grid-template-columns:repeat(2,1fr); gap:9px; }
  .si    { font-size:22px; }

  /* Genre 3 col */
  .ggrid { grid-template-columns:repeat(3,1fr); gap:8px; }
  .gi    { padding:10px 5px; font-size:10px; }
  .gi i  { font-size:17px; }

  /* Hero filter stack */
  .search-wrap { margin-bottom:24px; }
  .sbox { padding:5px; border-radius:14px; margin-bottom:10px; }
  .sbox input { font-size:14px; }
  .sbox button { height:42px; padding:0 14px; border-radius:10px; font-size:14px; }

  .filters {
    flex-direction:column;
    gap:8px;
    background:rgba(15,15,30,.6);
    border:1px solid var(--border);
    border-radius:14px;
    padding:10px;
  }
  .genre-dd,
  .filters select,
  .filters .btn {
    width:100%;
    min-width:0;
  }
  .genre-dd__trigger,
  .filters select {
    height:46px;
    border-radius:10px;
    font-size:14px;
    color:var(--t1);
    padding:0 16px;
  }
  .genre-dd__trigger {
    background:rgba(11,11,20,.95);
  }
  .filters select {
    background:rgba(11,11,20,.95);
  }
  .filters .btn--primary {
    height:42px;
    border-radius:10px;
    font-size:15px;
    font-weight:800;
    margin-top:2px;
  }

  /* Leaderboard */
  .lb-box { padding:18px 15px; }
  .pav    { width:42px; height:42px; font-size:17px; }
  .pod1 .pav { width:54px; height:54px; font-size:21px; }
  .pbar   { width:60px; }
  .pod p  { font-size:10.5px; }

  /* Trending */
  .tth { width:38px; height:38px; font-size:11px; }
  .trk { font-size:15px; width:22px; }

  /* Footer */
  .ft-grid { grid-template-columns:1fr; }
}

/* ── Very small  ≤ 360px ── */
@media (max-width:360px) {
  .cgrid { gap:7px; }
  .ggrid { grid-template-columns:repeat(3,1fr); gap:6px; }
  .gi    { padding:8px 4px; }
}

@media (min-width:901px) {
  .cgrid {
    grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  }
}

/* ── Touch devices — remove hover lifts ── */
@media (hover:none) and (pointer:coarse) {
  .sc:hover,.gi:hover,.ti:hover { transform:none; }
  .sc:active { transform:scale(.97); }
  .pov       { display:none; }
}

/* ── Safe-area (notch / Dynamic Island) ── */
@supports (padding:max(0px)) {
  .header .container { padding-left:max(16px,env(safe-area-inset-left)); padding-right:max(16px,env(safe-area-inset-right)); }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion:reduce) {
  *,*::before,*::after { animation-duration:.01ms !important; transition-duration:.01ms !important; }
  .vinyl__disc { animation:none; }
}