/* CDMP3 — Dark Theme · Red Accent */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

:root {
  --bg:         #0d0d0d;
  --bg2:        #121212;
  --bg3:        #1a1a1a;
  --card:       #1e1e1e;
  --card-hover: #282828;
  --border:     rgba(255,255,255,.08);
  --border2:    rgba(255,255,255,.14);
  --accent:     #e50914;
  --accent2:    #ff2030;
  --accent3:    #b3060f;
  --gradient:   linear-gradient(135deg,#e50914 0%,#b3060f 100%);
  --gradient-subtle: linear-gradient(135deg,rgba(229,9,20,.08) 0%,rgba(179,6,15,.05) 100%);
  --txt:   #ffffff;
  --txt2:  #b3b3b3;
  --txt3:  #727272;
  --success:#1db954; --danger:#e50914; --warn:#f59e0b; --info:#3b82f6;
  --sidebar-w: 220px;
  --header-h:  64px;
  --player-h:  80px;
  --radius:    10px;
  --radius-sm: 7px;
  --radius-xs: 4px;
  --shadow:    0 4px 20px rgba(0,0,0,.5);
  --shadow-sm: 0 2px 10px rgba(0,0,0,.4);
  --shadow-accent: 0 8px 32px rgba(229,9,20,.35);
  --transition:.18s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--txt);min-height:100vh;
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;
  padding-bottom:var(--player-h)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul,ol{list-style:none}
input,textarea,select,button{font-family:inherit}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}

/* ══ LAYOUT ══════════════════════════════════════════════ */
.app-layout{display:flex;min-height:100vh}

/* ── Sidebar ─────────────────────────────────────────── */
.sidebar{
  width:var(--sidebar-w);flex-shrink:0;
  background:var(--bg2);border-right:1px solid var(--border);
  position:fixed;top:0;left:0;bottom:var(--player-h);
  overflow-y:auto;display:flex;flex-direction:column;z-index:100;
  transition:transform .25s ease;
}
.sidebar-logo{
  padding:20px 18px 14px;font-size:1.15rem;font-weight:900;
  display:flex;align-items:center;gap:8px;flex-shrink:0;
  border-bottom:1px solid var(--border);
}
.sidebar-logo .logo-waves{color:var(--accent);font-size:1.35rem}
.sidebar-logo .logo-text em{color:var(--accent);font-style:normal}
.sidebar-nav{flex:1;padding:10px 12px;overflow-y:auto}
.sidebar-group{margin-bottom:20px}
.sidebar-group-label{
  font-size:.6rem;font-weight:700;letter-spacing:.1em;
  color:var(--txt3);padding:0 8px;margin-bottom:6px;text-transform:uppercase
}
.sidebar-link{
  display:flex;align-items:center;gap:11px;
  padding:9px 10px;border-radius:var(--radius-sm);
  font-size:.84rem;font-weight:500;color:var(--txt2);
  transition:var(--transition);margin-bottom:1px;
}
.sidebar-link i{width:18px;text-align:center;font-size:.88rem;flex-shrink:0}
.sidebar-link:hover{background:rgba(255,255,255,.05);color:var(--txt)}
.sidebar-link.active{
  background:rgba(229,9,20,.14);color:var(--accent);
  border-left:3px solid var(--accent);padding-left:7px
}
.sidebar-apps{padding:14px 18px 20px;flex-shrink:0;border-top:1px solid var(--border)}
.sidebar-apps-label{font-size:.6rem;font-weight:700;letter-spacing:.1em;color:var(--txt3);margin-bottom:10px;text-transform:uppercase}
.app-badge{
  display:flex;align-items:center;gap:10px;
  background:var(--bg3);border:1px solid var(--border);
  border-radius:8px;padding:8px 11px;margin-bottom:7px;
  font-size:.75rem;color:var(--txt2);transition:var(--transition);
}
.app-badge:hover{background:var(--card);color:var(--txt);border-color:var(--border2)}
.app-badge i{font-size:1.25rem;color:var(--txt)}
.app-badge-text{display:flex;flex-direction:column}
.app-badge-text small{font-size:.57rem;opacity:.7}
.app-badge-text strong{font-size:.77rem}

/* ── Main area ───────────────────────────────────────── */
.main-area{margin-left:var(--sidebar-w);flex:1;min-width:0;display:flex;flex-direction:column}

/* ── Header ──────────────────────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:90;
  background:rgba(13,13,13,.96);
  backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:14px;
  padding:0 22px;height:var(--header-h);
}
.header-search{position:relative;flex:1;max-width:380px}
.header-search form{display:flex}
.header-search input{
  width:100%;background:var(--bg3);border:1px solid var(--border);
  border-radius:99px;padding:9px 16px 9px 40px;
  font-size:.85rem;color:var(--txt);outline:none;transition:var(--transition);
}
.header-search input::placeholder{color:var(--txt3)}
.header-search input:focus{border-color:rgba(229,9,20,.5);background:var(--card)}
.header-search .si{
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  color:var(--txt3);font-size:.83rem;pointer-events:none;
}
.header-search .search-submit{display:none}
.header-nav{display:flex;align-items:center;gap:1px}
.header-nav-link{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:6px 10px;font-size:.72rem;font-weight:600;
  color:var(--txt3);border-radius:var(--radius-sm);
  transition:var(--transition);white-space:nowrap;position:relative;
}
.header-nav-link i{font-size:.9rem}
.header-nav-link:hover{color:var(--txt)}
.header-nav-link.active{color:var(--txt)}
.header-nav-link.active::after{
  content:'';position:absolute;bottom:-1px;left:50%;
  transform:translateX(-50%);width:18px;height:2px;
  background:var(--accent);border-radius:1px;
}
.header-actions{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}
.mobile-menu-btn{
  display:none;background:none;border:none;
  color:var(--txt);font-size:1.2rem;cursor:pointer;padding:6px;
}

/* ── Content wrapper ─────────────────────────────────── */
.page-content{flex:1;padding:24px;min-width:0}
.page-content .page-content{padding:0}
.main-wrapper{padding:0}

/* ══ BUTTONS ═════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 20px;border-radius:99px;font-size:.84rem;
  font-weight:600;cursor:pointer;transition:var(--transition);
  border:none;white-space:nowrap;
}
.btn-gradient{background:var(--accent);color:#fff;box-shadow:var(--shadow-accent)}
.btn-gradient:hover{background:var(--accent2);transform:translateY(-1px)}
.btn-outline{background:transparent;border:1px solid var(--border2);color:var(--txt2)}
.btn-outline:hover{border-color:var(--txt);color:var(--txt)}
.btn-ghost{background:rgba(255,255,255,.07);color:var(--txt2)}
.btn-ghost:hover{background:rgba(255,255,255,.12);color:var(--txt)}
.btn-sm{padding:6px 14px;font-size:.78rem}
.btn-lg{padding:13px 28px;font-size:.95rem}
.btn-login{background:transparent;border:1px solid var(--border2);color:var(--txt2);border-radius:99px;padding:7px 18px;font-size:.82rem;font-weight:600;cursor:pointer;transition:var(--transition)}
.btn-login:hover{border-color:var(--txt);color:var(--txt)}
.btn-register{background:var(--accent);color:#fff;border-radius:99px;padding:7px 18px;font-size:.82rem;font-weight:600;cursor:pointer;transition:var(--transition);border:none}
.btn-register:hover{background:var(--accent2)}
.btn-icon{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.07);color:var(--txt2);font-size:.85rem;transition:var(--transition);border:none;cursor:pointer}
.btn-icon:hover{background:rgba(255,255,255,.12);color:var(--txt)}

/* ══ USER MENU ═══════════════════════════════════════════ */
.user-menu{position:relative}
.user-menu::before{content:"";position:absolute;top:100%;left:0;right:0;height:12px;z-index:199}
.user-btn{display:flex;align-items:center;gap:8px;background:var(--bg3);border:1px solid var(--border);border-radius:99px;padding:5px 12px 5px 5px;cursor:pointer;transition:var(--transition);color:var(--txt);font-size:.82rem;font-weight:500}
.user-btn img{width:28px;height:28px;border-radius:50%;object-fit:cover}
.user-btn:hover{border-color:var(--border2);background:var(--card)}
.user-dropdown{position:absolute;top:100%;right:0;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);min-width:200px;box-shadow:0 12px 40px rgba(0,0,0,.5);opacity:0;visibility:hidden;flex-direction:column;overflow:hidden;z-index:200;transition:opacity .15s,visibility .15s;margin-top:4px}
.user-menu:hover .user-dropdown,.user-menu.open .user-dropdown{opacity:1;visibility:visible;display:flex}
.user-dropdown a{display:flex;align-items:center;gap:10px;padding:10px 16px;font-size:.83rem;color:var(--txt2);transition:var(--transition)}
.user-dropdown a:hover{background:var(--bg3);color:var(--txt)}
.user-dropdown a i{width:14px}
.user-dropdown .separator{height:1px;background:var(--border);margin:4px 0}

/* ══ SECTION HEADERS ═════════════════════════════════════ */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.section-title{font-size:.95rem;font-weight:700;display:flex;align-items:center;gap:7px}
.section-title i{color:var(--accent)}
.section-link{font-size:.72rem;color:var(--txt3);font-weight:700;letter-spacing:.05em;text-transform:uppercase;transition:var(--transition)}
.section-link:hover{color:var(--accent)}
.section-header-right{display:flex;align-items:center;gap:6px;flex-shrink:0}
.scroll-arrow{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--bg2);color:var(--txt2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.7rem;transition:.18s;flex-shrink:0}
.scroll-arrow:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.scroll-arrow:active{transform:scale(.92)}
.section{margin-bottom:32px}

/* ══ CARDS ═══════════════════════════════════════════════ */
.cards-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:6px;scroll-snap-type:x mandatory}
.cards-scroll::-webkit-scrollbar{display:none}
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:14px}
.cards-grid-lg{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:18px}

.card{background:var(--card);border-radius:var(--radius);overflow:hidden;transition:var(--transition);cursor:pointer;flex-shrink:0;scroll-snap-align:start;width:160px}
.cards-grid .card,.cards-grid-lg .card{width:auto}
.card:hover{background:var(--card-hover);transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.5)}
.card-cover{position:relative;width:100%;aspect-ratio:1;background:var(--bg3);overflow:hidden}
.card-cover img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.card:hover .card-cover img{transform:scale(1.06)}
.card-cover-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.7) 100%);opacity:0;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.card:hover .card-cover-overlay{opacity:1}
.card-play-btn{width:44px;height:44px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;border:none;cursor:pointer;box-shadow:var(--shadow-accent);transform:translateY(8px);transition:transform .2s}
.card:hover .card-play-btn{transform:translateY(0)}
.card-play-btn:hover{transform:scale(1.08) !important;background:var(--accent2)}
.card-body{padding:11px}
.card-title{font-size:.83rem;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
.card-sub{font-size:.74rem;color:var(--txt3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Artist card */
.artist-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;background:var(--card);border-radius:var(--radius);cursor:pointer;transition:var(--transition);flex-shrink:0;width:140px}
.artist-card:hover{background:var(--card-hover);transform:translateY(-3px)}
.artist-card-photo{width:80px;height:80px;border-radius:50%;object-fit:cover;background:var(--bg3);border:2px solid var(--border)}
.artist-card-name{font-size:.82rem;font-weight:600;text-align:center;color:var(--txt)}
.artist-card-subs{font-size:.72rem;color:var(--txt3)}
.cards-grid .artist-card,.cards-grid-lg .artist-card{width:auto;padding:20px 12px}
.cards-grid .artist-card-photo{width:90px;height:90px}

/* Genre card */
.genre-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/2;cursor:pointer;transition:var(--transition)}
.genre-card:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,.5)}
.genre-card img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.genre-card:hover img{transform:scale(1.06)}
.genre-card .overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 20%,rgba(0,0,0,.75) 100%)}
.genre-card .genre-info{position:absolute;bottom:10px;left:12px;right:12px}
.genre-card .genre-name{font-size:.9rem;font-weight:700;color:#fff}
.genre-card .genre-count{font-size:.72rem;color:rgba(255,255,255,.7)}
.genres-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px}

/* ══ HERO BANNER ══════════════════════════════════════════ */
.hero-banner{position:relative;border-radius:var(--radius);overflow:hidden;min-height:300px;background:var(--bg3);display:flex;align-items:flex-end;margin-bottom:28px}
.hero-bg{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;filter:brightness(.45)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.9) 0%,rgba(0,0,0,.3) 60%,transparent 100%)}
.hero-content{position:relative;padding:32px;max-width:500px}
.hero-tag{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:6px}
.hero-title{font-size:1.8rem;font-weight:900;line-height:1.15;margin-bottom:6px}
.hero-artist{font-size:.88rem;color:var(--txt2);margin-bottom:18px}
.hero-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.hero-dots{position:absolute;bottom:14px;right:20px;display:flex;gap:6px}
.hero-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.3);cursor:pointer;transition:var(--transition)}
.hero-dot.active{background:var(--accent);width:18px;border-radius:3px}

/* ══ HOME LAYOUT ══════════════════════════════════════════ */
.home-layout{display:grid;grid-template-columns:1fr 280px;gap:22px;align-items:start}
.home-main{min-width:0}
.home-side{min-width:0}

/* ══ MUSIC LIST ═══════════════════════════════════════════ */
.music-list{display:flex;flex-direction:column}
.music-item{display:grid;grid-template-columns:30px 44px 1fr auto;gap:11px;align-items:center;padding:7px 10px;border-radius:var(--radius-sm);transition:var(--transition);cursor:pointer;border:1px solid transparent}
.music-item:hover{background:var(--card);border-color:var(--border)}
.music-item.playing{background:rgba(229,9,20,.08);border-color:rgba(229,9,20,.2)}
.music-item.playing .music-title{color:var(--accent)}
.music-num{font-size:.83rem;font-weight:600;color:var(--txt3);text-align:center;flex-shrink:0}
.music-num-play{display:none;align-items:center;justify-content:center;color:var(--txt)}
.music-item:hover .music-num{display:none}
.music-item:hover .music-num-play{display:flex !important}
.music-item.playing .music-num{display:none}
.music-item.playing .eq-anim{display:flex}
.music-cover{width:44px;height:44px;border-radius:var(--radius-xs);object-fit:cover;background:var(--bg3);flex-shrink:0}
.music-info{min-width:0}
.music-title{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.music-artist{font-size:.75rem;color:var(--txt3);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.music-artist a:hover{color:var(--accent)}
.music-actions{display:flex;align-items:center;gap:9px;flex-shrink:0}
.music-duration{font-size:.78rem;color:var(--txt3);font-variant-numeric:tabular-nums;min-width:34px;text-align:right}
.music-plays{font-size:.75rem;color:var(--txt3)}
.music-download-btn{background:none;border:none;color:var(--txt3);cursor:pointer;padding:5px;border-radius:50%;font-size:.85rem;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.music-download-btn:hover{color:var(--accent);background:rgba(229,9,20,.1)}

/* Equalizer */
.eq-anim,.eq-icon{display:none;gap:2px;align-items:flex-end;height:14px;justify-content:center}
.music-item.playing .eq-anim{display:flex}
.eq-anim span,.eq-icon span{width:3px;background:var(--accent);border-radius:1px;animation:eqBar .8s ease infinite}
.eq-anim span:nth-child(1),.eq-icon span:nth-child(1){animation-duration:.9s}
.eq-anim span:nth-child(2),.eq-icon span:nth-child(2){animation-delay:.15s;animation-duration:.7s}
.eq-anim span:nth-child(3),.eq-icon span:nth-child(3){animation-delay:.3s;animation-duration:1s}
@keyframes eqBar{0%,100%{height:3px}50%{height:14px}}

/* ══ RANK LIST ════════════════════════════════════════════ */
.rank-list{display:flex;flex-direction:column;gap:1px}
.rank-item{display:grid;grid-template-columns:38px 44px 1fr auto;align-items:center;gap:12px;padding:8px 10px;border-radius:var(--radius-sm);transition:var(--transition);cursor:pointer}
.rank-item:hover{background:var(--card)}
.rank-item.playing{background:rgba(229,9,20,.08)}
.rank-num{font-size:.88rem;font-weight:700;color:var(--txt3);text-align:center}
.rank-num.gold{color:#f59e0b;font-size:1.1rem}
.rank-num.silver{color:#9ca3af;font-size:1rem}
.rank-num.bronze{color:#d97706}
.rank-cover{width:44px;height:44px;border-radius:var(--radius-xs);object-fit:cover;background:var(--bg3)}
.rank-info{min-width:0}
.rank-title{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rank-artist{font-size:.75rem;color:var(--txt3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rank-item.playing .rank-title{color:var(--accent)}
.rank-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.rank-duration{font-size:.75rem;color:var(--txt3);font-variant-numeric:tabular-nums}

/* ══ ALBUM PAGE ═══════════════════════════════════════════ */
.album-page-layout{display:grid;grid-template-columns:1fr 280px;gap:22px;align-items:start}
.album-header{background:var(--card);border-radius:var(--radius);overflow:hidden;margin-bottom:20px}
.album-header-bg{position:relative;min-height:200px;background:linear-gradient(135deg,#1a0808,#2d1010);display:flex;align-items:flex-end;padding:24px;gap:22px}
.album-header-bg::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 20%,rgba(0,0,0,.65) 100%);pointer-events:none}
.album-cover-large{width:160px;height:160px;border-radius:var(--radius);object-fit:cover;box-shadow:0 16px 48px rgba(0,0,0,.6);flex-shrink:0;position:relative}
.album-header-info{position:relative;min-width:0}
.album-type-tag{font-size:.64rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:5px}
.album-header-title{font-size:1.6rem;font-weight:900;line-height:1.2;margin-bottom:5px}
.album-header-artist{font-size:.9rem;color:var(--txt2);margin-bottom:10px}
.album-header-artist a:hover{color:var(--accent)}
.album-header-meta{display:flex;align-items:center;gap:14px;font-size:.77rem;color:var(--txt3);flex-wrap:wrap}
.album-header-meta span{display:flex;align-items:center;gap:4px}
.album-header-meta i{color:var(--accent)}
.album-actions-bar{display:flex;align-items:center;gap:12px;padding:16px 24px;flex-wrap:wrap;border-bottom:1px solid var(--border)}
.btn-play-big{width:50px;height:50px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-accent);transition:var(--transition)}
.btn-play-big:hover{background:var(--accent2);transform:scale(1.06)}
.btn-download-album{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:transparent;border:2px solid var(--accent);color:var(--accent);border-radius:99px;font-size:.84rem;font-weight:700;cursor:pointer;transition:var(--transition)}
.btn-download-album:hover{background:var(--accent);color:#fff;box-shadow:var(--shadow-accent)}

/* Track list */
.track-list{display:flex;flex-direction:column}
.track-item{display:grid;grid-template-columns:30px 44px 1fr auto;gap:12px;align-items:center;padding:9px 24px;border-bottom:1px solid var(--border);transition:var(--transition);cursor:pointer}
.track-item:last-child{border-bottom:none}
.track-item:hover{background:var(--bg3)}
.track-item.playing{background:rgba(229,9,20,.08)}
.track-item.playing .track-title{color:var(--accent)}
.track-num{font-size:.83rem;color:var(--txt3);text-align:center}
.track-cover{width:44px;height:44px;border-radius:var(--radius-xs);object-fit:cover;background:var(--bg3)}
.track-info{min-width:0}
.track-title{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.track-artist{font-size:.75rem;color:var(--txt3)}
.track-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.track-duration{font-size:.78rem;color:var(--txt3);font-variant-numeric:tabular-nums}

/* ══ TOP PAGES ════════════════════════════════════════════ */
.top-page-layout{display:grid;grid-template-columns:1fr 260px;gap:22px;align-items:start}
.period-tabs{display:flex;gap:6px;margin-bottom:18px;flex-wrap:wrap}
.period-tab{padding:7px 18px;border-radius:99px;font-size:.82rem;font-weight:600;color:var(--txt3);background:var(--card);border:1px solid var(--border);cursor:pointer;transition:var(--transition)}
.period-tab:hover{color:var(--txt);border-color:var(--border2)}
.period-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:var(--shadow-accent)}
.top-actions{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}

/* ══ ARTIST PAGE ══════════════════════════════════════════ */
.artist-hero{position:relative;height:260px;border-radius:var(--radius);overflow:hidden;margin-bottom:22px}
.artist-hero-bg{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;filter:brightness(.35)}
.artist-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.92) 100%)}
.artist-hero-content{position:absolute;bottom:24px;left:28px;right:28px;display:flex;align-items:flex-end;gap:20px}
.artist-hero-photo{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid rgba(255,255,255,.2);flex-shrink:0}
.artist-hero-info{flex:1;min-width:0}

/* Artist profile (abaixo do banner, sobrepõe via margin negativa) */
.artist-profile{display:flex;align-items:flex-end;gap:22px;margin-top:-70px;padding:0 4px;position:relative;z-index:2;margin-bottom:16px}
.artist-profile-photo{width:140px;height:140px;border-radius:50%;object-fit:cover;border:4px solid var(--bg);box-shadow:0 8px 28px rgba(0,0,0,.65);flex-shrink:0}
.artist-profile-info{flex:1;min-width:0;padding-bottom:6px}

.artist-verified{display:flex;align-items:center;gap:5px;font-size:.7rem;color:var(--accent);margin-bottom:4px}
.artist-name{font-size:2rem;font-weight:900;line-height:1.1;margin-bottom:4px}
.artist-genre{font-size:.82rem;color:var(--txt2);display:inline-flex;align-items:center;gap:4px;transition:var(--transition)}
.artist-genre:hover{color:var(--accent)}
.artist-stats{display:flex;gap:18px;flex-wrap:wrap}
.artist-stat{font-size:.78rem;color:var(--txt3)}
.artist-stat strong{font-size:.92rem;color:var(--txt);display:block;font-weight:700}
.artist-actions{display:flex;gap:10px;align-items:center;margin-bottom:22px;flex-wrap:wrap}

/* Bio + info line */
.artist-info-line{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:4px 0 6px}
.artist-genre-link{font-size:.78rem;color:var(--txt2);display:inline-flex;align-items:center;gap:5px;text-decoration:none;transition:color .2s}
.artist-genre-link:hover{color:var(--accent)}
.artist-location{font-size:.76rem;color:var(--txt3);display:flex;align-items:center;gap:4px}
.artist-bio-block{position:relative;z-index:2;margin-bottom:18px;padding:0 4px}
.artist-bio-text{font-size:.84rem;color:var(--txt2);line-height:1.65;max-height:200px;overflow:hidden;transition:max-height .35s ease}
.artist-bio-text.collapsed{max-height:72px;-webkit-mask-image:linear-gradient(to bottom,black 40%,transparent)}
.artist-bio-toggle{background:none;border:none;color:var(--accent);cursor:pointer;font-size:.76rem;font-weight:600;padding:4px 0;margin-top:2px}
.artist-bio-toggle:hover{text-decoration:underline}
.artist-social-inline{display:flex;gap:6px;align-items:center;margin-left:auto}
.artist-social-inline a{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--txt3);font-size:.82rem;transition:all .2s;text-decoration:none}
.artist-social-inline a:hover{background:var(--accent);border-color:var(--accent);color:#fff}

/* Álbuns carousel */
.artist-albums-row{display:flex;gap:14px;overflow-x:auto;padding:4px 4px 12px;scroll-snap-type:x mandatory;scrollbar-width:none;user-select:none;-webkit-user-select:none;cursor:grab}
.artist-albums-row::-webkit-scrollbar{display:none}
.artist-album-card{display:flex;flex-direction:column;gap:8px;cursor:pointer;flex-shrink:0;width:170px;scroll-snap-align:start;text-decoration:none;transition:transform .2s}
.artist-album-card:hover{transform:translateY(-3px)}
.artist-album-cover{position:relative;width:170px;height:170px;border-radius:6px;overflow:hidden;background:var(--bg3)}
.artist-album-cover img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.artist-album-card:hover .artist-album-cover img{transform:scale(1.06)}
.artist-album-play{position:absolute;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .25s}
.artist-album-card:hover .artist-album-play{opacity:1}
.artist-album-play i{font-size:2rem;color:#fff;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}
.artist-album-title{font-size:.8rem;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}
.artist-album-meta{font-size:.68rem;color:var(--txt3);line-height:1}

/* Music stat */
.music-stat{font-size:.72rem;color:var(--txt3);display:flex;align-items:center;gap:3px}
.music-stat.dl-btn{background:none;border:none;cursor:pointer;padding:0;font-family:inherit;transition:color .2s}
.music-stat.dl-btn:hover{color:var(--accent)}
.music-item.playing .music-stat{color:var(--accent)}
.ap-social-row{display:flex;gap:7px;align-items:center}

/* Tabs */
.artist-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:0;overflow-x:auto;white-space:nowrap}
.artist-tabs::-webkit-scrollbar{display:none}
.artist-tab{padding:11px 16px;font-size:.84rem;font-weight:600;color:var(--txt3);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:var(--transition);white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
.artist-tab:hover{color:var(--txt)}
.artist-tab.active{color:var(--txt);border-bottom-color:var(--accent)}
.ap-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:17px;background:rgba(255,255,255,.1);border-radius:99px;font-size:.63rem;font-weight:700;padding:0 5px;color:var(--txt3)}
.artist-tab.active .ap-badge{background:rgba(229,9,20,.18);color:var(--accent)}

/* Tab panels */
.artist-panel{display:block;padding-top:16px}
.artist-panel.hidden{display:none}

/* Two-column layout */
.artist-page-layout{display:grid;grid-template-columns:1fr 280px;gap:22px;align-items:start}
.artist-main{min-width:0}
.artist-side{min-width:0}

/* Follow / share buttons */
.btn-follow{display:inline-flex;align-items:center;gap:7px;padding:9px 22px;border-radius:99px;font-size:.84rem;font-weight:600;cursor:pointer;transition:var(--transition);border:2px solid var(--border2);background:transparent;color:var(--txt);white-space:nowrap}
.btn-follow:hover{border-color:var(--txt)}
.btn-follow.following{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-follow.following:hover{background:var(--accent3);border-color:var(--accent3)}
.ap-share-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:99px;font-size:.82rem;font-weight:600;cursor:pointer;transition:var(--transition);border:1px solid var(--border);background:transparent;color:var(--txt2)}
.ap-share-btn:hover{color:var(--txt);border-color:var(--border2)}

/* Music list extras for artist page */
.mi-dl{font-size:.72rem;color:var(--txt3);display:flex;align-items:center;gap:3px}
.mi-like{background:none;border:none;color:var(--txt3);cursor:pointer;padding:5px;border-radius:50%;font-size:.88rem;transition:var(--transition);display:flex;align-items:center;justify-content:center;line-height:1}
.mi-like:hover,.mi-like.liked{color:var(--accent)}
.mi-badge{display:inline-flex;align-items:center;gap:3px;background:rgba(229,9,20,.1);color:var(--accent);border-radius:4px;padding:1px 6px;font-size:.63rem;font-weight:600;margin-left:5px;vertical-align:middle}

/* Empty state */
.ap-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;gap:10px;text-align:center;color:var(--txt3)}
.ap-empty i{font-size:2.2rem}
.ap-empty p{font-size:.88rem}

/* Album grid */
.ap-album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:16px;padding:4px 0}
.ap-album-card{display:block;background:var(--card);border-radius:var(--radius);overflow:hidden;transition:var(--transition)}
.ap-album-card:hover{background:var(--card-hover);transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.5)}
.ap-album-card-inner{position:relative;aspect-ratio:1;background:var(--bg3);overflow:hidden}
.ap-album-cover{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.ap-album-card:hover .ap-album-cover{transform:scale(1.06)}
.ap-album-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--transition)}
.ap-album-card:hover .ap-album-overlay{opacity:1}
.ap-album-play-icon{font-size:1.6rem;color:#fff}
.ap-album-body{padding:11px}
.ap-album-title{font-size:.84rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px}
.ap-album-meta{font-size:.74rem;color:var(--txt3)}

/* Sidebar widgets — artist specific */
.ap-monthly{text-align:center;padding:16px 0 10px}
.ap-monthly-num{font-size:2.2rem;font-weight:900;color:var(--txt);line-height:1}
.ap-monthly-label{font-size:.74rem;color:var(--txt3);margin-top:6px}

.ap-last-release{display:flex;gap:11px;align-items:center;padding:7px;border-radius:var(--radius-sm);transition:var(--transition)}
.ap-last-release:hover{background:var(--bg3)}
.ap-last-release img{width:62px;height:62px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}
.ap-last-release-info{min-width:0}
.ap-last-release-title{font-size:.84rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ap-last-release-meta{font-size:.74rem;color:var(--txt3);margin-top:3px}

.ap-similar-item{display:flex;align-items:center;gap:10px;padding:8px 7px;border-radius:var(--radius-sm);transition:var(--transition)}
.ap-similar-item:hover{background:var(--bg3)}
.ap-similar-photo{width:42px;height:42px;border-radius:50%;object-fit:cover;flex-shrink:0;display:block}
.ap-similar-info{flex:1;min-width:0}
.ap-similar-name{font-size:.82rem;font-weight:600;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--txt);transition:var(--transition)}
.ap-similar-name:hover{color:var(--accent)}
.ap-similar-genre{font-size:.72rem;color:var(--txt3)}
.ap-follow-sm{font-size:.7rem;font-weight:700;color:var(--accent);cursor:pointer;background:none;border:1px solid rgba(229,9,20,.35);border-radius:99px;padding:3px 10px;transition:var(--transition);white-space:nowrap;flex-shrink:0;display:inline-flex;align-items:center}
.ap-follow-sm:hover{background:rgba(229,9,20,.1)}

.ap-bio-text{font-size:.84rem;color:var(--txt2);line-height:1.7;white-space:pre-line}
.ap-bio-text.collapsed{overflow:hidden;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical}
.ap-bio-toggle{background:none;border:none;color:var(--accent);font-size:.8rem;font-weight:600;cursor:pointer;padding:7px 0 0;display:block;transition:var(--transition)}
.ap-bio-toggle:hover{color:var(--accent2)}

/* Artist public page (old compat) */
.music-page{display:grid;grid-template-columns:220px 1fr;gap:32px;align-items:start}
.music-page-cover{width:100%;border-radius:var(--radius);aspect-ratio:1;object-fit:cover;background:var(--bg3)}
.music-page-title{font-size:1.5rem;font-weight:800;margin-bottom:6px}
.music-page-artist{font-size:.95rem;color:var(--txt2);margin-bottom:14px}
.music-page-artist a:hover{color:var(--accent)}
.music-page-actions{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.music-meta{display:flex;align-items:center;gap:14px;font-size:.8rem;color:var(--txt3);flex-wrap:wrap;margin-bottom:18px}
.music-meta span{display:flex;align-items:center;gap:5px}

/* ══ PAGE SIDEBAR (right column) ═════════════════════════ */
.page-sidebar{min-width:0}
.sidebar-widget{background:var(--card);border-radius:var(--radius);overflow:hidden;margin-bottom:14px}
.sidebar-widget-header{padding:13px 15px 9px;font-size:.82rem;font-weight:700;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:6px}
.sidebar-widget-header i{color:var(--accent)}
.sidebar-widget-body{padding:7px}
.widget-item{display:flex;align-items:center;gap:10px;padding:7px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}
.widget-item:hover{background:var(--bg3)}
.widget-item-rank{font-size:.77rem;font-weight:700;color:var(--txt3);width:18px;text-align:center;flex-shrink:0}
.widget-item img{width:38px;height:38px;border-radius:var(--radius-xs);object-fit:cover;flex-shrink:0}
.widget-item-info{flex:1;min-width:0}
.widget-item-title{font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.widget-item-sub{font-size:.72rem;color:var(--txt3)}

/* ══ BADGE ════════════════════════════════════════════════ */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:99px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.badge-success{background:rgba(29,185,84,.15);color:#1db954}
.badge-danger,.badge-error{background:rgba(229,9,20,.15);color:var(--accent)}
.badge-warn{background:rgba(245,158,11,.15);color:#f59e0b}
.badge-info{background:rgba(59,130,246,.15);color:#60a5fa}
.badge-gray{background:rgba(255,255,255,.08);color:var(--txt3)}

/* ══ FORMS ════════════════════════════════════════════════ */
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--txt2);margin-bottom:6px}
.form-control{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-size:.88rem;color:var(--txt);outline:none;transition:var(--transition)}
.form-control:focus{border-color:var(--accent);background:var(--card);box-shadow:0 0 0 3px rgba(229,9,20,.12)}
.form-control::placeholder{color:var(--txt3)}
textarea.form-control{resize:vertical;min-height:90px}
select.form-control{cursor:pointer}
.form-check{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.83rem;color:var(--txt2)}
.form-check input{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}
.form-hint{font-size:.76rem;color:var(--txt3);margin-top:4px}

/* ══ ALERTS ══════════════════════════════════════════════ */
.alert{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:14px}
.alert-success{background:rgba(29,185,84,.12);border:1px solid rgba(29,185,84,.25);color:#1db954}
.alert-error{background:rgba(229,9,20,.12);border:1px solid rgba(229,9,20,.25);color:var(--accent)}
.alert-info{background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.25);color:#60a5fa}
.alert-warn{background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.25);color:#f59e0b}

/* ══ EMPTY STATE ══════════════════════════════════════════ */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:12px;text-align:center}
.empty-state>i{font-size:2.5rem;color:var(--txt3)}
.empty-state h3{font-size:1.1rem;color:var(--txt)}
.empty-state p{font-size:.88rem;color:var(--txt3);max-width:300px}

/* ══ PAGINATION ══════════════════════════════════════════ */
.pagination{display:flex;gap:5px;justify-content:center;margin-top:24px;flex-wrap:wrap}
.page-link{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;border-radius:var(--radius-sm);padding:0 10px;font-size:.83rem;font-weight:600;background:var(--card);border:1px solid var(--border);color:var(--txt2);cursor:pointer;transition:var(--transition)}
.page-link:hover{border-color:var(--border2);color:var(--txt)}
.page-link.active{background:var(--accent);border-color:var(--accent);color:#fff}

/* ══ FOOTER ══════════════════════════════════════════════ */
.footer{background:var(--bg2);border-top:1px solid var(--border);padding:44px 24px 22px;margin-top:auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:28px;margin-bottom:28px}
.footer-brand{font-size:1.1rem;font-weight:900;display:flex;align-items:center;gap:7px;margin-bottom:9px}
.footer-brand i{color:var(--accent)}
.footer-brand em{color:var(--accent);font-style:normal}
.footer-desc{font-size:.82rem;color:var(--txt3);line-height:1.7}
.footer-heading{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--txt2);margin-bottom:13px}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-links a{font-size:.83rem;color:var(--txt3);transition:var(--transition)}
.footer-links a:hover{color:var(--accent)}
.footer-bottom{border-top:1px solid var(--border);padding-top:18px;display:flex;align-items:center;justify-content:space-between;font-size:.78rem;color:var(--txt3);flex-wrap:wrap;gap:8px}
.social-link{width:33px;height:33px;border-radius:50%;background:var(--card);border:1px solid var(--border);display:inline-flex;align-items:center;justify-content:center;color:var(--txt3);font-size:.88rem;transition:var(--transition)}
.social-link:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.newsletter-form{display:flex;gap:7px;margin-top:12px}
.newsletter-form input{flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:99px;padding:8px 14px;font-size:.82rem;color:var(--txt);outline:none}
.newsletter-form input:focus{border-color:var(--accent)}
.newsletter-form button{background:var(--accent);border:none;border-radius:99px;padding:8px 16px;color:#fff;font-size:.82rem;font-weight:600;cursor:pointer;transition:var(--transition)}
.newsletter-form button:hover{background:var(--accent2)}

/* ══ AUTH SPLIT ══════════════════════════════════════════ */
.auth-body{background:var(--bg);margin:0;padding:0;min-height:100vh}
.auth-split{display:flex;min-height:100vh}

/* Painel esquerdo — marca */
.auth-brand{flex:0 0 400px;background:linear-gradient(160deg,#0d0d0d 0%,#1c0900 60%,#0d0500 100%);border-right:1px solid var(--border);padding:48px 44px;display:flex;flex-direction:column;gap:36px;position:relative;overflow:hidden}
.auth-brand::before{content:'';position:absolute;top:-100px;right:-100px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(255,102,0,.2) 0%,transparent 70%);pointer-events:none}
.auth-brand::after{content:'';position:absolute;bottom:0;left:-60px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(255,102,0,.08) 0%,transparent 70%);pointer-events:none}
.auth-brand-logo{display:flex;align-items:center;gap:10px;font-size:1.35rem;font-weight:900;color:var(--txt);text-decoration:none;z-index:1}
.auth-brand-logo i{color:var(--accent);font-size:1.55rem}
.auth-brand-hero{flex:1;z-index:1}
.auth-brand-hero h1{font-size:1.9rem;font-weight:900;line-height:1.25;margin-bottom:14px;color:var(--txt)}
.auth-brand-hero h1 span{color:var(--accent)}
.auth-brand-hero p{color:var(--txt3);font-size:.88rem;line-height:1.65;max-width:280px}
.auth-features{list-style:none;display:flex;flex-direction:column;gap:14px;z-index:1}
.auth-features li{display:flex;align-items:center;gap:13px;font-size:.87rem;color:var(--txt2)}
.af-icon{width:34px;height:34px;border-radius:9px;background:rgba(255,102,0,.12);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:.82rem;flex-shrink:0}
.auth-brand-footer{margin-top:auto;z-index:1}
.auth-brand-footer a{font-size:.8rem;color:var(--txt3);text-decoration:none;transition:var(--transition)}
.auth-brand-footer a:hover{color:var(--accent)}

/* Painel direito — formulário */
.auth-form-side{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 24px;background:var(--bg)}
.auth-form-inner{width:100%;max-width:420px}
.auth-form-header{margin-bottom:28px}
.auth-form-header h2{font-size:1.55rem;font-weight:800;margin-bottom:5px;color:var(--txt)}
.auth-form-header p{color:var(--txt3);font-size:.88rem}
.auth-divider{display:flex;align-items:center;gap:10px;margin:20px 0;font-size:.78rem;color:var(--txt3)}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-links{text-align:center;font-size:.85rem;color:var(--txt3);line-height:2}
.auth-links a{color:var(--accent);font-weight:600;text-decoration:none}
.auth-links a:hover{text-decoration:underline}

/* Responsivo: empilha verticalmente */
@media(max-width:860px){
  .auth-split{flex-direction:column;min-height:unset}
  .auth-brand{flex:unset;padding:28px 24px;gap:16px;border-right:none;border-bottom:1px solid var(--border)}
  .auth-brand::before,.auth-brand::after{display:none}
  .auth-brand-hero{display:none}
  .auth-features{display:none}
  .auth-brand-footer{display:none}
  .auth-form-side{padding:32px 20px;min-height:unset}
}

/* Legado */
.auth-page{min-height:60vh;display:flex;align-items:center;justify-content:center;padding:40px 20px}
.auth-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:38px;width:100%;max-width:420px;box-shadow:var(--shadow)}
.auth-logo{font-size:1.4rem;font-weight:900;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:24px}
.auth-logo i{color:var(--accent)}
.auth-footer{text-align:center;font-size:.83rem;color:var(--txt3);margin-top:18px}
.auth-footer a{color:var(--accent);font-weight:600}
.auth-subtitle{font-size:.88rem;color:var(--txt3);text-align:center;margin-bottom:22px}
.auth-switch{text-align:center;font-size:.83rem;color:var(--txt3);margin-top:18px;line-height:1.9}
.auth-switch a{color:var(--accent);font-weight:600}

/* ══ SEARCH ══════════════════════════════════════════════ */
.search-tabs{display:flex;gap:6px;margin-bottom:20px;flex-wrap:wrap}
.search-tab{padding:6px 16px;border-radius:99px;font-size:.8rem;font-weight:600;background:var(--card);border:1px solid var(--border);color:var(--txt3);cursor:pointer;transition:var(--transition)}
.search-tab:hover{color:var(--txt);border-color:var(--border2)}
.search-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ══ DATA NUMBER ══════════════════════════════════════════ */
/* formatação feita via JavaScript (toLocaleString + K/M) */

/* ══ MOBILE OVERLAY & BOTTOM NAV ══════════════════════════ */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:98}
.sidebar-overlay.open{display:block}
.mobile-bottom-nav{display:none;position:fixed;bottom:var(--player-h);left:0;right:0;background:var(--bg2);border-top:1px solid var(--border);z-index:95;padding:5px 0}
.mobile-bottom-nav-inner{display:flex;justify-content:space-around}
.mobile-nav-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:5px 10px;font-size:.6rem;font-weight:600;color:var(--txt3);background:none;border:none;cursor:pointer;transition:var(--transition);min-width:52px}
.mobile-nav-btn i{font-size:1.15rem}
.mobile-nav-btn.active{color:var(--accent)}

/* ══ RESPONSIVE ═══════════════════════════════════════════ */
@media(min-width:1280px){.page-content{padding:28px 32px}}
@media(max-width:1100px){
  :root{--sidebar-w:200px}
  .home-layout{grid-template-columns:1fr 240px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:22px}
}
@media(max-width:900px){
  .home-layout,.album-page-layout,.top-page-layout,.artist-page-layout{grid-template-columns:1fr}
  .home-side,.page-sidebar,.artist-side{display:none}
  .music-page{grid-template-columns:180px 1fr;gap:22px}
}
@media(max-width:768px){
  body{padding-bottom:calc(var(--player-h) + 56px)}
  .sidebar{transform:translateX(-100%);z-index:99}
  .sidebar.open{transform:translateX(0)}
  .main-area{margin-left:0}
  .mobile-menu-btn{display:flex !important}
  .mobile-bottom-nav{display:block}
  .header-nav{display:none}
  .music-item{grid-template-columns:26px 40px 1fr auto;gap:8px}
  .track-item{padding:8px 14px}
  .album-header-bg{flex-direction:column;align-items:flex-start}
  .album-cover-large{width:120px;height:120px}
  .page-content{padding:14px}
  .footer{padding:28px 14px 16px}
  .footer-grid{grid-template-columns:1fr;gap:20px}
  .hero-banner{min-height:220px}
  .hero-title{font-size:1.4rem}
  .artist-hero{height:180px}
  .artist-name{font-size:1.5rem}
  .artist-profile{margin-top:-50px;gap:14px}
  .artist-profile-photo{width:100px;height:100px}
  .music-page{grid-template-columns:1fr}
  .music-page-cover{max-width:220px;margin:0 auto}
}
@media(max-width:480px){
  :root{--player-h:64px;--header-h:56px}
  .site-header{padding:0 12px;gap:8px}
  .header-search{flex:1}
  .btn-login{display:none}
  .music-plays{display:none}
  .album-header-title{font-size:1.25rem}
  .cards-grid{grid-template-columns:repeat(auto-fill,minmax(128px,1fr))}
  .hero-content{padding:18px}
  .hero-title{font-size:1.2rem}
  .ac-card{width:115px}
  .ac-img{width:76px;height:76px}
  .ac-name{font-size:.76rem}
  .scroll-float{width:30px;height:30px;font-size:.68rem}
  .scroll-row-wrap{margin:0 -8px;padding:0 8px}
  .scroll-row-wrap::before{left:8px}
  .scroll-row-wrap::after{right:8px}
}

/* ══ HOME HERO GRID ═══════════════════════════════════════ */
.home-hero-grid{display:grid;grid-template-columns:1fr 280px;gap:20px;margin-bottom:32px;align-items:start}
.home-hero-grid .hero-banner{margin-bottom:0}

/* Hero banner — home.php child class variant */
.hero-banner-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:blur(24px) brightness(.35);transform:scale(1.12)}
.hero-banner-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.25) 0%,rgba(0,0,0,.82) 100%)}
.hero-banner-content{position:relative;z-index:1;display:flex;align-items:flex-end;gap:22px;padding:28px;width:100%}
.hero-banner-cover{width:130px;height:130px;border-radius:var(--radius);object-fit:cover;box-shadow:0 10px 30px rgba(0,0,0,.6);flex-shrink:0}
.hero-banner-info{flex:1;min-width:0}
.hero-banner-tag{font-size:.64rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:6px;display:flex;align-items:center;gap:4px}
.hero-banner-title{font-size:1.5rem;font-weight:900;line-height:1.2;margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hero-banner-artist{font-size:.87rem;color:var(--txt2);margin-bottom:16px}
.hero-banner-actions{display:flex;gap:9px;align-items:center;flex-wrap:wrap}

/* ══ HOME HOT SIDEBAR (Em Alta) ═══════════════════════════ */
.home-hot{background:var(--card);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--border)}
.home-hot-head{padding:13px 15px;font-size:.82rem;font-weight:700;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:7px}
.home-hot-head i{color:var(--accent)}
.home-hot-item{display:flex;align-items:center;gap:10px;padding:9px 12px;cursor:pointer;transition:var(--transition);border-bottom:1px solid var(--border)}
.home-hot-item:last-of-type{border-bottom:none}
.home-hot-item:hover{background:var(--bg3)}
.home-hot-rank{font-size:.8rem;font-weight:700;color:var(--txt3);width:22px;text-align:center;flex-shrink:0}
.home-hot-rank.gold{color:#f59e0b}
.home-hot-rank.silver{color:#9ca3af}
.home-hot-rank.bronze{color:#d97706}
.home-hot-img{width:38px;height:38px;border-radius:var(--radius-xs);object-fit:cover;flex-shrink:0}
.home-hot-info{flex:1;min-width:0}
.home-hot-name{font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.home-hot-artist{font-size:.7rem;color:var(--txt3)}
.home-hot-plays{font-size:.7rem;color:var(--txt3);display:flex;align-items:center;gap:3px;flex-shrink:0}

/* ══ ARTIST CIRCLES ROW ═══════════════════════════════════ */
.artist-circles-row{display:flex;gap:16px;overflow-x:auto;padding:8px 4px 16px;scroll-snap-type:x mandatory;user-select:none;-webkit-user-select:none;cursor:grab;scrollbar-width:none}
.artist-circles-row::-webkit-scrollbar{display:none}

/* Scroll row wrapper — setas flutuantes + fade edges */
.scroll-row-wrap{position:relative;margin:0 -12px;padding:0 12px}
.scroll-row-wrap::before,
.scroll-row-wrap::after{content:'';position:absolute;top:0;bottom:0;width:32px;z-index:3;pointer-events:none;transition:opacity .3s}
.scroll-row-wrap::before{left:12px;background:linear-gradient(to right,var(--bg) 20%,transparent)}
.scroll-row-wrap::after{right:12px;background:linear-gradient(to left,var(--bg) 20%,transparent)}

/* Setas flutuantes */
.scroll-float{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:36px;height:36px;border-radius:50%;border:none;background:var(--bg2);color:var(--txt);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem;box-shadow:0 2px 12px rgba(0,0,0,.5);transition:all .2s;opacity:0}
.scroll-row-wrap:hover .scroll-float{opacity:1}
.scroll-float:hover{background:var(--accent);color:#fff;transform:translateY(-50%) scale(1.1);box-shadow:0 4px 20px rgba(229,9,20,.4)}
.scroll-float:active{transform:translateY(-50%) scale(.94)}
.scroll-float-left{left:0}
.scroll-float-right{right:0}

/* Touch devices — always visible */
@media(hover:none){.scroll-float{opacity:.7;background:rgba(30,30,30,.9)}}

.ac-card{display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:transform .25s ease,opacity .25s ease;flex-shrink:0;width:130px;text-align:center;scroll-snap-align:start;user-select:none;-webkit-user-select:none;text-decoration:none}
.ac-card:hover{transform:translateY(-5px)}
.ac-card:hover .ac-img{box-shadow:0 0 0 3px var(--accent),0 8px 24px rgba(229,9,20,.15)}

.ac-img-wrap{position:relative;flex-shrink:0}
.ac-img{width:90px;height:90px;border-radius:50%;object-fit:cover;background:var(--bg3);transition:box-shadow .25s ease,border-color .25s ease;border:2px solid var(--border);display:block}
.ac-verified{position:absolute;bottom:2px;right:2px;width:22px;height:22px;border-radius:50%;background:#3b82f6;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.6rem;box-shadow:0 2px 6px rgba(59,130,246,.4);border:2px solid var(--bg)}

.ac-name{font-size:.82rem;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;line-height:1.2}
.ac-genre{font-size:.68rem;color:var(--txt3);line-height:1}
.ac-stats{display:flex;flex-direction:column;align-items:center;gap:1px;font-size:.72rem;font-weight:700;color:var(--txt2)}

@keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ══ RELEASES GRID ════════════════════════════════════════ */
.releases-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}

/* ══ CARD COVER WRAP ══════════════════════════════════════ */
.card-cover-wrap{position:relative;width:100%;aspect-ratio:1;background:var(--bg3);overflow:hidden;border-radius:var(--radius) var(--radius) 0 0}
.card-cover-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.card:hover .card-cover-wrap img{transform:scale(1.06)}
.card-cover-wrap .card-play-btn{position:absolute;bottom:10px;right:10px;transform:translateY(10px);opacity:0;transition:var(--transition)}
.card:hover .card-cover-wrap .card-play-btn{transform:translateY(0);opacity:1}
.card-dl-badge{position:absolute;bottom:8px;left:8px;background:rgba(0,0,0,.75);border-radius:99px;padding:3px 8px;font-size:.67rem;color:#fff;display:flex;align-items:center;gap:4px;pointer-events:none}

/* Card text aliases used by home.php / explore views */
.card-name{font-size:.83rem;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
.card-meta{font-size:.74rem;color:var(--txt3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-stats{display:flex;align-items:center;gap:7px;margin-top:5px;flex-wrap:wrap}
.card-stat{font-size:.7rem;color:var(--txt3);display:flex;align-items:center;gap:3px}

/* ══ HOME SPLIT ═══════════════════════════════════════════ */
.home-split{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-bottom:32px}

/* ══ BUTTON — PRIMARY ═════════════════════════════════════ */
.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-accent)}
.btn-primary:hover{background:var(--accent2);transform:translateY(-1px)}

/* ══ TOP RANK COLORS ══════════════════════════════════════ */
.top-rank.gold{color:#f59e0b}
.top-rank.silver{color:#9ca3af}
.top-rank.bronze{color:#d97706}

/* ══ LIKE BUTTON ══════════════════════════════════════════ */
.btn-like{background:none;border:none;color:var(--txt3);cursor:pointer;padding:5px;border-radius:50%;font-size:.88rem;transition:var(--transition);display:flex;align-items:center;justify-content:center;line-height:1}
.btn-like:hover,.btn-like.liked{color:var(--accent)}

/* ══ SIMPLE HERO (no featured track) ═════════════════════ */
.hero{text-align:center;padding:60px 24px;background:var(--gradient-subtle);border-radius:var(--radius);margin-bottom:28px}
.hero-sub{font-size:.95rem;color:var(--txt2);margin-bottom:22px;max-width:440px;margin-left:auto;margin-right:auto}

/* ══ HOME ARTIST CTA ══════════════════════════════════════ */
.home-artist-cta{display:flex;align-items:center;justify-content:space-between;gap:20px;background:var(--gradient-subtle);border:1px solid rgba(229,9,20,.2);border-radius:var(--radius);padding:24px 28px;margin-bottom:32px;flex-wrap:wrap}
.home-artist-cta h3{font-size:1.05rem;font-weight:700;margin-bottom:6px;display:flex;align-items:center}
.home-artist-cta p{font-size:.83rem;color:var(--txt2);max-width:500px}
.home-artist-cta-text{flex:1;min-width:200px}
.home-artist-cta-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;flex-shrink:0}

/* ══ HOME WIDGET (sidebar) ════════════════════════════════ */
.home-widget{background:var(--card);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}
.home-side{display:flex;flex-direction:column;gap:16px;min-width:0}
.hw-head{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;border-bottom:1px solid var(--border);font-size:.82rem;font-weight:700}
.hw-head a{font-size:.71rem;color:var(--accent);font-weight:600}
.hw-head a:hover{text-decoration:underline}
.hw-tabs{display:flex;gap:4px}
.hw-tab{background:none;border:none;padding:3px 9px;border-radius:20px;font-size:.68rem;font-weight:700;cursor:pointer;color:var(--txt2);transition:.15s;letter-spacing:.01em}
.hw-tab.active{background:var(--accent);color:#fff}
.hw-tab:hover:not(.active){background:rgba(255,255,255,.08);color:var(--txt)}

/* Destaques / Mais Tocadas list item */
.hd-item{display:flex;align-items:center;gap:9px;padding:8px 12px;cursor:pointer;transition:background .15s;border-bottom:1px solid rgba(255,255,255,.04);text-decoration:none;}
.hd-item:last-child{border-bottom:none}
.hd-item:hover{background:var(--bg3)}
.hd-rank{width:18px;text-align:center;font-size:.67rem;font-weight:700;color:var(--txt3);flex-shrink:0}
.hd-rank.gold{color:#f59e0b}.hd-rank.silver{color:#9ca3af}.hd-rank.bronze{color:#d97706}
.hd-img{width:38px;height:38px;border-radius:5px;object-fit:cover;flex-shrink:0}
.hd-info{flex:1;min-width:0}
.hd-name{font-size:.77rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--txt)}
.hd-artist{font-size:.67rem;color:var(--txt2);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hd-plays{font-size:.62rem;color:var(--txt3);flex-shrink:0;display:flex;align-items:center;gap:3px}
.hd-badge{font-size:.59rem;color:var(--accent);font-weight:700;background:rgba(229,9,20,.12);padding:2px 6px;border-radius:3px;flex-shrink:0;white-space:nowrap;text-transform:uppercase;letter-spacing:.03em}

/* Gêneros sidebar grid */
.hw-genre-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px;padding:10px 10px 12px}
.hw-genre-pill{display:flex;align-items:center;gap:5px;padding:6px 8px;border-radius:6px;background:var(--bg2);font-size:.7rem;font-weight:600;text-decoration:none;color:var(--txt2);transition:.15s;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.hw-genre-pill:hover{background:rgba(229,9,20,.1);color:var(--accent)}
.hw-genre-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}

/* ══ RESPONSIVE ADDITIONS ═════════════════════════════════ */
@media(max-width:900px){
  .home-hero-grid{grid-template-columns:1fr}
  .home-split{grid-template-columns:1fr}
}
@media(max-width:600px){
  .hero-banner-cover{width:90px;height:90px}
  .hero-banner-title{font-size:1.15rem}
  .home-artist-cta{padding:18px}
  .releases-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
}

/* ══ EXPLORE PAGE ═════════════════════════════════════════ */
.explore-page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.explore-page-title{font-size:1.5rem;font-weight:900;letter-spacing:-.02em;margin-bottom:2px}
.explore-page-sub{font-size:.82rem;color:var(--txt3)}
.explore-searchbar{display:flex;align-items:center;gap:0;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;flex:1;max-width:380px}
.explore-searchbar i{padding:0 12px;color:var(--txt3);font-size:.84rem;flex-shrink:0}
.explore-searchbar input{flex:1;background:none;border:none;outline:none;color:var(--txt);font-size:.84rem;padding:10px 0;min-width:0}
.explore-searchbar input::placeholder{color:var(--txt3)}
.explore-searchbar button{background:var(--accent);color:#fff;border:none;padding:0 18px;font-size:.78rem;font-weight:700;cursor:pointer;height:100%;white-space:nowrap;transition:background .15s}
.explore-searchbar button:hover{background:var(--accent2)}

/* Genre pills bar */
.explore-genres-bar{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;margin-bottom:28px;scrollbar-width:none}
.explore-genres-bar::-webkit-scrollbar{display:none}
.explore-genre-pill{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:20px;font-size:.74rem;font-weight:700;white-space:nowrap;cursor:pointer;transition:.15s;text-decoration:none;flex-shrink:0;color:#fff;background:var(--gc,var(--card));border:1px solid transparent;opacity:.85}
.explore-genre-pill:hover{opacity:1;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.3)}
.explore-genre-pill.active{opacity:1;border-color:rgba(255,255,255,.3)}

/* Cover cards grid (Lançamentos) */
.explore-cover-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.explore-cover-card{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;background:var(--bg3);aspect-ratio:1}
.explore-cover-card:hover .explore-cover-img{transform:scale(1.06)}
.explore-cover-card:hover .explore-cover-play{opacity:1;transform:scale(1)}
.explore-cover-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.explore-cover-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.1) 55%);transition:.2s}
.explore-cover-tag{position:absolute;top:9px;left:9px;background:var(--accent);color:#fff;font-size:.6rem;font-weight:700;padding:2px 7px;border-radius:3px;letter-spacing:.04em;text-transform:uppercase}
.explore-cover-info{position:absolute;bottom:0;left:0;right:0;padding:10px 12px}
.explore-cover-title{font-size:.82rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.explore-cover-artist{font-size:.7rem;color:rgba(255,255,255,.7);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.explore-cover-play{position:absolute;top:9px;right:9px;width:34px;height:34px;border-radius:50%;background:rgba(229,9,20,.92);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.8);transition:opacity .15s,transform .15s;box-shadow:0 2px 10px rgba(0,0,0,.4)}

/* Artist grid cards */
.explore-artists-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}
.explore-artist-card{background:var(--card);border-radius:var(--radius);overflow:hidden;text-decoration:none;border:1px solid var(--border);transition:transform .2s,border-color .2s;display:block}
.explore-artist-card:hover{transform:translateY(-3px);border-color:var(--accent)}
.explore-artist-img-wrap{position:relative;width:100%;aspect-ratio:1;overflow:hidden;background:var(--bg3)}
.explore-artist-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.explore-artist-card:hover .explore-artist-img-wrap img{transform:scale(1.06)}
.explore-artist-badge{position:absolute;bottom:6px;right:6px;background:var(--accent);color:#fff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:.62rem}
.explore-artist-body{padding:8px 10px 10px}
.explore-artist-name{font-size:.8rem;font-weight:700;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.explore-artist-genre{font-size:.67rem;color:var(--accent);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.explore-artist-seg{font-size:.67rem;color:var(--txt3);margin-top:4px;display:flex;align-items:center;gap:3px}

/* Albums scroll row */
.explore-albums-row{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;scrollbar-width:none}
.explore-albums-row::-webkit-scrollbar{display:none}
.explore-album-card{flex-shrink:0;width:154px;text-decoration:none;display:block}
.explore-album-cover{position:relative;width:154px;height:154px;border-radius:var(--radius);overflow:hidden;background:var(--bg3);margin-bottom:8px}
.explore-album-cover img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.explore-album-card:hover .explore-album-cover img{transform:scale(1.06)}
.explore-album-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.4);opacity:0;transition:opacity .15s}
.explore-album-card:hover .explore-album-play{opacity:1}
.explore-album-play i{width:38px;height:38px;background:rgba(229,9,20,.9);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem;padding-left:3px}
.explore-album-title{font-size:.78rem;font-weight:700;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.explore-album-artist{font-size:.68rem;color:var(--txt2);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.explore-album-meta{font-size:.64rem;color:var(--txt3);margin-top:3px}

/* Responsive */
@media(max-width:768px){
  .explore-page-head{flex-direction:column;align-items:flex-start}
  .explore-searchbar{max-width:100%;width:100%}
  .explore-cover-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .explore-artists-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}
}
@media(max-width:480px){
  .explore-cover-grid{grid-template-columns:repeat(2,1fr)}
  .explore-artists-grid{grid-template-columns:repeat(2,1fr)}
}

/* ── Destaque da faixa ativa no player ───────────── */
.track-item.track-playing {
  background: rgba(255,102,0,.12);
  border-left: 3px solid var(--accent);
}
.track-item.track-paused {
  background: rgba(255,102,0,.06);
  border-left: 3px solid rgba(255,102,0,.3);
}
.track-item.track-playing .track-title,
.track-item.track-paused .track-title {
  color: var(--accent);
}
.track-item.track-playing .track-artist {
  color: rgba(255,102,0,.7);
}

/* ── Artist Grid Moderno ──────────────────────────────── */
.artists-grid-moderno {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 16px;
}

.artist-card-moderno {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 20px 12px 14px;
  background: var(--card);
  border-radius: var(--radius);
  text-decoration: none;
  transition: all .25s ease;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}

.artist-card-moderno:hover {
  background: var(--card-hover);
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0,0,0,.45);
}

/* ── Foto redonda com gradiente no hover ──────────── */
.artist-card-moderno-cover {
  position: relative;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--bg3);
  border: 2px solid var(--border);
  transition: border-color .25s;
}

.artist-card-moderno:hover .artist-card-moderno-cover {
  border-color: var(--accent);
}

.artist-card-moderno-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover; object-position: center top;
  transition: transform .35s ease;
}

.artist-card-moderno:hover .artist-card-moderno-cover img {
  transform: scale(1.08);
}

/* ── Overlay escuro com botão play ────────────────── */
.artist-card-moderno-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.35);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .2s ease;
  border-radius: 50%;
}

.artist-card-moderno:hover .artist-card-moderno-overlay {
  opacity: 1;
}

.artist-card-moderno-play {
  width: 40px;
  height: 40px;
  background: var(--accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: .85rem;
  box-shadow: 0 4px 16px rgba(255,102,0,.5);
  transform: translateY(8px);
  transition: transform .25s ease;
  padding-left: 3px;
}

.artist-card-moderno:hover .artist-card-moderno-play {
  transform: translateY(0);
}

.artist-card-moderno-play:hover {
  transform: scale(1.1) !important;
  background: #ff7722;
}

/* ── Texto do card ────────────────────────────────── */
.artist-card-moderno-body {
  text-align: center;
  width: 100%;
}

.artist-card-moderno-name {
  font-size: .85rem;
  font-weight: 700;
  color: var(--txt);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 3px;
  transition: color .2s;
}

.artist-card-moderno:hover .artist-card-moderno-name {
  color: var(--accent);
}

.artist-card-moderno-meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  flex-wrap: wrap;
  font-size: .7rem;
  color: var(--txt3);
}

.artist-card-moderno-tag {
  background: rgba(255,102,0,.15);
  color: var(--accent);
  padding: 1px 8px;
  border-radius: 10px;
  font-size: .65rem;
  font-weight: 600;
}

.artist-card-moderno-stat {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  color: var(--txt3);
}

.artist-card-moderno-stat i {
  font-size: .62rem;
}


/* ═══ ARTISTAS PAGE ═══ */
.az-filter-bar {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 4px;
  margin-bottom: 24px;
  padding: 12px 0;
}
.az-letter {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 6px;
  font-size: .82rem;
  font-weight: 600;
  color: var(--txt2);
  text-decoration: none;
  background: var(--card);
  border: 1px solid transparent;
  transition: all .2s;
}
.az-letter:hover { color: var(--accent); border-color: var(--accent); }
.az-letter.active { background: var(--accent); color: #fff; }

.artists-filter-bar {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 20px;
}
.artists-search-wrap {
  display: flex;
  align-items: center;
  background: #1e1e1e;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  max-width: 480px;
}
.artists-search-icon {
  padding: 0 14px;
  color: var(--txt3);
  font-size: .9rem;
}
.artists-search-input {
  flex: 1;
  background: none;
  border: none;
  color: var(--txt);
  padding: 10px 0;
  font-size: .9rem;
  outline: none;
}
.artists-search-input::placeholder { color: var(--txt3); }
.artists-search-btn {
  background: var(--accent);
  color: #fff;
  border: none;
  padding: 0 20px;
  height: 44px;
  cursor: pointer;
  font-size: .9rem;
}
.artists-search-btn:hover { background: #ff7722; }

.artists-order-pills {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  font-size: .82rem;
}
.order-label { color: var(--txt3); font-size: .78rem; margin-right: 4px; }
.order-sep { color: var(--border); margin: 0 4px; }

.filter-pill {
  display: inline-block;
  padding: 5px 14px;
  border-radius: 99px;
  font-size: .78rem;
  font-weight: 500;
  color: var(--txt2);
  background: var(--card);
  text-decoration: none;
  transition: all .2s;
  border: 1px solid transparent;
}
.filter-pill:hover { border-color: var(--accent); color: var(--accent); }
.filter-pill.active { background: var(--accent); color: #fff; }

.artists-count-bar {
  color: var(--txt3);
  font-size: .8rem;
  margin-bottom: 14px;
}

/* Mobile */
@media (max-width: 768px) {
  .az-filter-bar { gap: 2px; }
  .az-letter { width: 28px; height: 28px; font-size: .75rem; }
  .artists-grid-moderno { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .artists-search-wrap { max-width: 100%; }
  .artist-card-moderno { padding: 14px 8px 10px; }
  .artist-card-moderno-cover { width: 90px; height: 90px; }
}

/* ═══ HERO SLIDER (BANNERS) ═══ */
/* ═══ HERO SLIDER ═══ */
.hero-slider {
  position: relative;
  width: 100%;
  border-radius: 12px;
  overflow: hidden;
  background: var(--card);
  margin-bottom: 24px;
  aspect-ratio: 16 / 6;
  max-height: 400px;
}
.hero-slider-track {
  position: relative;
  width: 100%;
  height: 100%;
}
.hero-slide {
  display: none;
  width: 100%;
  height: 100%;
}
.hero-slide.active {
  display: block;
}

/* Banner slide */
.banner-slide {
  position: relative;
  width: 100%;
  height: 100%;
}
.banner-slide-img {
  width: 100%;
  height: 100%;
  display: block;
}
.banner-slide-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(0,0,0,.5) 0%, rgba(0,0,0,.05) 50%, rgba(0,0,0,.25) 100%);
  z-index: 1;
}
.banner-slide-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 2;
  padding: 40px 48px;
  max-width: 520px;
}
.banner-slide-content h2 {
  font-size: 2rem;
  font-weight: 800;
  color: #fff;
  margin: 0 0 8px;
  text-shadow: 0 2px 12px rgba(0,0,0,.5);
}
.banner-slide-content p {
  font-size: 1rem;
  color: rgba(255,255,255,.85);
  margin: 0 0 18px;
  text-shadow: 0 1px 8px rgba(0,0,0,.4);
}
.banner-slide-content .btn {
  font-size: .9rem;
  padding: 10px 24px;
}

/* Arrows */
.hero-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(0,0,0,.5);
  border: 1px solid rgba(255,255,255,.15);
  color: #fff;
  font-size: .9rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .25s, background .2s;
}
.hero-slider:hover .hero-arrow { opacity: 1; }
.hero-arrow:hover { background: rgba(0,0,0,.75); }
.hero-arrow-left  { left: 12px; }
.hero-arrow-right { right: 12px; }

/* Dots */
.hero-dots {
  position: absolute;
  bottom: 14px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: flex;
  gap: 8px;
}
.hero-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,.35);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background .2s, width .2s;
}
.hero-dot.active {
  background: #fff;
  width: 24px;
  border-radius: 4px;
}

/* ─── MUSIC FALLBACK SLIDES ──────────────────────────────── */
.hero-slide-bg {
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:blur(40px) brightness(.35);
  transform:scale(1.1);
}
.hero-slide-overlay {
  position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(0,0,0,.85) 0%, rgba(0,0,0,.3) 50%, rgba(0,0,0,.6) 100%);
  z-index:1;
}
.hero-slide-content {
  position:relative;z-index:2;
  display:flex;align-items:center;gap:24px;
  padding:28px 36px;height:100%;
}
.hero-slide-cover {
  width:160px;height:160px;min-width:160px;
  border-radius:8px;object-fit:cover;
  box-shadow:0 8px 32px rgba(0,0,0,.5);
}
.hero-slide-info {
  flex:1;min-width:0;
  display:flex;flex-direction:column;gap:6px;
}
.hero-slide-tag {
  display:inline-flex;align-items:center;gap:6px;
  font-size:.7rem;font-weight:700;
  text-transform:uppercase;letter-spacing:1px;
  color:#ffd700;
}
.hero-slide-title {
  font-size:1.8rem;font-weight:800;
  line-height:1.15;color:#fff;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.hero-slide-artist {
  font-size:.88rem;color:rgba(255,255,255,.75);
}
.hero-slide-artist a { color:inherit;transition:color .2s; }
.hero-slide-artist a:hover { color:#fff; }
.hero-genre { color:var(--accent);font-size:.78rem;font-weight:500; }
.hero-slide-actions {
  display:flex;gap:10px;margin-top:10px;
}
.hero-slide-stats {
  display:flex;gap:16px;margin-top:6px;
  font-size:.75rem;color:rgba(255,255,255,.5);
}
.hero-stat i { margin-right:4px; }

/* ─── SECTION SLIDER (Spotify-style horizontal scroll) ────── */
.section-slider-wrap {
  position:relative;
}
.section-slider {
  display:flex;gap:14px;
  overflow-x:auto;overflow-y:hidden;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  padding-bottom:4px;
  -webkit-overflow-scrolling:touch;
}
.section-slider::-webkit-scrollbar { display:none; }
.section-slider .card {
  flex:0 0 165px;scroll-snap-align:start;
}
.section-slider .card:last-child::after {
  content:'';flex:0 0 1px;
}
.section-slider-arrow {
  position:absolute;top:50%;transform:translateY(-50%);
  z-index:5;
  width:36px;height:36px;
  border-radius:50%;
  background:rgba(0,0,0,.7);
  border:1px solid rgba(255,255,255,.15);
  color:#fff;font-size:.8rem;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .2s,background .2s;
  pointer-events:none;
}
.section-slider-wrap:hover .section-slider-arrow {
  opacity:1;pointer-events:auto;
}
.section-slider-arrow:hover { background:rgba(0,0,0,.9); }
.section-slider-arrow-left  { left:-8px; }
.section-slider-arrow-right { right:-8px; }
.section-slider-arrow.sl-hidden { opacity:0 !important;pointer-events:none !important; }

@media (max-width:768px) {
  .section-slider-arrow { display:none; }
  .hero-slide-cover { width:120px;height:120px;min-width:120px; }
  .hero-slide-title { font-size:1.2rem; }
  .hero-slide-content { padding:16px 20px;gap:16px; }
}

/* ═══ Mobile Banner — imagem completa ═══ */
@media (max-width: 768px) {
  .hero-slider {
    aspect-ratio: auto;
    max-height: none;
    border-radius: 0;
    margin-bottom: 16px;
  }
  .hero-slider-track { height: auto; }
  .hero-slide { height: auto; }
  .hero-slide.active { display: block; }
  .banner-slide { height: auto; }
  .banner-slide-img {
    width: 100%;
    height: auto;
    max-height: 320px;
    display: block;
  }
  .banner-slide-overlay { display: none; }
  .banner-slide-content {
    position: relative;
    padding: 16px 20px 20px;
    background: linear-gradient(0deg, var(--bg) 0%, rgba(13,13,13,.9) 60%, transparent 100%);
  }
  .banner-slide-content h2 { font-size: 1.15rem; }
  .banner-slide-content p { font-size: .8rem; margin-bottom: 10px; }
  .hero-arrow { display: none; }
  .hero-dots { bottom: 8px; }
}

/* ═══ SEARCH EXPANSÍVEL (MOBILE) ═════════════════════════ */
.header-search.search-expanded{
  position:fixed;top:0;left:0;right:0;
  background:rgba(13,13,13,.98);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  padding:12px 16px;z-index:95;
  border-bottom:1px solid var(--border);
}
.header-search.search-expanded input{padding-left:40px;font-size:1rem}
.header-search.search-expanded .search-close{
  position:absolute;right:16px;top:50%;transform:translateY(-50%);
  background:none;border:none;color:var(--txt2);
  font-size:1.2rem;cursor:pointer;padding:8px;
}
.header-search.search-expanded .search-close:hover{color:var(--txt)}

/* Autocomplete dropdown */
.search-autocomplete{
  position:absolute;top:calc(100% + 6px);left:0;right:0;
  background:var(--card);border:1px solid var(--border);
  border-radius:10px;overflow:hidden;
  max-height:380px;overflow-y:auto;
  box-shadow:0 8px 32px rgba(0,0,0,.5);
  z-index:96;
  display:none;
}
.search-autocomplete.show{display:block}
.search-autocomplete-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 14px;cursor:pointer;
  transition:background .12s;
}
.search-autocomplete-item:hover,
.search-autocomplete-item.active{background:rgba(255,255,255,.06)}
.search-autocomplete-item img{
  width:36px;height:36px;border-radius:4px;object-fit:cover;
  flex-shrink:0;background:var(--bg3);
}
.search-autocomplete-item .ac-thumb{width:36px;height:36px;border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--bg3);color:var(--txt3);font-size:.9rem}
.search-autocomplete-item strong{display:block;color:var(--txt);font-weight:600;font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}
.search-autocomplete-item small{display:block;color:var(--txt3);font-size:.7rem;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-autocomplete-item .ac-type{font-size:.6rem;color:var(--accent);text-transform:uppercase;font-weight:700;margin-left:auto;flex-shrink:0;letter-spacing:.05em}
.search-autocomplete-divider{
  display:flex;align-items:center;padding:6px 14px 2px;
  font-size:.64rem;color:var(--txt3);text-transform:uppercase;
  font-weight:700;letter-spacing:.08em;
}
.search-autocomplete-divider::after{content:'';flex:1;height:1px;background:var(--border);margin-left:10px}
.search-autocomplete-empty{padding:20px;text-align:center;color:var(--txt3);font-size:.82rem}

.mobile-hide{display:none !important}
.mobile-only{display:none !important}
@media(max-width:768px){.mobile-only{display:inline-flex !important}}
@media(min-width:769px){.mobile-only{display:none !important}}

