/* ============================================================
   TamilMusic — Master Stylesheet v5.0
   Theme: Hot Pink (#e33ba3) on Deep Black
   Font: Sora + DM Sans | Font Awesome Icons
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;600;700;800;900&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap');
@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/css/all.min.css');

/* ── RESET ──────────────────────────────────────────────── */
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

/* ── CSS VARIABLES ─────────────────────────────────────── */
:root {
  --pink: #e33ba3;
  --pink-lt: #ff5dbd;
  --pink-dk: #b02c80;
  --pink-glow: #e33ba330;
  --pink-tint: #e33ba312;
  --pink-tint2: #e33ba808;

  --bg: #0a0a0a;
  --surface: #141414;
  --surface2: #1c1c1c;
  --surface3: #242424;
  --border: #202020;
  --border2: #2c2c2c;

  --text: #f0ecf8;
  --text2: #a899b8;
  --muted: #56506a;

  --sidebar-w: 248px;
  --topbar-h: 68px;
  --r: 12px;
  --r-lg: 18px;
  --r-xl: 24px;

  --font-head: 'Sora', sans-serif;
  --font-body: 'DM Sans', sans-serif;

  --shadow-sm: 0 2px 10px #00000050;
  --shadow-md: 0 6px 28px #00000060;
  --shadow-lg: 0 12px 48px #00000070;
  --shadow-pink: 0 4px 24px #e33ba340;
}

/* ── BASE ──────────────────────────────────────────────── */
body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  line-height: 1.55;
  min-height: 100dvh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

a {
  color: inherit;
  text-decoration: none;
}

button {
  cursor: pointer;
  font-family: var(--font-body);
  border: none;
  outline: none;
}

img {
  display: block;
  max-width: 100%;
}

input {
  border: none;
  outline: none;
}

h1,
h2,
h3,
h4 {
  font-family: var(--font-head);
}

.pink-text {
  color: var(--pink);
}

::-webkit-scrollbar {
  width: 5px;
  height: 5px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: var(--border2);
  border-radius: 99px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--pink);
}

/* ── SKELETON ──────────────────────────────────────────── */
.sk {
  background: linear-gradient(90deg, #1a1a1a 25%, #282828 50%, #1a1a1a 75%);
  background-size: 400% 100%;
  animation: shimmer 1.5s infinite ease-in-out;
  border-radius: var(--r);
}

@keyframes shimmer {
  0% {
    background-position: 200% 0
  }

  100% {
    background-position: -200% 0
  }
}

.sk-abs {
  position: absolute;
  inset: 0;
  z-index: 1;
  border-radius: inherit;
}

/* ── IMG WRAP ───────────────────────────────────────────── */
.img-wrap {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: inherit;
}

.img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: opacity .3s, transform .4s;
}

.img-wrap img.lazy-img {
  opacity: 0;
}

.img-wrap img.loaded {
  opacity: 1;
}

/* ── NO RESULTS ─────────────────────────────────────────── */
.no-results {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 60px 20px;
  color: var(--muted);
  font-size: 15px;
}

.no-results i {
  font-size: 36px;
  color: var(--border2);
}

/* ── APP SHELL ─────────────────────────────────────────── */
.app {
  display: flex;
  min-height: 100dvh;
}

/* ════════════════════════════════════════════════════════
   SIDEBAR
════════════════════════════════════════════════════════ */
.sidebar {
  width: var(--sidebar-w);
  background: #070707;
  border-right: 1px solid var(--border);
  padding: 24px 14px;
  display: flex;
  flex-direction: column;
  gap: 26px;
  flex-shrink: 0;
  position: sticky;
  top: 0;
  height: 100dvh;
  overflow-y: auto;
  overflow-x: hidden;
  transition: width .3s cubic-bezier(.4, 0, .2, 1);
  z-index: 100;
}

.sidebar.collapsed {
  width: 68px;
}

.sidebar.collapsed .brand-text,
.sidebar.collapsed .nav-label,
.sidebar.collapsed .sec-title,
.sidebar.collapsed .pl-label,
.sidebar.collapsed .sb-premium-text {
  display: none;
}

.sidebar.collapsed .side-nav a {
  justify-content: center;
  padding: 12px 8px;
}

.sidebar.collapsed .pl-item {
  justify-content: center;
  padding: 8px;
}

.sidebar.collapsed .brand-logo {
  width: 36px;
  height: 36px;
}

.sidebar.collapsed .brand-logo img {
  width: 36px;
  height: 36px;
  content: url('fav.png');
}

.sidebar.collapsed .sb-premium {
  padding: 12px;
  align-items: center;
}

.sidebar.collapsed .sb-premium-btn {
  font-size: 0;
  width: 38px;
  height: 38px;
  padding: 0;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sidebar.collapsed .sb-premium-btn::before {
  content: '⭐';
  font-size: 16px;
}

.sidebar-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.brand {
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}

.brand-logo {
  width: 125px;
  flex-shrink: 0;
  background: none;
  border-radius: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  box-shadow: none;
}

.brand-logo img {
  width: 130px;
  height: 40px;
  object-fit: contain;
}

.brand-logo-sym {
  display: none;
}

.brand-text {
  display: none;
}

.collapse-btn {
  background: none;
  color: var(--muted);
  padding: 7px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  flex-shrink: 0;
  transition: color .2s, background .2s;
}

.collapse-btn:hover {
  color: var(--pink);
  background: var(--surface);
}

.collapse-btn i {
  font-size: 16px;
}

.sec-title {
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--muted);
  padding: 0 12px;
  margin-bottom: -18px;
}

.side-nav {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.side-nav a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 13px;
  border-radius: 10px;
  color: var(--muted);
  font-size: 14px;
  font-weight: 500;
  transition: all .2s;
  white-space: nowrap;
}

.side-nav a:hover {
  color: var(--text2);
  background: var(--surface);
}

.side-nav a.active {
  color: var(--pink);
  background: var(--pink-tint);
  border-left: 2px solid var(--pink);
  padding-left: 11px;
}

.nav-icon {
  width: 22px;
  height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.nav-icon i {
  font-size: 15px;
}

.pl-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.pl-item {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  padding: 8px 10px;
  border-radius: 10px;
  transition: background .2s;
  font-size: 13px;
  color: var(--muted);
}

.pl-item:hover {
  background: var(--surface);
  color: var(--text2);
}

.pl-thumb {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  flex-shrink: 0;
}

.pl-label {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sb-premium {
  margin-top: auto;
  background: linear-gradient(135deg, #1c001040, #0f000a);
  border: 1px solid #e33ba320;
  border-radius: 14px;
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.sb-premium-text {
  font-size: 12px;
  color: var(--text2);
  line-height: 1.5;
}

.sb-premium-text strong {
  color: var(--pink-lt);
}

.sb-premium-btn {
  padding: 10px;
  border-radius: 9px;
  background: linear-gradient(90deg, var(--pink-dk), var(--pink));
  color: #fff;
  font-weight: 700;
  font-size: 13px;
  box-shadow: var(--shadow-pink);
  transition: opacity .2s;
}

.sb-premium-btn:hover {
  opacity: .88;
}

/* ════════════════════════════════════════════════════════
   MAIN
════════════════════════════════════════════════════════ */
.main {
  flex: 1;
  min-width: 0;
  overflow-x: hidden;
  display: flex;
  flex-direction: column;
}

/* ── TOPBAR ─────────────────────────────────────────────── */
.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  height: var(--topbar-h);
  background: linear-gradient(180deg, var(--bg) 60%, transparent);
  backdrop-filter: blur(18px);
  padding: 0 28px;
  display: flex;
  align-items: center;
  gap: 14px;
  border-bottom: 1px solid var(--border);
}

.search-wrapper {
  flex: 1;
  max-width: 500px;
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: 11px;
  padding: 10px 16px;
  transition: border .2s, box-shadow .2s;
}

.search-wrapper:focus-within {
  border-color: var(--pink-dk);
  box-shadow: 0 0 0 3px var(--pink-tint);
}

.search-wrapper i {
  font-size: 13px;
  color: var(--muted);
  flex-shrink: 0;
}

.search-bar {
  flex: 1;
  background: none;
  color: var(--text);
  font-family: var(--font-body);
  font-size: 14px;
}

.search-bar::placeholder {
  color: var(--muted);
}

.top-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: auto;
}

.upgrade-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 18px;
  border-radius: 9px;
  background: linear-gradient(90deg, var(--pink-dk), var(--pink));
  color: #fff;
  font-weight: 700;
  font-size: 13px;
  box-shadow: var(--shadow-pink);
  transition: opacity .2s;
}

.upgrade-btn:hover {
  opacity: .85;
}

.profile-btn {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--pink-dk), var(--pink));
  color: #fff;
  font-weight: 800;
  font-size: 14px;
  font-family: var(--font-head);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: box-shadow .2s;
}

.profile-btn:hover {
  box-shadow: 0 0 0 3px var(--pink-glow);
}

/* ── HERO BANNER ────────────────────────────────────────── */
.hero-banner {
  position: relative;
  margin: 24px 28px 28px;
  border-radius: var(--r-xl);
  overflow: hidden;
  min-height: 300px;
  display: flex;
  align-items: flex-end;
  background: linear-gradient(135deg, #0f0008, #150010);
  border: 1px solid #e33ba318;
  box-shadow: var(--shadow-lg);
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-size: cover;
  background-position: center;
  filter: blur(2px) brightness(.22) saturate(.6);
}

.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(100deg, #0a0a0add 35%, transparent 80%),
    linear-gradient(0deg, #0a0a0aee, transparent 55%);
}

.hero-album-art {
  position: absolute;
  right: 44px;
  top: 50%;
  transform: translateY(-50%);
  width: 172px;
  height: 172px;
  border-radius: var(--r-lg);
  overflow: hidden;
  z-index: 3;
  box-shadow: var(--shadow-lg), 0 0 0 1px #e33ba325;
}

.hero-content {
  position: relative;
  z-index: 4;
  padding: 40px 44px;
  max-width: 62%;
}

.hero-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--pink-tint);
  border: 1px solid #e33ba330;
  color: var(--pink-lt);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 99px;
  margin-bottom: 14px;
}

.hero-label i {
  font-size: 10px;
}

.hero-title {
  font-family: var(--font-head);
  font-size: 34px;
  font-weight: 900;
  line-height: 1.1;
  margin-bottom: 8px;
  background: linear-gradient(90deg, #fff 60%, var(--text2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero-meta {
  color: var(--text2);
  font-size: 13px;
  margin-bottom: 22px;
}

.hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

/* ── BUTTONS ────────────────────────────────────────────── */
.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 22px;
  border-radius: 10px;
  background: linear-gradient(90deg, var(--pink-dk), var(--pink));
  color: #fff;
  font-weight: 700;
  font-size: 13px;
  box-shadow: var(--shadow-pink);
  transition: opacity .2s, transform .15s;
}

.btn-primary:hover {
  opacity: .87;
  transform: translateY(-1px);
}

.btn-primary i {
  font-size: 13px;
}

.btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 22px;
  border-radius: 10px;
  background: var(--surface);
  border: 1px solid var(--border2);
  color: var(--text2);
  font-weight: 600;
  font-size: 13px;
  transition: all .2s;
}

.btn-outline:hover {
  border-color: var(--pink-dk);
  color: var(--pink);
  background: var(--pink-tint);
}

.btn-outline i {
  font-size: 13px;
}

/* ── FILTER BAR ─────────────────────────────────────────── */
.filter-bar {
  display: flex;
  gap: 8px;
  padding: 0 28px 22px;
  overflow-x: auto;
  scrollbar-width: none;
}

.filter-bar::-webkit-scrollbar {
  display: none;
}

.filter-btn {
  white-space: nowrap;
  padding: 8px 18px;
  border-radius: 99px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  background: var(--surface);
  border: 1px solid var(--border2);
  color: var(--muted);
  transition: all .2s;
  flex-shrink: 0;
}

.filter-btn:hover {
  color: var(--text2);
  background: var(--surface2);
}

.filter-btn.active {
  background: var(--pink-tint);
  border-color: var(--pink-dk);
  color: var(--pink);
}

/* ── INFO NOTICE ────────────────────────────────────────── */
.info-notice {
  margin: 0 28px 24px;
  background: #e33ba808;
  border: 1px solid #e33ba820;
  border-radius: 11px;
  padding: 11px 18px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
  color: var(--text2);
}

.info-notice i {
  color: var(--pink);
  flex-shrink: 0;
}

.info-notice strong {
  color: var(--pink);
}

/* ── SECTION ────────────────────────────────────────────── */
.section {
  padding: 0 28px 32px;
}

.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
}

.section-header h2 {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 18px;
  font-weight: 800;
}

.section-header h2 i {
  color: var(--pink);
  font-size: 16px;
}

.see-all {
  font-size: 13px;
  font-weight: 600;
  color: var(--text2);
  background: none;
  padding: 6px 14px;
  border-radius: 8px;
  border: 1px solid var(--border2);
  transition: all .2s;
}

.see-all:hover {
  color: var(--pink);
  border-color: var(--pink-dk);
  background: var(--pink-tint);
}

/* ── CARD GRID ──────────────────────────────────────────── */
.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 16px;
}

.music-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  cursor: pointer;
  transition: transform .25s, box-shadow .25s, border-color .25s;
}

.music-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: #e33ba328;
}

.card-img {
  position: relative;
  aspect-ratio: 1;
  background: var(--surface2);
  overflow: hidden;
}

.card-hover-overlay {
  position: absolute;
  inset: 0;
  background: #00000060;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .2s;
  z-index: 4;
}

.music-card:hover .card-hover-overlay {
  opacity: 1;
}

.card-dl-fab {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--pink-dk), var(--pink));
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 16px;
  box-shadow: 0 4px 18px #e33ba350;
  transition: transform .15s;
}

.card-dl-fab:hover {
  transform: scale(1.08);
}

.badge {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 5;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1.5px;
  padding: 3px 9px;
  border-radius: 99px;
  text-transform: uppercase;
}

.badge-new {
  background: #ff4d2e;
  color: #fff;
}

.badge-hot {
  background: linear-gradient(90deg, var(--pink-dk), var(--pink));
  color: #fff;
}

.card-body {
  padding: 13px 14px;
}

.card-title {
  font-weight: 700;
  font-size: 14px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 3px;
}

.card-artist {
  font-size: 12px;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 11px;
}

.card-btn {
  width: 100%;
  padding: 8px;
  border-radius: 8px;
  background: var(--pink-tint);
  border: 1px solid #e33ba328;
  color: var(--pink);
  font-size: 12px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition: all .2s;
}

.card-btn:hover {
  background: linear-gradient(90deg, var(--pink-dk), var(--pink));
  color: #fff;
  border-color: transparent;
}

/* ── SONG LIST TABLE ────────────────────────────────────── */
.song-list-wrap {
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--border);
}

.song-list-head {
  display: grid;
  grid-template-columns: 48px 1fr 160px 90px 120px;
  padding: 11px 20px;
  background: var(--surface2);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
}

.song-row {
  display: grid;
  grid-template-columns: 48px 1fr 160px 90px 120px;
  padding: 10px 20px;
  align-items: center;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  transition: background .18s;
  cursor: pointer;
}

.song-row:last-child {
  border-bottom: none;
}

.song-row:hover {
  background: var(--surface2);
}

.song-num {
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
  text-align: center;
}

.song-cell {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.song-thumb {
  width: 42px;
  height: 42px;
  border-radius: 8px;
  flex-shrink: 0;
  background: var(--surface2);
  overflow: hidden;
}

.song-name {
  font-size: 14px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.song-artist {
  font-size: 12px;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.song-movie {
  font-size: 13px;
  color: var(--text2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.song-dur {
  font-size: 13px;
  color: var(--muted);
  text-align: center;
  font-variant-numeric: tabular-nums;
}

.row-btn {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  color: var(--pink);
  font-size: 12px;
  font-weight: 700;
  background: none;
  padding: 7px 12px;
  border-radius: 8px;
  border: 1px solid #e33ba325;
  transition: all .2s;
  white-space: nowrap;
  margin-left: auto;
}

.row-btn:hover {
  background: var(--pink-tint);
  border-color: var(--pink-dk);
}

/* ── RIGHT PANEL ────────────────────────────────────────── */
.right-panel {
  width: 270px;
  flex-shrink: 0;
  padding: 24px 18px;
  display: flex;
  flex-direction: column;
  gap: 28px;
  border-left: 1px solid var(--border);
  background: #080808;
  position: sticky;
  top: 0;
  height: 100dvh;
  overflow-y: auto;
}

.panel-box h3 {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  font-weight: 800;
  color: var(--text2);
  margin-bottom: 14px;
}

.panel-box h3 i {
  color: var(--pink);
  font-size: 14px;
}

.trend-item {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
}

.trend-item:last-child {
  border-bottom: none;
}

.trend-item:hover .trend-title {
  color: var(--pink);
}

.trend-num {
  font-size: 20px;
  font-weight: 900;
  font-family: var(--font-head);
  color: var(--border2);
  min-width: 30px;
}

.trend-title {
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.trend-sub {
  font-size: 11px;
  color: var(--muted);
}

.nr-item {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 9px 0;
  border-bottom: 1px solid var(--border);
}

.nr-item:last-child {
  border-bottom: none;
}

.nr-thumb {
  width: 44px;
  height: 44px;
  border-radius: 9px;
  flex-shrink: 0;
  background: var(--surface2);
  overflow: hidden;
}

.nr-info {
  flex: 1;
  min-width: 0;
}

.nr-info p {
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.nr-info small {
  font-size: 11px;
  color: var(--muted);
}

.nr-btn {
  background: none;
  border: 1px solid #e33ba325;
  color: var(--pink);
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all .2s;
  font-size: 12px;
}

.nr-btn:hover {
  background: var(--pink-tint);
  border-color: var(--pink-dk);
}

.platform-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.plat-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: all .2s;
}

.pc-saavn {
  background: #1db95418;
  border: 1px solid #1db95438;
  color: #1db954;
}

.pc-gaana {
  background: #e2294518;
  border: 1px solid #e2294538;
  color: #e22945;
}

.pc-spotify {
  background: #1ed76018;
  border: 1px solid #1ed76038;
  color: #1ed760;
}

.pc-yt {
  background: #ff000018;
  border: 1px solid #ff000038;
  color: #ff4444;
}

.pc-saavn:hover {
  background: #1db95428;
}

.pc-gaana:hover {
  background: #e2294528;
}

.pc-spotify:hover {
  background: #1ed76028;
}

.pc-yt:hover {
  background: #ff000028;
}

/* ════════════════════════════════════════════════════════
   DOWNLOAD MODAL  (MassTamilan-style)
════════════════════════════════════════════════════════ */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: #000000a0;
  backdrop-filter: blur(16px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .28s;
}

.modal-overlay.show {
  opacity: 1;
  pointer-events: all;
}

.modal-box {
  background: var(--surface);
  border: 1px solid #e33ba322;
  border-radius: var(--r-xl);
  width: 560px;
  max-width: 100%;
  max-height: 92dvh;
  overflow-y: auto;
  box-shadow: 0 28px 90px #00000095;
  transform: translateY(20px) scale(.97);
  transition: transform .34s cubic-bezier(.34, 1.35, .64, 1);
  scrollbar-width: thin;
  scrollbar-color: var(--border2) transparent;
}

.modal-overlay.show .modal-box {
  transform: translateY(0) scale(1);
}

/* ── MODAL HEADER BANNER ── */
.modal-header-banner {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, #12000d, #0a0007);
  border-bottom: 1px solid #e33ba320;
  padding: 24px 24px 20px;
  display: flex;
  gap: 18px;
  align-items: flex-start;
}

.modal-header-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-size: cover;
  background-position: center;
  filter: blur(3px) brightness(.18) saturate(.5);
}

.modal-header-content {
  position: relative;
  z-index: 1;
  display: flex;
  gap: 18px;
  align-items: flex-start;
  width: 100%;
}

.modal-art {
  width: 96px;
  height: 96px;
  flex-shrink: 0;
  border-radius: var(--r);
  overflow: hidden;
  background: var(--surface2);
  box-shadow: 0 8px 28px #00000070, 0 0 0 1px #e33ba320;
}

.modal-art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.modal-header-info {
  flex: 1;
  min-width: 0;
  padding-top: 4px;
}

.modal-title {
  font-family: var(--font-head);
  font-size: 20px;
  font-weight: 900;
  color: #fff;
  line-height: 1.2;
  margin-bottom: 5px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.modal-movie {
  font-size: 13px;
  color: var(--text2);
  margin-bottom: 3px;
}

.modal-meta-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.modal-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: #ffffff0d;
  border: 1px solid #ffffff15;
  color: #ffffffaa;
  font-size: 10px;
  font-weight: 600;
  padding: 3px 9px;
  border-radius: 99px;
  letter-spacing: .3px;
}

.modal-tag.pink-tag {
  background: var(--pink-tint);
  border-color: #e33ba330;
  color: var(--pink-lt);
}

.modal-close-x {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 2;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #ffffff14;
  border: 1px solid #ffffff20;
  color: #ffffffaa;
  font-size: 14px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .2s;
}

.modal-close-x:hover {
  background: #e33ba330;
  border-color: var(--pink);
  color: var(--pink);
}

/* ── MODAL BODY ── */
.modal-body {
  padding: 20px 24px 24px;
}

/* ── ZIP / ALBUM DOWNLOAD STRIP ── */
.modal-zip-strip {
  display: flex;
  gap: 8px;
  margin-bottom: 20px;
  padding: 14px 16px;
  background: linear-gradient(135deg, #e33ba30d, #e33ba806);
  border: 1px solid #e33ba322;
  border-radius: 12px;
  align-items: center;
}

.modal-zip-label {
  flex: 1;
  font-size: 12px;
  font-weight: 700;
  color: var(--text2);
  display: flex;
  align-items: center;
  gap: 7px;
}

.modal-zip-label i {
  color: var(--pink);
  font-size: 13px;
}

.modal-zip-btns {
  display: flex;
  gap: 7px;
}

.modal-zip-btn {
  padding: 7px 14px;
  border-radius: 8px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .3px;
  cursor: pointer;
  transition: all .2s;
  border: 1px solid;
  display: flex;
  align-items: center;
  gap: 5px;
}

.modal-zip-btn.zip {
  background: #e33ba312;
  border-color: #e33ba338;
  color: var(--pink-lt);
}

.modal-zip-btn.zip:hover {
  background: var(--pink);
  border-color: var(--pink);
  color: #fff;
}

.modal-zip-btn.rar {
  background: #ff6a0012;
  border-color: #ff6a0038;
  color: #ff9944;
}

.modal-zip-btn.rar:hover {
  background: #ff6a00;
  border-color: #ff6a00;
  color: #fff;
}

/* ── SECTION LABEL ── */
.modal-section-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 10px;
  padding-left: 2px;
}

/* ── SONG DOWNLOAD ROWS (MassTamilan style) ── */
.modal-song-rows {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 20px;
}

.modal-song-row {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 11px;
  padding: 12px 14px;
  transition: border-color .2s;
}

.modal-song-row:hover {
  border-color: #e33ba330;
}

.msr-num {
  width: 24px;
  height: 24px;
  border-radius: 6px;
  background: var(--surface3);
  border: 1px solid var(--border2);
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.msr-info {
  flex: 1;
  min-width: 0;
}

.msr-title {
  font-size: 13px;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--text);
}

.msr-artist {
  font-size: 11px;
  color: var(--muted);
  margin-top: 1px;
}

.msr-dur {
  font-size: 11px;
  color: var(--muted);
  flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}

.msr-btns {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

.msr-btn {
  padding: 6px 11px;
  border-radius: 7px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .2px;
  cursor: pointer;
  transition: all .2s;
  display: flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
}

.msr-btn:disabled {
  opacity: .6;
  cursor: not-allowed;
}

.msr-btn.q128 {
  background: #3b82f610;
  border: 1px solid #3b82f630;
  color: #60a5fa;
}

.msr-btn.q128:hover:not(:disabled) {
  background: #3b82f6;
  border-color: #3b82f6;
  color: #fff;
}

.msr-btn.q320 {
  background: var(--pink-tint);
  border: 1px solid #e33ba330;
  color: var(--pink);
}

.msr-btn.q320:hover:not(:disabled) {
  background: var(--pink);
  border-color: var(--pink);
  color: #fff;
}

/* ── STREAM PLATFORMS ── */
.modal-stream-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 10px;
  padding-left: 2px;
}

.modal-stream-chips {
  display: flex;
  gap: 7px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.modal-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: all .2s;
}

.mc-saavn {
  background: #1db95412;
  border: 1px solid #1db95435;
  color: #1db954;
}

.mc-gaana {
  background: #e2294512;
  border: 1px solid #e2294535;
  color: #e22945;
}

.mc-yt {
  background: #ff000012;
  border: 1px solid #ff000035;
  color: #ff4444;
}

.mc-spotify {
  background: #1ed76012;
  border: 1px solid #1ed76035;
  color: #1ed760;
}

.mc-saavn:hover {
  background: #1db95422;
}

.mc-gaana:hover {
  background: #e2294522;
}

.mc-yt:hover {
  background: #ff000022;
}

.mc-spotify:hover {
  background: #1ed76022;
}

/* ── CLOSE BUTTON ── */
.modal-close {
  width: 100%;
  padding: 12px;
  border-radius: 10px;
  background: var(--surface3);
  border: 1px solid var(--border2);
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
  transition: all .2s;
  cursor: pointer;
}

.modal-close:hover {
  color: var(--text);
  background: var(--surface2);
}

/* ── TOAST ──────────────────────────────────────────────── */
#toast {
  position: fixed;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%) translateY(16px);
  background: var(--surface2);
  border: 1px solid #e33ba328;
  color: var(--text2);
  padding: 11px 22px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 500;
  box-shadow: var(--shadow-md);
  opacity: 0;
  pointer-events: none;
  transition: all .3s;
  white-space: nowrap;
  z-index: 9999;
  max-width: 90vw;
  text-align: center;
  display: flex;
  align-items: center;
  gap: 8px;
}

#toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ── MOBILE NAV ─────────────────────────────────────────── */
.mobile-nav {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 200;
  background: #060606;
  border-top: 1px solid var(--border);
  padding: 8px 0 max(env(safe-area-inset-bottom, 0px), 8px);
}

.mob-nav {
  display: flex;
  justify-content: space-around;
}

.mob-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  background: none;
  color: var(--muted);
  font-size: 10px;
  font-weight: 600;
  padding: 6px 10px;
  border-radius: 8px;
  transition: color .2s;
  min-width: 52px;
}

.mob-btn i {
  font-size: 20px;
  margin-bottom: 2px;
}

.mob-btn.active {
  color: var(--pink);
}

/* ════════════════════════════════════════════════════════
   SEARCH PAGE
════════════════════════════════════════════════════════ */
.search-page-hero {
  padding: 36px 28px 20px;
}

.search-page-hero h1 {
  font-size: 30px;
  font-weight: 900;
  background: linear-gradient(90deg, var(--pink), var(--pink-lt));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 6px;
}

.search-page-hero p {
  color: var(--text2);
  font-size: 14px;
}

.search-big-wrap {
  margin: 0 28px 26px;
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--surface);
  border: 1.5px solid var(--border2);
  border-radius: 14px;
  padding: 14px 20px;
  transition: border .2s, box-shadow .2s;
}

.search-big-wrap:focus-within {
  border-color: var(--pink-dk);
  box-shadow: 0 0 0 3px var(--pink-tint);
}

.search-big-wrap i {
  font-size: 18px;
  color: var(--muted);
  flex-shrink: 0;
}

.search-big-input {
  flex: 1;
  background: none;
  color: var(--text);
  font-family: var(--font-body);
  font-size: 16px;
}

.search-big-input::placeholder {
  color: var(--muted);
}

.genre-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0 28px 24px;
}

.genre-chip {
  padding: 7px 17px;
  border-radius: 99px;
  font-size: 13px;
  font-weight: 600;
  border: 1px solid var(--border2);
  background: var(--surface);
  color: var(--text2);
  cursor: pointer;
  transition: all .2s;
}

.genre-chip:hover {
  border-color: var(--pink-dk);
  color: var(--pink);
  background: var(--pink-tint);
}

.genre-chip.active {
  border-color: var(--pink);
  color: var(--pink);
  background: var(--pink-tint);
}

.search-label {
  padding: 0 28px 16px;
  font-size: 13px;
  color: var(--muted);
}

.search-count-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--pink-tint);
  border: 1px solid #e33ba330;
  color: var(--pink);
  font-size: 12px;
  font-weight: 700;
  padding: 4px 14px;
  border-radius: 99px;
  margin: 0 28px 20px;
}

/* ════════════════════════════════════════════════════════
   MOVIES PAGE
════════════════════════════════════════════════════════ */
.movies-page-hero {
  padding: 36px 28px 28px;
}

.movies-page-hero h1 {
  font-size: 28px;
  font-weight: 900;
  background: linear-gradient(90deg, var(--pink), var(--pink-lt));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 6px;
}

.movies-page-hero p {
  color: var(--text2);
  font-size: 14px;
}

.movies-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(185px, 1fr));
  gap: 20px;
}

.movie-card {
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--surface);
  border: 1px solid var(--border);
  transition: transform .25s, box-shadow .25s, border-color .25s;
  cursor: pointer;
}

.movie-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-md);
  border-color: #e33ba328;
}

.movie-cover {
  aspect-ratio: 3/4;
  background: var(--surface2);
  position: relative;
  overflow: hidden;
}

.movie-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.movie-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, #0a0a0acc, transparent 50%);
  display: flex;
  align-items: flex-end;
  padding: 12px;
}

.movie-count {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  color: #fff;
  font-weight: 700;
  background: var(--pink-tint);
  border: 1px solid #e33ba330;
  padding: 4px 10px;
  border-radius: 99px;
}

.movie-count i {
  font-size: 10px;
}

.movie-info {
  padding: 12px 14px;
}

.movie-name {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 5px;
}

.movie-meta {
  font-size: 12px;
  color: var(--muted);
  display: flex;
  gap: 8px;
  align-items: center;
}

.movie-meta i {
  font-size: 10px;
  color: var(--pink);
}

/* Movie songs section */
.movie-songs-section {
  margin: 0 28px 32px;
  border: 1px solid #e33ba325;
  border-radius: var(--r-xl);
  background: linear-gradient(135deg, #0f00080a, #0a00070a);
  overflow: hidden;
}

.movie-songs-header {
  padding: 20px 24px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.movie-songs-header h3 {
  font-size: 18px;
  font-weight: 800;
  display: flex;
  align-items: center;
  gap: 10px;
}

.movie-songs-header h3 i {
  color: var(--pink);
}

.movie-songs-close {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: var(--surface2);
  border: 1px solid var(--border2);
  color: var(--muted);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  transition: all .2s;
}

.movie-songs-close:hover {
  color: var(--text);
  background: var(--surface3);
}

.movie-songs-body {
  padding: 24px;
}

/* ════════════════════════════════════════════════════════
   TRENDING PAGE
════════════════════════════════════════════════════════ */
.trending-hero {
  margin: 0 28px 28px;
  border-radius: var(--r-xl);
  background: linear-gradient(135deg, #12000a, #0a0007);
  border: 1px solid #e33ba318;
  padding: 40px 44px;
  position: relative;
  overflow: hidden;
}

.trending-hero::before {
  content: '';
  position: absolute;
  top: -60px;
  right: -60px;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: radial-gradient(circle, #e33ba318, transparent 70%);
  pointer-events: none;
}

.trending-hero h1 {
  font-size: 32px;
  font-weight: 900;
  background: linear-gradient(90deg, var(--pink), var(--pink-lt));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 8px;
  position: relative;
  z-index: 1;
}

.trending-hero p {
  color: var(--text2);
  font-size: 14px;
  position: relative;
  z-index: 1;
}

.trend-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--pink-tint);
  border: 1px solid #e33ba330;
  color: var(--pink-lt);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 99px;
  margin-bottom: 14px;
  position: relative;
  z-index: 1;
}

.trend-badge i {
  font-size: 10px;
}

/* ════════════════════════════════════════════════════════
   LIBRARY PAGE
════════════════════════════════════════════════════════ */
.library-hero {
  padding: 36px 28px 24px;
}

.library-hero h1 {
  font-size: 28px;
  font-weight: 900;
  margin-bottom: 5px;
}

.library-hero p {
  color: var(--text2);
  font-size: 14px;
}

.lib-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
  padding: 0 28px 36px;
}

.lib-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 22px;
  cursor: pointer;
  transition: all .25s;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.lib-card:hover {
  border-color: #e33ba328;
  transform: translateY(-3px);
  box-shadow: var(--shadow-sm);
}

.lib-emoji {
  font-size: 32px;
}

.lib-name {
  font-size: 15px;
  font-weight: 800;
}

.lib-count {
  font-size: 12px;
  color: var(--muted);
}

/* ════════════════════════════════════════════════════════
   RESPONSIVE — Tablet (≤ 1200px)
════════════════════════════════════════════════════════ */
@media (max-width: 1200px) {
  .right-panel {
    display: none;
  }

  .hero-album-art {
    display: none;
  }

  .hero-content {
    max-width: 80%;
  }
}

/* ════════════════════════════════════════════════════════
   RESPONSIVE — Mobile (≤ 768px)
════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .sidebar {
    display: none !important;
  }

  .mobile-nav {
    display: flex;
  }

  .main {
    padding-bottom: 76px;
  }

  .topbar {
    padding: 0 16px;
  }

  .search-wrapper {
    max-width: none;
  }

  .upgrade-btn {
    display: none;
  }

  .hero-banner {
    margin: 16px 16px 22px;
    min-height: 210px;
    border-radius: var(--r-lg);
  }

  .hero-content {
    padding: 24px 22px;
    max-width: 100%;
  }

  .hero-title {
    font-size: 22px;
  }

  .hero-meta {
    font-size: 12px;
    margin-bottom: 16px;
  }

  .btn-primary,
  .btn-outline {
    padding: 9px 16px;
    font-size: 12px;
  }

  .filter-bar {
    padding: 0 16px 18px;
  }

  .info-notice {
    margin: 0 16px 18px;
    font-size: 12px;
  }

  .section {
    padding: 0 16px 28px;
  }

  .section-header h2 {
    font-size: 16px;
  }

  .card-grid {
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 12px;
  }

  .song-list-head {
    grid-template-columns: 36px 1fr 80px;
  }

  .song-list-head span:nth-child(3),
  .song-list-head span:nth-child(4) {
    display: none;
  }

  .song-row {
    grid-template-columns: 36px 1fr 80px;
  }

  .song-movie,
  .song-dur {
    display: none;
  }

  .trending-hero {
    margin: 0 16px 22px;
    padding: 28px 22px;
  }

  .trending-hero h1 {
    font-size: 24px;
  }

  .search-page-hero {
    padding: 24px 16px 16px;
  }

  .search-big-wrap {
    margin: 0 16px 20px;
  }

  .genre-chips {
    padding: 0 16px 20px;
  }

  .search-label {
    padding: 0 16px 14px;
  }

  .search-count-badge {
    margin: 0 16px 16px;
  }

  .movies-grid {
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 14px;
  }

  .lib-grid {
    grid-template-columns: repeat(2, 1fr);
    padding: 0 16px 28px;
  }

  .library-hero {
    padding: 24px 16px 20px;
  }

  .modal-box {
    border-radius: var(--r-lg);
  }

  .modal-title {
    font-size: 17px;
  }

  .modal-header-banner {
    padding: 18px 16px 16px;
  }

  .modal-body {
    padding: 16px;
  }

  .msr-btn.q128,
  .msr-btn.q320 {
    padding: 6px 8px;
    font-size: 10px;
  }

  .msr-dur {
    display: none;
  }

  .movie-songs-section {
    margin: 0 16px 28px;
  }

  .movies-page-hero {
    padding: 24px 16px 20px;
  }
}

@media (max-width: 400px) {
  .card-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }

  .lib-grid {
    grid-template-columns: 1fr;
  }

  .hero-title {
    font-size: 18px;
  }
}

@media (min-width: 1600px) {
  .card-grid {
    grid-template-columns: repeat(auto-fill, minmax(185px, 1fr));
  }

  .movies-grid {
    grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  }

  .hero-title {
    font-size: 40px;
  }
}