/* Fonts vendored under wwwroot/fonts/ (OFL). */
@font-face { font-family:'Space Grotesk'; font-style:normal; font-weight:500; font-display:swap; src:url('/fonts/space-grotesk-500.woff2') format('woff2'); }
@font-face { font-family:'Space Grotesk'; font-style:normal; font-weight:600; font-display:swap; src:url('/fonts/space-grotesk-600.woff2') format('woff2'); }
@font-face { font-family:'Space Grotesk'; font-style:normal; font-weight:700; font-display:swap; src:url('/fonts/space-grotesk-700.woff2') format('woff2'); }
@font-face { font-family:'IBM Plex Mono'; font-style:normal; font-weight:400; font-display:swap; src:url('/fonts/ibm-plex-mono-400.woff2') format('woff2'); }
@font-face { font-family:'IBM Plex Mono'; font-style:normal; font-weight:500; font-display:swap; src:url('/fonts/ibm-plex-mono-500.woff2') format('woff2'); }

:root {
  color-scheme:dark;
  /* ── NEUTRAL FOUNDATION (platform-owned) ── */
  --bg:#080807; --surface:#0d0c0a; --surface-hi:#131210; --surface-2:#16140f;
  --border:#1e1d16; --border-hi:#302f24;
  --text:#eee9e0; --text-muted:#b5b0a2; --text-dim:#5a5750;
  --bg-glass:rgba(8,8,7,.86);

  /* ── TENANT TOKEN (injected by layout via body style) — fallback only ── */
  --accent:#e8b94f;
  --accent-contrast:#080807;
  --accent-ink:var(--accent-contrast);
  --accent-dim:color-mix(in srgb, var(--accent) 10%, transparent);
  --accent-line:color-mix(in srgb, var(--accent) 42%, transparent);

  --font-display:'Space Grotesk', system-ui, sans-serif;
  --font-mono:'IBM Plex Mono', ui-monospace, monospace;
  --r:5px; --maxw:1180px;

  /* archive density (overridden by [data-density]) */
  --grid-min:212px; --grid-gap:18px;
}
[data-density="compact"] { --grid-min:150px; --grid-gap:10px; }
@media (max-width:480px){ :root { --grid-min:155px; --grid-gap:11px; } }

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; scroll-behavior:smooth; }
body {
  background:var(--bg); color:var(--text);
  font-family:var(--font-mono); font-size:.8125rem; line-height:1.6; letter-spacing:.01em;
  -webkit-font-smoothing:antialiased; min-height:100dvh; overflow-x:hidden;
}
/* film grain — signature texture */
body::before {
  content:""; position:fixed; inset:0; pointer-events:none; z-index:9000;
  opacity:.03; mix-blend-mode:overlay; background-size:200px 200px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='256' height='256'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
a { color:inherit; text-decoration:none; }
button,input { font-family:inherit; }
img { display:block; max-width:100%; }
:focus-visible { outline:2px solid var(--accent); outline-offset:2px; border-radius:2px; }
::selection { background:var(--accent); color:var(--accent-ink); }

/* ── type helpers ── */
.kicker { font-weight:500; font-size:.625rem; text-transform:uppercase; letter-spacing:.26em; color:var(--text-dim); }
.mono { font-family:var(--font-mono); }
.dim { color:var(--text-dim); } .muted { color:var(--text-muted); }
.tnum { font-variant-numeric:tabular-nums; }
.mlabel { display:inline-flex; align-items:center; gap:9px; font-size:.625rem; letter-spacing:.26em; text-transform:uppercase; color:var(--accent); }
.mlabel::before { content:""; width:5px; height:5px; border-radius:50%; background:var(--accent); }

/* ════════ MASTHEAD ════════ */
.site-head { position:sticky; top:0; z-index:100; background:var(--bg-glass); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-bottom:1px solid var(--border); }
.site-head__inner { max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(1.1rem,4vw,2.4rem); height:64px; display:flex; align-items:center; gap:26px; }
.site-brand { font-family:var(--font-display); font-weight:700; font-size:1.2rem; letter-spacing:-.01em; display:flex; align-items:center; gap:9px; }
.site-brand .pin { width:6px; height:6px; border-radius:50%; background:var(--accent); }
.site-nav { margin-left:auto; display:flex; align-items:center; gap:6px; }
.site-nav a { position:relative; font-size:.66rem; text-transform:uppercase; letter-spacing:.2em; color:var(--text-dim); padding:.5rem .8rem; transition:color .15s; white-space:nowrap; }
.site-nav a:hover { color:var(--text-muted); }
.site-nav a[aria-current="page"] { color:var(--text); }
.site-nav a[aria-current="page"]::after { content:""; position:absolute; left:.8rem; right:.8rem; bottom:0; height:2px; background:var(--accent); }
@media (max-width:560px){ .site-head__inner { gap:10px; } .site-nav a { padding:.5rem .55rem; letter-spacing:.14em; } }
@media (max-width:480px){ .site-nav a { font-size:.58rem; letter-spacing:.1em; } }

/* ════════ PAGE SCAFFOLD ════════ */
.page { max-width:var(--maxw); margin-inline:auto; padding:clamp(2rem,5vw,3.4rem) clamp(1.1rem,4vw,2.4rem) 6rem; }
.page--narrow { max-width:920px; }
.breadcrumb { display:flex; align-items:center; gap:9px; font-size:.7rem; letter-spacing:.04em; color:var(--text-dim); margin-bottom:1.4rem; flex-wrap:wrap; }
.breadcrumb a { color:var(--accent); transition:color .15s; }
.breadcrumb a:hover { color:var(--text); }
.breadcrumb .sep { color:var(--text-dim); }
.page-head { margin-bottom:clamp(1.6rem,3vw,2.4rem); }
.page-head h1 { font-family:var(--font-display); font-weight:700; font-size:clamp(2.2rem,5.5vw,3.6rem); line-height:.98; letter-spacing:-.02em; text-wrap:balance; }
.page-head .lead { margin-top:.85rem; color:var(--text-muted); font-size:.82rem; letter-spacing:.04em; max-width:60ch; text-wrap:pretty; }
.page-head .lead b { color:var(--text); font-weight:400; }

/* ── buttons ── */
.btn { display:inline-flex; align-items:center; gap:8px; font-family:var(--font-mono); font-weight:500; font-size:.68rem; text-transform:uppercase; letter-spacing:.14em; padding:.6rem 1rem; border-radius:var(--r); border:1px solid transparent; cursor:pointer; transition:transform .12s, background .15s, border-color .15s, color .15s; white-space:nowrap; }
.btn:hover { transform:translateY(-1px); }
.btn--accent { background:var(--accent); color:var(--accent-ink); font-weight:600; }
.btn--ghost { border-color:var(--border-hi); color:var(--text); }
.btn--ghost:hover { background:var(--surface-hi); border-color:var(--text-dim); }
.btn--quiet { color:var(--text-dim); padding:.6rem .7rem; }
.btn--quiet:hover { color:var(--text); transform:none; }

/* ════════ ARCHIVE TOOLBAR ════════ */
.toolbar { display:flex; align-items:center; gap:16px 22px; flex-wrap:wrap; padding-bottom:1.2rem; border-bottom:1px solid var(--border); margin-bottom:1.6rem; }
.toolbar__count { font-size:.72rem; color:var(--text-dim); letter-spacing:.04em; white-space:nowrap; }
.toolbar__count b { color:var(--text-muted); font-weight:400; }
.toolbar__grow { flex:1 1 0; min-width:8px; }
.toolbar__group { display:flex; align-items:center; gap:9px; }
.toolbar__lab { font-size:.58rem; letter-spacing:.2em; text-transform:uppercase; color:var(--text-dim); }

/* segmented (Covers / Rows) */
.seg { display:inline-flex; border:1px solid var(--border-hi); border-radius:var(--r); overflow:hidden; }
.seg button { appearance:none; background:transparent; border:0; border-left:1px solid var(--border-hi); color:var(--text-dim); font:500 .6rem/1 var(--font-mono); letter-spacing:.18em; text-transform:uppercase; padding:.5rem .78rem; cursor:pointer; transition:.15s; display:inline-flex; align-items:center; gap:6px; }
.seg button:first-child { border-left:0; }
.seg button.is-on { color:var(--accent); background:var(--accent-dim); }
.seg button .gi { width:11px; height:11px; display:inline-block; }

/* chips (year) */
.chips { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:1.6rem; }
.chip { background:transparent; border:1px solid var(--border); color:var(--text-muted); font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; padding:.36rem .72rem; border-radius:999px; cursor:pointer; transition:.15s; display:inline-flex; align-items:center; gap:7px; white-space:nowrap; }
.chip:hover { border-color:var(--text-dim); color:var(--text); }
.chip.is-on { border-color:var(--accent-line); color:var(--text); background:var(--accent-dim); }
.chip .n { font-size:.56rem; color:var(--text-dim); }
.chip.is-on .n { color:var(--accent); }

/* sort select */
.selectwrap { position:relative; display:inline-flex; align-items:center; }
.selectwrap::after { content:"▾"; position:absolute; right:.6rem; color:var(--text-dim); pointer-events:none; font-size:.7rem; }
.select { appearance:none; background:transparent; border:1px solid var(--border-hi); border-radius:var(--r); color:var(--text-muted); font-family:var(--font-mono); font-size:.64rem; letter-spacing:.12em; text-transform:uppercase; padding:.5rem 1.9rem .5rem .72rem; cursor:pointer; transition:.15s; }
.select:hover { border-color:var(--text-dim); color:var(--text); }
.select:focus { outline:none; border-color:var(--accent); }

/* ════════ ARCHIVE — LAYOUTS ════════ */
[data-view="list"] .archive-grid { display:none; }
[data-view="covers"] .archive-rows { display:none; }

/* cover grid */
.archive-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(var(--grid-min),1fr)); gap:var(--grid-gap); }
.mixcard { border:1px solid var(--border); background:var(--surface); border-radius:var(--r); overflow:hidden; cursor:pointer; transition:border-color .15s, transform .12s, background .15s; display:flex; flex-direction:column; }
.mixcard:hover { border-color:var(--border-hi); background:var(--surface-hi); transform:translateY(-2px); }
.mixcard__art { aspect-ratio:1/1; position:relative; border-bottom:1px solid var(--border); overflow:hidden; }
.mixcard__art--placeholder { background:linear-gradient(135deg, var(--surface-hi) 0%, var(--surface-2) 100%); }
.mixcard__num { position:absolute; left:10px; bottom:8px; font-family:var(--font-display); font-weight:700; font-size:2.6rem; line-height:1; color:rgba(238,233,224,.10); letter-spacing:-.02em; }
.mixcard__tl { position:absolute; right:9px; top:9px; width:7px; height:7px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 3px rgba(8,8,7,.5); }
.mixcard__body { padding:.7rem .8rem .8rem; display:flex; flex-direction:column; gap:.4rem; flex:1; }
.mixcard__title { font-family:var(--font-display); font-weight:600; font-size:.92rem; line-height:1.12; letter-spacing:-.005em; text-wrap:balance; }
.mixcard__meta { margin-top:auto; font-size:.58rem; letter-spacing:.12em; text-transform:uppercase; color:var(--text-dim); display:flex; gap:.7rem; flex-wrap:wrap; }
[data-density="compact"] .mixcard__title { font-size:.78rem; }
[data-density="compact"] .mixcard__num { font-size:1.9rem; }
[data-density="compact"] .mixcard__meta { font-size:.54rem; gap:.5rem; }
[data-density="compact"] .mixcard__body { padding:.55rem .6rem .62rem; gap:.3rem; }

/* catalogue rows / list */
.archive-rows { border:1px solid var(--border); border-radius:var(--r); overflow:hidden; }
.mixrow { display:grid; grid-template-columns:88px 1fr 80px 70px 96px 52px; align-items:center; border-bottom:1px solid var(--border); cursor:pointer; transition:background .12s; min-height:88px; }
.mixrow:last-child { border-bottom:0; }
.mixrow:hover { background:var(--surface-hi); }
.mixrow__thumb { width:88px; height:88px; flex-shrink:0; }
.mixrow__thumb--placeholder { background:linear-gradient(135deg, var(--surface-hi) 0%, var(--surface-2) 100%); }
.mixrow__body { padding:.5rem .95rem; min-width:0; }
.mixrow__title { font-family:var(--font-display); font-weight:600; font-size:.94rem; letter-spacing:-.005em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mixrow__sub { font-size:.6rem; letter-spacing:.06em; color:var(--text-dim); margin-top:1px; }
.mixrow__date { font-size:.68rem; color:var(--text-muted); letter-spacing:.04em; }
.mixrow__dur { font-size:.68rem; color:var(--text-muted); letter-spacing:.04em; font-variant-numeric:tabular-nums; }
.mixrow__tracks { font-size:.62rem; letter-spacing:.12em; text-transform:uppercase; color:var(--text-dim); display:inline-flex; align-items:center; gap:7px; }
.mixrow__tracks .dot--on { width:6px; height:6px; border-radius:50%; background:var(--accent); display:inline-block; }
.mixrow__tracks .dot--off { width:6px; height:6px; border-radius:50%; border:1px solid var(--text-dim); display:inline-block; }
.mixrow__go { padding-right:1.1rem; text-align:right; font-size:.6rem; letter-spacing:.16em; text-transform:uppercase; color:var(--text-dim); }
.mixrow:hover .mixrow__go { color:var(--accent); }
.mixrow__go::after { content:" →"; }
[data-density="compact"] .mixrow { min-height:56px; grid-template-columns:56px 1fr 70px 62px 84px 48px; }
[data-density="compact"] .mixrow__thumb { width:56px; height:56px; }
[data-density="compact"] .mixrow__title { font-size:.82rem; }
@media (max-width:860px) and (min-width:641px){
  .mixrow { grid-template-columns:88px 1fr 80px 70px 52px; }
  .mixrow__tracks { display:none; }
}
@media (max-width:640px){
  .mixrow { grid-template-columns:72px 1fr auto; min-height:72px; }
  .mixrow__thumb { width:72px; height:72px; }
  .mixrow__date, .mixrow__tracks, .mixrow__go { display:none; }
  .mixrow__dur { padding-right:.9rem; font-size:.62rem; }
}

/* sentinel + infinite scroll */
.scroll-sentinel { height:1px; }
.loadmore { padding:1.6rem 0 .4rem; text-align:center; font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--text-dim); }
.endcap { padding:1.2rem 0; text-align:center; font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--text-dim); opacity:.6; }
.dot--pulse { display:inline-block; width:6px; height:6px; border-radius:50%; background:var(--accent); margin-right:9px; animation:pulse 1s ease-in-out infinite; vertical-align:middle; }
@keyframes pulse { 0%,100%{ opacity:.25; } 50%{ opacity:1; } }

/* ════════ MIX DETAIL ════════ */
.mix-detail { max-width:980px; }
.mix-stage  { margin-top:1.6rem; }

/* stage meta / title / actions */
.stage-meta { display:flex; flex-wrap:wrap; gap:14px 20px; font-family:var(--font-mono); font-size:.64rem; letter-spacing:.18em; text-transform:uppercase; color:var(--text-muted); }
.stage-meta span { display:inline-flex; align-items:center; gap:8px; white-space:nowrap; }
.stage-meta i { width:5px; height:5px; border-radius:50%; background:var(--accent); flex-shrink:0; }
.stage-title { font-family:var(--font-display); font-weight:700; letter-spacing:-.025em; line-height:.9; text-wrap:balance; font-size:clamp(1.9rem,3.8vw,3.1rem); max-width:14ch; }
.stage-actions { display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.stage-share { display:inline-flex; align-items:center; gap:8px; font-family:var(--font-mono); font-weight:500; font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; padding:.62rem 1.15rem; border-radius:999px; background:var(--accent); color:var(--accent-contrast); border:0; cursor:pointer; transition:transform .12s, filter .15s; }
.stage-share:hover { transform:translateY(-1px); filter:brightness(1.08); }
.sc-cta { font-size:.6rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-dim); display:inline-flex; align-items:center; gap:5px; white-space:nowrap; transition:color .15s; }
.sc-cta:hover { color:var(--text-muted); }

/* split grid: cover + info, fused to the player below */
.split-grid { display:grid; grid-template-columns:minmax(0,360px) 1fr; overflow:hidden;
  border:1px solid var(--border-hi); border-bottom:0; border-radius:11px 11px 0 0; }
.stage-art { position:relative; aspect-ratio:1/1; overflow:hidden; border-right:1px solid var(--border);
  background:repeating-linear-gradient(96deg, #1a1610 0 8px, #221c12 8px 17px); }
.stage-art img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.split-info { padding:clamp(22px,3vw,38px); min-width:0;
  display:flex; flex-direction:column; justify-content:center; gap:clamp(16px,1.8vw,22px); }

/* SoundCloud classic player bar, fused to the grid.
   Wrapper owns the border/radius so they aren't inverted.
   filter: invert+hue-rotate flips the widget's white bg to dark; only technique for cross-origin iframes. */
.sc-frame-wrap { border:1px solid var(--border-hi); border-top:0; border-radius:0 0 11px 11px; overflow:hidden; }
.sc-frame { display:block; width:100%; height:120px; border:0; filter:invert(1) hue-rotate(180deg); }
.sc-frame--placeholder { display:flex; align-items:center; justify-content:center; height:120px; color:var(--text-dim); font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; }

@media (max-width:640px) {
  .split-grid { grid-template-columns:1fr; }
  .stage-art  { aspect-ratio:1/1; border-right:0; border-bottom:1px solid var(--border); }
}

/* intro prose */
.mix-intro { margin-top:2rem; }
.mix-intro p { color:var(--text-muted); line-height:1.75; }
.mix-intro p + p { margin-top:.75em; }

/* tracklist */
.section-head { display:flex; align-items:baseline; gap:14px; margin:2.6rem 0 .4rem; }
.section-head h2 { font-family:var(--font-display); font-weight:600; font-size:1.5rem; letter-spacing:-.01em; }
.section-head .n { font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--text-dim); }
.tracklist { margin-top:.6rem; border-top:1px solid var(--border); }
.tl-row { display:grid; grid-template-columns:42px 1fr; align-items:baseline; gap:14px; padding:.85rem 4px; border-bottom:1px solid var(--border); transition:background .12s; }
.tl-row:hover { background:var(--surface); }
.tl-row .pos { font-variant-numeric:tabular-nums; font-size:.74rem; color:var(--text-dim); text-align:right; }
.tl-row .tl-text { font-size:.86rem; line-height:1.45; }
.tl-row .ar { color:var(--text); transition:color .15s; }
.tl-row a.ar:hover { color:var(--accent); }
.tl-row .sep { color:var(--text-dim); margin:0 .4rem; }
.tl-row .ti { color:var(--text-muted); }
.tl-row .lab { color:var(--text-dim); margin-left:.5rem; }

/* tracklist empty state */
.tl-empty { margin-top:.6rem; border:1px solid var(--border); border-radius:var(--r); background:var(--surface); padding:2.2rem 1.6rem; text-align:center; }
.tl-empty__big { font-family:var(--font-display); font-weight:600; font-size:1.15rem; color:var(--text-muted); margin-bottom:.55rem; letter-spacing:-.01em; }
.tl-empty p { font-size:.76rem; color:var(--text-dim); line-height:1.65; max-width:48ch; margin-inline:auto; text-wrap:pretty; }

/* chips row on archive */
.chips-row { display:flex; align-items:center; gap:10px; margin-bottom:1.6rem; }
.chips-row .chips { margin-bottom:0; flex:1; }
.chips-row .sc-archive-cta { font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; color:var(--text-dim); white-space:nowrap; flex-shrink:0; transition:color .15s; }
.chips-row .sc-archive-cta:hover { color:var(--text-muted); }

/* prev / next */
.mixnav { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:3rem; }
@media (max-width:560px){ .mixnav { grid-template-columns:1fr; } }
.mixnav a { border:1px solid var(--border); border-radius:var(--r); padding:1rem 1.1rem; background:var(--surface); transition:border-color .15s, background .15s; min-width:0; }
.mixnav a:hover { border-color:var(--border-hi); background:var(--surface-hi); }
.mixnav .dir { font-size:.58rem; letter-spacing:.2em; text-transform:uppercase; color:var(--text-dim); }
.mixnav .t { font-family:var(--font-display); font-weight:600; font-size:.95rem; margin-top:.4rem; letter-spacing:-.005em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mixnav a:hover .t { color:var(--accent); }
.mixnav .next { text-align:right; }
.mixnav .empty { pointer-events:none; opacity:.4; }

/* related strip */
.related { margin-top:3.2rem; }
.related-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:1rem; }
@media (max-width:680px){ .related-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:400px){ .related-grid { grid-template-columns:repeat(2,1fr); gap:9px; } }

/* ════════ ARTISTS INDEX ════════ */
.alpha-jump { display:flex; flex-wrap:wrap; gap:3px; margin-bottom:2.2rem; padding-bottom:1.4rem; border-bottom:1px solid var(--border); }
.alpha-jump a { font-size:.66rem; letter-spacing:.1em; color:var(--text-dim); padding:.3rem .5rem; border-radius:3px; transition:.15s; min-width:1.6rem; text-align:center; }
.alpha-jump a:hover { color:var(--accent); background:var(--accent-dim); }
.alpha-group { margin-bottom:2.2rem; scroll-margin-top:84px; }
.alpha-letter { font-family:var(--font-display); font-weight:700; font-size:1.4rem; color:var(--text-dim); margin-bottom:.5rem; }
.artist-row { display:flex; align-items:baseline; gap:.7rem; padding:.7rem 2px; border-bottom:1px solid var(--border); cursor:pointer; transition:background .12s; }
.artist-row:hover { background:var(--surface); }
.artist-row .nm { font-family:var(--font-display); font-weight:600; font-size:1rem; letter-spacing:-.005em; transition:color .15s; }
.artist-row:hover .nm { color:var(--accent); }
.artist-row .ct { font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-dim); }
.artist-row .arrow { margin-left:auto; color:var(--text-dim); opacity:0; transition:opacity .15s; }
.artist-row:hover .arrow { opacity:1; color:var(--accent); }

/* ════════ ARTIST PAGE ════════ */
.artist-mixes { display:flex; flex-direction:column; gap:0; border-top:1px solid var(--border); margin-top:.6rem; }
.artist-mix { display:grid; grid-template-columns:64px 1fr auto; align-items:center; gap:16px; padding:1rem 4px; border-bottom:1px solid var(--border); cursor:pointer; transition:background .12s; }
.artist-mix:hover { background:var(--surface); }
.artist-mix__thumb { width:64px; height:64px; border-radius:4px; border:1px solid var(--border-hi); position:relative; overflow:hidden; }
.artist-mix__thumb--placeholder { background:linear-gradient(135deg, var(--surface-hi) 0%, var(--surface-2) 100%); }
.artist-mix__thumb .n { position:absolute; left:6px; bottom:3px; font-family:var(--font-display); font-weight:700; font-size:.85rem; color:rgba(238,233,224,.55); }
.artist-mix__body { min-width:0; }
.artist-mix__title { font-family:var(--font-display); font-weight:600; font-size:1.05rem; letter-spacing:-.005em; }
.artist-mix:hover .artist-mix__title { color:var(--accent); }
.artist-mix__track { font-size:.72rem; color:var(--text-muted); margin-top:.3rem; letter-spacing:.02em; }
.artist-mix__track .lab { color:var(--text-dim); }
.artist-mix__date { font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-dim); white-space:nowrap; }
@media (max-width:560px){ .artist-mix { grid-template-columns:48px 1fr; } .artist-mix__thumb { width:48px; height:48px; } .artist-mix__date { display:none; } }

/* ════════ SEARCH ════════ */
.search-stage { max-width:920px; }
.searchbar { display:flex; align-items:center; gap:14px; padding:1.1rem 1.2rem; border:1px solid var(--border-hi); border-radius:8px; background:var(--surface); transition:border-color .15s; }
.searchbar:focus-within { border-color:var(--accent); }
.searchbar .ic { width:18px; height:18px; border:1.8px solid var(--text-dim); border-radius:50%; position:relative; flex-shrink:0; transition:border-color .15s; }
.searchbar:focus-within .ic { border-color:var(--accent); }
.searchbar .ic::after { content:""; position:absolute; width:7px; height:1.8px; background:var(--text-dim); bottom:-2px; right:-4px; transform:rotate(45deg); }
.searchbar:focus-within .ic::after { background:var(--accent); }
.searchbar input { flex:1; background:transparent; border:0; outline:none; color:var(--text); font-family:var(--font-mono); font-size:1.15rem; letter-spacing:.01em; min-width:0; }
.searchbar input::placeholder { color:var(--text-dim); }
.searchbar .clear { background:transparent; border:0; color:var(--text-dim); cursor:pointer; font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; padding:.3rem .5rem; }
.searchbar .clear:hover { color:var(--text); }

.search-sug { margin-top:1.2rem; display:flex; align-items:center; gap:10px; flex-wrap:wrap; font-size:.66rem; color:var(--text-dim); letter-spacing:.04em; }
.search-sug button { background:transparent; border:1px solid var(--border); color:var(--text-muted); border-radius:999px; padding:.32rem .7rem; font-family:var(--font-mono); font-size:.64rem; letter-spacing:.06em; cursor:pointer; transition:.15s; }
.search-sug button:hover { border-color:var(--accent-line); color:var(--text); background:var(--accent-dim); }

.search-meta { margin-top:2rem; font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--text-dim); }
.search-meta b { color:var(--text-muted); font-weight:400; }

.results { margin-top:1.4rem; display:grid; grid-template-columns:1fr; gap:2.4rem; }
.result-sec h3 { font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--text-dim); display:flex; justify-content:space-between; align-items:baseline; padding-bottom:.7rem; border-bottom:1px solid var(--border); }
.result-sec h3 .c { color:var(--accent); }
.res { display:flex; align-items:baseline; gap:14px; padding:.7rem 2px; border-bottom:1px solid var(--border); cursor:pointer; transition:background .12s; }
.res:hover { background:var(--surface); }
.res .nm { font-family:var(--font-display); font-weight:600; font-size:.98rem; letter-spacing:-.005em; }
.res .nm .ar { color:var(--text); } .res .nm .ti { color:var(--text-muted); } .res .nm .dash { color:var(--text-dim); margin:0 .35rem; }
.res .nm mark { background:var(--accent-dim); color:var(--accent); border-radius:2px; padding:0 2px; }
.res:hover .nm .ar { color:var(--accent); }
.res .mt { margin-left:auto; font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-dim); white-space:nowrap; text-align:right; }
.res .mt b { color:var(--text-muted); font-weight:400; }
.results-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(170px,1fr)); gap:14px; }
.res-empty { padding:1rem 0; color:var(--text-dim); font-style:italic; }
.search-blank { margin-top:3rem; padding:3rem 0; text-align:center; color:var(--text-dim); border-top:1px solid var(--border); }
.search-blank .big { font-family:var(--font-display); font-weight:600; font-size:1.2rem; color:var(--text-muted); margin-bottom:.6rem; }

/* ════════ SEARCH RESULTS GROUPS ════════ */
.res-group { display:flex; flex-direction:column; gap:0; }
.res-group h2 { font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--text-dim); padding-bottom:.7rem; border-bottom:1px solid var(--border); margin-bottom:0; }
.res-mixes { display:grid; grid-template-columns:repeat(auto-fill,minmax(170px,1fr)); gap:14px; margin-top:.7rem; }
.res-mix { border:1px solid var(--border); background:var(--surface); border-radius:var(--r); padding:.7rem .8rem; display:flex; flex-direction:column; gap:.3rem; transition:border-color .15s, background .15s; }
.res-mix:hover { border-color:var(--border-hi); background:var(--surface-hi); }
.res-mix__title { font-family:var(--font-display); font-weight:600; font-size:.88rem; letter-spacing:-.005em; }
.res-mix__date { font-size:.58rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-dim); }
.search-empty { padding:1rem 0; color:var(--text-dim); font-style:italic; }

/* ════════ FOOTER ════════ */
.site-foot { border-top:1px solid var(--border); margin-top:2rem; }
.site-foot__inner { max-width:var(--maxw); margin-inline:auto; padding:2rem clamp(1.1rem,4vw,2.4rem) 3rem; display:flex; justify-content:space-between; align-items:center; gap:18px; flex-wrap:wrap; }
.site-foot__inner p { font-size:.68rem; color:var(--text-dim); letter-spacing:.04em; }
.site-foot__inner a { color:var(--text-muted); transition:color .15s; }
.site-foot__inner a:hover { color:var(--text); }
.site-foot__links { display:flex; gap:18px; font-size:.66rem; text-transform:uppercase; letter-spacing:.14em; }

/* toast (copy link) */
.toast { position:fixed; left:50%; bottom:26px; transform:translateX(-50%) translateY(20px); background:var(--surface-hi); border:1px solid var(--border-hi); border-radius:999px; padding:.6rem 1.1rem; font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text); opacity:0; pointer-events:none; transition:opacity .2s, transform .2s; z-index:9600; display:flex; align-items:center; gap:9px; }
.toast.is-on { opacity:1; transform:translateX(-50%) translateY(0); }
.toast .d { width:6px; height:6px; border-radius:50%; background:var(--accent); }

/* page entrance */
.page { animation:fade .26s ease; }
@keyframes fade { from { opacity:.4; transform:translateY(5px); } to { opacity:1; transform:none; } }

@media (max-width:500px){
  .toolbar { gap:8px 14px; }
  .toolbar__lab { display:none; }
}
@media (max-width:480px){
  .page-head h1 { font-size:clamp(1.9rem,9vw,3.6rem); }
}
@media (prefers-reduced-motion:reduce){ *{ animation:none !important; transition:none !important; } }
