/* ================================================================
   KONKANI SOUNDS v2.1 — Pure Black. Zero Brown.
   Syne + Manrope | #000000 base | #FF9500 accent on text/icons only
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=Manrope:wght@300;400;500;600;700&display=swap');

:root {
  /* ── Pure black palette. No warm tones in backgrounds. ── */
  --bg-void:     #000000;
  --bg-base:     #000000;   /* sidebar: pure black */
  --bg-surface:  #0D0D0D;
  --bg-elevated: #161616;
  --bg-card:     #1C1C1C;
  --bg-hover:    #222222;
  --bg-active:   #2A2A2A;

  /* ── Accent: orange ONLY on text and borders, never as bg fill ── */
  --accent:         #FF9500;
  --accent-bright:  #FFB340;
  --accent-dim:     #CC7700;
  --accent-glow:    rgba(255,149,0,0.20);
  /* WHITE-BASED subtle bg so there is zero brown tint */
  --accent-subtle:  rgba(255,255,255,0.05);
  --accent-border:  rgba(255,149,0,0.30);

  /* ── Mood colours ── */
  --mood-joyful:      #FFD60A;
  --mood-devotional:  #FF9500;
  --mood-romantic:    #FF375F;
  --mood-festive:     #FF6B35;
  --mood-nostalgic:   #BF5AF2;
  --mood-melancholic: #6E6E73;
  --mood-energetic:   #30D158;
  --mood-peaceful:    #64D2FF;
  --mood-patriotic:   #FF9F0A;
  --mood-humorous:    #FFD60A;

  --text-primary:   #FFFFFF;
  --text-secondary: #A1A1AA;
  --text-muted:     #52525B;
  --text-xmuted:    #3F3F46;

  --border:        rgba(255,255,255,0.07);
  --border-strong: rgba(255,255,255,0.13);

  --player-bg:  rgba(0,0,0,0.97);
  --player-h:   82px;
  --nav-h:      60px;
  --sidebar-w:  224px;

  --shadow-sm:  0 1px 4px rgba(0,0,0,0.8);
  --shadow-md:  0 4px 20px rgba(0,0,0,0.85);
  --shadow-lg:  0 16px 48px rgba(0,0,0,0.9);
  --shadow-glow:0 0 28px rgba(255,149,0,0.25);

  --r-xs:4px;  --r-sm:8px;  --r-md:12px;
  --r-lg:18px; --r-xl:28px; --r-full:999px;

  --font-display: 'Syne', sans-serif;
  --font-ui:      'Manrope', sans-serif;

  --t-fast:   0.12s ease;
  --t-base:   0.22s ease;
  --t-slow:   0.4s ease;
  --t-spring: 0.35s cubic-bezier(0.34,1.56,0.64,1);
}

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; scroll-behavior:smooth; }
body {
  background:var(--bg-void);
  color:var(--text-primary);
  font-family:var(--font-ui);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
a { color:inherit; text-decoration:none; transition:color var(--t-fast); }
a:hover { color:var(--accent); }
img { max-width:100%; display:block; }
button { cursor:pointer; border:none; background:none; font-family:inherit; color:inherit; }
ul,ol { list-style:none; }
input,select,textarea { font-family:inherit; }

/* ── Scrollbar ──────────────────────────────────────────────── */
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:rgba(255,255,255,0.1); border-radius:2px; }
::-webkit-scrollbar-thumb:hover { background:rgba(255,255,255,0.2); }

/* ── Layout ─────────────────────────────────────────────────── */
.ks-body { display:flex; min-height:100vh; padding-bottom:var(--player-h); }

/* ================================================================
   SIDEBAR — pure black, no warm tones
   ================================================================ */
.ks-sidebar {
  width:var(--sidebar-w);
  min-width:var(--sidebar-w);
  background:#000000; /* hard black, not a variable */
  height:calc(100vh - var(--player-h));
  position:sticky; top:0;
  overflow-y:auto;
  display:flex; flex-direction:column;
  border-right:1px solid var(--border);
  z-index:10;
}

.ks-sidebar__logo {
  padding:22px 18px 16px;
  border-bottom:1px solid var(--border);
}
.ks-sidebar__logo a { display:flex; align-items:center; gap:11px; }
.ks-sidebar__logo-text {
  font-family:var(--font-display);
  font-size:1rem; font-weight:800;
  color:#fff; line-height:1.1; letter-spacing:-0.01em;
}
.ks-sidebar__logo-sub {
  font-size:0.58rem; color:var(--accent);
  letter-spacing:0.2em; text-transform:uppercase;
  font-weight:700; margin-top:2px;
}

.ks-nav { padding:10px 0; flex:1; }
.ks-nav__section { margin-bottom:6px; }
.ks-nav__label {
  font-size:0.58rem; font-weight:800;
  letter-spacing:0.2em; text-transform:uppercase;
  color:var(--text-xmuted); padding:14px 18px 5px;
}
.ks-nav__item {
  display:flex; align-items:center; gap:12px;
  padding:9px 18px;
  color:var(--text-muted);
  font-size:0.845rem; font-weight:500;
  transition:color var(--t-fast), background var(--t-fast);
  border-radius:0 var(--r-full) var(--r-full) 0;
  margin-right:12px;
  border-left:2px solid transparent;
}
.ks-nav__item:hover {
  color:var(--text-primary);
  background:rgba(255,255,255,0.05);
}
/* Active: white accent bar on left, white text, NO orange background */
.ks-nav__item.active {
  color:#fff;
  background:rgba(255,255,255,0.06);
  border-left-color:var(--accent);
  padding-left:16px; /* compensate for border */
}
.ks-nav__item svg { width:16px; height:16px; flex-shrink:0; }

/* Collections: horizontal pill chips, not vertical nav items */
.ks-nav__chips {
  padding:4px 16px 14px;
  display:flex; flex-wrap:wrap; gap:5px;
}
.ks-nav__chip {
  display:inline-block;
  padding:4px 11px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--r-full);
  font-size:0.72rem; font-weight:500;
  color:var(--text-muted);
  white-space:nowrap;
  transition:all var(--t-fast);
}
.ks-nav__chip:hover {
  color:var(--text-primary);
  background:rgba(255,255,255,0.1);
  border-color:rgba(255,255,255,0.15);
}
.ks-nav__chip.active {
  color:var(--accent);
  background:rgba(255,149,0,0.08);
  border-color:var(--accent-border);
}

/* ── Main ────────────────────────────────────────────────────── */
.ks-main {
  flex:1; min-width:0;
  overflow-y:auto;
  height:calc(100vh - var(--player-h));
}

/* ── Top Bar ─────────────────────────────────────────────────── */
.ks-topbar {
  position:sticky; top:0; z-index:9;
  background:linear-gradient(180deg,#000 50%,transparent);
  padding:16px 32px 12px;
  display:flex; align-items:center; gap:16px;
}

/* ── Search ──────────────────────────────────────────────────── */
.ks-search { flex:1; max-width:440px; position:relative; }
.ks-search__input {
  width:100%;
  background:var(--bg-elevated);
  border:1px solid var(--border-strong);
  border-radius:var(--r-full);
  padding:9px 18px 9px 40px;
  color:#fff; font-size:0.845rem; outline:none;
  transition:all var(--t-fast);
}
.ks-search__input::placeholder { color:var(--text-muted); }
.ks-search__input:focus {
  border-color:var(--accent);
  background:var(--bg-card);
  box-shadow:0 0 0 3px rgba(255,149,0,0.10);
}
.ks-search__icon {
  position:absolute; left:13px; top:50%;
  transform:translateY(-50%);
  color:var(--text-muted); pointer-events:none;
}
.ks-search__results {
  position:absolute; top:calc(100% + 8px);
  left:0; right:0;
  background:var(--bg-elevated);
  border:1px solid var(--border-strong);
  border-radius:var(--r-md);
  box-shadow:var(--shadow-lg);
  overflow:hidden; z-index:100; display:none;
}
.ks-search__results.visible { display:block; }
.ks-search__empty { padding:16px; color:var(--text-muted); font-size:0.84rem; text-align:center; }
.ks-search-result {
  display:flex; align-items:center; gap:12px;
  padding:9px 14px; cursor:pointer;
  transition:background var(--t-fast);
}
.ks-search-result:hover { background:var(--bg-hover); }
.ks-search-result__art {
  width:36px; height:36px; border-radius:var(--r-xs);
  object-fit:cover; background:var(--bg-card); flex-shrink:0;
}
.ks-search-result__title { font-size:0.845rem; font-weight:500; }
.ks-search-result__meta  { font-size:0.72rem; color:var(--text-muted); }
.ks-search-result__type {
  margin-left:auto; font-size:0.6rem;
  text-transform:uppercase; letter-spacing:0.1em;
  color:var(--accent); background:rgba(255,149,0,0.08);
  padding:2px 8px; border-radius:var(--r-full); flex-shrink:0;
}

/* ── Content ─────────────────────────────────────────────────── */
.ks-content { padding:0 32px 80px; }

/* ── Sections ────────────────────────────────────────────────── */
.ks-section { margin-bottom:52px; }
.ks-section__header {
  display:flex; align-items:baseline;
  justify-content:space-between; margin-bottom:22px;
}
.ks-section__eyebrow {
  font-size:0.62rem; font-weight:800;
  letter-spacing:0.22em; text-transform:uppercase;
  color:var(--accent); margin-bottom:6px;
}
.ks-section__title {
  font-family:var(--font-display);
  font-size:1.45rem; font-weight:700;
  color:#fff; letter-spacing:-0.025em;
}
.ks-section__link {
  font-size:0.75rem; font-weight:600;
  letter-spacing:0.04em; text-transform:uppercase;
  color:var(--text-muted); transition:color var(--t-fast);
}
.ks-section__link:hover { color:var(--accent); }

/* ================================================================
   HERO
   ================================================================ */
.ks-hero {
  position:relative; overflow:hidden;
  min-height:80vh;
  display:flex; align-items:flex-end;
  background:#000; margin:0 -32px 52px;
}
.ks-hero__bg {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
  opacity:0.28;
}
.ks-hero__gradient {
  position:absolute; inset:0;
  background:linear-gradient(0deg,#000 0%,rgba(0,0,0,0.65) 45%,rgba(0,0,0,0.05) 100%),
             linear-gradient(90deg,rgba(0,0,0,0.75) 0%,transparent 65%);
}
.ks-hero__content {
  position:relative; z-index:2;
  padding:56px 48px;
  max-width:660px;
  animation:ks-hero-in 0.65s ease both;
}
@keyframes ks-hero-in {
  from { opacity:0; transform:translateY(20px); }
  to   { opacity:1; transform:translateY(0); }
}
.ks-hero__label {
  display:inline-flex; align-items:center; gap:8px;
  font-size:0.62rem; font-weight:800;
  letter-spacing:0.22em; text-transform:uppercase;
  color:var(--accent); margin-bottom:14px;
}
.ks-hero__label-dot {
  width:6px; height:6px; border-radius:50%;
  background:var(--accent);
  animation:ks-pulse 2s infinite;
}
@keyframes ks-pulse {
  0%,100%{opacity:1;transform:scale(1);}
  50%{opacity:0.4;transform:scale(0.7);}
}
.ks-hero__title {
  font-family:var(--font-display);
  font-size:clamp(2.6rem,5.5vw,4.8rem);
  font-weight:800; line-height:1.0;
  letter-spacing:-0.03em; color:#fff; margin-bottom:12px;
}
.ks-hero__title span { color:var(--accent); }
.ks-hero__sub { font-size:1rem; color:var(--text-secondary); margin-bottom:8px; }
.ks-hero__meta {
  display:flex; align-items:center; gap:10px;
  font-size:0.8rem; color:var(--text-muted); margin-bottom:28px;
}
.ks-hero__meta-dot { width:3px; height:3px; border-radius:50%; background:currentColor; }
.ks-hero__actions { display:flex; gap:12px; align-items:center; }

/* Floating card */
.ks-hero__float {
  position:absolute; right:6%; top:50%; transform:translateY(-50%);
  width:clamp(170px,20vw,260px);
  background:rgba(255,255,255,0.04);
  backdrop-filter:blur(28px); -webkit-backdrop-filter:blur(28px);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:var(--r-lg); overflow:hidden;
  box-shadow:0 32px 64px rgba(0,0,0,0.9);
  animation:ks-float 6s ease-in-out infinite; z-index:2;
}
@keyframes ks-float{
  0%,100%{transform:translateY(-50%) translateY(0);}
  50%{transform:translateY(-50%) translateY(-12px);}
}
.ks-hero__float-art { width:100%; aspect-ratio:1; object-fit:cover; }
.ks-hero__float-info { padding:13px 15px; }
.ks-hero__float-label { font-size:0.58rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--text-muted); margin-bottom:4px; }
.ks-hero__float-title { font-family:var(--font-display); font-size:0.88rem; font-weight:700; color:#fff; margin-bottom:12px; line-height:1.2; }
.ks-hero__float-play {
  display:flex; align-items:center; justify-content:center;
  width:100%; padding:7px; background:var(--accent);
  border-radius:var(--r-sm); font-size:0.76rem; font-weight:700; color:#000; gap:5px;
  transition:background var(--t-fast);
}
.ks-hero__float-play:hover { background:var(--accent-bright); color:#000; }

/* Hero fallback (no albums yet) */
.ks-hero--fallback {
  min-height:40vh; align-items:center;
  background:linear-gradient(135deg,#0D0D0D 0%,#000 100%);
}
.ks-hero--fallback .ks-hero__content { padding:40px 48px; }

/* ================================================================
   STATS BAR — forced horizontal flex row
   ================================================================ */
.ks-stats-bar {
  display:flex;          /* flex is more reliable than grid here */
  flex-direction:row;    /* HORIZONTAL */
  align-items:stretch;
  background:var(--border);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  overflow:hidden;
  margin-bottom:52px;
  gap:1px;
}
.ks-stat {
  flex:1;
  background:var(--bg-surface);
  padding:22px 20px;
  display:flex; flex-direction:column; gap:3px;
}
.ks-stat__num {
  font-family:var(--font-display);
  font-size:1.8rem; font-weight:800;
  color:#fff; line-height:1; letter-spacing:-0.03em;
}
.ks-stat__num span { color:var(--accent); }
.ks-stat__label {
  font-size:0.7rem; color:var(--text-muted);
  font-weight:600; text-transform:uppercase; letter-spacing:0.1em;
}

/* ================================================================
   MOOD GRID — explicit 5 cols, never a single column
   ================================================================ */
.ks-mood-grid {
  display:grid;
  grid-template-columns:repeat(5, 1fr); /* explicit — not auto-fill */
  gap:10px;
}
@media (max-width:1400px) { .ks-mood-grid { grid-template-columns:repeat(5,1fr); } }
@media (max-width:1100px) { .ks-mood-grid { grid-template-columns:repeat(4,1fr); } }
@media (max-width:800px)  { .ks-mood-grid { grid-template-columns:repeat(3,1fr); } }
@media (max-width:560px)  { .ks-mood-grid { grid-template-columns:repeat(2,1fr); } }

.ks-mood-card {
  display:flex; flex-direction:column; align-items:flex-start;
  padding:16px 16px 14px;
  border-radius:var(--r-md);
  background:var(--bg-surface);
  border:1px solid var(--border);
  cursor:pointer; text-decoration:none;
  transition:all var(--t-base);
  position:relative; overflow:hidden;
}
.ks-mood-card::before {
  content:'';
  position:absolute; bottom:-10px; right:-10px;
  width:56px; height:56px; border-radius:50%;
  background:var(--mood-c, var(--accent));
  opacity:0.10;
  transition:all var(--t-slow);
}
.ks-mood-card:hover {
  transform:translateY(-3px);
  border-color:var(--mood-c, var(--accent));
  box-shadow:0 8px 24px rgba(0,0,0,0.5);
  color:inherit;
}
.ks-mood-card:hover::before { opacity:0.20; transform:scale(1.4); }
.ks-mood-card__icon { font-size:1.5rem; margin-bottom:10px; line-height:1; }
.ks-mood-card__name {
  font-family:var(--font-display);
  font-size:0.875rem; font-weight:700; color:#fff; margin-bottom:2px;
}
.ks-mood-card__count { font-size:0.68rem; color:var(--text-muted); }

/* ================================================================
   HORIZONTAL SCROLL
   ================================================================ */
.ks-hscroll {
  display:flex; gap:16px;
  overflow-x:auto; overflow-y:visible;
  padding-bottom:10px; scrollbar-width:none; -ms-overflow-style:none;
  scroll-snap-type:x mandatory;
}
.ks-hscroll::-webkit-scrollbar { display:none; }
.ks-hscroll > * { scroll-snap-align:start; flex-shrink:0; }
.ks-grid--hscroll .ks-album-card { width:168px; }

/* ================================================================
   ALBUM CARDS
   ================================================================ */
.ks-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(168px,1fr)); gap:16px; }
.ks-grid--large { grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); }

.ks-album-card {
  background:var(--bg-surface);
  border-radius:var(--r-md); overflow:hidden;
  transition:all var(--t-base); cursor:pointer; display:block;
  border:1px solid transparent;
}
.ks-album-card:hover {
  background:var(--bg-elevated);
  transform:translateY(-4px); box-shadow:var(--shadow-md);
  border-color:var(--border-strong); color:inherit;
}
.ks-album-card__art-wrap { position:relative; aspect-ratio:1; overflow:hidden; background:var(--bg-elevated); }
.ks-album-card__art { width:100%; height:100%; object-fit:cover; transition:transform var(--t-slow); }
.ks-album-card:hover .ks-album-card__art { transform:scale(1.06); }

.ks-album-card__play {
  position:absolute; bottom:10px; right:10px;
  width:42px; height:42px; border-radius:50%;
  background:var(--accent); color:#000;
  display:flex; align-items:center; justify-content:center;
  opacity:0; transform:translateY(10px) scale(0.9);
  transition:all var(--t-spring);
  box-shadow:0 8px 24px rgba(0,0,0,0.6),var(--shadow-glow);
  border:none;
}
.ks-album-card:hover .ks-album-card__play { opacity:1; transform:translateY(0) scale(1); }
.ks-album-card__play:hover { background:var(--accent-bright); transform:scale(1.1) !important; }

.ks-album-card__info { padding:12px 14px 14px; }
.ks-album-card__title {
  font-family:var(--font-display);
  font-size:0.845rem; font-weight:700; color:#fff;
  line-height:1.3; margin-bottom:4px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.ks-album-card__meta { font-size:0.72rem; color:var(--text-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* ================================================================
   ARTIST CARDS
   ================================================================ */
.ks-artist-card {
  text-align:center;
  background:var(--bg-surface); border-radius:var(--r-md);
  padding:26px 16px 20px; transition:all var(--t-base);
  cursor:pointer; display:block; border:1px solid transparent;
}
.ks-artist-card:hover { background:var(--bg-elevated); transform:translateY(-4px); border-color:var(--border-strong); color:inherit; }
.ks-artist-card__photo-wrap { position:relative; width:88px; height:88px; margin:0 auto 12px; }
.ks-artist-card__photo {
  width:88px; height:88px; border-radius:50%;
  object-fit:cover; background:var(--bg-elevated);
  border:2px solid var(--border-strong); transition:border-color var(--t-fast);
}
.ks-artist-card:hover .ks-artist-card__photo { border-color:var(--accent); }
.ks-artist-card__badge {
  position:absolute; bottom:-2px; right:-2px;
  width:22px; height:22px; border-radius:50%;
  background:var(--accent); color:#000; font-size:0.55rem; font-weight:800;
  display:flex; align-items:center; justify-content:center;
  border:2px solid var(--bg-void);
}
.ks-artist-card__name { font-family:var(--font-display); font-size:0.875rem; font-weight:700; color:#fff; margin-bottom:2px; }
.ks-artist-card__origin { font-size:0.7rem; color:var(--text-muted); }
.ks-artist-card__albums { font-size:0.68rem; color:var(--accent); margin-top:3px; font-weight:600; }

/* ================================================================
   ARTIST SPOTLIGHT
   ================================================================ */
.ks-artist-spotlight {
  display:grid; grid-template-columns:2fr 1fr 1fr;
  grid-template-rows:auto auto; gap:10px;
}
.ks-artist-feature { position:relative; border-radius:var(--r-lg); overflow:hidden; cursor:pointer; display:block; }
.ks-artist-feature:first-child { grid-row:span 2; }
.ks-artist-feature__img { width:100%; height:100%; object-fit:cover; min-height:180px; transition:transform var(--t-slow); }
.ks-artist-feature:first-child .ks-artist-feature__img { min-height:100%; }
.ks-artist-feature:hover .ks-artist-feature__img { transform:scale(1.04); }
.ks-artist-feature__overlay { position:absolute; inset:0; background:linear-gradient(0deg,rgba(0,0,0,0.88) 0%,transparent 60%); }
.ks-artist-feature__info { position:absolute; bottom:14px; left:16px; right:16px; }
.ks-artist-feature__name { font-family:var(--font-display); font-weight:800; color:#fff; letter-spacing:-0.02em; }
.ks-artist-feature:first-child .ks-artist-feature__name { font-size:1.5rem; }
.ks-artist-feature__name { font-size:0.92rem; }
.ks-artist-feature__albums { font-size:0.7rem; color:var(--accent); margin-top:2px; font-weight:600; }

/* ================================================================
   THEME COLLECTION CARDS
   ================================================================ */
.ks-theme-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(210px,1fr)); gap:10px; }
.ks-theme-card {
  position:relative; border-radius:var(--r-md); overflow:hidden;
  aspect-ratio:16/9; cursor:pointer; display:block; min-height:110px;
  transition:transform var(--t-base);
}
.ks-theme-card:hover { transform:scale(1.02); color:inherit; }
.ks-theme-card__bg { width:100%; height:100%; object-fit:cover; position:absolute; inset:0; }
.ks-theme-card__gradient { position:absolute; inset:0; background:linear-gradient(135deg,var(--tc,rgba(255,149,0,0.8)) 0%,rgba(0,0,0,0.7) 100%); }
.ks-theme-card__name { position:absolute; bottom:13px; left:14px; right:14px; font-family:var(--font-display); font-size:0.95rem; font-weight:800; color:#fff; letter-spacing:-0.01em; }
.ks-theme-card__count { position:absolute; top:10px; right:10px; font-size:0.65rem; font-weight:700; color:rgba(255,255,255,0.7); background:rgba(0,0,0,0.4); padding:2px 7px; border-radius:var(--r-full); }

/* ================================================================
   FILTER BAR
   ================================================================ */
.ks-filter-bar {
  background:var(--bg-surface); border:1px solid var(--border);
  border-radius:var(--r-md); padding:14px 18px; margin-bottom:26px;
  display:flex; flex-wrap:wrap; align-items:center; gap:8px;
}
.ks-filter-bar__title { font-size:0.6rem; font-weight:800; letter-spacing:0.18em; text-transform:uppercase; color:var(--text-xmuted); margin-right:2px; flex-shrink:0; }
.ks-filter-select {
  background:var(--bg-elevated); border:1px solid var(--border-strong);
  border-radius:var(--r-sm); color:var(--text-secondary);
  padding:6px 28px 6px 11px; font-size:0.8rem; font-family:var(--font-ui);
  font-weight:500; outline:none; cursor:pointer;
  appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2352525B' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 9px center;
  transition:all var(--t-fast);
}
.ks-filter-select:focus,.ks-filter-select:hover { border-color:var(--accent); color:#fff; }
.ks-sort-tabs { display:flex; gap:3px; margin-left:auto; }
.ks-sort-tab {
  padding:5px 12px; border-radius:var(--r-sm);
  font-size:0.76rem; font-weight:600; color:var(--text-muted);
  background:transparent; border:1px solid transparent; transition:all var(--t-fast);
}
.ks-sort-tab:hover { color:#fff; background:var(--bg-elevated); }
.ks-sort-tab.active { color:var(--accent); background:rgba(255,149,0,0.08); border-color:var(--accent-border); }
.ks-filter-count { font-size:0.72rem; color:var(--text-muted); padding-left:8px; border-left:1px solid var(--border); white-space:nowrap; }

/* ================================================================
   TRACKLIST
   ================================================================ */
.ks-tracklist { width:100%; }
.ks-tracklist__header {
  display:grid; grid-template-columns:36px 1fr 150px 60px 52px;
  gap:12px; padding:8px 14px; border-bottom:1px solid var(--border); margin-bottom:4px;
}
.ks-tracklist__header span { font-size:0.6rem; font-weight:800; letter-spacing:0.14em; text-transform:uppercase; color:var(--text-muted); }

.ks-song-row {
  display:grid; grid-template-columns:36px 1fr 150px 60px 52px;
  gap:12px; align-items:center; padding:6px 14px;
  border-radius:var(--r-sm); transition:background var(--t-fast);
  cursor:pointer; border:1px solid transparent;
}
.ks-song-row:hover { background:var(--bg-elevated); border-color:var(--border); }
.ks-song-row.playing { background:rgba(255,149,0,0.06); border-color:rgba(255,149,0,0.2); }

.ks-song-row__num { font-size:0.84rem; color:var(--text-muted); text-align:center; display:flex; align-items:center; justify-content:center; }
.ks-song-row.playing .ks-song-row__track-num { color:var(--accent); }
.ks-song-row__play-icon { display:none; color:#fff; }
.ks-song-row:hover .ks-song-row__track-num { display:none; }
.ks-song-row:hover .ks-song-row__play-icon { display:flex; }
.ks-song-row__info { display:flex; align-items:center; gap:12px; min-width:0; }
.ks-song-row__art { width:38px; height:38px; border-radius:var(--r-xs); object-fit:cover; flex-shrink:0; background:var(--bg-elevated); }
.ks-song-row__text { min-width:0; }
.ks-song-row__title { font-size:0.875rem; font-weight:500; color:#fff; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ks-song-row.playing .ks-song-row__title { color:var(--accent); }
.ks-song-row__artist { font-size:0.76rem; color:var(--text-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ks-song-row__mood-badge { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ks-song-row__duration { font-size:0.78rem; color:var(--text-muted); text-align:right; }
.ks-mood-tag { display:inline-block; padding:2px 9px; border-radius:var(--r-full); font-size:0.62rem; font-weight:700; color:#000; }

/* ================================================================
   ALBUM HERO
   ================================================================ */
.ks-album-hero {
  display:flex; gap:36px; align-items:flex-end;
  padding:40px 32px 36px; position:relative;
}
.ks-album-hero__gradient { position:absolute; inset:0; background:linear-gradient(180deg,rgba(0,0,0,0) 0%,#000 100%); pointer-events:none; }
.ks-album-hero__art {
  width:200px; height:200px; border-radius:var(--r-md);
  object-fit:cover; box-shadow:var(--shadow-lg); flex-shrink:0;
  background:var(--bg-elevated); position:relative; z-index:1;
}
.ks-album-hero__info { flex:1; min-width:0; position:relative; z-index:1; }
.ks-album-hero__type { font-size:0.6rem; font-weight:800; letter-spacing:0.22em; text-transform:uppercase; color:var(--text-muted); margin-bottom:8px; }
.ks-album-hero__title { font-family:var(--font-display); font-size:clamp(1.8rem,4vw,3rem); font-weight:800; color:#fff; line-height:1.05; margin-bottom:12px; letter-spacing:-0.03em; }
.ks-album-hero__meta { display:flex; align-items:center; flex-wrap:wrap; gap:10px; color:var(--text-secondary); font-size:0.845rem; margin-bottom:18px; }
.ks-album-hero__meta-dot { width:4px; height:4px; border-radius:50%; background:var(--text-muted); }
.ks-album-hero__actions { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

/* ================================================================
   BUTTONS
   ================================================================ */
.ks-btn {
  display:inline-flex; align-items:center; gap:7px;
  padding:10px 24px; border-radius:var(--r-full);
  font-family:var(--font-ui); font-size:0.875rem; font-weight:700;
  transition:all var(--t-fast); cursor:pointer; border:none;
}
.ks-btn--primary { background:var(--accent); color:#000; }
.ks-btn--primary:hover { background:var(--accent-bright); color:#000; transform:scale(1.02); box-shadow:var(--shadow-glow); }
.ks-btn--ghost { background:rgba(255,255,255,0.08); color:#fff; border:1px solid var(--border-strong); }
.ks-btn--ghost:hover { background:rgba(255,255,255,0.14); color:#fff; }

/* ================================================================
   TAGS
   ================================================================ */
.ks-tag {
  display:inline-flex; align-items:center; gap:4px;
  padding:3px 10px; border-radius:var(--r-full);
  font-size:0.66rem; font-weight:600;
  background:rgba(255,149,0,0.08); color:var(--accent);
  border:1px solid var(--accent-border);
}

/* ================================================================
   PERSISTENT PLAYER
   ================================================================ */
.ks-player {
  position:fixed; bottom:0; left:0; right:0;
  height:var(--player-h);
  background:var(--player-bg);
  border-top:1px solid rgba(255,255,255,0.07);
  backdrop-filter:blur(28px); -webkit-backdrop-filter:blur(28px);
  display:grid; grid-template-columns:1fr auto 1fr;
  align-items:center; gap:16px; padding:0 20px; z-index:1000;
}
.ks-player__song { display:flex; align-items:center; gap:13px; min-width:0; }
.ks-player__art { width:50px; height:50px; border-radius:var(--r-sm); object-fit:cover; background:var(--bg-card); flex-shrink:0; }
.ks-player.is-playing .ks-player__art { box-shadow:var(--shadow-glow); }
.ks-player__song-info { min-width:0; }
.ks-player__song-title { font-family:var(--font-display); font-size:0.875rem; font-weight:700; color:#fff; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ks-player__song-artist { font-size:0.7rem; color:var(--text-muted); margin-top:1px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ks-player__like { width:30px; height:30px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--text-muted); transition:all var(--t-fast); flex-shrink:0; }
.ks-player__like:hover { color:var(--accent); transform:scale(1.2); }
.ks-player__like.liked { color:var(--accent); }

.ks-player__controls { display:flex; flex-direction:column; align-items:center; gap:7px; }
.ks-player__buttons { display:flex; align-items:center; gap:14px; }
.ks-player__btn { width:30px; height:30px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--text-secondary); transition:all var(--t-fast); }
.ks-player__btn:hover { color:#fff; transform:scale(1.1); }
.ks-player__btn--play { width:40px; height:40px; background:#fff; color:#000; border-radius:50%; }
.ks-player__btn--play:hover { background:#fff; transform:scale(1.07); box-shadow:0 0 18px rgba(255,255,255,0.2); }

.ks-player__progress { display:flex; align-items:center; gap:9px; width:100%; max-width:400px; }
.ks-player__time { font-size:0.66rem; color:var(--text-muted); min-width:34px; text-align:center; font-variant-numeric:tabular-nums; font-weight:600; }
.ks-player__bar { flex:1; position:relative; height:16px; cursor:pointer; display:flex; align-items:center; }
.ks-player__bar-bg { width:100%; height:3px; background:var(--bg-hover); border-radius:2px; position:absolute; }
.ks-player__bar-fill { height:3px; background:var(--text-secondary); border-radius:2px; position:absolute; width:0%; pointer-events:none; transition:width 0.5s linear; }
.ks-player__bar:hover .ks-player__bar-fill { background:var(--accent); }
.ks-player__bar-thumb { width:11px; height:11px; border-radius:50%; background:#fff; position:absolute; left:0%; transform:translateX(-50%); opacity:0; transition:opacity var(--t-fast); pointer-events:none; }
.ks-player__bar:hover .ks-player__bar-thumb { opacity:1; }

.ks-player__options { display:flex; align-items:center; gap:10px; justify-content:flex-end; }
.ks-player__volume-bar { width:72px; height:16px; cursor:pointer; position:relative; display:flex; align-items:center; }
.ks-player__volume-bar::before { content:''; position:absolute; width:100%; height:3px; background:var(--bg-hover); border-radius:2px; }
.ks-player__volume-fill { height:3px; background:var(--text-secondary); border-radius:2px; position:absolute; width:70%; pointer-events:none; }
.ks-player.no-song .ks-player__btn--play { opacity:0.3; pointer-events:none; }

/* ================================================================
   LOADING + TRANSITIONS
   ================================================================ */
.ks-loading-bar { position:fixed; top:0; left:0; right:0; height:2px; background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform 0.3s ease,opacity 0.3s ease; opacity:0; z-index:9999; }
.ks-loading-bar.active { opacity:1; transform:scaleX(0.65); }
.ks-loading-bar.done { transform:scaleX(1); transition:transform 0.15s ease; }
#ks-content { transition:opacity 0.18s ease,transform 0.18s ease; }

/* ================================================================
   UTILITY
   ================================================================ */
.ks-empty { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:80px 20px; text-align:center; }
.ks-empty svg { margin-bottom:20px; opacity:0.18; }
.ks-empty h3 { font-family:var(--font-display); font-size:1.15rem; margin-bottom:8px; color:var(--text-secondary); }
.ks-empty p { font-size:0.875rem; color:var(--text-muted); }
.ks-404 { padding:80px 40px; text-align:center; min-height:60vh; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.ks-404__code { font-family:var(--font-display); font-size:9rem; font-weight:800; color:var(--accent); opacity:0.12; line-height:1; margin-bottom:16px; letter-spacing:-0.04em; }
.ks-post-content { max-width:680px; font-size:0.95rem; line-height:1.9; color:var(--text-secondary); }
.ks-post-content p { margin-bottom:1.2em; }
.ks-post-content h2,.ks-post-content h3 { font-family:var(--font-display); color:#fff; margin:1.6em 0 0.6em; }

/* ================================================================
   ADMIN TRACKLIST
   ================================================================ */
.ks-admin-tracklist { margin-top:8px; }
.ks-admin-track-header { display:grid; grid-template-columns:36px 1fr 160px 70px 1fr 130px 32px; gap:6px; padding:6px 8px; background:#1d2327; border-radius:3px; margin-bottom:6px; }
.ks-admin-track-header span { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.06em; color:#8c8f94; }
.ks-admin-track-row { display:grid; grid-template-columns:36px 1fr 160px 70px 1fr 130px 32px; gap:6px; margin-bottom:4px; align-items:center; background:#2c3338; border-radius:3px; padding:4px 8px; }
.ks-admin-track-row input,.ks-admin-track-row select { width:100%; padding:5px 7px; background:#1d2327; border:1px solid #50575e; border-radius:3px; color:#f0f0f1; font-size:13px; }
.ks-admin-track-row input:focus,.ks-admin-track-row select:focus { border-color:#2271b1; outline:none; box-shadow:0 0 0 1px #2271b1; }
.ks-admin-remove-row { width:26px; height:26px; border-radius:50%; background:#c02b0a; color:#fff; border:none; cursor:pointer; font-size:13px; display:flex; align-items:center; justify-content:center; }
.ks-admin-remove-row:hover { background:#d63638; }
.ks-admin-track-actions { margin-top:12px; display:flex; gap:10px; align-items:center; }
#ks-export-msg { font-size:12px; color:#46b450; }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width:1100px) {
  :root { --sidebar-w:196px; }
  .ks-artist-spotlight { grid-template-columns:1fr 1fr; }
  .ks-artist-spotlight > :first-child { grid-column:span 2; }
  .ks-hero__float { display:none; }
}

@media (max-width:768px) {
  .ks-sidebar { display:none; }
  .ks-body { padding-bottom:calc(var(--player-h) + var(--nav-h)); }
  .ks-content { padding:0 16px 40px; }
  .ks-topbar { padding:12px 16px 10px; }
  .ks-hero { min-height:55vh; margin:0 -16px 36px; }
  .ks-hero__content { padding:30px 22px; }
  .ks-hero__title { font-size:2.1rem; }
  .ks-hero__float { display:none; }
  .ks-stats-bar { flex-direction:row; flex-wrap:wrap; }
  .ks-stat { min-width:calc(50% - 1px); }
  .ks-album-hero { flex-direction:column; align-items:flex-start; padding:22px 16px; gap:16px; }
  .ks-album-hero__art { width:130px; height:130px; }
  .ks-album-hero__title { font-size:1.7rem; }
  .ks-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
  .ks-artist-spotlight { grid-template-columns:1fr; }
  .ks-artist-spotlight > :first-child { grid-column:auto; }
  .ks-tracklist__header { display:none; }
  .ks-song-row { grid-template-columns:32px 1fr 50px 30px; }
  .ks-song-row__mood-badge { display:none; }

  .ks-player { grid-template-columns:1fr auto; height:64px; padding:0 14px; gap:0; }
  .ks-player__controls,.ks-player__options { display:none; }
  .ks-player__controls--mobile { display:flex; align-items:center; gap:10px; flex-shrink:0; }
  .ks-player__song { cursor:pointer; flex:1; }
  .ks-player__art { width:44px; height:44px; }

  .ks-mobile-nav { display:flex; position:fixed; bottom:64px; left:0; right:0; height:var(--nav-h); background:rgba(0,0,0,0.97); border-top:1px solid var(--border); z-index:999; justify-content:space-around; align-items:center; backdrop-filter:blur(20px); }
  .ks-mobile-nav__item { display:flex; flex-direction:column; align-items:center; gap:3px; color:var(--text-muted); padding:8px 14px; transition:color var(--t-fast); }
  .ks-mobile-nav__item.active { color:var(--accent); }
  .ks-mobile-nav__item svg { width:21px; height:21px; }
  .ks-mobile-nav__item span { font-size:0.57rem; font-weight:600; letter-spacing:0.05em; }

  .ks-player-full { position:fixed; inset:0; background:var(--bg-surface); z-index:1010; display:flex; flex-direction:column; align-items:center; padding:50px 28px 36px; transform:translateY(100%); transition:transform 0.42s cubic-bezier(0.4,0,0.2,1); overflow-y:auto; }
  .ks-player-full.open { transform:translateY(0); }
  .ks-player-full__handle { width:40px; height:4px; background:rgba(255,255,255,0.2); border-radius:2px; position:absolute; top:14px; left:50%; transform:translateX(-50%); cursor:pointer; }
  .ks-player-full__art { width:min(74vw,300px); height:min(74vw,300px); border-radius:var(--r-lg); object-fit:cover; box-shadow:0 32px 80px rgba(0,0,0,0.8),var(--shadow-glow); margin-bottom:36px; }
  .ks-player-full__info { text-align:center; width:100%; margin-bottom:22px; }
  .ks-player-full__title { font-family:var(--font-display); font-size:1.5rem; font-weight:800; letter-spacing:-0.02em; color:#fff; margin-bottom:5px; }
  .ks-player-full__artist { color:var(--text-muted); font-size:0.9rem; }
  .ks-player-full__bar-wrap { width:100%; margin-bottom:8px; }
  .ks-player-full__times { display:flex; justify-content:space-between; margin-top:6px; }
  .ks-player-full__controls { display:flex; justify-content:center; gap:24px; align-items:center; margin-top:18px; }
  .ks-player-full__btn { display:flex; align-items:center; justify-content:center; border-radius:50%; color:var(--text-secondary); transition:all var(--t-fast); }
  .ks-player-full__btn:hover { color:#fff; transform:scale(1.1); }
  .ks-player-full__btn--play { width:62px; height:62px; background:#fff; color:#000; }
}

@media (min-width:769px) {
  .ks-mobile-nav { display:none; }
  .ks-player-full { display:none; }
  .ks-player__controls--mobile { display:none; }
}
