/**
 * home.css - RPOOL.NET Home Page Styles
 * Premium Dark Theme — matching RPool Store design
 */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

/* ═══ Verified Badge ═══ */
.verified-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    background: #1d9bf0;
    border-radius: 50%;
    margin-left: 6px;
    vertical-align: middle;
    flex-shrink: 0;
    position: relative;
    top: -1px;
}
.verified-badge i {
    font-size: 9px;
    color: #fff;
    line-height: 1;
}
.verified-badge-sm {
    width: 14px;
    height: 14px;
}
.verified-badge-sm i {
    font-size: 8px;
}
.verified-badge-lg {
    width: 20px;
    height: 20px;
}
.verified-badge-lg i {
    font-size: 11px;
}

:root {
    --bg-primary: #0a0a0f;
    --bg-secondary: #12121a;
    --bg-card: #1a1a28;
    --bg-card-hover: #222236;
    --accent: #6c5ce7;
    --accent-light: #a29bfe;
    --accent-glow: rgba(108,92,231,0.3);
    --success: #00b894;
    --danger: #ff6b6b;
    --warning: #feca57;
    --text-primary: #ffffff;
    --text-secondary: #a0a0b8;
    --text-muted: #6c6c80;
    --border: rgba(255,255,255,0.06);
    --border-hover: rgba(108,92,231,0.4);
    --gradient-1: linear-gradient(135deg, #6c5ce7 0%, #a29bfe 100%);
    --gradient-2: linear-gradient(135deg, #fd79a8 0%, #e17055 100%);
    --radius: 16px;
    --radius-sm: 10px;
    --shadow: 0 8px 32px rgba(0,0,0,0.4);
    --shadow-lg: 0 16px 48px rgba(0,0,0,0.6);
    --transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
}

* { box-sizing: border-box; }
img, video, iframe, embed, object { max-width: 100%; height: auto; }

html {
    background: var(--bg-primary) !important;
    min-height: 100vh;
    overflow-x: hidden;
}

body {
    background: var(--bg-primary) !important;
    color: var(--text-primary) !important;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    min-height: 100vh;
    margin: 0 !important;
    padding: 0 !important;
    overflow-x: hidden;
    -webkit-text-size-adjust: 100%;
    -moz-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

/* Scrollbar */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg-secondary); }
::-webkit-scrollbar-thumb { background: var(--accent); border-radius: 3px; }

/* ===== NAVBAR (MODERN 2-ROW) ===== */
@keyframes navGlowSlide {
    0%   { background-position: 0% 50%; }
    100% { background-position: 200% 50%; }
}
@keyframes logoPulse {
    0%, 100% { filter: drop-shadow(0 0 4px var(--accent-glow)); }
    50%      { filter: drop-shadow(0 0 12px var(--accent)); }
}
@keyframes dotBlink {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.3; }
}

.nav-main {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(10,10,15,0.92);
    backdrop-filter: blur(30px) saturate(1.4);
    -webkit-backdrop-filter: blur(30px) saturate(1.4);
    transition: background 0.35s ease, box-shadow 0.35s ease;
}
.nav-main.nav-scrolled {
    background: rgba(10,10,15,0.97);
    box-shadow: 0 8px 40px rgba(0,0,0,0.5);
}

/* Gradient bottom glow line */
.nav-glow-line {
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--accent), var(--accent-light), var(--accent), transparent);
    background-size: 200% 100%;
    animation: navGlowSlide 4s linear infinite;
    opacity: 0.45;
}

/* ---- Top Row: Logo + Search + Account ---- */
.nav-top {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 12px 28px 10px;
    min-height: 62px;
}

/* Logo */
.nav-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    flex-shrink: 0;
    position: relative;
}
.nav-logo-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 11px;
    background: var(--gradient-1);
    color: #fff;
    font-size: 1.05rem;
    animation: logoPulse 3s ease infinite;
    transition: transform 0.3s ease;
}
.nav-logo:hover .nav-logo-icon {
    transform: rotate(90deg) scale(1.1);
}
.nav-logo-text {
    font-weight: 800;
    font-size: 1.35rem;
    line-height: 40px;
    background: linear-gradient(135deg, #fff 0%, var(--accent-light) 100%);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    letter-spacing: 1px;
    text-transform: uppercase;
}
.nav-logo-tld {
    background: linear-gradient(135deg, var(--accent-light) 0%, var(--accent) 100%);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-weight: 700;
    font-size: 0.85em;
    letter-spacing: 0;
}
.nav-logo-dot {
    display: none;
}

/* ===== Unified Search Bar Container ===== */
.nav-search-form {
    display: flex;
    align-items: center;
    flex: 1;
    min-width: 0;
    height: 40px;
    margin: 0;
    background: rgba(255,255,255,0.045);
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 14px;
    box-sizing: border-box;
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.nav-search-form:focus-within {
    border-color: rgba(108,92,231,0.4);
    box-shadow: 0 0 0 3px rgba(108,92,231,0.1), 0 4px 24px rgba(108,92,231,0.08);
    background: rgba(255,255,255,0.055);
}

/* Search input area */
.nav-search-box {
    position: relative;
    flex: 1;
    min-width: 140px;
}
.nav-search-icon {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-muted);
    font-size: 0.85rem;
    pointer-events: none;
    transition: color 0.2s ease;
}
.nav-search-input {
    width: 100%;
    height: 38px;
    padding: 0 72px 0 42px;
    background: transparent;
    border: none;
    border-radius: 0;
    color: #fff;
    font-size: 0.86rem;
    font-family: inherit;
    outline: none;
    transition: background 0.2s ease;
}
.nav-search-input::placeholder { color: var(--text-muted); }
.nav-search-input:focus {
    background: rgba(108,92,231,0.03);
}
.nav-search-input:focus ~ .nav-search-icon { color: var(--accent-light); }
.nav-search-kbd {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    padding: 3px 8px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 6px;
    color: var(--text-muted);
    font-size: 0.6rem;
    font-family: inherit;
    font-weight: 600;
    letter-spacing: 0.5px;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

/* Inline divider-separated filter selects */
.nav-filter-select {
    height: 38px;
    padding: 0 32px 0 14px;
    background: transparent;
    border: none;
    border-left: 1px solid rgba(255,255,255,0.06);
    border-radius: 0;
    color: var(--text-secondary);
    font-size: 0.82rem;
    font-family: inherit;
    outline: none;
    cursor: pointer;
    transition: all 0.2s ease;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23888' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    min-width: 115px;
    flex-shrink: 0;
    white-space: nowrap;
}
.nav-filter-select:hover {
    background-color: rgba(255,255,255,0.03);
    color: #fff;
}
.nav-filter-select:focus {
    background-color: rgba(108,92,231,0.06);
    color: #fff;
}
.nav-filter-select option {
    background: var(--bg-card);
    color: #fff;
}
.nav-filter-sort { min-width: 95px; }

/* Advanced Filter Toggle Button */
.nav-filter-toggle {
    width: 42px;
    height: 38px;
    border: none;
    border-left: 1px solid rgba(255,255,255,0.06);
    border-radius: 0;
    background: transparent;
    color: var(--text-muted);
    font-size: 0.9rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    flex-shrink: 0;
    position: relative;
}
.nav-filter-toggle:hover { color: #fff; background: rgba(255,255,255,0.05); }
.nav-filter-toggle.active { color: var(--accent-light); background: rgba(108,92,231,0.1); }
.nav-filter-badge {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--accent);
    color: #fff;
    font-size: 0.55rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

/* Advanced Filters Bar */
.nav-adv-filters {
    max-height: 0;
    overflow: hidden;
    background: linear-gradient(180deg, rgba(18,18,26,0.98), rgba(10,10,15,0.95));
    border-top: 1px solid rgba(255,255,255,0.04);
    transition: max-height 0.3s cubic-bezier(0.4,0,0.2,1), padding 0.3s ease;
    padding: 0 20px;
}
.nav-adv-filters.open {
    max-height: 80px;
    padding: 10px 20px;
    border-top-color: rgba(108,92,231,0.15);
}
.nav-adv-inner {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}
.nav-adv-group {
    display: flex;
    align-items: center;
    gap: 8px;
}
.nav-adv-label {
    color: var(--text-muted);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 4px;
}
.nav-adv-label i { font-size: 0.78rem; color: var(--accent-light); }
.nav-bpm-inputs {
    display: flex;
    align-items: center;
    gap: 6px;
}
.nav-adv-input {
    width: 68px;
    height: 32px;
    padding: 0 8px;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 8px;
    color: #fff;
    font-size: 0.8rem;
    font-family: inherit;
    outline: none;
    transition: border-color 0.2s, background 0.2s;
    -moz-appearance: textfield;
}
.nav-adv-input::-webkit-inner-spin-button,
.nav-adv-input::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
.nav-adv-input:focus {
    border-color: rgba(108,92,231,0.4);
    background: rgba(108,92,231,0.06);
}
.nav-adv-input::placeholder { color: var(--text-muted); font-size: 0.75rem; }
.nav-bpm-sep { color: var(--text-muted); font-size: 0.75rem; }
.nav-adv-select {
    height: 32px;
    padding: 0 28px 0 10px;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 8px;
    color: #fff;
    font-size: 0.8rem;
    font-family: inherit;
    outline: none;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%23888' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 8px center;
    min-width: 100px;
}
.nav-adv-select:focus {
    border-color: rgba(108,92,231,0.4);
    background-color: rgba(108,92,231,0.06);
}
.nav-adv-select option { background: var(--bg-card); color: #fff; }
.nav-adv-select optgroup { color: var(--text-muted); font-weight: 600; }
.nav-adv-apply {
    height: 32px;
    padding: 0 14px;
    background: var(--gradient-1);
    border: none;
    border-radius: 8px;
    color: #fff;
    font-size: 0.78rem;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 4px;
    transition: filter 0.2s, transform 0.15s;
    white-space: nowrap;
}
.nav-adv-apply:hover { filter: brightness(1.2); transform: translateY(-1px); }
.nav-adv-apply:active { transform: translateY(0); }

/* Integrated search & reset buttons */
.nav-search-btn {
    width: 48px;
    height: 38px;
    border: none;
    border-left: 1px solid rgba(255,255,255,0.06);
    border-radius: 0;
    background: var(--gradient-1);
    color: #fff;
    font-size: 0.9rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    flex-shrink: 0;
}
.nav-search-btn:hover {
    filter: brightness(1.2);
}
.nav-reset-btn {
    width: 44px;
    height: 38px;
    border: none;
    border-left: 1px solid rgba(255,255,255,0.06);
    border-radius: 0;
    background: transparent;
    color: var(--text-muted);
    font-size: 0.88rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    text-decoration: none;
    flex-shrink: 0;
}
.nav-reset-btn:hover {
    color: #fff;
    background: rgba(255,255,255,0.05);
}

/* ===== Clean Avatar Button ===== */
.nav-account {
    position: relative;
    flex-shrink: 0;
}
.nav-avatar-btn {
    background: none;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    padding: 0;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.25s ease;
}
.nav-avatar-btn:hover,
.nav-account.open .nav-avatar-btn {
    background: rgba(108,92,231,0.12);
    box-shadow: 0 0 0 3px rgba(108,92,231,0.08);
}
.nav-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--gradient-1);
    color: #fff;
    font-size: 0.82rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    box-shadow: 0 2px 8px rgba(108,92,231,0.25);
}
.nav-avatar-name {
    display: none;
}
.nav-avatar-chevron {
    display: none;
}

/* Dropdown */
.nav-dropdown {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    width: 230px;
    background: rgba(26,26,40,0.98);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.6), 0 0 0 1px rgba(255,255,255,0.02);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px) scale(0.96);
    transition: all 0.25s cubic-bezier(0.4,0,0.2,1);
    z-index: 1001;
    overflow: hidden;
}
.nav-account.open .nav-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
}
.nav-dropdown-header {
    padding: 16px 18px 12px;
    display: flex;
    flex-direction: column;
    gap: 3px;
    background: rgba(108,92,231,0.04);
}
.nav-dropdown-greeting {
    font-size: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    color: var(--accent-light);
    font-weight: 600;
}
.nav-dropdown-name {
    font-size: 0.95rem;
    font-weight: 700;
    color: #fff;
}
.nav-dropdown-divider {
    height: 1px;
    background: rgba(255,255,255,0.06);
    margin: 0;
}
.nav-dropdown-item {
    display: flex;
    align-items: center;
    gap: 11px;
    padding: 11px 18px;
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 0.84rem;
    font-weight: 500;
    transition: all 0.2s ease;
}
.nav-dropdown-item i {
    font-size: 1rem;
    width: 18px;
    text-align: center;
}
.nav-dropdown-item:hover {
    background: rgba(108,92,231,0.1);
    color: #fff;
}
.nav-dropdown-danger { color: var(--danger) !important; }
.nav-dropdown-danger:hover {
    background: rgba(255,107,107,0.1) !important;
    color: #fff !important;
}

/* ===== Mobile Dropdown Portal (lives on <body>) ===== */
.mobile-dropdown-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0);
    z-index: 99998;
    transition: background 0.25s ease;
}
.mobile-dropdown-overlay.show {
    background: rgba(0,0,0,0.55);
}
.nav-dropdown.mobile-portal {
    position: fixed !important;
    top: auto !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    max-height: 70vh;
    border-radius: 20px 20px 0 0 !important;
    background: #161624 !important;
    border: none !important;
    border-top: 1px solid rgba(255,255,255,0.12) !important;
    box-shadow: 0 -10px 50px rgba(0,0,0,0.6) !important;
    z-index: 1100 !important;
    opacity: 1 !important;
    visibility: visible !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    transform: translateY(100%);
    transition: transform 0.25s cubic-bezier(0.4,0,0.2,1);
}
.nav-dropdown.mobile-portal.show {
    transform: translateY(0);
}
.nav-dropdown.mobile-portal .nav-dropdown-header {
    padding: 22px 22px 14px;
    background: transparent;
    text-align: center;
}
.nav-dropdown.mobile-portal .nav-dropdown-greeting {
    font-size: 0.65rem;
    letter-spacing: 1.5px;
}
.nav-dropdown.mobile-portal .nav-dropdown-name {
    font-size: 1.05rem;
}
.nav-dropdown.mobile-portal .nav-dropdown-item {
    padding: 15px 22px;
    font-size: 0.92rem;
    gap: 12px;
}
.nav-dropdown.mobile-portal .nav-dropdown-item i {
    font-size: 1.1rem;
    width: 20px;
}
.nav-dropdown.mobile-portal .nav-dropdown-divider {
    margin: 2px 18px;
}

/* ===== Bottom Row: Tab Navigation ===== */
.nav-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 28px;
    border-top: 1px solid rgba(255,255,255,0.04);
}
.nav-links {
    display: flex;
    align-items: center;
    gap: 0;
}
.nav-pill {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 12px 18px;
    color: var(--text-muted);
    text-decoration: none;
    font-size: 0.82rem;
    font-weight: 500;
    white-space: nowrap;
    transition: color 0.2s ease, border-color 0.2s ease;
    position: relative;
    border-bottom: 2px solid transparent;
}
.nav-pill i {
    font-size: 0.9rem;
    opacity: 0.7;
    transition: all 0.25s ease;
}
.nav-pill:hover {
    color: var(--text-secondary);
}
.nav-pill:hover i { opacity: 1; transform: scale(1.1); }

/* Active tab indicator */
.nav-pill-active {
    color: #fff !important;
    font-weight: 600;
    border-bottom-color: var(--accent) !important;
}
.nav-pill-active i {
    opacity: 1 !important;
    color: var(--accent-light);
}
.nav-pill-active::after {
    display: none;
}

/* Membership pill - subtle accent */
.nav-pill-gem {
    color: var(--accent-light);
    border: none;
    background: none;
}
.nav-pill-gem i { color: var(--accent-light); opacity: 1; }
.nav-pill-gem:hover {
    color: #fff;
}

/* Store pill */
.nav-pill-store {
    color: var(--accent, #6c5ce7);
    font-weight: 700;
}
.nav-pill-store i { color: var(--accent, #6c5ce7); opacity: 1; }
.nav-pill-store:hover {
    color: var(--accent-light, #a29bfe);
}

/* "More" dropdown in navbar */
.nav-more-wrap {
    position: relative;
}
.nav-more-btn {
    background: none;
    border: none;
    cursor: pointer;
    font-family: inherit;
}
.nav-more-chev {
    font-size: 0.6rem !important;
    opacity: 0.5 !important;
    margin-left: 2px;
    transition: transform 0.25s ease;
}
.nav-more-wrap.open .nav-more-chev {
    transform: rotate(180deg);
}
.nav-more-dropdown {
    position: absolute;
    top: calc(100% + 6px);
    left: 50%;
    transform: translateX(-50%) translateY(8px);
    min-width: 220px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 8px 0;
    box-shadow: 0 16px 48px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.04);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
    z-index: 1001;
    backdrop-filter: blur(20px);
}
.nav-more-wrap.open .nav-more-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}
.nav-more-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 18px;
    color: var(--text-muted);
    text-decoration: none;
    font-size: 0.82rem;
    font-weight: 500;
    transition: all 0.15s ease;
    white-space: nowrap;
}
.nav-more-item i {
    font-size: 0.9rem;
    width: 18px;
    text-align: center;
    opacity: 0.6;
    transition: opacity 0.15s;
}
.nav-more-item:hover {
    color: #fff;
    background: rgba(255,255,255,0.05);
}
.nav-more-item:hover i { opacity: 1; }
.nav-more-item.active {
    color: var(--accent-light);
    font-weight: 600;
}
.nav-more-item.active i {
    color: var(--accent-light);
    opacity: 1;
}
.nav-more-gem {
    color: var(--accent-light) !important;
}
.nav-more-gem i { color: var(--accent-light) !important; opacity: 1 !important; }
.nav-more-gem:hover { background: rgba(108,92,231,0.1); }
.nav-more-divider {
    height: 1px;
    margin: 6px 14px;
    background: rgba(255,255,255,0.06);
}
.nav-more-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.4);
    z-index: 1001;
    opacity: 0;
    transition: opacity 0.2s ease;
}
.nav-more-overlay.show { opacity: 1; }

/* Stats badge */
.nav-stats {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}
.nav-stat {
    font-size: 0.7rem;
    color: var(--text-muted);
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 5px;
    opacity: 0.6;
}
.nav-stat i {
    font-size: 0.72rem;
    color: var(--accent);
}
.nav-stat-sep {
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: var(--text-muted);
    opacity: 0.3;
}


.container-narrow {
    max-width: 100%;
    width: 100%;
    margin: 0;
    padding: 0;
    background: transparent;
    border-radius: 0;
    box-shadow: none;
    border: none;
}

/* ===== SEARCH / FILTER ===== */
.search-controls {
    background: var(--bg-card);
    padding: 20px;
    border-radius: var(--radius);
    margin-bottom: 20px;
    border: 1px solid var(--border);
}

/* ===== TRACK LIBRARY INLINE FILTERS ===== */
.tl-filters {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 12px 16px;
    margin-bottom: 12px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    flex-wrap: wrap;
}
.tl-filter-group {
    display: flex;
    align-items: center;
    gap: 6px;
}
.tl-filter-label {
    color: var(--text-muted);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 4px;
}
.tl-filter-label i { font-size: 0.76rem; color: var(--accent-light); }
.tl-filter-input {
    width: 64px;
    height: 30px;
    padding: 0 8px;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 8px;
    color: #fff;
    font-size: 0.8rem;
    font-family: inherit;
    outline: none;
    transition: border-color 0.2s, background 0.2s;
    -moz-appearance: textfield;
}
.tl-filter-input::-webkit-inner-spin-button,
.tl-filter-input::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
.tl-filter-input:focus { border-color: rgba(108,92,231,0.4); background: rgba(108,92,231,0.06); }
.tl-filter-input::placeholder { color: var(--text-muted); font-size: 0.72rem; }
.tl-filter-sep { color: var(--text-muted); font-size: 0.72rem; }
.tl-filter-select {
    height: 30px;
    padding: 0 26px 0 10px;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 8px;
    color: #fff;
    font-size: 0.8rem;
    font-family: inherit;
    outline: none;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%23888' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 8px center;
    min-width: 80px;
}
.tl-filter-select:focus { border-color: rgba(108,92,231,0.4); background-color: rgba(108,92,231,0.06); }
.tl-filter-select option { background: var(--bg-card); color: #fff; }
.tl-filter-select optgroup { color: var(--text-muted); font-weight: 600; }
.tl-filter-apply {
    width: 32px;
    height: 30px;
    background: var(--gradient-1);
    border: none;
    border-radius: 8px;
    color: #fff;
    font-size: 0.78rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: filter 0.2s, transform 0.15s;
    flex-shrink: 0;
}
.tl-filter-apply:hover { filter: brightness(1.2); transform: translateY(-1px); }
.tl-filter-apply:active { transform: translateY(0); }
.tl-filter-clear {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: rgba(255,118,117,0.12);
    color: #ff7675;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.65rem;
    text-decoration: none;
    transition: background 0.2s, transform 0.15s;
    flex-shrink: 0;
}
.tl-filter-clear:hover { background: rgba(255,118,117,0.25); color: #fff; transform: scale(1.1); }

/* ===== ACTIVE FILTERS BAR ===== */
.active-filters-bar {
    background: var(--bg-card);
    padding: 14px 18px;
    border-radius: var(--radius-sm);
    border: 1px solid rgba(108,92,231,0.25);
    box-shadow: 0 0 20px rgba(108,92,231,0.08);
    margin-bottom: 16px;
    animation: filterBarIn 0.3s ease both;
}
@keyframes filterBarIn {
    from { opacity: 0; transform: translateY(-6px); }
    to { opacity: 1; transform: none; }
}
.active-filters-label {
    color: var(--text-secondary);
    font-weight: 700;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    white-space: nowrap;
    margin-right: 4px;
}
.filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 12px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    border: 1px solid;
    white-space: nowrap;
    transition: var(--transition);
}
.filter-chip i:first-child {
    font-size: 0.7rem;
}
.filter-chip-bpm {
    background: rgba(0,206,201,0.12);
    color: #00cec9;
    border-color: rgba(0,206,201,0.3);
}
.filter-chip-genre {
    background: rgba(108,92,231,0.12);
    color: var(--accent-light);
    border-color: rgba(108,92,231,0.3);
}
.filter-chip-sort {
    background: rgba(253,203,110,0.12);
    color: #fdcb6e;
    border-color: rgba(253,203,110,0.3);
}
.filter-chip-key {
    background: rgba(116,185,255,0.12);
    color: #74b9ff;
    border-color: rgba(116,185,255,0.3);
}
.filter-chip-version {
    background: rgba(255,118,117,0.12);
    color: #ff7675;
    border-color: rgba(255,118,117,0.3);
}
.filter-chip-close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: rgba(255,255,255,0.1);
    color: inherit;
    text-decoration: none;
    font-size: 0.55rem;
    margin-left: 2px;
    transition: var(--transition);
}
.filter-chip-close:hover {
    background: rgba(255,255,255,0.25);
    color: #fff;
    transform: scale(1.15);
}
.filter-clear-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 5px 14px;
    border-radius: 20px;
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--text-muted);
    background: rgba(255,255,255,0.05);
    border: 1px solid var(--border);
    text-decoration: none;
    transition: var(--transition);
    margin-left: auto;
}
.filter-clear-btn:hover {
    background: rgba(214,48,49,0.15);
    color: #ff7675;
    border-color: rgba(214,48,49,0.3);
}

.form-control-custom {
    background: var(--bg-secondary) !important;
    color: #ffffff !important;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 10px 15px;
    font-weight: 500;
    height: 42px;
    transition: var(--transition);
}

.form-control-custom:focus {
    background: var(--bg-card) !important;
    border-color: var(--accent);
    color: #ffffff !important;
    box-shadow: 0 0 0 3px var(--accent-glow);
}

.form-control-custom option {
    background: var(--bg-card) !important;
    color: #ffffff !important;
}

.form-control-custom::placeholder {
    color: var(--text-muted) !important;
    opacity: 1;
}

.btn-search {
    background: var(--gradient-1) !important;
    border: none;
    color: #fff !important;
    border-radius: var(--radius-sm);
    padding: 10px 15px;
    font-weight: 600;
    transition: var(--transition);
    height: 42px;
    min-width: 50px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
}

.btn-search:hover {
    opacity: 0.9;
    transform: translateY(-1px);
    box-shadow: 0 4px 15px var(--accent-glow);
}

.btn-reset {
    background: var(--bg-card) !important;
    border: 1px solid var(--border);
    color: var(--text-secondary) !important;
    border-radius: var(--radius-sm);
    padding: 10px 15px;
    font-weight: 600;
    transition: var(--transition);
    height: 42px;
    min-width: 50px;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
}

.btn-reset:hover {
    background: var(--bg-card-hover) !important;
    border-color: var(--accent);
    color: #fff !important;
    text-decoration: none;
}

.btn-outline-light {
    border: 1px solid var(--border);
    color: var(--text-secondary);
    transition: var(--transition);
}

.btn-outline-light:hover {
    background: var(--bg-card-hover) !important;
    border-color: var(--accent);
    color: #fff !important;
    transform: translateY(-1px);
}

/* ===== TRACK LIST (NEW) ===== */
@keyframes slideInRow {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: none; }
}
@keyframes detailSlideDown {
    from { opacity: 0; max-height: 0; transform: translateY(-8px); }
    to   { opacity: 1; max-height: 400px; transform: none; }
}
@keyframes detailSlideUp {
    from { opacity: 1; max-height: 400px; }
    to   { opacity: 0; max-height: 0; }
}
@keyframes fadeUpIn {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: none; }
}
@keyframes slideRight {
    from { opacity: 0; transform: translateX(-16px); }
    to   { opacity: 1; transform: none; }
}
@keyframes shimmer {
    0%   { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}
@keyframes glowPulse {
    0%, 100% { box-shadow: 0 0 8px rgba(108,92,231,0.25); }
    50%      { box-shadow: 0 0 20px rgba(108,92,231,0.45); }
}

.anim-slide-in  { animation: slideInRow 0.2s ease both; }
.anim-slide-in:nth-child(n+9) { animation: none; opacity: 1; } /* skip animation after 8th row */
.anim-fade-up   { animation: fadeUpIn 0.3s ease both; }
.anim-slide-right { animation: slideRight 0.2s ease both; }
.anim-slide-right:nth-child(n+6) { animation: none; opacity: 1; }

/* Respect user preference for reduced motion */
@media (prefers-reduced-motion: reduce) {
    .anim-slide-in, .anim-fade-up, .anim-slide-right { animation: none !important; opacity: 1; }
    .rpool-ad-shimmer { display: none !important; }
    * { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* ===== SKELETON LOADING ===== */
@keyframes skeletonShimmer {
    0%   { background-position: 100% 0; }
    100% { background-position: -100% 0; }
}
@keyframes skeletonRowIn {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: none; }
}
@keyframes skeletonFadeOut {
    from { opacity: 1; }
    to   { opacity: 0; }
}

/* Container: visible only when skeleton-active */
.skeleton-track-container {
    display: none;
}
.track-list.skeleton-active .skeleton-track-container {
    display: block;
}

/* Hide real content when skeleton is active */
.track-list.skeleton-active > .track-row,
.track-list.skeleton-active > .track-date-separator,
.track-list.skeleton-active > .track-detail-panel,
.track-list.skeleton-active > .track-empty {
    display: none !important;
}

/* Skeleton row — matches .track-row layout */
.skeleton-row {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    gap: 0;
    position: relative;
    animation: skeletonRowIn 0.4s ease both;
    opacity: 0;
}
.skeleton-row::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 16px;
    right: 16px;
    height: 1px;
    background: rgba(108,92,231,0.06);
}
.skeleton-row:last-child::after {
    display: none;
}

/* Skeleton cells — same widths as track-row children */
.sk-cell {
    flex-shrink: 0;
    display: flex;
    align-items: center;
}
.sk-num {
    width: 36px;
    justify-content: center;
}
.sk-play {
    width: 36px;
    justify-content: center;
}
.sk-main {
    flex: 1;
    min-width: 0;
    padding: 0 8px 0 4px;
    flex-direction: column;
    gap: 7px;
}
.sk-artist {
    width: 150px;
    padding: 0 6px;
}
.sk-meta {
    display: flex;
    align-items: center;
    gap: 8px;
}
.sk-acts {
    width: 70px;
    justify-content: center;
    gap: 6px;
}

/* Bone base — the shimmer element */
.sk-bone {
    background: rgba(255,255,255,0.04);
    position: relative;
    overflow: hidden;
    border-radius: 4px;
}
.sk-bone::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(108,92,231,0.15) 30%,
        rgba(162,155,254,0.25) 50%,
        rgba(108,92,231,0.15) 70%,
        transparent 100%
    );
    animation: skeletonShimmer 1.6s ease-in-out infinite;
    background-size: 200% 100%;
}

/* Bone variants — sized to match real content */
.sk-bone-num   { width: 18px; height: 12px; border-radius: 3px; }
.sk-circle     { width: 30px; height: 30px; border-radius: 50%; }
.sk-circle-sm  { width: 26px; height: 26px; border-radius: 50%; }
.sk-bar-title  { width: 65%; height: 14px; max-width: 220px; }
.sk-bar-subtitle { width: 40%; height: 10px; max-width: 140px; }
.sk-bar-artist { width: 80%; height: 12px; }
.sk-pill       { width: 80px; height: 22px; border-radius: 20px; }
.sk-bar-bpm    { width: 36px; height: 12px; }
.sk-bar-key    { width: 36px; height: 12px; }

/* Stagger shimmer for visual depth */
.skeleton-row:nth-child(even) .sk-bone::after {
    animation-delay: 0.15s;
}
.skeleton-row:nth-child(3n) .sk-bone::after {
    animation-delay: 0.3s;
}

/* Fade-out transition when hiding skeleton */
.skeleton-track-container.skeleton-fade-out {
    animation: skeletonFadeOut 0.3s ease forwards;
    pointer-events: none;
}

/* Sort bar shimmer while skeleton active */
.skeleton-active ~ .track-sort-bar,
.track-list.skeleton-active {
    position: relative;
}

/* Mobile: hide num + artist columns like real tracks */
@media (max-width: 768px) {
    .sk-num { display: none; }
    .sk-artist { display: none; }
    .sk-play { width: 32px; }
    .sk-meta { gap: 4px; }
    .sk-pill { width: 60px; height: 18px; }
    .sk-bar-bpm { width: 28px; height: 10px; }
    .sk-bar-key { width: 28px; height: 10px; }
    .sk-acts { width: 60px; gap: 4px; }
    .sk-circle-sm { width: 22px; height: 22px; }
    .sk-bar-title { max-width: 160px; }
    .sk-bar-subtitle { max-width: 100px; }
}

/* Sort Bar */
.track-sort-bar {
    display: flex;
    align-items: center;
    gap: 0;
    padding: 12px 16px;
    background: var(--bg-card);
    border-radius: 12px 12px 0 0;
    border: 1px solid var(--border);
    border-bottom: 1px solid rgba(108,92,231,0.12);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--text-muted);
    user-select: none;
}
.sort-col { padding: 0 6px; }
.sort-num { width: 36px; text-align: center; flex-shrink: 0; }
.sort-play { width: 36px; flex-shrink: 0; }
.sort-title { flex: 1; min-width: 0; padding-left: 4px; }
.sort-artist { width: 150px; flex-shrink: 0; }
.sort-genre { width: 120px; text-align: center; flex-shrink: 0; }
.sort-bpm { width: 60px; text-align: center; flex-shrink: 0; white-space: nowrap; }
.sort-key { width: 60px; text-align: center; flex-shrink: 0; white-space: nowrap; }
.sort-actions { width: 70px; text-align: center; flex-shrink: 0; }

.sortable-header {
    cursor: pointer;
    transition: color 0.2s ease;
}
.sortable-header:hover {
    color: var(--accent-light) !important;
}
.sortable-header i { margin-left: 3px; font-size: 0.65rem; }

/* Track List Container */
.track-list {
    border: 1px solid var(--border);
    border-top: none;
    border-radius: 0 0 12px 12px;
    overflow: visible;
    background: var(--bg-secondary);
}
.track-list > .track-row:last-child {
    border-radius: 0 0 12px 12px;
}

/* Empty State */
.track-empty {
    text-align: center;
    padding: 60px 20px;
    color: var(--text-muted);
}
.track-empty i { font-size: 3rem; margin-bottom: 12px; display: block; opacity: 0.55; }
.track-empty p { font-size: 0.95rem; margin: 0; }
.track-empty .empty-hint {
    font-size: 0.8rem;
    color: var(--text-muted);
    margin-top: 8px;
    opacity: 0.7;
}

/* Track Row */
.track-row {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 10px 16px;
    cursor: pointer;
    position: relative;
    transition: background 0.25s ease, transform 0.15s ease;
    border-bottom: none;
}
.track-row:nth-child(even) {
    background: rgba(108,92,231,0.03);
}
.track-row:focus-visible {
    outline: 2px solid var(--accent-light);
    outline-offset: -2px;
    z-index: 1;
}
.track-row::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 16px;
    right: 16px;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(108,92,231,0.25), rgba(162,155,254,0.15), transparent);
    transition: opacity 0.3s ease;
}
.track-row:last-child::after {
    display: none;
}
.track-row:hover::after {
    background: linear-gradient(90deg, transparent, rgba(108,92,231,0.45), rgba(162,155,254,0.3), transparent);
}
.track-row::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 3px;
    background: var(--accent);
    border-radius: 0 3px 3px 0;
    transform: scaleY(0);
    transition: transform 0.25s cubic-bezier(0.4,0,0.2,1);
}
.track-row:hover {
    background: rgba(108,92,231,0.06);
}
.track-row:hover::before {
    transform: scaleY(1);
}
.track-row.expanded {
    background: linear-gradient(135deg, rgba(108,92,231,0.12), rgba(162,155,254,0.06));
}
.track-row.expanded::before {
    transform: scaleY(1);
    background: var(--accent-light);
}
.track-row.expanded::after {
    background: linear-gradient(90deg, transparent, rgba(108,92,231,0.5), rgba(162,155,254,0.35), transparent);
}

/* Now Playing Row Highlight */
.track-row.now-playing {
    background: linear-gradient(135deg, rgba(108,92,231,0.14), rgba(162,155,254,0.07)) !important;
    border-left: 3px solid var(--accent-light);
    padding-left: calc(14px - 3px);
    position: relative;
}
.track-row.now-playing::before {
    transform: scaleY(1);
    background: var(--accent-light);
    opacity: 0;
}
.track-row.now-playing::after {
    background: linear-gradient(90deg, transparent, rgba(108,92,231,0.4), rgba(162,155,254,0.25), transparent);
}
.track-row.now-playing .track-row-num {
    color: var(--accent-light);
}
.track-row.now-playing .track-name {
    color: var(--accent-light);
}
@keyframes nowPlayingPulse {
    0%, 100% { border-left-color: var(--accent-light); }
    50% { border-left-color: var(--accent); }
}
.track-row.now-playing {
    animation: nowPlayingPulse 3s ease-in-out infinite;
}

/* Row Number */
.track-row-num {
    width: 36px;
    text-align: center;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-muted);
    flex-shrink: 0;
}

/* Play Button Column */
.track-row-play {
    width: 36px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Exclusive artwork thumbnail */
.track-row-thumb {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    margin-right: 4px;
}
.track-thumb-img {
    width: 40px;
    height: 40px;
    border-radius: 8px;
    object-fit: cover;
    border: 1px solid rgba(255,255,255,0.06);
}

/* Main Info */
.track-row-main {
    flex: 1;
    min-width: 0;
    padding: 0 8px 0 4px;
}
.track-row-title {
    display: flex;
    align-items: center;
    gap: 6px;
    font-weight: 600;
    font-size: 0.85rem;
    color: #fff;
    line-height: 1.3;
}
.track-row-subtitle {
    font-size: 0.72rem;
    color: var(--text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: 1px;
}
.track-name {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.track-ver-icon {
    color: var(--accent-light);
    font-size: 0.9rem;
    flex-shrink: 0;
}
.track-ver-badge {
    background: rgba(108,92,231,0.2);
    color: var(--accent-light);
    font-size: 0.6rem;
    font-weight: 700;
    padding: 2px 7px;
    border-radius: 10px;
    border: 1px solid rgba(108,92,231,0.3);
    white-space: nowrap;
    flex-shrink: 0;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}
.exc-tag {
    background: linear-gradient(135deg, #f39c12, #f1c40f);
    color: #000;
    font-size: 0.55rem;
    font-weight: 700;
    padding: 2px 7px;
    border-radius: 8px;
    white-space: nowrap;
    flex-shrink: 0;
    letter-spacing: 0.3px;
    margin-left: 4px;
}
.track-row-artist {
    width: 150px;
    flex-shrink: 0;
    font-size: 0.75rem;
    color: var(--text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.3;
    padding: 0 6px;
}
.artist-link {
    color: var(--text-secondary);
    text-decoration: none;
    transition: color 0.2s ease;
    position: relative;
}
.artist-link:hover {
    color: var(--accent-light);
    text-decoration: underline;
    text-underline-offset: 2px;
}
.artist-sep {
    color: var(--text-muted);
    font-size: 0.7rem;
}
.artist-unknown {
    color: var(--text-muted);
    font-style: italic;
}

/* Meta (genre, bpm, key) */
.track-row-meta {
    display: flex;
    align-items: center;
    gap: 0;
    flex-shrink: 0;
}
.track-genre-pill {
    background: rgba(108,92,231,0.12);
    color: var(--accent-light);
    font-size: 0.65rem;
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 20px;
    border: 1px solid rgba(108,92,231,0.2);
    white-space: nowrap;
    width: 120px;
    text-align: center;
    overflow: hidden;
    text-overflow: ellipsis;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.2s ease;
}
.track-genre-pill:hover {
    background: rgba(108,92,231,0.25);
    border-color: var(--accent);
    color: #fff;
    transform: translateY(-1px);
}
.track-bpm-key {
    display: contents;
}
.track-bpm, .track-key {
    font-size: 0.75rem;
    color: var(--text-secondary);
    width: 60px;
    text-align: center;
    font-weight: 500;
    padding: 0 4px;
}
.track-key {
    color: var(--accent-light);
    font-weight: 600;
}

/* Action Buttons */
.track-row-actions {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
    padding-left: 4px;
    width: 70px;
    justify-content: center;
}
.btn-action {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: 1px solid var(--border);
    background: var(--bg-card);
    color: var(--text-secondary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.82rem;
    cursor: pointer;
    transition: all 0.2s ease;
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
    padding: 0;
    min-width: 0;
    box-sizing: border-box;
}
.btn-action:hover {
    transform: scale(1.12);
    box-shadow: 0 4px 15px var(--accent-glow);
}
.btn-action-play {
    background: rgba(108,92,231,0.12);
    color: var(--accent-light);
    border-color: rgba(108,92,231,0.25);
    width: 32px;
    height: 32px;
    font-size: 0.9rem;
}
.btn-action-play.loading {
    pointer-events: none;
    position: relative;
}
.btn-action-play.loading i { visibility: hidden; }
.btn-action-play.loading::after {
    content: '';
    position: absolute;
    width: 16px; height: 16px;
    border: 2px solid rgba(108,92,231,0.3);
    border-top-color: var(--accent-light);
    border-radius: 50%;
    animation: btnLoadingSpin .6s linear infinite;
}
@keyframes btnLoadingSpin { to { transform: rotate(360deg); } }
.btn-action-play:hover {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent);
    transform: scale(1.15);
}
.btn-action-dl {
    background: transparent;
    color: var(--text-secondary);
    border-color: transparent;
}
.btn-action-dl:hover {
    color: var(--accent-light);
    background: rgba(108,92,231,0.1);
    border-color: rgba(108,92,231,0.2);
}
.btn-action-lock {
    color: var(--text-muted);
    opacity: 0.5;
    cursor: not-allowed;
}
.btn-action.played {
    background: rgba(0,184,148,0.12) !important;
    border-color: var(--success) !important;
    color: var(--success) !important;
}
.btn-action.played:hover {
    background: var(--success) !important;
    color: #fff !important;
}

/* Detail Panel */
.track-detail-panel {
    background: linear-gradient(180deg, rgba(108,92,231,0.06) 0%, var(--bg-secondary) 100%);
    border-bottom: 1px solid rgba(108,92,231,0.15);
    overflow: hidden;
}
.detail-inner {
    display: flex;
    gap: 24px;
    padding: 20px 24px 20px 56px;
}
.detail-info {
    flex: 1;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 14px;
}
.detail-field {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.detail-label {
    font-size: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--text-muted);
    font-weight: 700;
    margin-bottom: 4px;
}
.detail-value {
    font-size: 0.82rem;
    color: #fff;
    font-weight: 500;
}
.detail-value .artist-link {
    color: var(--accent-light);
}
.detail-value .artist-link:hover {
    color: #fff;
}
.detail-genre-link {
    color: var(--accent-light);
    text-decoration: none;
    transition: color 0.2s ease;
}
.detail-genre-link:hover {
    color: #fff;
    text-decoration: underline;
    text-underline-offset: 2px;
}
.detail-actions-panel {
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex-shrink: 0;
    justify-content: center;
}
.btn-detail {
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: #fff;
    padding: 8px 18px;
    border-radius: 8px;
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
}
.btn-detail:hover {
    background: var(--accent);
    border-color: var(--accent);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px var(--accent-glow);
}
.btn-detail-dl {
    background: var(--gradient-1);
    border: none;
}
.btn-detail-dl:hover {
    opacity: 0.9;
    transform: translateY(-1px);
}
.btn-detail.played {
    border-color: var(--success);
    color: var(--success);
}

/* ===== PAGINATION ===== */
.pagination-wrapper {
    background: var(--bg-card);
    padding: 18px 24px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    margin-top: 20px;
    margin-bottom: 80px;
}

.pagination-custom {
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 3px;
}

.pagination-custom .page-item {
    margin: 0;
}

.pagination-custom .page-link {
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    border-radius: 8px;
    padding: 0;
    font-weight: 500;
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    font-size: 0.85rem;
    transition: all 0.25s cubic-bezier(0.4,0,0.2,1);
    line-height: 1;
}

.pagination-custom .page-text {
    width: auto !important;
    min-width: 50px;
    padding: 0 12px !important;
    font-size: 0.8rem;
}

.pagination-custom .page-number {
    width: 40px;
    height: 40px;
    padding: 0;
}

.pagination-custom .page-link:hover {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px var(--accent-glow);
}

.pagination-custom .page-item.active .page-link {
    background: var(--gradient-1);
    border-color: var(--accent-light);
    color: #fff;
    box-shadow: 0 4px 15px var(--accent-glow);
    font-weight: 600;
}

.pagination-custom .page-item.disabled .page-link {
    background: var(--bg-secondary);
    border-color: var(--border);
    color: var(--text-muted);
    cursor: not-allowed;
    opacity: 0.5;
}

.pagination-custom .page-item.disabled .page-link:hover {
    background: var(--bg-secondary);
    border-color: var(--border);
    color: var(--text-muted);
    transform: none;
    box-shadow: none;
}

.pagination-info {
    color: var(--text-secondary);
    font-weight: 500;
    margin: 0;
    font-size: 0.9rem;
}

/* ===== BUTTONS ===== */
.btn-play {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 50%;
    width: 34px;
    height: 34px;
    color: var(--accent-light);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: var(--transition);
}

.btn-play:hover {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent);
    box-shadow: 0 2px 10px var(--accent-glow);
}

.btn-download {
    background: var(--gradient-1) !important;
    border: none;
    color: #fff !important;
    border-radius: 20px;
    padding: 8px 18px;
    font-size: 0.8rem;
    text-decoration: none;
    display: inline-block;
    font-weight: 600;
    min-width: 110px;
    max-width: 100%;
    text-align: center;
    transition: var(--transition);
}

.btn-download:hover {
    opacity: 0.9;
    transform: translateY(-1px);
    box-shadow: 0 4px 15px var(--accent-glow);
    color: #fff !important;
}

/* ===== GENRE NAV ===== */
.genre-nav {
    background: var(--bg-card);
    padding: 24px;
    border-radius: var(--radius);
    border: 1px solid var(--border);
    margin-bottom: 20px;
}

.genre-nav h4 {
    margin-bottom: 0;
    font-weight: 700;
    color: var(--accent-light) !important;
}

.genre-see-all {
    color: var(--accent-light);
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    transition: var(--transition);
}
.genre-see-all:hover {
    color: #fff;
    transform: translateX(4px);
}

/* Current Genre Chip */
.current-genre-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    border-radius: 24px;
    background: linear-gradient(135deg, rgba(108,92,231,0.18), rgba(162,155,254,0.1));
    border: 1px solid rgba(108,92,231,0.35);
    color: var(--accent-light);
    font-size: 0.82rem;
    font-weight: 600;
}
.current-genre-chip i.bi-funnel-fill {
    font-size: 0.75rem;
    color: var(--accent-light);
}
.current-genre-chip strong {
    color: #fff;
}
.current-genre-clear {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: rgba(255,255,255,0.1);
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 0.6rem;
    transition: var(--transition);
    margin-left: 4px;
}
.current-genre-clear:hover {
    background: rgba(214,48,49,0.3);
    color: #ff7675;
    transform: scale(1.15);
}

/* Gig Context Chips */
.gig-chips-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.gig-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border-radius: 20px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    font-size: 0.82rem;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.2s ease;
    cursor: pointer;
}
.gig-chip:hover {
    background: rgba(108, 92, 231, 0.15);
    border-color: var(--accent);
    color: var(--accent-light);
    transform: translateY(-1px);
}
.gig-chip i {
    font-size: 1rem;
}
.gig-chip small {
    opacity: 0.6;
    font-size: 0.72rem;
}
.gig-chip-active {
    background: linear-gradient(135deg, rgba(108, 92, 231, 0.25), rgba(162, 155, 254, 0.15));
    border-color: var(--accent);
    color: var(--accent-light);
    box-shadow: 0 0 12px rgba(108, 92, 231, 0.2);
}
.gig-chip-clear {
    background: rgba(255, 107, 107, 0.1);
    border-color: rgba(255, 107, 107, 0.3);
    color: #ff6b6b;
}
.gig-chip-clear:hover {
    background: rgba(255, 107, 107, 0.2);
    border-color: #ff6b6b;
    color: #ff6b6b;
}

/* Sub-genre tag on tracks */
.sub-genre-tag {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 10px;
    background: rgba(108, 92, 231, 0.12);
    color: var(--accent-light);
    font-size: 0.7rem;
    font-weight: 500;
    margin-left: 6px;
    text-decoration: none;
    transition: background 0.2s;
}
.sub-genre-tag:hover {
    background: rgba(108, 92, 231, 0.25);
    color: var(--accent-light);
}

/* Genre Card Grid */
.genre-card-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 12px;
}

.genre-card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 20px 10px 16px;
    border-radius: var(--radius-sm);
    background: linear-gradient(145deg, rgba(255,255,255,0.03) 0%, rgba(255,255,255,0.01) 100%);
    border: 1px solid var(--border);
    text-decoration: none;
    color: var(--text-secondary);
    transition: var(--transition);
    overflow: hidden;
    text-align: center;
    cursor: pointer;
}
.genre-card::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(145deg, var(--gc-from), var(--gc-to));
    opacity: 0;
    transition: opacity .3s ease;
    z-index: 0;
}
.genre-card:hover::before { opacity: .15; }
.genre-card:hover {
    border-color: var(--gc-from);
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.3), 0 0 20px color-mix(in srgb, var(--gc-from) 30%, transparent);
    text-decoration: none;
    color: #fff;
}
.genre-card-active {
    border-color: var(--gc-from) !important;
    background: linear-gradient(145deg, color-mix(in srgb, var(--gc-from) 18%, transparent), color-mix(in srgb, var(--gc-to) 8%, transparent)) !important;
    box-shadow: 0 0 20px color-mix(in srgb, var(--gc-from) 25%, transparent);
}
.genre-card-active .genre-card-name { color: #fff; }

.genre-card-icon {
    position: relative;
    z-index: 1;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    background: linear-gradient(135deg, var(--gc-from), var(--gc-to));
    color: #fff;
    margin-bottom: 10px;
    box-shadow: 0 4px 16px color-mix(in srgb, var(--gc-from) 40%, transparent);
}
.genre-card-name {
    position: relative;
    z-index: 1;
    font-weight: 700;
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}
.genre-card-count {
    position: relative;
    z-index: 1;
    font-size: 0.7rem;
    color: var(--text-muted);
    font-weight: 500;
}

.dropdown-menu-dark {
    background: var(--bg-card) !important;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
}

.dropdown-menu-dark .dropdown-item {
    color: var(--text-secondary);
    padding: 8px 16px;
    font-size: 0.85rem;
    transition: var(--transition);
}

.dropdown-menu-dark .dropdown-item:hover {
    background: rgba(108,92,231,0.15);
    color: var(--accent-light);
}

.dropdown-menu-dark .dropdown-item.active {
    background: var(--gradient-1);
    color: #fff;
}

.current-genre-display {
    margin-top: 10px;
}

.current-genre-display .badge {
    background: var(--gradient-1) !important;
    padding: 8px 12px;
    font-size: 0.8rem;
    border-radius: 8px;
}

.current-genre-display .badge a {
    color: #fff;
    text-decoration: none;
    opacity: 0.8;
    margin-left: 8px;
    font-weight: bold;
}

.current-genre-display .badge a:hover {
    opacity: 1;
}

.date-display {
    text-align: right;
    color: var(--text-secondary);
    font-size: 0.85rem;
    font-weight: 500;
    letter-spacing: 1px;
}

/* ===== SIDEBAR (NEW) ===== */
.sidebar-card {
    background: var(--bg-card);
    border-radius: 14px;
    border: 1px solid var(--border);
    padding: 0;
    margin-bottom: 24px;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    position: relative;
}
.sidebar-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 40px rgba(0,0,0,0.4);
}
.sidebar-card::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--gradient-1);
    transform: scaleX(0);
    transition: transform 0.4s ease;
    transform-origin: left;
}
.sidebar-card:hover::after {
    transform: scaleX(1);
}
.sidebar-popular::after {
    background: linear-gradient(90deg, var(--warning), #f0932b);
}

.sidebar-card-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 16px 12px;
    border-bottom: 1px solid var(--border);
}
.sidebar-icon-wrap {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    flex-shrink: 0;
}
.sidebar-icon-recent {
    background: linear-gradient(135deg, rgba(108,92,231,0.2), rgba(162,155,254,0.15));
    color: var(--accent-light);
    border: 1px solid rgba(108,92,231,0.3);
}
.sidebar-icon-fire {
    background: linear-gradient(135deg, rgba(254,202,87,0.2), rgba(240,147,43,0.15));
    color: var(--warning);
    border: 1px solid rgba(254,202,87,0.3);
}
.sidebar-icon-exc {
    background: linear-gradient(135deg, rgba(255,107,129,0.2), rgba(238,82,83,0.15));
    color: #ff6b81;
    border: 1px solid rgba(255,107,129,0.3);
}
.sidebar-card-title {
    font-size: 0.85rem;
    font-weight: 700;
    color: #fff;
    margin: 0;
    line-height: 1.2;
}
.sidebar-card-sub {
    font-size: 0.65rem;
    color: var(--text-muted);
    margin: 2px 0 0;
}

/* Sidebar Track List */
.sidebar-track-list {
    padding: 8px 0;
}
.sidebar-track {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 14px;
    transition: background 0.2s ease, padding-left 0.2s ease;
    position: relative;
    cursor: default;
}
.sidebar-track:hover {
    background: rgba(108,92,231,0.05);
    padding-left: 18px;
}
.sidebar-popular .sidebar-track:hover {
    background: rgba(254,202,87,0.04);
}

.sidebar-rank {
    width: 22px;
    height: 22px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.65rem;
    font-weight: 800;
    flex-shrink: 0;
    transition: transform 0.2s ease;
}
.sidebar-track:hover .sidebar-rank {
    transform: scale(1.15);
}
.sidebar-rank-new {
    background: rgba(108,92,231,0.15);
    color: var(--accent-light);
    border: 1px solid rgba(108,92,231,0.25);
}
.sidebar-rank-top {
    background: linear-gradient(135deg, var(--warning), #f0932b);
    color: #000;
    border: none;
    box-shadow: 0 2px 8px rgba(254,202,87,0.3);
}
.sidebar-rank-pop {
    background: rgba(254,202,87,0.1);
    color: var(--warning);
    border: 1px solid rgba(254,202,87,0.2);
}

.sidebar-track-info {
    flex: 1;
    min-width: 0;
}
.sidebar-track-name {
    font-size: 0.72rem;
    font-weight: 600;
    color: #fff;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.sidebar-track-meta {
    font-size: 0.62rem;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 1px;
}
.sidebar-date {
    color: var(--text-muted);
    font-size: 0.58rem;
}
.sidebar-dl-count {
    color: var(--accent-light);
    font-weight: 700;
    font-size: 0.58rem;
    display: inline-flex;
    align-items: center;
    gap: 2px;
}
.sidebar-dl-count i { font-size: 0.55rem; }

/* Sidebar Action Buttons */
.sidebar-track-actions {
    display: flex;
    gap: 4px;
    flex-shrink: 0;
    opacity: 0.6;
    transition: opacity 0.2s ease;
}
.sidebar-track:hover .sidebar-track-actions {
    opacity: 1;
}
.sidebar-btn {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    border: 1px solid var(--border);
    background: var(--bg-secondary);
    color: var(--text-secondary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.6rem;
    cursor: pointer;
    transition: all 0.2s ease;
}
.sidebar-btn-play:hover {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent);
    transform: scale(1.15);
    box-shadow: 0 3px 10px var(--accent-glow);
}
.sidebar-btn-dl:hover {
    background: rgba(108,92,231,0.15);
    color: var(--accent-light);
    border-color: rgba(108,92,231,0.3);
    transform: scale(1.1);
}
.sidebar-btn-lock {
    color: var(--text-muted);
    opacity: 0.4;
    cursor: not-allowed;
}
.sidebar-btn.played {
    background: rgba(0,184,148,0.12) !important;
    border-color: var(--success) !important;
    color: var(--success) !important;
}
.sidebar-btn.played:hover {
    background: var(--success) !important;
    color: #fff !important;
}

/* Sidebar skeleton loading */
@keyframes skeleton-shimmer {
    0% { background-position: -200px 0; }
    100% { background-position: calc(200px + 100%) 0; }
}
.sidebar-skeleton {
    pointer-events: none;
}
.sidebar-skeleton .skeleton-rank,
.sidebar-skeleton .skeleton-line,
.sidebar-skeleton .skeleton-btn {
    background: linear-gradient(90deg, rgba(255,255,255,0.04) 25%, rgba(255,255,255,0.08) 50%, rgba(255,255,255,0.04) 75%);
    background-size: 200px 100%;
    animation: skeleton-shimmer 1.4s ease-in-out infinite;
    border-radius: 6px;
}
.skeleton-rank {
    width: 28px;
    height: 28px;
    border-radius: 8px !important;
    flex-shrink: 0;
}
.skeleton-line.skeleton-title {
    width: 75%;
    height: 13px;
    margin-bottom: 6px;
}
.skeleton-line.skeleton-meta {
    width: 50%;
    height: 10px;
}
.skeleton-btn {
    width: 28px;
    height: 28px;
    border-radius: 50% !important;
}

/* ===== CHARTS PREVIEW (sidebar) ===== */
.monthly-charts-preview,
.most-popular-preview {
    background: var(--bg-card);
    border-radius: var(--radius);
    padding: 25px;
    margin-bottom: 20px;
    border: 1px solid var(--border);
    transition: var(--transition);
}

.monthly-charts-preview:hover,
.most-popular-preview:hover {
    transform: translateY(-3px);
    box-shadow: 0 5px 25px rgba(0,0,0,0.3);
    border-color: var(--border-hover);
}

.chart-preview-item,
.popular-preview-item {
    transition: var(--transition);
    border-left: 3px solid var(--accent);
}

.chart-preview-item:hover,
.popular-preview-item:hover {
    background: rgba(108,92,231,0.08) !important;
    transform: translateX(3px);
    border-left-color: var(--accent-light);
}

.popular-preview-item {
    border-left-color: var(--warning) !important;
}

.popular-preview-item:hover {
    border-left-color: #f0d78c !important;
    background: rgba(254,202,87,0.06) !important;
}

.chart-position-mini,
.popular-position-mini {
    flex-shrink: 0;
}

.chart-title-mini,
.popular-title-mini {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.chart-artist-mini,
.popular-artist-mini {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ===== LOADING ===== */
.loading-overlay {
    position: fixed;
    inset: 0;
    background: rgba(10, 10, 18, 0.97);
    z-index: 1100;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s ease, visibility .3s ease;
}
.loading-overlay.show {
    opacity: 1;
    visibility: visible;
}
.loading-overlay.hide-out {
    opacity: 0;
    visibility: hidden;
}
.loading-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 18px;
}

/* Vinyl disc loader */
.rpool-vinyl-loader {
    position: relative;
    width: 90px;
    height: 90px;
}
.vinyl-disc {
    width: 90px;
    height: 90px;
    border-radius: 50%;
    background: conic-gradient(from 0deg, #1a1a2e, #2d2d4a, #1a1a2e, #2d2d4a, #1a1a2e);
    box-shadow: 0 0 0 3px rgba(108, 92, 231, .25), inset 0 0 0 18px rgba(0,0,0,.5);
    animation: vinylSpin 1.6s linear infinite;
    will-change: transform;
    display: flex;
    align-items: center;
    justify-content: center;
}
.vinyl-label {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent, #6c5ce7), #a29bfe);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 0 12px rgba(108, 92, 231, .5);
    z-index: 1;
}
.vinyl-label i {
    font-size: 18px;
    color: #fff;
}
.vinyl-glow {
    position: absolute;
    inset: -8px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(108, 92, 231, .2) 0%, transparent 70%);
    opacity: .6;
}

.loading-text {
    color: #fff;
    font-weight: 800;
    font-size: 1.3rem;
    letter-spacing: 4px;
    opacity: .9;
}

/* Bouncing dots */
.loading-dots {
    display: flex;
    gap: 6px;
}
.loading-dots span {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--accent, #6c5ce7);
    animation: dotBounce .6s ease-in-out infinite;
}
.loading-dots span:nth-child(2) { animation-delay: .15s; }
.loading-dots span:nth-child(3) { animation-delay: .3s; }

@keyframes vinylSpin {
    0%   { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}
@keyframes vinylPulse {
    0%, 100% { opacity: .4; transform: scale(1); }
    50%      { opacity: .8; transform: scale(1.1); }
}
@keyframes dotBounce {
    0%, 80%, 100% { transform: translateY(0); opacity: .4; }
    40%           { transform: translateY(-8px); opacity: 1; }
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* ===== MODERN BTN STYLES ===== */
.btn-play-modern, .btn-download-modern {
    width: 40px;
    height: 40px;
    border-radius: 50% !important;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    font-size: 16px;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}

.btn-play-modern {
    background: var(--gradient-1);
    box-shadow: 0 4px 15px var(--accent-glow);
}

.btn-play-modern:hover {
    transform: scale(1.1);
    box-shadow: 0 6px 25px var(--accent-glow);
}

.btn-download-modern {
    background: var(--gradient-1);
    box-shadow: 0 4px 15px var(--accent-glow);
}

.btn-download-modern:hover {
    transform: scale(1.1);
    box-shadow: 0 6px 25px var(--accent-glow);
}

.play-icon, .download-icon {
    color: white;
    font-size: 16px;
}

/* Disabled Download */
.btn-download:disabled,
.btn-download-modern:disabled,
button[onclick*="downloadTrack"]:disabled {
    background: var(--bg-card) !important;
    cursor: not-allowed !important;
    opacity: 0.5 !important;
    transform: none !important;
    box-shadow: none !important;
    pointer-events: none;
}

/* Download in progress */
.download-in-progress {
    position: relative;
    overflow: hidden;
}

.download-in-progress::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
    animation: downloadProgress 2s infinite;
}

@keyframes downloadProgress {
    0% { left: -100%; }
    100% { left: 100%; }
}

/* Spinning animation for Bootstrap Icons */
.spinning {
    display: inline-block;
    animation: spinIcon 1s linear infinite;
}

@keyframes spinIcon {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* ===== MUSIC PLAYER WIDGET — BOTTOM BAR ===== */
.music-player-widget {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    background: #181818;
    border-top: 1px solid rgba(255,255,255,0.06);
    z-index: 9999;
    transform: translateY(100%);
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 -2px 20px rgba(0,0,0,0.6);
    /* Safe area for iOS notch / home indicator */
    padding-bottom: env(safe-area-inset-bottom, 0px);
    -webkit-transform: translateY(100%);
}
.music-player-widget.show {
    transform: translateY(0) !important;
    -webkit-transform: translateY(0) !important;
    visibility: visible !important;
    opacity: 1 !important;
}
body.player-active {
    padding-bottom: calc(72px + env(safe-area-inset-bottom, 0px)) !important;
}

.player-bar-inner {
    position: relative;
}

/* ---- Main row ---- */
.player-bar-controls {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 0 16px;
    height: 64px;
}

/* ---- Left: Artwork + Info + Version ---- */
.player-bar-track {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
    min-width: 0;
    max-width: 280px;
}
.player-artwork {
    width: 42px;
    height: 42px;
    border-radius: 4px;
    background: rgba(255,255,255,0.06);
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,0.3);
    font-size: 18px;
    flex-shrink: 0;
    overflow: hidden;
}
.player-artwork.has-image {
    background: #000;
}
.player-artwork img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.player-bar-info {
    min-width: 0;
    flex-shrink: 1;
}
.music-player-widget .current-track-title {
    font-size: 0.82rem;
    font-weight: 600;
    color: #fff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.35;
    margin: 0;
}
.music-player-widget .current-track-artist {
    font-size: 0.7rem;
    color: rgba(255,255,255,0.4);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.3;
    margin: 0;
}

/* Version badge */
.player-version-badge {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 8px;
    border-radius: 3px;
    border: 1px solid rgba(255,255,255,0.15);
    background: rgba(255,255,255,0.06);
    color: rgba(255,255,255,0.7);
    font-size: 0.65rem;
    font-weight: 500;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    transition: all 0.15s;
}
.player-version-badge:hover {
    border-color: rgba(255,255,255,0.3);
    color: #fff;
}

/* ---- Center: Transport ---- */
.player-bar-transport {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
}
.transport-btn {
    background: none;
    border: none;
    color: rgba(255,255,255,0.7);
    width: 34px;
    height: 34px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    cursor: pointer;
    border-radius: 50%;
    transition: all 0.15s;
}
.transport-btn:hover {
    color: #fff;
    background: rgba(255,255,255,0.06);
}
.transport-btn.transport-play {
    width: 38px;
    height: 38px;
    font-size: 22px;
    color: #fff;
}
.transport-btn.transport-play:hover {
    transform: scale(1.05);
}
.transport-btn.playing {
    color: #fff;
}

/* ---- Waveform area ---- */
.player-bar-waveform-area {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
    min-width: 0;
}
.player-time {
    font-size: 0.72rem;
    color: rgba(255,255,255,0.45);
    font-variant-numeric: tabular-nums;
    font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
    flex-shrink: 0;
    letter-spacing: 0.3px;
    min-width: 36px;
    text-align: center;
}

/* ---- Waveform ---- */
.waveform-wrapper {
    position: relative;
    flex: 1;
    min-width: 0;
    height: 40px;
    background: transparent;
    border-radius: 2px;
    overflow: hidden;
    cursor: pointer;
}
.waveform-canvas {
    display: block;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 0.4s ease;
}
.waveform-canvas.loaded {
    opacity: 1;
}

/* Progress overlay — hidden, canvas handles coloring */
.waveform-progress {
    display: none;
}

/* Playhead — orange/red vertical line */
.waveform-playhead {
    position: absolute;
    top: 0;
    left: 0%;
    width: 2px;
    height: 100%;
    background: #e8480c;
    pointer-events: none;
    transition: left 0.15s linear;
    box-shadow: 0 0 6px rgba(232,72,12,0.6);
    z-index: 2;
}

/* Hover cursor */
.waveform-cursor {
    position: absolute;
    top: 0;
    left: 0;
    width: 1px;
    height: 100%;
    background: rgba(255,255,255,0.35);
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.12s;
    z-index: 1;
}
.waveform-wrapper:hover .waveform-cursor {
    opacity: 1;
}

/* Hover time tooltip */
.waveform-wrapper::after {
    content: attr(data-hover-time);
    position: absolute;
    top: -26px;
    left: var(--hover-x, 50%);
    transform: translateX(-50%);
    background: rgba(0,0,0,0.85);
    color: #fff;
    font-size: 0.68rem;
    font-weight: 600;
    padding: 2px 7px;
    border-radius: 4px;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.12s;
    z-index: 3;
    font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
}
.waveform-wrapper:hover::after {
    opacity: 1;
}

/* Loading shimmer */
.waveform-loading {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s;
}
.waveform-loading.active {
    opacity: 1;
}
.waveform-loading-shimmer {
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.03) 50%, transparent 100%);
    background-size: 200% 100%;
    animation: waveformShimmer 1.5s infinite;
}

/* ---- Volume ---- */
.player-bar-volume {
    display: flex;
    align-items: center;
    gap: 2px;
    flex-shrink: 0;
}
.player-bar-volume .transport-btn {
    width: 30px;
    height: 30px;
    font-size: 15px;
    color: rgba(255,255,255,0.5);
}
.player-bar-volume .transport-btn:hover {
    color: #fff;
    background: none;
}
.volume-slider {
    width: 70px;
    height: 3px;
    -webkit-appearance: none;
    appearance: none;
    background: rgba(255,255,255,0.2);
    border-radius: 2px;
    outline: none;
    cursor: pointer;
}
.volume-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #fff;
    cursor: pointer;
    border: none;
}
.volume-slider::-moz-range-thumb {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #fff;
    cursor: pointer;
    border: none;
}

/* ---- Right actions ---- */
.player-bar-actions {
    display: flex;
    align-items: center;
    gap: 2px;
    flex-shrink: 0;
}
.action-btn {
    background: none;
    border: none;
    color: rgba(255,255,255,0.45);
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    cursor: pointer;
    border-radius: 4px;
    transition: all 0.15s;
}
.action-btn:hover {
    color: #fff;
    background: rgba(255,255,255,0.06);
}
.action-btn.is-fav {
    color: #ff6b6b;
}
.action-btn.is-fav:hover {
    color: #ff4444;
}
.action-btn-collapse {
    color: rgba(255,255,255,0.35);
}
.action-btn-collapse:hover {
    color: #fff;
}

/* ---- Player Dropdown Menu ---- */
.player-more-wrapper {
    position: relative;
}
.player-dropdown {
    position: absolute;
    bottom: calc(100% + 8px);
    right: 0;
    min-width: 210px;
    background: #1e1e2e;
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 10px;
    padding: 6px 0;
    box-shadow: 0 8px 32px rgba(0,0,0,0.6);
    opacity: 0;
    visibility: hidden;
    transform: translateY(6px);
    transition: all 0.18s ease;
    z-index: 1000;
}
.player-dropdown.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.player-dropdown-item {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 9px 16px;
    background: none;
    border: none;
    color: rgba(255,255,255,0.8);
    font-size: 0.82rem;
    cursor: pointer;
    transition: all 0.12s;
    text-align: left;
    white-space: nowrap;
}
.player-dropdown-item:hover {
    background: rgba(108,92,231,0.15);
    color: #fff;
}
.player-dropdown-item i {
    font-size: 1rem;
    width: 20px;
    text-align: center;
    color: rgba(108,92,231,0.85);
    flex-shrink: 0;
}
.player-dropdown-item:hover i {
    color: #6c5ce7;
}

@keyframes waveformShimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ===== Bottom bar responsive ===== */
@media (max-width: 768px) {
    .player-bar-controls {
        gap: 8px;
        padding: 0 10px;
        height: 56px;
    }
    .player-bar-track {
        max-width: 160px;
    }
    .player-artwork {
        width: 36px;
        height: 36px;
    }
    .music-player-widget .current-track-title {
        font-size: 0.75rem;
    }
    .music-player-widget .current-track-artist {
        font-size: 0.62rem;
    }
    .player-version-badge {
        display: none;
    }
    .player-bar-waveform-area {
        display: none !important;
    }
    .player-bar-volume {
        display: none !important;
    }
    #playerDownloadBtn,
    #playerFavBtn {
        display: flex !important;
        width: 32px;
        height: 32px;
        font-size: 16px;
    }
    .transport-btn {
        width: 28px;
        height: 28px;
        font-size: 15px;
    }
    .transport-btn.transport-play {
        width: 32px;
        height: 32px;
        font-size: 18px;
    }
    .volume-slider {
        display: none;
    }
    .player-time {
        font-size: 0.62rem;
        min-width: 28px;
    }
    .music-player-widget {
        z-index: 1100 !important;
    }
    .music-player-widget.show {
        display: block !important;
        transform: translateY(0) !important;
        -webkit-transform: translateY(0) !important;
    }
    body.player-active {
        padding-bottom: calc(60px + env(safe-area-inset-bottom, 0px)) !important;
    }
}
@media (max-width: 575px) {
    .player-bar-track {
        max-width: 120px;
    }
    .player-bar-transport {
        gap: 0;
    }
    .player-bar-waveform-area {
        gap: 6px;
    }
    .player-bar-actions > .action-btn {
        display: none;
    }
    #playerDownloadBtn,
    #playerFavBtn {
        display: flex !important;
    }
    .player-more-wrapper,
    .action-btn-collapse {
        display: flex !important;
    }
}

/* ===== Smart Search: Did You Mean Banner ===== */
.fuzzy-search-banner {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    margin-bottom: 12px;
    background: rgba(108,92,231,0.08);
    border: 1px solid rgba(108,92,231,0.2);
    border-radius: 10px;
    font-size: 0.85rem;
    color: rgba(255,255,255,0.8);
    animation: fuzzySlide 0.4s ease;
}
.fuzzy-search-banner i {
    color: var(--accent-light);
    font-size: 1.1rem;
}
.fuzzy-search-banner strong {
    color: var(--accent-light);
}
.fuzzy-original {
    color: rgba(255,255,255,0.4);
}
.fuzzy-original s {
    color: rgba(255,255,255,0.35);
}
.fuzzy-original-link {
    margin-left: auto;
    color: var(--accent-light);
    text-decoration: none;
    font-size: 0.78rem;
    font-weight: 600;
    opacity: 0.7;
    transition: opacity 0.2s;
    white-space: nowrap;
}
.fuzzy-original-link:hover {
    opacity: 1;
    text-decoration: underline;
}
@keyframes fuzzySlide {
    from { opacity: 0; transform: translateY(-8px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ===== Interactive Onboarding Tour ===== */
.onboarding-overlay {
    position: fixed;
    inset: 0;
    z-index: 99990;
    background: transparent;
    pointer-events: auto;
}
.onboarding-spotlight {
    position: fixed;
    z-index: 99991;
    border-radius: 12px;
    box-shadow: 0 0 0 9999px rgba(0,0,0,0.7);
    border: 2px solid var(--accent);
    transition: top 0.4s ease, left 0.4s ease, width 0.4s ease, height 0.4s ease;
    pointer-events: none;
}
.onboarding-tooltip {
    position: fixed;
    z-index: 99992;
    width: 340px;
    max-width: calc(100vw - 24px);
    background: linear-gradient(135deg, #1a1a2e 0%, #16162a 100%);
    border: 1px solid rgba(108,92,231,0.4);
    border-radius: 16px;
    padding: 20px;
    box-shadow: 0 12px 40px rgba(0,0,0,0.6), 0 0 30px rgba(108,92,231,0.15);
    animation: onboardingFadeIn 0.3s ease;
}
.onboarding-tooltip kbd {
    display: inline-block;
    background: rgba(108,92,231,0.15);
    border: 1px solid rgba(108,92,231,0.3);
    border-radius: 4px;
    padding: 1px 6px;
    font-size: 0.75rem;
    color: var(--accent-light);
    font-family: inherit;
}
.onboarding-step-badge {
    display: inline-block;
    background: rgba(108,92,231,0.15);
    color: var(--accent-light);
    font-size: 0.72rem;
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 20px;
    margin-bottom: 8px;
    letter-spacing: 0.5px;
}
.onboarding-title {
    font-size: 1.05rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 6px;
}
.onboarding-desc {
    font-size: 0.85rem;
    color: rgba(255,255,255,0.7);
    line-height: 1.5;
    margin-bottom: 16px;
}
.onboarding-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}
.onboarding-btn-skip {
    background: none;
    border: none;
    color: rgba(255,255,255,0.4);
    font-size: 0.8rem;
    cursor: pointer;
    padding: 6px 10px;
    border-radius: 8px;
    transition: color 0.2s, background 0.2s;
}
.onboarding-btn-skip:hover {
    color: rgba(255,255,255,0.7);
    background: rgba(255,255,255,0.05);
}
.onboarding-btn-next {
    background: var(--accent);
    color: #fff;
    border: none;
    font-size: 0.85rem;
    font-weight: 600;
    padding: 8px 18px;
    border-radius: 10px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
    transition: background 0.2s, transform 0.1s;
}
.onboarding-btn-next:hover {
    background: var(--accent-light);
    transform: translateY(-1px);
}
.onboarding-btn-next:active {
    transform: translateY(0);
}
.onboarding-dots {
    display: flex;
    gap: 5px;
    align-items: center;
}
.onboarding-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: rgba(255,255,255,0.15);
    transition: all 0.3s;
}
.onboarding-dot.active {
    background: var(--accent);
    width: 20px;
    border-radius: 4px;
}
.onboarding-dot.done {
    background: var(--accent-light);
}
.onboarding-btn-finish {
    background: linear-gradient(135deg, #00b894, #00cec9) !important;
    font-size: 0.9rem !important;
    padding: 10px 24px !important;
}
@keyframes onboardingFadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Onboarding mobile responsive */
@media (max-width: 576px) {
    .onboarding-tooltip {
        width: calc(100vw - 32px);
        padding: 16px;
        border-radius: 14px;
    }
    .onboarding-title {
        font-size: 0.95rem;
    }
    .onboarding-desc {
        font-size: 0.8rem;
        margin-bottom: 12px;
    }
    .onboarding-actions {
        flex-wrap: wrap;
        gap: 6px;
    }
    .onboarding-dots {
        order: -1;
        width: 100%;
        justify-content: center;
        margin-bottom: 6px;
    }
    .onboarding-btn-skip {
        font-size: 0.75rem;
        padding: 6px 8px;
    }
    .onboarding-btn-next {
        font-size: 0.8rem;
        padding: 8px 14px;
    }
    .onboarding-spotlight {
        border-radius: 8px;
    }
}

/* Hover tooltip for waveform — now in bottom bar section above */

.time-display {
    display: flex;
    justify-content: space-between;
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.player-controls {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 15px;
    margin-bottom: 15px;
}

.control-btn {
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: white;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    cursor: pointer;
    transition: var(--transition);
}

.control-btn:hover {
    background: var(--accent);
    border-color: var(--accent);
    transform: scale(1.05);
    box-shadow: 0 4px 15px var(--accent-glow);
}

.control-btn.play-pause {
    width: 54px;
    height: 54px;
    font-size: 20px;
    background: var(--gradient-1);
    border: none;
    box-shadow: 0 4px 15px var(--accent-glow);
}

.control-btn.play-pause:hover {
    transform: scale(1.05);
    box-shadow: 0 6px 25px var(--accent-glow);
}

/* Player Animations */
.control-btn.playing {
    animation: playPulse 2s infinite;
}

@keyframes playPulse {
    0% { box-shadow: 0 0 0 0 var(--accent-glow); transform: scale(1); }
    50% { box-shadow: 0 0 0 10px rgba(108,92,231,0.1); transform: scale(1.05); }
    100% { box-shadow: 0 0 0 0 rgba(108,92,231,0); transform: scale(1); }
}

.control-btn.stopping {
    animation: stopFade 0.6s ease-out;
}

@keyframes stopFade {
    0% { background: var(--gradient-1); }
    50% { background: var(--danger); transform: scale(0.95); }
    100% { background: var(--gradient-1); transform: scale(1); }
}

.control-btn.pausing {
    animation: pauseBounce 0.4s ease-out;
}

@keyframes pauseBounce {
    0% { transform: scale(1); }
    50% { transform: scale(0.9); box-shadow: 0 0 0 5px rgba(254,202,87,0.3); }
    100% { transform: scale(1); box-shadow: none; }
}

/* Volume */
.volume-control {
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: center;
}

.volume-slider,
.volume-slider-widget {
    width: 80px;
    height: 4px;
    background: var(--border);
    border-radius: 2px;
    outline: none;
    -webkit-appearance: none;
    appearance: none;
    cursor: pointer;
}

.volume-slider::-webkit-slider-thumb,
.volume-slider-widget::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 14px;
    height: 14px;
    background: var(--accent-light);
    border-radius: 50%;
    cursor: pointer;
}

.volume-slider::-moz-range-thumb,
.volume-slider-widget::-moz-range-thumb {
    width: 14px;
    height: 14px;
    background: var(--accent-light);
    border-radius: 50%;
    cursor: pointer;
    border: none;
}

/* ===== Player Action Bar ===== */
.player-action-bar {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid rgba(255,255,255,0.06);
}

.player-action-btn {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    color: var(--text-secondary);
    width: 36px;
    height: 36px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.2s ease;
    position: relative;
}

.player-action-btn:hover {
    background: rgba(108,92,231,0.15);
    border-color: rgba(108,92,231,0.3);
    color: var(--accent-light);
    transform: translateY(-1px);
}

.player-action-btn:active {
    transform: scale(0.95);
}

.player-action-btn.pa-download:hover {
    background: rgba(0,184,148,0.15);
    border-color: rgba(0,184,148,0.3);
    color: #00b894;
}

.player-action-btn.pa-fav:hover,
.player-action-btn.pa-fav.is-fav {
    background: rgba(255,107,107,0.15);
    border-color: rgba(255,107,107,0.3);
    color: #ff6b6b;
}

.player-action-btn.pa-fav.is-fav {
    animation: favPop 0.3s ease;
}

@keyframes favPop {
    0% { transform: scale(1); }
    50% { transform: scale(1.2); }
    100% { transform: scale(1); }
}

.player-action-btn.pa-crate:hover {
    background: rgba(253,203,110,0.15);
    border-color: rgba(253,203,110,0.3);
    color: #fdcb6e;
}

.player-action-btn.pa-set:hover {
    background: rgba(116,185,255,0.15);
    border-color: rgba(116,185,255,0.3);
    color: #74b9ff;
}

/* Player Action Dropdown */
.player-action-more-wrap {
    position: relative;
}

.player-action-menu {
    position: absolute;
    bottom: calc(100% + 8px);
    right: 0;
    min-width: 200px;
    background: rgba(18,18,26,0.98);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 12px;
    padding: 6px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.5), 0 0 0 1px rgba(108,92,231,0.1);
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px) scale(0.95);
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 1001;
}

.player-action-menu.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
}

.player-action-menu button {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 10px 14px;
    background: none;
    border: none;
    color: var(--text-secondary);
    font-size: 0.85rem;
    cursor: pointer;
    border-radius: 8px;
    transition: all 0.15s ease;
    white-space: nowrap;
}

.player-action-menu button:hover {
    background: rgba(108,92,231,0.12);
    color: #fff;
}

.player-action-menu button i {
    font-size: 1rem;
    color: var(--accent-light);
    width: 18px;
    text-align: center;
}

.pa-menu-divider {
    height: 1px;
    background: rgba(255,255,255,0.06);
    margin: 4px 8px;
}

/* Play Button States */
.btn-play.played,
.btn-play-mini.played,
.chart-play-btn.played {
    background: rgba(0,184,148,0.15) !important;
    border: 2px solid var(--success) !important;
    position: relative;
    overflow: hidden;
}

.btn-play.played::before,
.btn-play-mini.played::before,
.chart-play-btn.played::before {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(0,184,148,0.3), transparent);
    animation: playedShimmer 2s infinite;
}

@keyframes playedShimmer {
    0% { left: -100%; }
    100% { left: 100%; }
}

.btn-play.playing,
.btn-play-mini.playing,
.chart-play-btn.playing,
.btn-action-play.playing {
    background: var(--gradient-1) !important;
    animation: playingPulse 1.5s ease-in-out infinite;
    box-shadow: 0 0 20px var(--accent-glow);
}

@keyframes playingPulse {
    0%, 100% { transform: scale(1); box-shadow: 0 0 10px var(--accent-glow); }
    50% { transform: scale(1.1); box-shadow: 0 0 25px var(--accent-glow); }
}

.btn-play[title="Stop"],
.btn-play-mini[title="Stop"],
.chart-play-btn[title="Stop"],
.btn-action-play[title="Stop"] {
    background: linear-gradient(135deg, var(--danger), #e17055) !important;
    color: #fff !important;
    border: 1px solid var(--danger) !important;
    animation: stopButtonGlow 2s infinite;
}

@keyframes stopButtonGlow {
    0%, 100% { box-shadow: 0 0 15px rgba(255,107,107,0.4); transform: scale(1); }
    50% { box-shadow: 0 0 25px rgba(255,107,107,0.7); transform: scale(1.05); }
}

.btn-play[title="Replay"],
.btn-play-mini[title="Replay"],
.chart-play-btn[title="Replay"],
.btn-action-play[title="Replay"] {
    background: linear-gradient(135deg, var(--warning), #f0932b) !important;
    color: #fff !important;
    border: 1px solid var(--warning) !important;
    box-shadow: 0 0 10px rgba(254,202,87,0.3);
}

/* Track Status */
.track-status {
    position: absolute;
    top: 2px;
    right: 2px;
    font-size: 10px;
    color: var(--success);
    font-weight: bold;
    z-index: 3;
}

/* ===== LAYOUT ===== */
.main-row {
    display: flex;
    gap: 0;
    align-items: flex-start;
    margin: 0;
    max-width: 100%;
    min-height: 100vh;
}

.left-pane {
    flex: 1;
    min-width: 0;
    overflow-x: auto;
    padding: 20px;
    background: transparent;
}

.track-library-container {
    background: var(--bg-secondary);
    border-radius: var(--radius);
    padding: 25px;
    box-shadow: var(--shadow);
    border: 1px solid var(--border);
}

.track-library-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 1px solid var(--border);
    flex-wrap: wrap;
    gap: 10px;
}

.track-library-controls {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}

/* === Custom Sort Dropdown === */
@keyframes sortDropIn {
    from { opacity: 0; transform: translateY(-8px) scale(0.96); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes sortItemIn {
    from { opacity: 0; transform: translateX(-10px); }
    to   { opacity: 1; transform: translateX(0); }
}

.sort-dropdown {
    position: relative;
    z-index: 50;
}
.sort-dropdown-toggle {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(108,92,231,0.1);
    border: 1px solid rgba(108,92,231,0.3);
    border-radius: 24px;
    padding: 9px 18px;
    font-size: 0.9rem;
    color: var(--text-primary);
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
    font-weight: 700;
    letter-spacing: 0.3px;
    user-select: none;
}
.sort-dropdown-toggle:hover {
    border-color: var(--accent);
    background: linear-gradient(135deg, rgba(108,92,231,0.22), rgba(162,155,254,0.14));
    transform: translateY(-1px);
    box-shadow: 0 4px 18px var(--accent-glow);
}
.sort-dropdown-icon {
    font-size: 1rem;
    color: var(--accent-light);
}
.sort-dropdown-label {
    font-weight: 700;
}
.sort-dropdown-arrow {
    font-size: 0.65rem;
    color: var(--text-muted);
    transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
    margin-left: 2px;
}
.sort-dropdown.open .sort-dropdown-arrow {
    transform: rotate(180deg);
}
.sort-dropdown.open .sort-dropdown-toggle {
    border-color: var(--accent);
    box-shadow: 0 4px 18px var(--accent-glow);
    background: linear-gradient(135deg, rgba(108,92,231,0.22), rgba(162,155,254,0.14));
}

/* Dropdown Menu */
.sort-dropdown-menu {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 210px;
    background: var(--bg-card);
    border: 1px solid rgba(108,92,231,0.25);
    border-radius: 14px;
    padding: 8px;
    box-shadow: 0 12px 40px rgba(0,0,0,0.5), 0 0 20px var(--accent-glow);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px) scale(0.96);
    transition: all 0.25s cubic-bezier(0.4,0,0.2,1);
    pointer-events: none;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}
.sort-dropdown.open .sort-dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
    pointer-events: auto;
}

/* Dropdown Items */
.sort-dropdown-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-radius: 10px;
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 0.88rem;
    font-weight: 600;
    transition: all 0.2s ease;
    cursor: pointer;
    opacity: 0;
    animation: sortItemIn 0.3s ease forwards;
}
.sort-dropdown.open .sort-dropdown-item {
    opacity: 0;
    animation: sortItemIn 0.3s ease forwards;
}
.sort-dropdown-item i:first-child {
    font-size: 1rem;
    width: 22px;
    text-align: center;
    color: var(--text-muted);
    transition: color 0.2s ease;
}
.sort-dropdown-item span {
    flex: 1;
}
.sort-dropdown-item:hover {
    background: rgba(108,92,231,0.12);
    color: #fff;
    transform: translateX(4px);
}
.sort-dropdown-item:hover i:first-child {
    color: var(--accent-light);
}
.sort-dropdown-item.active {
    background: linear-gradient(135deg, rgba(108,92,231,0.2), rgba(162,155,254,0.1));
    color: #fff;
}
.sort-dropdown-item.active i:first-child {
    color: var(--accent-light);
}
.sort-check {
    color: var(--accent-light);
    font-size: 0.85rem;
    margin-left: auto;
}

.track-library-title {
    font-size: 1.5rem;
    font-weight: 700;
    background: var(--gradient-1);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    margin: 0;
}

.right-pane {
    width: 340px;
    max-width: 100%;
    flex-shrink: 0;
    position: relative;
    align-self: flex-start;
    overflow-y: visible;
    overflow-x: hidden;
    background: transparent;
    border-left: none;
    padding: 20px 15px;
}

.right-pane::-webkit-scrollbar {
    width: 6px;
}

.right-pane::-webkit-scrollbar-track {
    background: var(--bg-secondary);
    border-radius: 3px;
}

.right-pane::-webkit-scrollbar-thumb {
    background: var(--accent);
    border-radius: 3px;
}

/* ===== MONTHLY CHARTS SECTION ===== */
.monthly-charts-section {
    background: var(--bg-card);
    border-radius: var(--radius);
    padding: 25px;
    margin-bottom: 30px;
    border: 1px solid var(--border);
}

.monthly-charts-title {
    background: var(--gradient-1);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: 1.8rem;
    font-weight: 700;
    margin-bottom: 20px;
    text-align: center;
}

.region-selector {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-bottom: 25px;
    flex-wrap: wrap;
}

.region-btn {
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    text-decoration: none;
    padding: 10px 16px;
    border-radius: var(--radius-sm);
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.5px;
    transition: var(--transition);
    cursor: pointer;
    min-width: 90px;
    text-align: center;
}

.region-btn:hover {
    background: rgba(108,92,231,0.15);
    border-color: var(--accent);
    color: #fff;
    text-decoration: none;
    transform: translateY(-2px);
    box-shadow: 0 4px 10px var(--accent-glow);
}

.region-btn.active {
    background: var(--gradient-1);
    border-color: var(--accent-light);
    color: #fff;
    box-shadow: 0 3px 12px var(--accent-glow);
}

.charts-container {
    min-height: 200px;
}

.charts-loading {
    text-align: center;
    padding: 40px 20px;
    color: var(--text-secondary);
}

.loading-spinner-charts {
    width: 40px;
    height: 40px;
    border: 3px solid var(--border);
    border-left: 3px solid var(--accent);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin: 0 auto 20px;
}

.chart-track {
    display: flex;
    align-items: center;
    padding: 12px;
    margin-bottom: 8px;
    background: rgba(0,0,0,0.2);
    border-radius: var(--radius-sm);
    border-left: 4px solid var(--accent);
    transition: var(--transition);
}

.chart-track:hover {
    background: rgba(108,92,231,0.08);
    transform: translateX(5px);
}

.chart-position {
    background: var(--gradient-1);
    color: white;
    width: 35px;
    height: 35px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    margin-right: 15px;
    flex-shrink: 0;
    font-size: 0.85rem;
}

.chart-info {
    flex: 1;
    min-width: 0;
}

.chart-title {
    font-weight: 600;
    color: #fff;
    font-size: 0.9rem;
    margin-bottom: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.chart-artist {
    color: var(--text-secondary);
    font-size: 0.8rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.chart-actions {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
}

.chart-play-btn {
    background: var(--gradient-1);
    border: none;
    color: white;
    width: 35px;
    height: 35px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    cursor: pointer;
    transition: var(--transition);
}

.chart-play-btn:hover {
    transform: scale(1.1);
    box-shadow: 0 4px 15px var(--accent-glow);
}

.chart-download-btn {
    background: var(--gradient-1);
    border: none;
    color: white;
    padding: 6px 12px;
    border-radius: 8px;
    font-size: 0.8rem;
    cursor: pointer;
    transition: var(--transition);
}

.chart-download-btn:hover {
    opacity: 0.85;
    transform: translateY(-1px);
}

.charts-empty {
    text-align: center;
    padding: 30px;
    color: var(--text-muted);
}

.charts-stats {
    text-align: center;
    margin-top: 15px;
    color: var(--text-secondary);
    font-size: 0.9rem;
}

/* ===== FILTER PANEL ===== */
.filter-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.85);
    backdrop-filter: blur(10px);
    z-index: 9998;
    display: none;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.filter-overlay.show {
    display: flex;
    opacity: 1;
}

.filter-panel {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-hover) !important;
    border-radius: var(--radius);
    padding: 30px;
    max-width: 900px;
    width: 90%;
    max-height: 80vh;
    overflow-y: auto;
    box-shadow: var(--shadow-lg);
    transform: scale(0.9);
    transition: transform 0.3s ease;
    position: relative;
}

.filter-overlay.show .filter-panel {
    transform: scale(1);
}

.filter-panel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 25px;
    padding-bottom: 15px;
    border-bottom: 1px solid var(--border);
}

.filter-panel-title {
    background: var(--gradient-1);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: 1.5rem;
    font-weight: 700;
    margin: 0;
}

.filter-close-btn {
    background: transparent;
    border: none;
    color: var(--text-muted);
    font-size: 28px;
    cursor: pointer;
    padding: 0;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    transition: var(--transition);
    display: flex;
    align-items: center;
    justify-content: center;
}

.filter-close-btn:hover {
    background: rgba(255,107,107,0.15);
    color: var(--danger);
    transform: rotate(90deg);
}

.filter-label {
    color: var(--text-secondary);
    font-size: 0.9rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 10px;
}

.filter-btn {
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    padding: 8px 16px;
    border-radius: 8px;
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--transition);
    min-width: 80px;
}

.filter-btn:hover {
    background: var(--bg-card-hover);
    border-color: var(--accent);
    color: #fff;
    transform: translateY(-1px);
}

.filter-btn.active {
    background: var(--gradient-1);
    border-color: var(--accent);
    color: #fff;
    box-shadow: 0 2px 10px var(--accent-glow);
}

.key-grid {
    display: grid;
    grid-template-columns: auto repeat(12, 1fr) repeat(12, 1fr);
    gap: 4px;
    align-items: center;
}

.key-btn {
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    padding: 8px 4px;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
    text-align: center;
    min-width: 35px;
    height: 35px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.key-btn.all-keys {
    grid-column: 1;
    background: var(--bg-card);
    min-width: 50px;
    font-size: 0.7rem;
}

.key-btn.major {
    background: rgba(108,92,231,0.2);
    border-color: rgba(108,92,231,0.3);
}

.key-btn.minor {
    background: rgba(0,184,148,0.15);
    border-color: rgba(0,184,148,0.25);
}

.key-btn:hover {
    transform: scale(1.05);
    border-color: #fff;
    color: #fff;
}

.key-btn.major:hover {
    background: rgba(108,92,231,0.4);
}

.key-btn.minor:hover {
    background: rgba(0,184,148,0.35);
}

.key-btn.active {
    background: #fff !important;
    color: #000 !important;
    border-color: #fff !important;
    box-shadow: 0 0 10px rgba(255,255,255,0.3);
    transform: scale(1.1);
}

.bpm-controls .form-control {
    background: var(--bg-secondary) !important;
    border: 1px solid var(--border) !important;
    color: #fff !important;
}

.bpm-controls .form-control:focus {
    background: var(--bg-card) !important;
    border-color: var(--accent) !important;
    box-shadow: 0 0 5px var(--accent-glow) !important;
}

/* Cache Status */
.cache-status {
    position: fixed;
    top: 10px;
    right: 10px;
    background: var(--bg-card);
    color: #fff;
    padding: 8px 12px;
    border-radius: 8px;
    font-size: 0.7rem;
    z-index: 9999;
    border: 1px solid var(--border);
    display: none;
}

.cache-status.show { display: block; }
.cache-status.buffering { background: rgba(254,202,87,0.9); border-color: var(--warning); }
.cache-status.ready { background: rgba(0,184,148,0.9); border-color: var(--success); }
.cache-status.error { background: rgba(255,107,107,0.9); border-color: var(--danger); }

/* ===== VINYL DISC ===== */
.vinyl-disc {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: conic-gradient(from 0deg, #1a1a28, #2a2a3d, #1a1a28, #2a2a3d, #1a1a28);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    border: 2px solid var(--accent);
    box-shadow: 0 0 15px var(--accent-glow);
}

.vinyl-disc::after {
    content: '';
    width: 12px;
    height: 12px;
    background: var(--accent-light);
    border-radius: 50%;
    border: 2px solid var(--accent);
}

.vinyl-disc.spinning {
    animation: vinylSpin 2s linear infinite;
}

@keyframes vinylSpin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* ===== ALERTS ===== */
.alert-info {
    background: rgba(108,92,231,0.1) !important;
    border: 1px solid var(--border-hover) !important;
    color: var(--accent-light) !important;
    border-radius: var(--radius-sm);
}

.alert-warning {
    background: rgba(254,202,87,0.1) !important;
    border: 1px solid rgba(254,202,87,0.3) !important;
    color: var(--warning) !important;
    border-radius: var(--radius-sm);
}

.alert-danger {
    background: rgba(255,107,107,0.1) !important;
    border: 1px solid rgba(255,107,107,0.3) !important;
    color: var(--danger) !important;
    border-radius: var(--radius-sm);
}

.alert-success {
    background: rgba(0,184,148,0.1) !important;
    border: 1px solid rgba(0,184,148,0.3) !important;
    color: var(--success) !important;
    border-radius: var(--radius-sm);
}

/* ===== MODALS ===== */
.modal-content {
    background: var(--bg-card) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius);
    color: #fff;
}

.modal-header {
    border-bottom: 1px solid var(--border) !important;
}

.modal-footer {
    border-top: 1px solid var(--border) !important;
}

.modal-title {
    color: var(--accent-light);
}

.btn-close {
    filter: invert(1);
}

/* ===== TEXT HELPERS ===== */
.text-light { color: var(--text-primary) !important; }
.text-muted { color: var(--text-muted) !important; }
.text-secondary { color: var(--text-secondary) !important; }
.text-warning { color: var(--warning) !important; }
.text-success { color: var(--success) !important; }
.text-danger { color: var(--danger) !important; }
.text-info { color: var(--accent-light) !important; }

/* Badge Colors */
.bg-danger { background: var(--danger) !important; }
.bg-success { background: var(--success) !important; }
.bg-warning { background: var(--warning) !important; color: #000 !important; }
.bg-info { background: var(--accent) !important; }
.bg-primary { background: var(--accent) !important; }
.bg-secondary { background: var(--bg-card) !important; }
.bg-dark { background: var(--bg-secondary) !important; }

/* ===== RESPONSIVE ===== */

/* ---- Tablet ---- */
@media (max-width: 1024px) {
    .nav-top { padding: 10px 16px 8px; gap: 12px; }
    .nav-bottom { padding: 0 10px; }
    .nav-pill { padding: 10px 12px; font-size: 0.78rem; }
    .left-pane { padding: 14px; }
    .right-pane { width: 280px !important; }
    .genre-card-grid { grid-template-columns: repeat(5, 1fr); }
}

/* ---- Mobile ---- */
@media (max-width: 768px) {
    /* Navbar */
    .nav-top {
        flex-wrap: wrap;
        padding: 10px 12px 8px;
        gap: 8px;
    }
    .nav-logo-text { font-size: 1rem; }
    .nav-search-form {
        order: 3;
        flex: 1 1 100%;
        border-radius: 10px;
    }
    .nav-search-input { height: 38px; font-size: 0.82rem; padding-right: 12px; }
    .nav-search-box { min-width: 80px; flex: 1; }
    .nav-search-kbd { display: none; }
    .nav-filter-select { min-width: 0; max-width: 90px; font-size: 0.76rem; height: 38px; padding: 0 22px 0 8px; background-position: right 4px center; }
    .nav-search-btn { width: 40px; height: 38px; }
    .nav-reset-btn { width: 36px; height: 38px; }
    .nav-filter-sort { display: none; }
    .nav-filter-toggle { width: 36px; height: 38px; font-size: 0.82rem; }
    .nav-filter-badge { width: 14px; height: 14px; font-size: 0.5rem; top: 3px; right: 2px; }
    .nav-adv-filters.open { max-height: 160px; padding: 10px 12px; }
    .nav-adv-inner { gap: 10px; }
    .nav-adv-group { flex: 1 1 auto; min-width: 0; }
    .nav-adv-label { font-size: 0.65rem; }
    .nav-adv-input { width: 55px; height: 30px; font-size: 0.75rem; padding: 0 6px; }
    .nav-adv-select { height: 30px; font-size: 0.75rem; min-width: 80px; padding: 0 22px 0 8px; }
    .nav-adv-apply { height: 30px; font-size: 0.72rem; padding: 0 10px; }
    .nav-avatar-name { display: none; }
    .nav-avatar-chevron { display: none; }
    .nav-avatar { width: 34px; height: 34px; font-size: 0.75rem; }
    .nav-avatar-btn { width: 34px; height: 34px; }
    .nav-account { margin-left: auto; order: 2; }
    .nav-logo { order: 1; }
    .nav-search-form { order: 3; }

    /* On mobile the dropdown is portaled to <body> via JS — hide the in-nav one */
    .nav-account.open .nav-dropdown { display: none; }

    /* Nav links — horizontal scroll */
    .nav-bottom { padding: 0 8px; overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .nav-bottom::-webkit-scrollbar { display: none; }
    .nav-links { gap: 0; flex-wrap: nowrap; }
    .nav-pill { padding: 8px 10px; font-size: 0.72rem; white-space: nowrap; gap: 4px; }
    .nav-pill i { font-size: 0.78rem; }
    .nav-pill span { font-size: 0.72rem; }
    .nav-stats { display: none; }
    /* More dropdown on mobile — portaled to <body> */
    .nav-more-dropdown.mobile-portal {
        position: fixed;
        min-width: 220px;
        opacity: 0;
        visibility: hidden;
        transform: none;
        transition: opacity 0.2s ease, visibility 0.2s;
        z-index: 1002;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        overscroll-behavior: contain;
    }
    .nav-more-dropdown.mobile-portal::-webkit-scrollbar { width: 4px; }
    .nav-more-dropdown.mobile-portal::-webkit-scrollbar-thumb { background: rgba(108,92,231,0.3); border-radius: 2px; }
    .nav-more-dropdown.mobile-portal.show {
        opacity: 1;
        visibility: visible;
    }
    .nav-more-chev { display: none !important; }
    .nav-more-btn span { display: none; }
    .nav-more-btn i.bi-grid-fill { font-size: 1rem; }

    /* Layout stacking */
    .main-row { flex-direction: column !important; gap: 0 !important; }
    .left-pane { width: 100% !important; padding: 12px; order: 1; }
    .right-pane { width: 100% !important; max-width: 100% !important; order: 2; padding: 12px; }
    .container-narrow { padding: 10px !important; margin: 10px auto !important; }

    /* Track Library */
    .track-library-container { padding: 14px; border-radius: 12px; }
    .track-library-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
        padding-bottom: 10px;
        margin-bottom: 12px;
    }
    .track-library-title { font-size: 1.15rem; }
    .track-library-controls {
        width: 100%;
        justify-content: space-between;
    }
    .sort-dropdown-toggle { font-size: 0.8rem; padding: 7px 12px; gap: 6px; }
    .sort-dropdown-menu { min-width: 180px; }
    .sort-dropdown-item { font-size: 0.82rem; padding: 8px 12px; }

    /* Sort bar */
    .track-sort-bar { display: none; }

    /* Track rows — compact sidebar-style on mobile */
    .track-row {
        display: grid;
        grid-template-columns: 28px 1fr auto;
        grid-template-rows: auto auto;
        gap: 2px 8px;
        padding: 10px 10px;
        align-items: center;
    }
    .track-row-num { display: none; }
    .track-row-thumb { display: none; }
    .track-row-play {
        grid-column: 1;
        grid-row: 1 / 3;
        width: 28px;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .track-row-main {
        grid-column: 2 / 3;
        grid-row: 1;
        min-width: 0;
        padding: 0;
    }
    .track-row-title { font-size: 0.78rem; }
    .track-row-subtitle { font-size: 0.65rem; margin-top: 1px; }
    .track-row-artist { display: none; }
    .track-row-meta {
        grid-column: 2 / 3;
        grid-row: 2;
        display: flex;
        flex-wrap: nowrap;
        align-items: center;
        justify-content: flex-start;
        gap: 4px;
        margin-top: 3px;
        overflow: hidden;
    }
    .track-genre-pill { font-size: 0.58rem; padding: 2px 7px; width: 80px; min-width: 0; }
    .track-bpm-key {
        display: inline-flex !important;
        align-items: center;
        gap: 4px;
        flex-shrink: 0;
        white-space: nowrap;
    }
    .track-bpm, .track-key { font-size: 0.62rem; width: auto; text-align: left; padding: 0; }
    .track-bpm::before { content: 'BPM '; font-weight: 600; color: var(--text-muted); font-size: 0.55rem; }
    .track-key::before { content: '· '; color: var(--text-muted); margin-right: 1px; }
    .track-row-actions {
        grid-column: 3 / 4;
        grid-row: 1 / 3;
        display: flex;
        flex-direction: row;
        gap: 6px;
        align-items: center;
        justify-content: center;
        width: auto;
    }
    .btn-action { width: 28px; height: 28px; font-size: 0.65rem; }
    .btn-action,
    .btn-action-play {
        width: 28px !important;
        height: 28px !important;
        max-width: 28px !important;
        max-height: 28px !important;
        min-width: 28px !important;
        min-height: 28px !important;
        padding: 0 !important;
        font-size: 0.75rem;
        box-sizing: border-box !important;
        aspect-ratio: 1 / 1;
    }
    .btn-action:hover, .btn-action-play:hover { transform: none !important; box-shadow: none !important; }
    .btn-action-play.playing,
    .btn-action-play[title="Stop"],
    .btn-action-play[title="Replay"],
    .btn-action.played,
    .btn-action.played:hover {
        width: 28px !important;
        height: 28px !important;
        max-width: 28px !important;
        max-height: 28px !important;
        min-width: 28px !important;
        min-height: 28px !important;
        padding: 0 !important;
        animation: none !important;
        transform: none !important;
        box-shadow: none !important;
        border-width: 1px !important;
        aspect-ratio: 1 / 1;
    }
    .track-ver-badge { font-size: 0.52rem; padding: 1px 5px; }
    .exc-tag { font-size: 0.48rem; padding: 1px 5px; }

    /* Track detail panel */
    .track-detail-panel { padding: 0; }
    .track-detail-grid { grid-template-columns: 1fr !important; gap: 8px; }
    .detail-inner {
        flex-direction: column;
        padding: 14px 12px;
        gap: 14px;
    }
    .detail-info {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }
    .detail-actions-panel {
        flex-direction: row;
        gap: 8px;
        width: 100%;
    }
    .btn-detail {
        flex: 1;
        text-align: center;
        padding: 10px 12px;
        font-size: 0.78rem;
    }

    /* Date separators */
    .track-date-separator { margin: 8px 0; }
    .track-date-label { font-size: 0.65rem; padding: 0 8px; }

    /* Genre nav cards — horizontal scroll on mobile */
    .genre-nav { padding: 14px; }
    .genre-nav h4 { font-size: 1.05rem; }

    /* Gig chips — horizontal scroll on mobile */
    .gig-chips-grid {
        overflow-x: auto;
        flex-wrap: nowrap;
        padding-bottom: 4px;
        -webkit-overflow-scrolling: touch;
    }
    .gig-chips-grid::-webkit-scrollbar { display: none; }
    .gig-chip {
        flex-shrink: 0;
        padding: 6px 12px;
        font-size: 0.78rem;
    }

    .genre-card-grid {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        gap: 8px;
        padding-bottom: 4px;
        -webkit-overflow-scrolling: touch;
    }
    .genre-card-grid::-webkit-scrollbar { display: none; }
    .genre-card {
        min-width: 100px;
        flex-shrink: 0;
        scroll-snap-align: start;
        padding: 12px 10px 10px;
    }
    .genre-card-icon { display: none !important; }
    .genre-card-name { font-size: 0.75rem; margin-bottom: 1px; }
    .genre-card-count { font-size: 0.6rem; }
    .genre-see-all { font-size: 0.78rem; }

    /* Ad Banner */
    .rpool-ad-carousel { border-radius: 10px; }
    .rpool-ad-banner { border-radius: 10px; }
    .rpool-ad-inner { padding: 24px 16px; }
    .rpool-ad-title { font-size: 1.1rem !important; }
    .rpool-ad-subtitle { font-size: 0.8rem !important; }
    .rpool-ad-arrow { width: 30px; height: 30px; font-size: 0.8rem; }
    .rpool-ad-arrow.left { left: 6px; }
    .rpool-ad-arrow.right { right: 6px; }

    /* Sidebar */
    .sidebar-card { padding: 14px; border-radius: 12px; }
    .sidebar-card-header { padding: 0 0 10px 0; }
    .sidebar-card-title { font-size: 0.95rem; }
    .sidebar-track { padding: 8px 6px; }
    .sidebar-track-name { font-size: 0.78rem; }
    .sidebar-track-meta { font-size: 0.62rem; }
    .sidebar-rank { width: 22px; height: 22px; font-size: 0.55rem; }
    .sidebar-btn { width: 28px; height: 28px; font-size: 0.65rem; }
    .sidebar-track-actions { opacity: 1; }

    /* Pagination */
    .pagination-wrapper {
        flex-direction: column;
        gap: 12px;
        text-align: center;
        padding: 12px;
    }
    .pagination-custom { justify-content: center; flex-wrap: wrap; gap: 2px; }
    .pagination-custom .page-link { width: 34px; height: 34px; font-size: 0.72rem; }
    .pagination-custom .page-text { width: auto !important; min-width: 40px !important; padding: 0 6px !important; font-size: 0.68rem !important; }
    .pagination-custom .page-number { width: 34px !important; height: 34px !important; font-size: 0.72rem !important; }
    .pagination-info { font-size: 0.78rem; text-align: center; order: -1; }

    /* Search / Filters */
    .search-controls { padding: 12px !important; margin-bottom: 12px !important; }
    .filter-panel { padding: 18px !important; width: 95% !important; max-height: 90vh !important; }
    .filter-panel-title { font-size: 1.1rem !important; }
    .key-grid { grid-template-columns: auto repeat(6, 1fr) !important; gap: 2px !important; }
    .key-btn { min-width: 28px !important; height: 28px !important; font-size: 0.62rem !important; padding: 4px 2px !important; }
    .filter-btn { min-width: 65px !important; padding: 6px 10px !important; font-size: 0.72rem !important; }

    /* Charts (monthly, most-popular) */
    .monthly-charts-section { padding: 16px 12px; }
    .monthly-charts-title { font-size: 1.3rem; }
    .region-selector { gap: 4px; flex-wrap: wrap; }
    .region-btn { padding: 6px 10px; font-size: 0.75rem; min-width: 60px; }
    .chart-track { padding: 10px; }
    .chart-title { font-size: 0.82rem; }
    .chart-artist { font-size: 0.72rem; }

    /* Current genre badge */
    .current-genre-display .badge { font-size: 0.72rem; padding: 6px 10px; }

    /* Music Player Widget — bottom bar, no overrides needed here */
    .player-action-bar {
        gap: 4px;
        margin-top: 10px;
        padding-top: 10px;
    }
    .player-action-btn {
        width: 32px;
        height: 32px;
        font-size: 12px;
        border-radius: 8px;
    }
    .player-action-menu {
        min-width: 180px;
        right: -10px;
    }
    .player-art .vinyl-disc { width: 36px; height: 36px; }
    .player-info-widget { max-width: calc(100% - 160px); }
    .track-title-widget { font-size: 0.78rem; }
    .track-artist-widget { font-size: 0.65rem; }
    .player-controls-widget button { width: 32px; height: 32px; font-size: 0.85rem; }
    .player-controls-widget .main-btn { width: 38px; height: 38px; }
    .player-extra-controls .volume-slider-widget { display: none; }
    .close-widget { width: 24px; height: 24px; font-size: 0.7rem; }

    /* Version picker swal */
    .swal-version-popup { width: 95vw !important; max-width: 95vw !important; padding: 16px !important; }
    .ver-item { grid-template-columns: 1fr auto !important; gap: 8px; padding: 10px 12px; }
    .ver-item-info { font-size: 0.8rem; }
    .ver-item-actions { gap: 4px; }
    .ver-btn-play, .ver-btn-dl, .ver-btn-lock { width: 32px; height: 32px; font-size: 0.75rem; }

    /* Version modal (Bootstrap fallback) — mobile fix */
    #versionModal .modal-dialog { margin: 10px; max-width: calc(100vw - 20px); }
    #versionModal .modal-title { font-size: 0.95rem; }
    #versionModal .modal-body { padding: 12px; max-height: 65vh !important; }
    .version-info .fw-bold { font-size: 0.85rem; }
    .version-actions .btn-download { min-width: 0 !important; font-size: 0.78rem !important; }

    /* Loading overlay */
    .rpool-vinyl-loader .vinyl-disc { width: 60px; height: 60px; }
    .rpool-vinyl-loader .vinyl-label { width: 22px; height: 22px; font-size: 0.55rem; }
    .rpool-vinyl-loader .loader-text { font-size: 0.75rem; }
}

/* ---- Small phones ---- */
@media (max-width: 400px) {
    .nav-top { padding: 8px 10px 6px; }
    .nav-logo-text { font-size: 0.9rem; }
    .nav-pill { padding: 7px 8px; font-size: 0.68rem; }
    .left-pane { padding: 6px; }
    .track-library-container { padding: 8px; }
    .track-row {
        grid-template-columns: 22px 1fr auto;
        padding: 7px 6px;
        gap: 1px 4px;
    }
    .track-row-title { font-size: 0.7rem; }
    .track-row-subtitle { font-size: 0.58rem; }
    .track-genre-pill { width: 50px; font-size: 0.5rem; }
    .genre-card-grid { gap: 8px; }
    .genre-card { padding: 14px 6px 10px; }
    .genre-card-icon { width: 36px; height: 36px; font-size: 0.9rem; }
    .rpool-ad-inner { padding: 18px 12px; }
    .rpool-ad-title { font-size: 0.95rem !important; }
    .rpool-ad-subtitle { font-size: 0.72rem !important; }
    .btn-action,
    .btn-action-play {
        width: 22px !important;
        height: 22px !important;
        max-width: 22px !important;
        max-height: 22px !important;
        min-width: 22px !important;
        min-height: 22px !important;
        font-size: 0.55rem;
    }
}

/* ===================================================================
   FEATURE INTEGRATION — Notification Bell, Favorites, Track Menu, Toast
   =================================================================== */

/* --- Notification Bell --- */
.nav-notif-bell {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    color: var(--text-secondary);
    font-size: 1.1rem;
    transition: all .25s ease;
    text-decoration: none;
    margin-right: 2px;
}
.nav-notif-bell:hover {
    color: var(--accent-light);
    background: rgba(108,92,231,.12);
}

.nav-notif-badge {
    position: absolute;
    top: 2px;
    right: 2px;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    border-radius: 99px;
    background: #ff4757;
    color: #fff;
    font-size: .65rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    box-shadow: 0 0 6px rgba(255,71,87,.5);
    animation: bellPulse 2s infinite;
}
@keyframes bellPulse {
    0%, 100% { box-shadow: 0 0 6px rgba(255,71,87,.5); }
    50% { box-shadow: 0 0 12px rgba(255,71,87,.8); }
}

/* --- Favorite Button on Track Rows --- */
.btn-action-fav {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: none;
    background: transparent;
    color: var(--text-muted);
    font-size: .88rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .25s ease;
    flex-shrink: 0;
}
.btn-action-fav:hover {
    color: #ff6b81;
    background: rgba(255,107,129,.1);
    transform: scale(1.15);
}
.btn-action-fav.is-fav {
    color: #ff4757;
}
.btn-action-fav.is-fav:hover {
    color: #ff6b81;
    transform: scale(1.15);
}

/* --- More Menu (Three-dot) --- */
.track-more-menu {
    position: relative;
    display: inline-flex;
}

.btn-action-more {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: none;
    background: transparent;
    color: var(--text-muted);
    font-size: .85rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .2s ease;
    flex-shrink: 0;
}
.btn-action-more:hover {
    color: var(--text-primary);
    background: rgba(255,255,255,.06);
}

.track-menu-popup {
    display: none;
    position: fixed;
    min-width: 200px;
    background: #1a1a2e;
    border: 1px solid rgba(108,92,231,.2);
    border-radius: 12px;
    padding: 6px 0;
    z-index: 99990;
    box-shadow: 0 12px 40px rgba(0,0,0,.65);
    animation: menuFadeIn .15s ease;
}
.track-menu-popup.show {
    display: block;
}

@keyframes menuFadeIn {
    from { opacity: 0; transform: translateY(-4px); }
    to { opacity: 1; transform: translateY(0); }
}

.track-menu-popup button {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 9px 16px;
    background: transparent;
    border: none;
    color: var(--text-secondary);
    font-size: .82rem;
    cursor: pointer;
    transition: all .15s;
    white-space: nowrap;
}
.track-menu-popup button:hover {
    background: rgba(108,92,231,.12);
    color: var(--accent-light);
}
.track-menu-popup button i {
    font-size: 1rem;
    width: 18px;
    text-align: center;
    color: var(--accent);
}
.track-menu-popup .menu-divider {
    height: 1px;
    background: rgba(108,92,231,.12);
    margin: 4px 12px;
}

/* --- SweetAlert2 Toast z-index fix (must be above navbar z-index:10000) --- */
.swal2-container {
    z-index: 1200 !important;
}
.swal2-container.swal2-top-end,
.swal2-container.swal2-top-right {
    top: 70px !important;  /* Push below sticky navbar */
}

/* --- Toast Notifications --- */
.rpool-toast {
    position: fixed;
    bottom: 140px;
    right: 24px;
    padding: 12px 20px;
    border-radius: 12px;
    color: #fff;
    font-size: .85rem;
    font-weight: 500;
    z-index: 1100;
    display: flex;
    align-items: center;
    gap: 8px;
    opacity: 0;
    transform: translateY(10px);
    transition: all .3s ease;
    pointer-events: none;
    box-shadow: 0 4px 20px rgba(0,0,0,.4);
}
.rpool-toast.show {
    opacity: 1;
    transform: translateY(0);
}
.rpool-toast-success {
    background: rgba(0,200,83,.9);
    border: 1px solid rgba(0,200,83,.4);
}
.rpool-toast-error {
    background: rgba(255,71,87,.9);
    border: 1px solid rgba(255,71,87,.4);
}
.rpool-toast-info {
    background: rgba(108,92,231,.9);
    border: 1px solid rgba(108,92,231,.4);
}

/* --- Responsive adjustments for feature buttons --- */
/* Native <dialog> bottom-sheet for mobile track menus */
dialog.rpool-mobile-menu-dialog {
    position: fixed;
    bottom: 12px;
    left: 12px;
    right: 12px;
    top: auto;
    margin: 0;
    padding: 6px 0;
    max-width: none;
    width: calc(100% - 24px);
    max-height: min(60vh, 380px);
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    background: #1a1a2e;
    border: 1px solid rgba(108,92,231,.2);
    border-radius: 16px;
    box-shadow: 0 12px 40px rgba(0,0,0,.65);
    color: #fff;
    z-index: 1100;
}
dialog.rpool-mobile-menu-dialog::backdrop {
    background: rgba(0,0,0,.5);
    -webkit-tap-highlight-color: transparent;
}

@media (max-width: 768px) {
    .btn-action-fav {
        width: 28px;
        height: 28px;
        font-size: .85rem;
    }
    .btn-action-more {
        width: 28px;
        height: 28px;
        font-size: .8rem;
    }
    .track-menu-popup:not(dialog) {
        right: -40px;
        min-width: 170px;
        max-height: 70vh;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        overscroll-behavior: contain;
    }
    .rpool-toast {
        bottom: 120px;
        right: 12px;
        font-size: .8rem;
        padding: 10px 16px;
    }
    .nav-notif-bell {
        width: 34px;
        height: 34px;
        font-size: 1rem;
    }
}
@media (max-width: 480px) {
    .track-more-menu {
        display: block;
    }
    .track-menu-popup:not(dialog) {
        right: -10px;
        min-width: 160px;
        max-height: 68vh;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        overscroll-behavior: contain;
    }
    .detail-info {
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }
    .btn-detail {
        padding: 9px 10px;
        font-size: 0.75rem;
    }
    /* Version modal — small phones */
    #versionModal .modal-title { font-size: 0.85rem; }
    .version-info .fw-bold { font-size: 0.82rem; }
    .version-actions .btn-download {
        padding: 7px 12px !important;
        font-size: 0.75rem !important;
    }
    .version-actions .btn-download .me-1 { margin-right: 0 !important; }
}

/* --- Download Corner Toast --- */
.dl-corner-toast {
    position: fixed;
    top: 16px;
    right: 16px;
    z-index: 1100;
    display: flex;
    align-items: center;
    gap: 10px;
    background: rgba(18,18,28,.95);
    border: 1px solid rgba(108,92,231,.25);
    border-radius: 12px;
    padding: 12px 18px;
    min-width: 240px;
    max-width: 340px;
    box-shadow: 0 8px 32px rgba(0,0,0,.5), 0 0 0 1px rgba(108,92,231,.1);
    backdrop-filter: blur(12px);
    opacity: 0;
    transform: translateX(100%);
    transition: all .35s cubic-bezier(.4,0,.2,1);
    pointer-events: auto;
}
.dl-corner-toast.show {
    opacity: 1;
    transform: translateX(0);
}
.dl-toast-icon {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.dl-toast-spinner {
    width: 20px;
    height: 20px;
    border: 2.5px solid rgba(108,92,231,.2);
    border-top-color: var(--accent);
    border-radius: 50%;
    animation: dlSpin .7s linear infinite;
}
@keyframes dlSpin {
    to { transform: rotate(360deg); }
}
.dl-toast-body {
    flex: 1;
    min-width: 0;
}
.dl-toast-title {
    font-size: .82rem;
    font-weight: 600;
    color: #fff;
    line-height: 1.3;
}
.dl-toast-sub {
    font-size: .7rem;
    color: var(--text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: 1px;
}
.dl-toast-progress {
    width: 100%;
    height: 3px;
    background: rgba(255,255,255,.08);
    border-radius: 3px;
    margin-top: 6px;
    overflow: hidden;
}
.dl-toast-progress-bar {
    height: 100%;
    width: 0%;
    background: var(--accent);
    border-radius: 3px;
    transition: width .3s ease;
}

/* Download remaining badge */
.dl-remaining-badge {
    display: inline-block;
    font-size: .65rem;
    font-weight: 700;
    padding: 1px 6px;
    border-radius: 8px;
    background: rgba(108,92,231,.2);
    color: var(--accent-light);
    margin-left: 4px;
    vertical-align: middle;
}

/* ── Modern Audio Player (Bottom Bar) ───────── */
.modern-audio-player {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(90deg, rgba(18,18,26,0.97), rgba(20,20,30,0.97));
    backdrop-filter: blur(12px);
    border-top: 2px solid var(--accent, #6c5ce7);
    padding: 14px 20px;
    z-index: 1050;
    box-shadow: 0 -5px 24px rgba(0,0,0,0.5);
}
.modern-audio-player .player-container {
    display: flex;
    align-items: center;
    gap: 18px;
    max-width: 1200px;
    margin: 0 auto;
}
.modern-audio-player .player-controls {
    display: flex;
    gap: 10px;
    align-items: center;
}
.modern-audio-player .control-btn {
    background: linear-gradient(135deg, var(--accent, #6c5ce7), #7c6cf7);
    border: none;
    color: #fff;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    cursor: pointer;
    transition: all .25s ease;
    box-shadow: 0 3px 10px rgba(108,92,231,0.3);
}
.modern-audio-player .control-btn:hover {
    background: linear-gradient(135deg, #5b4bd6, #6c5ce7);
    transform: scale(1.06);
    box-shadow: 0 5px 16px rgba(108,92,231,0.45);
}
.modern-audio-player .control-btn.play-pause {
    width: 52px;
    height: 52px;
    font-size: 18px;
}
.modern-audio-player .player-info {
    flex: 1;
    min-width: 0;
    margin: 0 12px;
}
.modern-audio-player .player-info .track-title {
    font-weight: 600;
    color: #fff;
    font-size: 1.05rem;
    margin-bottom: 3px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.modern-audio-player .player-info .track-artist {
    color: #8e8ea0;
    font-size: .88rem;
    margin-bottom: 8px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.modern-audio-player .progress-container {
    width: 100%;
}
.modern-audio-player .progress-bar {
    width: 100%;
    height: 5px;
    background: rgba(255,255,255,0.12);
    border-radius: 3px;
    cursor: pointer;
    margin-bottom: 4px;
    overflow: hidden;
}
.modern-audio-player .progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--accent, #6c5ce7), var(--accent-light, #a29bfe));
    border-radius: 3px;
    width: 0%;
    transition: width .1s linear;
}
.modern-audio-player .time-info {
    display: flex;
    justify-content: space-between;
    font-size: .78rem;
    color: #6b6b80;
}
.modern-audio-player .player-actions {
    display: flex;
    align-items: center;
    gap: 12px;
}
.modern-audio-player .download-current {
    background: linear-gradient(135deg, #6c5ce7, #a29bfe) !important;
}
.modern-audio-player .download-current:hover {
    background: linear-gradient(135deg, #5b4bd6, #8b83e0) !important;
}
.modern-audio-player .volume-control {
    display: flex;
    align-items: center;
    gap: 8px;
}
.modern-audio-player .volume-slider {
    width: 80px;
    height: 4px;
    background: rgba(255,255,255,0.15);
    border-radius: 2px;
    outline: none;
    -webkit-appearance: none;
    appearance: none;
}
.modern-audio-player .volume-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 14px;
    height: 14px;
    background: var(--accent, #6c5ce7);
    border-radius: 50%;
    cursor: pointer;
}
.modern-audio-player .volume-slider::-moz-range-thumb {
    width: 14px;
    height: 14px;
    background: var(--accent, #6c5ce7);
    border-radius: 50%;
    cursor: pointer;
    border: none;
}
.modern-audio-player .close-player {
    background: transparent;
    border: none;
    color: #6b6b80;
    font-size: 16px;
    cursor: pointer;
    padding: 5px;
    border-radius: 4px;
    transition: all .25s ease;
}
.modern-audio-player .close-player:hover {
    color: var(--accent, #6c5ce7);
    background: rgba(108,92,231,0.1);
}
.modern-audio-player .player-loading {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #8e8ea0;
    font-size: .85rem;
}
.modern-audio-player .loading-spinner-small {
    width: 16px;
    height: 16px;
    border: 2px solid rgba(108,92,231,0.3);
    border-top-color: var(--accent, #6c5ce7);
    border-radius: 50%;
    animation: spin .8s linear infinite;
}
@media (max-width: 768px) {
    .modern-audio-player .player-container { gap: 12px; padding: 0 8px; }
    .modern-audio-player .control-btn { width: 36px; height: 36px; font-size: 13px; }
    .modern-audio-player .control-btn.play-pause { width: 44px; height: 44px; font-size: 15px; }
    .modern-audio-player .player-info { margin: 0 6px; }
    .modern-audio-player .player-info .track-title { font-size: .92rem; }
    .modern-audio-player .player-info .track-artist { font-size: .8rem; }
    .modern-audio-player .volume-control { display: none; }
    .modern-audio-player .download-current { display: none; }
}

/* ===== SONG REQUEST BOX ===== */
.song-request-section {
    padding: 48px 16px 0;
    margin-bottom: 0;
}
.song-request-box {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 32px;
    position: relative;
    overflow: hidden;
}
.song-request-box::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--accent), var(--accent-light), var(--accent));
}
.request-header {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 24px;
}
.request-icon-wrap {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(108,92,231,0.2), rgba(162,155,254,0.1));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    color: var(--accent-light);
    flex-shrink: 0;
    border: 1px solid rgba(108,92,231,0.2);
}
.request-title {
    font-size: 1.15rem;
    font-weight: 700;
    color: #fff;
    margin: 0;
}
.request-subtitle {
    font-size: 0.8rem;
    color: var(--text-muted);
    margin: 4px 0 0;
}
.request-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 16px;
    margin-bottom: 16px;
}
.request-field-wide {
    grid-column: 1 / -1;
}
.request-field label {
    display: block;
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.request-field label i {
    color: var(--accent-light);
    margin-right: 4px;
}
.req-star {
    color: #ff6b6b;
}
.request-field input,
.request-field textarea {
    width: 100%;
    padding: 10px 14px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: var(--bg-secondary);
    color: #fff;
    font-size: 0.85rem;
    font-family: inherit;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    outline: none;
    resize: none;
}
.request-field input::placeholder,
.request-field textarea::placeholder {
    color: var(--text-muted);
    opacity: 0.6;
}
.request-field input:focus,
.request-field textarea:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(108,92,231,0.15);
}
.request-form-footer {
    display: flex;
    align-items: center;
    gap: 16px;
}
.btn-request-submit {
    padding: 10px 28px;
    border-radius: 10px;
    border: none;
    background: linear-gradient(135deg, var(--accent), var(--accent-light));
    color: #fff;
    font-weight: 700;
    font-size: 0.85rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: all 0.25s ease;
    box-shadow: 0 4px 15px rgba(108,92,231,0.3);
}
.btn-request-submit:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 25px rgba(108,92,231,0.4);
}
.btn-request-submit:active {
    transform: translateY(0);
}
.btn-request-submit:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}
.request-hint {
    font-size: 0.72rem;
    color: var(--text-muted);
}
.request-success {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 18px;
    border-radius: 10px;
    background: rgba(46, 213, 115, 0.1);
    border: 1px solid rgba(46, 213, 115, 0.25);
    color: #2ed573;
    font-size: 0.85rem;
    font-weight: 500;
    margin-top: 16px;
    animation: fadeUpIn 0.4s ease both;
}
.request-success i {
    font-size: 1.2rem;
}

@media (max-width: 768px) {
    .song-request-section { padding: 32px 10px 0; }
    .song-request-box { padding: 20px 16px; }
    .request-form-grid {
        grid-template-columns: 1fr;
    }
    .request-form-footer {
        flex-direction: column;
        align-items: stretch;
    }
    .btn-request-submit { justify-content: center; }
    .request-header { gap: 12px; }
    .request-icon-wrap { width: 40px; height: 40px; font-size: 1.1rem; }
    .request-title { font-size: 1rem; }
}

/* ===== CTA CARDS (Request & Submit) ===== */
.cta-cards-section {
    margin-top: 48px;
    padding: 0 16px;
}
.cta-cards-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.cta-card {
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 22px 26px;
    border-radius: var(--radius);
    text-decoration: none;
    border: 1px solid var(--border);
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}
.cta-card::before {
    content: '';
    position: absolute;
    left: 0; top: 0;
    width: 3px; height: 100%;
    border-radius: 3px;
}
.cta-card-request {
    background: linear-gradient(135deg, rgba(108,92,231,0.08), rgba(108,92,231,0.02));
}
.cta-card-request::before {
    background: linear-gradient(180deg, var(--accent), var(--accent-light));
}
.cta-card-request:hover {
    background: linear-gradient(135deg, rgba(108,92,231,0.14), rgba(108,92,231,0.05));
    border-color: rgba(108,92,231,0.3);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(108,92,231,0.15);
}
.cta-card-submit {
    background: linear-gradient(135deg, rgba(46,213,115,0.08), rgba(46,213,115,0.02));
}
.cta-card-submit::before {
    background: linear-gradient(180deg, #2ed573, #7bed9f);
}
.cta-card-submit:hover {
    background: linear-gradient(135deg, rgba(46,213,115,0.14), rgba(46,213,115,0.05));
    border-color: rgba(46,213,115,0.3);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(46,213,115,0.15);
}
.cta-card-icon {
    width: 48px; height: 48px;
    border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem;
    flex-shrink: 0;
}
.cta-card-request .cta-card-icon {
    background: rgba(108,92,231,0.15);
    color: var(--accent-light);
}
.cta-card-submit .cta-card-icon {
    background: rgba(46,213,115,0.15);
    color: #2ed573;
}
.cta-card-body { flex: 1; min-width: 0; }
.cta-card-body h4 {
    font-size: 0.9rem; font-weight: 700; color: #fff;
    margin: 0 0 4px;
}
.cta-card-body p {
    font-size: 0.75rem; color: var(--text-muted);
    margin: 0; line-height: 1.4;
}
.cta-card-arrow {
    font-size: 1.1rem;
    color: var(--text-muted);
    transition: transform 0.25s, color 0.25s;
    flex-shrink: 0;
}
.cta-card:hover .cta-card-arrow {
    transform: translateX(4px);
}
.cta-card-request:hover .cta-card-arrow { color: var(--accent-light); }
.cta-card-submit:hover .cta-card-arrow { color: #2ed573; }

@media (max-width: 768px) {
    .cta-cards-grid { grid-template-columns: 1fr; }
    .cta-card { padding: 18px 20px; gap: 14px; }
    .cta-card-icon { width: 42px; height: 42px; font-size: 1.1rem; }
}

/* ===== FOOTER ===== */
.rpool-footer {
    margin-top: 48px;
    padding: 48px 16px 120px;
    background: var(--bg-secondary);
    border-top: 1px solid var(--border);
    position: relative;
}
.rpool-footer::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(108,92,231,0.4), transparent);
}
.footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 40px;
    margin-bottom: 40px;
}
.footer-brand {
    padding-right: 24px;
}
.footer-logo {
    display: flex;
    align-items: center;
    gap: 0;
    margin-bottom: 12px;
}
.footer-logo-text {
    font-size: 1.5rem;
    font-weight: 800;
    color: #fff;
    letter-spacing: 2px;
}
.footer-logo-dot {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--accent-light);
    letter-spacing: 2px;
}
.footer-tagline {
    font-size: 0.82rem;
    color: var(--text-muted);
    line-height: 1.6;
    margin-bottom: 20px;
}
.footer-social {
    display: flex;
    gap: 10px;
}
.footer-social-link {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: var(--bg-card);
    color: var(--text-muted);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    transition: all 0.25s ease;
    text-decoration: none;
}
.footer-social-link:hover {
    color: var(--accent-light);
    border-color: var(--accent);
    background: rgba(108,92,231,0.1);
    transform: translateY(-2px);
}
.footer-col-title {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 16px;
}
.footer-link {
    display: block;
    font-size: 0.82rem;
    color: var(--text-muted);
    text-decoration: none;
    padding: 5px 0;
    transition: color 0.2s ease, padding-left 0.2s ease;
}
.footer-link:hover {
    color: var(--accent-light);
    padding-left: 6px;
}
.footer-legal {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 20px 0;
    border-top: 1px solid var(--border);
}
.footer-legal .footer-link {
    display: inline;
    font-size: 0.78rem;
    padding: 0;
    color: var(--text-muted);
    opacity: 0.7;
    transition: color 0.2s, opacity 0.2s;
}
.footer-legal .footer-link:hover {
    color: var(--accent-light);
    padding-left: 0;
    opacity: 1;
}
.footer-legal-sep {
    color: rgba(255,255,255,0.15);
    font-size: 0.6rem;
}
.footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 16px;
    border-top: 1px solid var(--border);
}
.footer-copy {
    font-size: 0.75rem;
    color: var(--text-muted);
}
.footer-built {
    font-size: 0.72rem;
    color: var(--text-muted);
}
.footer-contact {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 12px;
}
.footer-contact-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--text-muted);
    text-decoration: none;
    font-size: 0.75rem;
    transition: color 0.2s;
}
.footer-contact-item:hover { color: var(--accent-light); }
.footer-contact-item i { font-size: 0.8rem; opacity: 0.7; }

@media (max-width: 992px) {
    .footer-grid {
        grid-template-columns: 1fr 1fr;
        gap: 32px;
    }
    .footer-brand {
        grid-column: 1 / -1;
        padding-right: 0;
    }
}
@media (max-width: 576px) {
    .rpool-footer { padding: 32px 14px 110px; margin-top: 32px; }
    .footer-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }
    .footer-bottom {
        flex-direction: column;
        gap: 8px;
        text-align: center;
    }
    .footer-legal {
        flex-wrap: wrap;
        justify-content: center;
    }
}

/* ===== UI/UX ENHANCEMENTS ===== */

/* Result count badge */
.result-count-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-secondary);
    background: rgba(108,92,231,0.08);
    border: 1px solid rgba(108,92,231,0.15);
    padding: 4px 12px;
    border-radius: 20px;
    margin-left: 10px;
    vertical-align: middle;
}
.result-count-badge i { color: var(--accent-light); font-size: 0.7rem; }

/* Track list fade transition for AJAX pagination */
.track-list.fade-out {
    opacity: 0;
    transform: translateY(6px);
    transition: opacity 0.2s ease, transform 0.2s ease;
}
.track-list.fade-in {
    opacity: 1;
    transform: none;
    transition: opacity 0.3s ease, transform 0.3s ease;
}

/* Favorite button pulse animation */
@keyframes favPulse {
    0% { transform: scale(1); }
    30% { transform: scale(1.35); }
    60% { transform: scale(0.95); }
    100% { transform: scale(1); }
}
.btn-action-fav.fav-animating {
    animation: favPulse 0.4s ease;
}

/* Focus-visible for interactive elements */
.btn-action:focus-visible,
.btn-action-fav:focus-visible,
.btn-action-more:focus-visible,
.page-link:focus-visible,
.filter-chip-close:focus-visible,
.sort-dropdown-toggle:focus-visible {
    outline: 2px solid var(--accent-light);
    outline-offset: 2px;
}

/* Skeleton stagger delays */
.skeleton-row:nth-child(1) { animation-delay: 0ms; }
.skeleton-row:nth-child(2) { animation-delay: 60ms; }
.skeleton-row:nth-child(3) { animation-delay: 120ms; }
.skeleton-row:nth-child(4) { animation-delay: 180ms; }
.skeleton-row:nth-child(5) { animation-delay: 240ms; }
.skeleton-row:nth-child(6) { animation-delay: 300ms; }
.skeleton-row:nth-child(7) { animation-delay: 360ms; }
.skeleton-row:nth-child(8) { animation-delay: 420ms; }

/* Genre pill hover polish */
.track-genre-pill:active {
    transform: scale(0.95);
}

/* Pagination first/last hidden on small screens */
@media (max-width: 480px) {
    .pagination-custom .page-text {
        display: none;
    }
    .pagination-custom .page-text:nth-child(2),
    .pagination-custom .page-text:nth-last-child(2) {
        display: flex;
    }
    .pagination-info {
        font-size: 0.72rem !important;
    }
}

/* Download button loading state */
.btn-action-dl.dl-loading {
    pointer-events: none;
    position: relative;
}
.btn-action-dl.dl-loading i { visibility: hidden; }
.btn-action-dl.dl-loading::after {
    content: '';
    position: absolute;
    width: 14px; height: 14px;
    border: 2px solid rgba(108,92,231,0.3);
    border-top-color: var(--accent-light);
    border-radius: 50%;
    animation: btnLoadingSpin .6s linear infinite;
}

/* Copy success flash */
@keyframes copyFlash {
    0% { background: rgba(0,184,148,0.15); }
    100% { background: transparent; }
}
.copy-flash {
    animation: copyFlash 0.6s ease;
}

/* RPOOL mini-toast (lightweight, non-blocking) */
.rpool-mini-toast {
    position: fixed;
    bottom: 140px;
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    padding: 10px 20px;
    border-radius: 10px;
    color: #fff;
    font-size: 0.82rem;
    font-weight: 600;
    z-index: 1100;
    display: flex;
    align-items: center;
    gap: 8px;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.25s ease, transform 0.25s ease;
    box-shadow: 0 8px 24px rgba(0,0,0,0.4);
    backdrop-filter: blur(8px);
}
.rpool-mini-toast.show {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
    pointer-events: auto;
}
.rpool-mini-toast.toast-success {
    background: rgba(0,184,148,0.9);
    border: 1px solid rgba(0,184,148,0.4);
}
.rpool-mini-toast.toast-info {
    background: rgba(108,92,231,0.9);
    border: 1px solid rgba(108,92,231,0.4);
}
.rpool-mini-toast.toast-error {
    background: rgba(255,107,107,0.9);
    border: 1px solid rgba(255,107,107,0.4);
}

/* ═══════════════════════════════════════════════════════════════
   LIGHT THEME — Toggle via [data-theme="light"] on <html>
   ═══════════════════════════════════════════════════════════════ */
html[data-theme="light"] {
    --bg-primary: #f5f5fa;
    --bg-secondary: #eeeef4;
    --bg-card: #ffffff;
    --bg-card-hover: #f0f0f8;
    --accent: #6c5ce7;
    --accent-light: #7c6ff0;
    --accent-glow: rgba(108,92,231,0.18);
    --success: #00b894;
    --danger: #e74c3c;
    --warning: #f39c12;
    --text-primary: #1a1a2e;
    --text-secondary: #555570;
    --text-muted: #8888a0;
    --border: rgba(0,0,0,0.08);
    --border-hover: rgba(108,92,231,0.35);
    --gradient-1: linear-gradient(135deg, #6c5ce7 0%, #a29bfe 100%);
    --gradient-2: linear-gradient(135deg, #fd79a8 0%, #e17055 100%);
    --shadow: 0 4px 20px rgba(0,0,0,0.08);
    --shadow-lg: 0 8px 32px rgba(0,0,0,0.12);
}

/* Body & HTML overrides */
html[data-theme="light"] body {
    background: #f3f2fa !important;
    color: var(--text-primary) !important;
}
html[data-theme="light"] html {
    background: #f3f2fa !important;
}

/* Scrollbar */
html[data-theme="light"] ::-webkit-scrollbar-track { background: var(--bg-secondary); }
html[data-theme="light"] ::-webkit-scrollbar-thumb { background: var(--accent); }

/* Navbar */
html[data-theme="light"] .nav-main {
    background: rgba(250,249,255,0.98);
    border-bottom: 1px solid rgba(108,92,231,0.08);
}
html[data-theme="light"] .nav-main.nav-scrolled {
    background: rgba(252,251,255,0.99);
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
html[data-theme="light"] .nav-glow-line {
    opacity: 0.4;
}

/* Search form */
html[data-theme="light"] .nav-search-form {
    background: rgba(108,92,231,0.04);
    border-color: rgba(108,92,231,0.1);
}
html[data-theme="light"] .nav-search-form:focus-within {
    background: rgba(108,92,231,0.06);
    border-color: rgba(108,92,231,0.35);
    box-shadow: 0 0 0 3px rgba(108,92,231,0.08);
}
html[data-theme="light"] .nav-search-input {
    color: #1a1a2e;
}
html[data-theme="light"] .nav-search-input::placeholder {
    color: #8888a0;
}
html[data-theme="light"] .nav-search-kbd {
    background: rgba(0,0,0,0.05);
    border-color: rgba(0,0,0,0.1);
    color: #8888a0;
}
html[data-theme="light"] .nav-filter-select {
    color: #555570;
    border-left-color: rgba(0,0,0,0.08);
}
html[data-theme="light"] .nav-filter-select:hover {
    color: #1a1a2e;
}
html[data-theme="light"] .nav-filter-select option {
    background: #fff;
    color: #1a1a2e;
}
html[data-theme="light"] .nav-reset-btn {
    border-left-color: rgba(0,0,0,0.08);
}
html[data-theme="light"] .nav-filter-toggle {
    border-left-color: rgba(0,0,0,0.08);
    color: #555570;
}
html[data-theme="light"] .nav-filter-toggle:hover { color: #1a1a2e; background: rgba(0,0,0,0.04); }
html[data-theme="light"] .nav-filter-toggle.active { color: var(--accent); background: rgba(108,92,231,0.08); }
html[data-theme="light"] .nav-adv-filters {
    background: #f8f8fc;
    border-top-color: rgba(0,0,0,0.06);
}
html[data-theme="light"] .nav-adv-filters.open { border-top-color: rgba(108,92,231,0.12); }
html[data-theme="light"] .nav-adv-label { color: #555570; }
html[data-theme="light"] .nav-adv-input {
    background: rgba(0,0,0,0.04);
    border-color: rgba(0,0,0,0.1);
    color: #1a1a2e;
}
html[data-theme="light"] .nav-adv-input:focus { border-color: rgba(108,92,231,0.4); background: rgba(108,92,231,0.04); }
html[data-theme="light"] .nav-adv-input::placeholder { color: #999; }
html[data-theme="light"] .nav-adv-select {
    background-color: rgba(0,0,0,0.04);
    border-color: rgba(0,0,0,0.1);
    color: #1a1a2e;
}
html[data-theme="light"] .nav-adv-select:focus { border-color: rgba(108,92,231,0.4); }
html[data-theme="light"] .nav-adv-select option { background: #fff; color: #1a1a2e; }
html[data-theme="light"] .nav-bpm-sep { color: #999; }

/* Logo text */
html[data-theme="light"] .nav-logo-text {
    background: linear-gradient(135deg, #1a1a2e 0%, var(--accent) 100%);
    background-clip: text;
    -webkit-background-clip: text;
}

/* Dropdown */
html[data-theme="light"] .nav-dropdown {
    background: #fefeff;
    border-color: rgba(108,92,231,0.1);
    box-shadow: 0 8px 24px rgba(0,0,0,0.06);
}
html[data-theme="light"] .nav-dropdown-header {
    background: rgba(108,92,231,0.04);
}
html[data-theme="light"] .nav-dropdown-name {
    color: #1a1a2e;
}
html[data-theme="light"] .nav-dropdown-divider {
    background: rgba(0,0,0,0.08);
}
html[data-theme="light"] .nav-dropdown-item:hover {
    background: rgba(108,92,231,0.08);
    color: #1a1a2e;
}

/* Nav pills */
html[data-theme="light"] .nav-bottom {
    border-top-color: rgba(0,0,0,0.06);
}
html[data-theme="light"] .nav-pill {
    color: #555570;
}
html[data-theme="light"] .nav-pill:hover {
    color: var(--accent);
    background: rgba(108,92,231,0.08);
}
html[data-theme="light"] .nav-pill-active {
    color: #fff !important;
}

/* More dropdown */
html[data-theme="light"] .nav-more-dropdown {
    background: #fcfbff;
    border-color: rgba(108,92,231,0.1);
    box-shadow: 0 8px 24px rgba(0,0,0,0.06);
}
html[data-theme="light"] .nav-more-item {
    color: #555570;
}
html[data-theme="light"] .nav-more-item:hover {
    background: rgba(108,92,231,0.08);
    color: var(--accent);
}
html[data-theme="light"] .nav-more-divider {
    background: linear-gradient(90deg, transparent, rgba(108,92,231,0.15), rgba(162,155,254,0.1), transparent);
    height: 1px;
}

/* Track rows */
html[data-theme="light"] .track-row {
    border-bottom: 1px solid transparent;
    border-image: linear-gradient(90deg, transparent 2%, rgba(108,92,231,0.12) 20%, rgba(162,155,254,0.18) 50%, rgba(108,92,231,0.12) 80%, transparent 98%) 1;
}
html[data-theme="light"] .track-row:nth-child(even) {
    background: rgba(108,92,231,0.03);
}
html[data-theme="light"] .track-row:hover {
    background: rgba(108,92,231,0.06);
}
html[data-theme="light"] .track-row.expanded {
    background: rgba(108,92,231,0.08);
}
html[data-theme="light"] .track-row.expanded::after {
    background: linear-gradient(90deg, transparent, rgba(108,92,231,0.25), rgba(162,155,254,0.2), transparent);
}
html[data-theme="light"] .track-row.now-playing {
    background: rgba(108,92,231,0.08) !important;
    border-left-color: var(--accent);
}
html[data-theme="light"] .track-row.now-playing .track-name {
    color: var(--accent);
}
html[data-theme="light"] .track-row.now-playing .track-row-num {
    color: var(--accent);
}
html[data-theme="light"] .track-row-title {
    color: #1a1a2e;
}
html[data-theme="light"] .track-row-subtitle {
    color: #555570;
}

/* Buttons */
html[data-theme="light"] .btn-action {
    background: rgba(108,92,231,0.035);
    border-color: rgba(108,92,231,0.1);
    color: #555570;
}
html[data-theme="light"] .btn-action:hover {
    background: rgba(108,92,231,0.1);
    border-color: rgba(108,92,231,0.2);
    color: var(--accent);
}

/* Genre cards */
html[data-theme="light"] .genre-card {
    background: #faf9ff;
    border: 1px solid rgba(108,92,231,0.12);
    box-shadow: 0 2px 10px rgba(0,0,0,0.04);
}
html[data-theme="light"] .genre-card:hover {
    box-shadow: 0 6px 20px rgba(0,0,0,0.08);
    color: #1a1a2e;
    border-color: var(--gc-from, rgba(108,92,231,0.3));
}
html[data-theme="light"] .genre-card-name {
    color: #555570;
}

/* Dropdown menus */
html[data-theme="light"] .dropdown-menu-dark {
    background: #fff !important;
    border-color: rgba(0,0,0,0.1);
}
html[data-theme="light"] .dropdown-menu-dark .dropdown-item {
    color: #555570;
}
html[data-theme="light"] .dropdown-menu-dark .dropdown-item:hover {
    background: rgba(108,92,231,0.08);
    color: var(--accent);
}

/* Live search dropdown */
html[data-theme="light"] .live-search-dropdown {
    background: #fcfbff;
    border-color: rgba(108,92,231,0.1);
    box-shadow: 0 8px 24px rgba(0,0,0,0.06);
}
html[data-theme="light"] .ls-item {
    color: #1a1a2e;
}
html[data-theme="light"] .ls-item:hover,
html[data-theme="light"] .ls-item.ls-active {
    background: rgba(108,92,231,0.08);
}
html[data-theme="light"] .ls-label {
    color: rgba(0,0,0,0.35);
}

/* Skeleton shimmer (adjust for light bg) */
html[data-theme="light"] .sk-bone {
    background: rgba(108,92,231,0.12);
    border-radius: 6px;
}
html[data-theme="light"] .sk-bone::after {
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(255,255,255,0.5) 20%,
        rgba(255,255,255,0.8) 50%,
        rgba(255,255,255,0.5) 80%,
        transparent 100%
    );
}
html[data-theme="light"] .skeleton-row {
    background: rgba(108,92,231,0.025);
}
html[data-theme="light"] .skeleton-row::after {
    background: linear-gradient(90deg, transparent, rgba(108,92,231,0.12), transparent);
}

/* Footer */
html[data-theme="light"] .rpool-footer {
    background: #e8e7f2;
    border-top: 2px solid rgba(108,92,231,0.15);
}
html[data-theme="light"] .rpool-footer::before {
    background: rgba(108,92,231,0.3);
    height: 2px;
}
html[data-theme="light"] .footer-col-title { color: #1a1a2e; }
html[data-theme="light"] .footer-link { color: #555570; }
html[data-theme="light"] .footer-link:hover { color: var(--accent); }
html[data-theme="light"] .footer-tagline { color: #8888a0; }
html[data-theme="light"] .footer-logo-text { color: #1a1a2e; }
html[data-theme="light"] .footer-copy { color: #8888a0; }

/* Track detail panel */
html[data-theme="light"] .track-detail-panel {
    background: #faf9ff;
    border: 1px solid rgba(108,92,231,0.15);
    box-shadow: 0 4px 16px rgba(0,0,0,0.06);
}

/* Cards & containers */
html[data-theme="light"] .song-request-box {
    background: #faf9ff;
    border: 1px solid rgba(108,92,231,0.15);
    box-shadow: 0 4px 16px rgba(0,0,0,0.04);
}
html[data-theme="light"] .request-field input,
html[data-theme="light"] .request-field textarea {
    background: #f5f4fa;
    border-color: rgba(108,92,231,0.12);
    color: #1a1a2e;
}
html[data-theme="light"] .request-title { color: #1a1a2e; }

/* Mobile dropdown portal */
html[data-theme="light"] .nav-dropdown.mobile-portal {
    background: #fcfbff !important;
    border-top-color: rgba(108,92,231,0.12) !important;
    box-shadow: 0 -4px 16px rgba(0,0,0,0.06) !important;
}

/* CTA cards */
html[data-theme="light"] .cta-card {
    background: #faf9ff;
    border: 1px solid rgba(108,92,231,0.12);
    box-shadow: 0 2px 10px rgba(0,0,0,0.04);
}
html[data-theme="light"] .cta-card:hover {
    box-shadow: 0 6px 20px rgba(0,0,0,0.06);
    border-color: rgba(108,92,231,0.22);
}
html[data-theme="light"] .cta-card-body h4 { color: #1a1a2e; }

/* Player */
html[data-theme="light"] .modern-audio-player {
    background: rgba(252,251,255,0.99) !important;
    border-color: rgba(108,92,231,0.1) !important;
    box-shadow: 0 -2px 12px rgba(0,0,0,0.06) !important;
}
html[data-theme="light"] .modern-audio-player .track-title { color: #1a1a2e; }
html[data-theme="light"] .modern-audio-player .track-artist { color: #555570; }
html[data-theme="light"] .modern-audio-player .control-btn {
    background: rgba(0,0,0,0.04);
    color: #555570;
}
html[data-theme="light"] .modern-audio-player .control-btn:hover {
    background: rgba(108,92,231,0.1);
    color: var(--accent);
}
html[data-theme="light"] .modern-audio-player .progress-bar-bg {
    background: rgba(0,0,0,0.1);
}
html[data-theme="light"] .modern-audio-player .volume-slider {
    background: rgba(0,0,0,0.15);
}
html[data-theme="light"] .modern-audio-player .time-info { color: #8888a0; }
html[data-theme="light"] .modern-audio-player .close-player { color: #8888a0; }

/* Toast */
html[data-theme="light"] .rpool-mini-toast {
    box-shadow: 0 8px 24px rgba(0,0,0,0.15);
}

/* SweetAlert2 popup override */
html[data-theme="light"] .swal2-popup {
    background: #ffffff !important;
    color: #1a1a2e !important;
    box-shadow: 0 8px 24px rgba(0,0,0,0.08) !important;
}
html[data-theme="light"] .swal2-title { color: #1a1a2e !important; }
html[data-theme="light"] .swal2-html-container { color: #555570 !important; }

/* ===== Theme Toggle — Sliding Switch ===== */
.nav-theme-toggle {
    position: relative;
    display: flex;
    align-items: center;
    width: 56px;
    height: 28px;
    border-radius: 50px;
    border: 1px solid rgba(108,92,231,0.25);
    background: linear-gradient(135deg, #1a1a2e, #2a2a40);
    cursor: pointer;
    transition: all .4s cubic-bezier(0.4,0,0.2,1);
    margin-right: 2px;
    flex-shrink: 0;
    padding: 0;
    overflow: hidden;
}
.nav-theme-toggle::before {
    content: '';
    position: absolute;
    top: 3px;
    left: 3px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: linear-gradient(135deg, #6c5ce7, #a29bfe);
    box-shadow: 0 2px 8px rgba(108,92,231,0.5);
    transition: all .4s cubic-bezier(0.4,0,0.2,1);
    z-index: 2;
}
.nav-theme-toggle .bi-moon-stars-fill {
    position: absolute;
    left: 8px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 0.7rem;
    color: rgba(255,255,255,0.7);
    z-index: 1;
    transition: opacity .3s ease;
}
.nav-theme-toggle .bi-sun-fill {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 0.75rem;
    color: rgba(255,255,255,0.3);
    z-index: 1;
    transition: opacity .3s ease;
}
.nav-theme-toggle:hover {
    border-color: rgba(108,92,231,0.5);
    box-shadow: 0 0 12px rgba(108,92,231,0.2);
}

/* Light mode — slide indicator to right */
html[data-theme="light"] .nav-theme-toggle {
    background: #eeedf5;
    border-color: rgba(108,92,231,0.2);
}
html[data-theme="light"] .nav-theme-toggle::before {
    left: calc(100% - 23px);
    background: linear-gradient(135deg, #f9a825, #ffcc02);
    box-shadow: 0 2px 8px rgba(249,168,37,0.5);
}
html[data-theme="light"] .nav-theme-toggle .bi-moon-stars-fill {
    color: rgba(0,0,0,0.2);
}
html[data-theme="light"] .nav-theme-toggle .bi-sun-fill {
    color: rgba(249,168,37,0.9);
}
html[data-theme="light"] .nav-theme-toggle:hover {
    border-color: rgba(249,168,37,0.4);
    box-shadow: 0 0 12px rgba(249,168,37,0.15);
}

/* Style.css legacy overrides for light theme */
html[data-theme="light"] .container-narrow {
    background: rgba(255,255,255,0.96);
    border: 1px solid rgba(108,92,231,0.1);
    box-shadow: 0 2px 16px rgba(0,0,0,0.04);
}
html[data-theme="light"] .card-box {
    background: #faf9ff;
    border: 1px solid rgba(108,92,231,0.12);
    box-shadow: 0 2px 12px rgba(0,0,0,0.04);
}
html[data-theme="light"] .section-title {
    color: var(--accent);
}
html[data-theme="light"] .list-group-item {
    background: linear-gradient(135deg, #f8f6ff 0%, #f0f0f8 100%);
    border-color: rgba(108,92,231,0.08);
    color: #1a1a2e;
}
html[data-theme="light"] table.dataTable td {
    background: #fefeff;
    color: #1a1a2e;
    border-color: rgba(108,92,231,0.08);
}
html[data-theme="light"] table.dataTable th {
    background: #edeaf9;
    color: #1a1a2e;
    border-color: rgba(108,92,231,0.1);
}
html[data-theme="light"] table.dataTable {
    background: #f2f0fa;
    box-shadow: 0 2px 12px rgba(108,92,231,0.06);
    border: 1px solid rgba(108,92,231,0.1);
}
html[data-theme="light"] .btn-download {
    border-color: rgba(108,92,231,0.3) !important;
    color: var(--accent) !important;
    background: rgba(108,92,231,0.06) !important;
}
html[data-theme="light"] .btn-download:hover {
    background: rgba(108,92,231,0.12) !important;
}

/* Version badges */
html[data-theme="light"] .version-badge {
    opacity: 0.9;
}

/* Pagination */
html[data-theme="light"] .dataTables_wrapper .dataTables_paginate {
    background: #f2f0fa;
    box-shadow: 0 2px 12px rgba(108,92,231,0.06);
}
html[data-theme="light"] .dataTables_wrapper .dataTables_paginate ul.pagination li.page-item a.page-link {
    border-color: rgba(108,92,231,0.2) !important;
    background: #faf9fd !important;
    color: var(--accent) !important;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}

/* Page container (for migrated pages: social, submit_song, etc.) */
html[data-theme="light"] .page-container {
    background: #faf9ff;
}
html[data-theme="light"] .page-card {
    background: #faf9ff;
    border: 1px solid rgba(108,92,231,0.12);
    box-shadow: 0 2px 12px rgba(0,0,0,0.04);
}
html[data-theme="light"] .page-header h2 { color: #1a1a2e; }

/* Feature container (favorites, dj-sets, etc.) */
html[data-theme="light"] .feat-container {
    background: #faf9ff;
    border: 1px solid rgba(108,92,231,0.08);
}

/* ===== Additional Light Mode Fixes ===== */

/* Nav pill active — was hardcoded #fff, invisible on light */
html[data-theme="light"] .nav-pill-active {
    color: var(--accent) !important;
}

/* "Home" text in nav pill needs accent color */
html[data-theme="light"] .nav-pill {
    color: #555570;
}
html[data-theme="light"] .nav-pill:hover {
    color: var(--accent);
}

/* Nav stats — boost opacity for light bg */
html[data-theme="light"] .nav-stat {
    opacity: 0.85;
    color: #555570;
}

/* Track row title — hardcoded #fff */
html[data-theme="light"] .track-row-title {
    color: #1a1a2e;
}
/* Track row subtitle */
html[data-theme="light"] .track-row-subtitle {
    color: #555570;
}

/* Sidebar card title — hardcoded #fff */
html[data-theme="light"] .sidebar-card-title {
    color: #1a1a2e;
}

/* Sidebar track name — hardcoded #fff */
html[data-theme="light"] .sidebar-track-name {
    color: #1a1a2e;
}

/* Sidebar card — gradient bg + hover */
html[data-theme="light"] .sidebar-card {
    background: #faf9ff;
    border: 1px solid rgba(108,92,231,0.12);
    border-radius: 16px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.04);
    position: relative;
    overflow: hidden;
}
html[data-theme="light"] .sidebar-card::after {
    transform: scaleX(1) !important;
    background: linear-gradient(90deg, #6c5ce7, #a29bfe, #6c5ce7) !important;
    opacity: 0.5;
    height: 2px !important;
}
html[data-theme="light"] .sidebar-card:hover {
    box-shadow: 0 6px 20px rgba(0,0,0,0.06);
    border-color: rgba(108,92,231,0.2);
}
html[data-theme="light"] .sidebar-card:hover::after {
    opacity: 0.9;
}

/* Browse by Genre header — .text-light override */
html[data-theme="light"] .text-light {
    color: #1a1a2e !important;
}

/* Genre see-all hover */
html[data-theme="light"] .genre-see-all:hover {
    color: var(--accent);
}

/* Genre card text */
html[data-theme="light"] .genre-card-name {
    color: #1a1a2e;
}

/* Sort dropdown menu for light mode */
html[data-theme="light"] .sort-dropdown-menu {
    background: #fcfbff;
    border-color: rgba(108,92,231,0.15);
    box-shadow: 0 8px 24px rgba(0,0,0,0.06);
}
html[data-theme="light"] .sort-dropdown-item:hover {
    background: rgba(108,92,231,0.08);
    color: var(--accent);
}
html[data-theme="light"] .sort-dropdown-item.active {
    color: var(--accent);
}

/* Ad banner — elevated with accent shadow */
html[data-theme="light"] .rpool-ad-banner {
    box-shadow: 0 4px 20px rgba(0,0,0,0.06);
    border-radius: 16px;
}
html[data-theme="light"] .rpool-ad-banner:hover {
    box-shadow: 0 8px 28px rgba(0,0,0,0.1);
}
html[data-theme="light"] .rpool-ad-carousel {
    border-radius: 16px;
    box-shadow: 0 4px 24px rgba(108,92,231,0.08);
}

/* Track sort bar header */
html[data-theme="light"] .track-sort-bar {
    background: #eeeef8;
    border-bottom: 2px solid rgba(108,92,231,0.12);
}

/* Track row border and play button */
html[data-theme="light"] .track-row {
    border-bottom: 1px solid transparent;
    border-image: linear-gradient(90deg, transparent, rgba(108,92,231,0.15) 30%, rgba(162,155,254,0.2) 50%, rgba(108,92,231,0.15) 70%, transparent) 1;
}
html[data-theme="light"] .track-row:nth-child(even) {
    background: rgba(108,92,231,0.03);
}
html[data-theme="light"] .btn-action-play {
    background: rgba(108,92,231,0.04);
    border-color: rgba(108,92,231,0.12);
}
html[data-theme="light"] .btn-action-play:hover {
    background: rgba(108,92,231,0.11);
    border-color: rgba(108,92,231,0.25);
}

/* Track list container */
html[data-theme="light"] .track-list {
    background: #faf9ff;
    border: 1px solid rgba(108,92,231,0.1);
    box-shadow: 0 2px 16px rgba(108,92,231,0.06);
}

/* Track genre pill */
html[data-theme="light"] .track-genre-pill {
    background: rgba(108,92,231,0.09);
    color: var(--accent);
    border-color: rgba(108,92,231,0.15);
}

/* Play button SVG (style.css legacy) */
html[data-theme="light"] .play-anim-btn:hover,
html[data-theme="light"] .play-anim-btn.playing {
    background: rgba(108,92,231,0.1);
}
html[data-theme="light"] .play-anim-btn svg {
    fill: var(--accent);
}

/* Artist link */
html[data-theme="light"] .artist-link {
    color: #555570;
}
html[data-theme="light"] .artist-link:hover {
    color: var(--accent);
}
html[data-theme="light"] .artist-sep {
    color: #8888a0;
}

/* Loading overlay */
html[data-theme="light"] .loading-overlay {
    background: rgba(245,243,255,0.92);
}
html[data-theme="light"] .loading-text {
    color: #1a1a2e;
}
html[data-theme="light"] .loading-subtext {
    color: #555570;
}

/* Sidebar btn */
html[data-theme="light"] .sidebar-btn {
    background: #f0edff;
    border: 1px solid rgba(108,92,231,0.12);
    color: #555570;
}
html[data-theme="light"] .sidebar-btn:hover {
    background: rgba(108,92,231,0.09);
    border-color: rgba(108,92,231,0.2);
    color: var(--accent);
}

/* Pagination custom */
html[data-theme="light"] .pagination-custom .page-link {
    background: #fcfbff;
    border-color: rgba(108,92,231,0.1);
    color: #555570;
}
html[data-theme="light"] .pagination-custom .page-link:hover,
html[data-theme="light"] .pagination-custom .page-item.active .page-link {
    background: var(--accent);
    color: #fff;
}

/* Version picker (SweetAlert) */
html[data-theme="light"] .swal-version-popup {
    border-color: rgba(108,92,231,0.1) !important;
}
html[data-theme="light"] .ver-item {
    background: rgba(108,92,231,0.025);
    border-color: rgba(108,92,231,0.06);
}
html[data-theme="light"] .ver-item:hover {
    background: rgba(108,92,231,0.065);
    border-color: rgba(108,92,231,0.2);
}
html[data-theme="light"] .ver-item-title {
    color: #1a1a2e;
}

/* Dropdown name text */
html[data-theme="light"] .nav-dropdown-name {
    color: #1a1a2e;
}

/* Mobile overlay */
html[data-theme="light"] .mobile-dropdown-overlay.show {
    background: rgba(0,0,0,0.25);
}

/* Nav more dropdown shadow */
html[data-theme="light"] .nav-more-dropdown {
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
}

/* Footer player container (style.css legacy) */
html[data-theme="light"] #footerPlayerContainer {
    background: rgba(252,251,255,0.98);
    box-shadow: 0 -1px 8px rgba(0,0,0,0.06);
}
html[data-theme="light"] #footerPlayerBar {
    background: rgba(0,0,0,0.08);
}
html[data-theme="light"] #footerPlayerBarProgress {
    background: var(--accent);
}
html[data-theme="light"] #footerPlayerTime {
    color: #555570;
}

/* ===== COMPREHENSIVE LIGHT MODE COLOR FIXES ===== */

/* --- Navbar extras --- */
html[data-theme="light"] .nav-avatar {
    color: #fff; /* white on gradient bg is fine */
}
html[data-theme="light"] .nav-dropdown-item {
    color: #1a1a2e;
}
html[data-theme="light"] .nav-dropdown-item:hover {
    background: rgba(108,92,231,0.08);
    color: var(--accent);
}
html[data-theme="light"] .nav-dropdown-danger {
    color: #d63031 !important;
}
html[data-theme="light"] .nav-dropdown-danger:hover {
    background: rgba(214,48,49,0.08) !important;
    color: #d63031 !important;
}
html[data-theme="light"] .nav-pill-gem:hover {
    color: var(--accent);
}
html[data-theme="light"] .nav-more-item:hover {
    color: var(--accent);
    background: rgba(108,92,231,0.06);
}

/* --- Filter chips & buttons --- */
html[data-theme="light"] .filter-chip {
    background: rgba(108,92,231,0.07);
    border-color: rgba(108,92,231,0.15);
    color: #1a1a2e;
}
html[data-theme="light"] .filter-chip-close:hover {
    color: var(--accent);
}
html[data-theme="light"] .filter-clear-btn {
    color: #555570;
}
html[data-theme="light"] .filter-clear-btn:hover {
    color: var(--accent);
}
/* Track Library Filters - Light theme */
html[data-theme="light"] .tl-filters {
    background: #fff;
    border-color: rgba(0,0,0,0.08);
}
html[data-theme="light"] .tl-filter-label { color: #555570; }
html[data-theme="light"] .tl-filter-input {
    background: rgba(0,0,0,0.04);
    border-color: rgba(0,0,0,0.1);
    color: #1a1a2e;
}
html[data-theme="light"] .tl-filter-input:focus { border-color: rgba(108,92,231,0.4); background: rgba(108,92,231,0.04); }
html[data-theme="light"] .tl-filter-input::placeholder { color: #999; }
html[data-theme="light"] .tl-filter-select {
    background-color: rgba(0,0,0,0.04);
    border-color: rgba(0,0,0,0.1);
    color: #1a1a2e;
}
html[data-theme="light"] .tl-filter-select:focus { border-color: rgba(108,92,231,0.4); }
html[data-theme="light"] .tl-filter-select option { background: #fff; color: #1a1a2e; }
html[data-theme="light"] .tl-filter-sep { color: #999; }
html[data-theme="light"] .tl-filter-clear { background: rgba(255,118,117,0.08); }
html[data-theme="light"] .btn-reset {
    color: #555570;
    border-color: rgba(108,92,231,0.15);
}
html[data-theme="light"] .btn-reset:hover {
    background: rgba(108,92,231,0.08) !important;
    color: var(--accent) !important;
    border-color: rgba(108,92,231,0.3);
}
html[data-theme="light"] .btn-outline-light {
    border-color: rgba(108,92,231,0.15);
    color: #555570;
}
html[data-theme="light"] .btn-outline-light:hover {
    background: rgba(108,92,231,0.08) !important;
    color: var(--accent) !important;
    border-color: rgba(108,92,231,0.3);
}

/* --- Form controls (search, BPM, key filter) --- */
html[data-theme="light"] .form-control-custom {
    background: #f5f3ff !important;
    color: #1a1a2e !important;
    border-color: rgba(108,92,231,0.15);
}
html[data-theme="light"] .form-control-custom:focus {
    background: #fff !important;
    color: #1a1a2e !important;
    border-color: var(--accent);
}
html[data-theme="light"] .form-control-custom option {
    background: #fff !important;
    color: #1a1a2e !important;
}
html[data-theme="light"] .bpm-controls .form-control {
    background: #f5f3ff !important;
    color: #1a1a2e !important;
    border-color: rgba(108,92,231,0.15) !important;
}
html[data-theme="light"] .bpm-controls .form-control:focus {
    background: #fff !important;
    color: #1a1a2e !important;
}
html[data-theme="light"] #filterBar input[type="search"] {
    background: #f5f3ff !important;
    color: #1a1a2e !important;
    border-color: rgba(108,92,231,0.3) !important;
}
html[data-theme="light"] #filterBar input[type="search"]:focus {
    background: #fff !important;
    color: #1a1a2e !important;
    border-color: var(--accent) !important;
}

/* --- Track detail panel elements --- */
html[data-theme="light"] .detail-value {
    color: #1a1a2e;
}
html[data-theme="light"] .detail-value .artist-link:hover {
    color: var(--accent);
}
html[data-theme="light"] .detail-genre-link {
    color: var(--accent);
}
html[data-theme="light"] .detail-genre-link:hover {
    color: #6c5ce7;
}
html[data-theme="light"] .btn-detail {
    background: #f5f3ff;
    border-color: rgba(108,92,231,0.15);
    color: #1a1a2e;
}
html[data-theme="light"] .btn-detail:hover {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent);
}
html[data-theme="light"] .btn-action.played:hover {
    color: #fff !important;
}

/* --- Genre card elements --- */
html[data-theme="light"] .genre-card-icon {
    color: var(--accent);
}
html[data-theme="light"] .genre-card-active .genre-card-name {
    color: #1a1a2e;
}

/* --- Player bar (new player) --- */
html[data-theme="light"] .transport-btn {
    color: rgba(0,0,0,0.5);
}
html[data-theme="light"] .transport-btn:hover {
    color: var(--accent);
    background: rgba(108,92,231,0.08);
}
html[data-theme="light"] .transport-btn.transport-play {
    color: #1a1a2e;
}
html[data-theme="light"] .transport-btn.playing {
    color: var(--accent);
}
html[data-theme="light"] .player-bar-volume .transport-btn {
    color: rgba(0,0,0,0.4);
}
html[data-theme="light"] .player-bar-volume .transport-btn:hover {
    color: var(--accent);
}
html[data-theme="light"] .volume-slider {
    background: rgba(0,0,0,0.12);
}
html[data-theme="light"] .volume-slider::-webkit-slider-thumb {
    background: var(--accent);
}
html[data-theme="light"] .volume-slider::-moz-range-thumb {
    background: var(--accent);
}
html[data-theme="light"] .player-time {
    color: #555570;
}
html[data-theme="light"] .waveform-wrapper::after {
    color: #1a1a2e;
}
html[data-theme="light"] .player-version-badge {
    color: #555570;
    border-color: rgba(108,92,231,0.15);
}
html[data-theme="light"] .player-version-badge:hover {
    color: var(--accent);
    border-color: var(--accent);
}

/* --- Action buttons in player --- */
html[data-theme="light"] .action-btn {
    color: rgba(0,0,0,0.5);
}
html[data-theme="light"] .action-btn:hover {
    color: var(--accent);
    background: rgba(108,92,231,0.08);
}
html[data-theme="light"] .action-btn-collapse {
    color: rgba(0,0,0,0.4);
}
html[data-theme="light"] .action-btn-collapse:hover {
    color: var(--accent);
}

/* --- Player action menu (right-click/more) --- */
html[data-theme="light"] .player-action-menu {
    background: #fcfbff;
    border-color: rgba(108,92,231,0.1);
    box-shadow: 0 8px 24px rgba(108,92,231,0.1);
}
html[data-theme="light"] .player-action-menu button {
    color: #1a1a2e;
}
html[data-theme="light"] .player-action-menu button:hover {
    background: rgba(108,92,231,0.08);
    color: var(--accent);
}
html[data-theme="light"] .player-action-menu button i {
    color: var(--accent);
}
html[data-theme="light"] .pa-menu-divider {
    background: rgba(108,92,231,0.08);
}

/* --- Sort dropdown items --- */
html[data-theme="light"] .sort-dropdown-item {
    color: #555570;
}
html[data-theme="light"] .sort-dropdown-item:hover {
    background: rgba(108,92,231,0.08);
    color: var(--accent);
}
html[data-theme="light"] .sort-dropdown-item.active {
    background: rgba(108,92,231,0.1);
    color: var(--accent);
}

/* --- Region / Charts --- */
html[data-theme="light"] .chart-title {
    color: #1a1a2e;
}
html[data-theme="light"] .chart-subtitle,
html[data-theme="light"] .chart-artist {
    color: #555570;
}
html[data-theme="light"] .chart-rank {
    color: #8888a0;
}
html[data-theme="light"] .chart-play-btn {
    color: var(--accent);
}
html[data-theme="light"] .chart-download-btn {
    color: var(--accent);
}
html[data-theme="light"] .region-btn {
    color: #555570;
    border-color: rgba(108,92,231,0.15);
}
html[data-theme="light"] .region-btn:hover {
    color: var(--accent);
    border-color: var(--accent);
}
html[data-theme="light"] .region-btn.active {
    color: #fff;
}
html[data-theme="light"] .charts-loading {
    color: #555570;
}

/* --- Key filter buttons --- */
html[data-theme="light"] .key-btn {
    color: #555570;
    border-color: rgba(108,92,231,0.15);
}
html[data-theme="light"] .key-btn:hover {
    border-color: var(--accent);
    color: var(--accent);
}
html[data-theme="light"] .key-btn.active {
    background: var(--accent) !important;
    color: #fff !important;
    border-color: var(--accent) !important;
}
html[data-theme="light"] .filter-btn {
    color: #555570;
    border-color: rgba(108,92,231,0.15);
}
html[data-theme="light"] .filter-btn:hover {
    color: var(--accent);
    border-color: var(--accent);
}
html[data-theme="light"] .filter-btn.active {
    color: #fff;
}

/* --- Onboarding tooltip --- */
html[data-theme="light"] .onboarding-tooltip {
    background: #fcfbff;
    border-color: rgba(108,92,231,0.15);
    box-shadow: 0 8px 32px rgba(108,92,231,0.12);
}
html[data-theme="light"] .onboarding-title {
    color: #1a1a2e;
}
html[data-theme="light"] .onboarding-desc {
    color: #555570;
}
html[data-theme="light"] .onboarding-btn-skip {
    color: #8888a0;
}
html[data-theme="light"] .onboarding-btn-skip:hover {
    color: #555570;
    background: rgba(108,92,231,0.06);
}
html[data-theme="light"] .onboarding-btn-next {
    color: #fff;
}

/* --- Cache status --- */
html[data-theme="light"] .cache-status {
    background: #f5f3ff;
    color: #1a1a2e;
    border-color: rgba(108,92,231,0.15);
}

/* --- Modal (Bootstrap) --- */
html[data-theme="light"] .modal-content {
    background: #fcfbff !important;
    color: #1a1a2e !important;
    border-color: rgba(108,92,231,0.15) !important;
}
html[data-theme="light"] .modal-header {
    border-color: rgba(108,92,231,0.1);
    color: #1a1a2e;
}
html[data-theme="light"] .modal-body {
    color: #1a1a2e;
}
html[data-theme="light"] .modal-footer {
    border-color: rgba(108,92,231,0.1);
}

/* --- Notification dropdown --- */
html[data-theme="light"] .nav-notif-list {
    background: #fcfbff;
}
html[data-theme="light"] .nav-notif-item {
    color: #1a1a2e;
    border-color: rgba(108,92,231,0.06);
}
html[data-theme="light"] .nav-notif-item:hover {
    background: rgba(108,92,231,0.04);
}
html[data-theme="light"] .nav-notif-title {
    color: #1a1a2e;
}
html[data-theme="light"] .nav-notif-time {
    color: #8888a0;
}

/* --- Verified badge (white on accent bg - keep white) --- */
html[data-theme="light"] .verified-badge i {
    color: #fff;
}

/* --- style.css legacy: sidebar track list & titles --- */
html[data-theme="light"] .sidebar-track-list .list-title {
    color: #1a1a2e;
}
html[data-theme="light"] .sidebar-track-artist {
    color: #555570;
}

/* --- Vinyl/loading spinner area --- */
html[data-theme="light"] .vinyl-label i {
    color: var(--accent);
}

/* --- SweetAlert crate/set picker items inline --- */
html[data-theme="light"] .swal-crate-pick {
    background: rgba(108,92,231,0.04) !important;
    border-color: rgba(108,92,231,0.1) !important;
    color: #1a1a2e !important;
}
html[data-theme="light"] .swal-crate-pick:hover {
    background: rgba(108,92,231,0.1) !important;
    border-color: rgba(108,92,231,0.2) !important;
}

/* --- Version picker text inside SweetAlert --- */
html[data-theme="light"] .ver-item-title {
    color: #1a1a2e;
}
html[data-theme="light"] .ver-btn-play {
    color: var(--accent);
    border-color: rgba(108,92,231,0.2);
}
html[data-theme="light"] .ver-btn-dl {
    color: #fff; /* white on accent gradient bg is fine */
}
html[data-theme="light"] .ver-upgrade-btn {
    color: #fff; /* white on accent gradient bg is fine */
}

/* --- Social toast --- */
html[data-theme="light"] .social-toast {
    background: #ffffff !important;
    border-color: rgba(108,92,231,0.12) !important;
    box-shadow: 0 8px 24px rgba(108,92,231,0.1) !important;
}
html[data-theme="light"] .social-toast-title {
    color: #1a1a2e;
}
html[data-theme="light"] .social-toast-close {
    color: #8888a0;
}
html[data-theme="light"] .social-toast-close:hover {
    color: var(--accent);
}

/* --- Misc: play/download icons on cards --- */
html[data-theme="light"] .play-icon,
html[data-theme="light"] .download-icon {
    color: var(--accent);
}

/* --- "control-btn" (old player) --- */
html[data-theme="light"] .control-btn {
    color: #555570;
}
html[data-theme="light"] .control-btn:hover {
    color: var(--accent);
}

/* --- Track row ::after glow in light mode --- */
html[data-theme="light"] .track-row::after {
    background: linear-gradient(90deg, transparent, rgba(108,92,231,0.12), rgba(162,155,254,0.08), transparent);
}
html[data-theme="light"] .track-row:hover::after {
    background: linear-gradient(90deg, transparent, rgba(108,92,231,0.25), rgba(162,155,254,0.2), transparent);
}
html[data-theme="light"] .track-row::before {
    background: var(--accent);
}

/* ===== GLOBAL SWAL2 LIGHT MODE ===== */
html[data-theme="light"] .swal2-popup {
    background: #ffffff !important;
    color: #1a1a2e !important;
}
html[data-theme="light"] .swal2-title {
    color: #1a1a2e !important;
}
html[data-theme="light"] .swal2-html-container {
    color: #555570 !important;
}
html[data-theme="light"] .swal2-html-container b,
html[data-theme="light"] .swal2-html-container strong {
    color: #1a1a2e !important;
}
html[data-theme="light"] .swal2-close {
    color: #8888a0 !important;
}
html[data-theme="light"] .swal2-close:hover {
    color: #1a1a2e !important;
}
html[data-theme="light"] .swal2-input,
html[data-theme="light"] .swal2-textarea {
    background: #f8f7ff !important;
    color: #1a1a2e !important;
    border-color: rgba(108,92,231,0.2) !important;
}
html[data-theme="light"] .swal2-input:focus,
html[data-theme="light"] .swal2-textarea:focus {
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 3px rgba(108,92,231,0.15) !important;
}

/* ═══ LIGHT THEME — Remaining components ═══ */

/* Top 50 horizontal scroll section (inline in home.php) */
html[data-theme="light"] .top50-subtitle {
    color: var(--text-muted);
    background: rgba(0,0,0,0.04);
}
html[data-theme="light"] .top50-card {
    background: var(--bg-card);
    border-color: rgba(0,0,0,0.08);
    box-shadow: 0 2px 10px rgba(108,92,231,0.04);
}
html[data-theme="light"] .top50-card:hover {
    border-color: rgba(108,92,231,0.2);
    box-shadow: 0 8px 24px rgba(108,92,231,0.1);
}
html[data-theme="light"] .top50-scroll-btn {
    background: var(--bg-card);
    border-color: rgba(0,0,0,0.08);
    color: var(--text-primary);
    box-shadow: 0 4px 16px rgba(0,0,0,0.08);
}
html[data-theme="light"] .top50-scroll-btn:hover {
    background: var(--accent);
    color: #fff;
}

/* Social toast notification text */
html[data-theme="light"] .social-toast-text {
    color: #555570;
}

/* Version picker (SweetAlert version list) */
html[data-theme="light"] .ver-item {
    background: rgba(108,92,231,0.04);
    border-color: rgba(108,92,231,0.08);
}
html[data-theme="light"] .ver-item:hover {
    background: rgba(108,92,231,0.08);
    border-color: rgba(108,92,231,0.2);
}
html[data-theme="light"] .ver-item-title {
    color: var(--text-primary);
}
html[data-theme="light"] .ver-item-meta {
    color: #8888a0;
}
html[data-theme="light"] .ver-btn-lock {
    border-color: rgba(0,0,0,0.1);
    background: rgba(0,0,0,0.03);
    color: #8888a0;
}

/* Vinyl disc (decorative) */
html[data-theme="light"] .vinyl-disc {
    background: conic-gradient(from 0deg, #e8e6f2, #d0cee8, #e8e6f2, #d0cee8, #e8e6f2) !important;
    opacity: 0.6;
}

/* Onboarding tooltip */
html[data-theme="light"] .onboarding-tooltip {
    background: #fcfbff;
    border-color: rgba(108,92,231,0.15);
    color: var(--text-primary);
    box-shadow: 0 8px 32px rgba(108,92,231,0.12);
}

/* Player action menu */
html[data-theme="light"] .player-action-menu {
    background: #fcfbff;
    border-color: rgba(108,92,231,0.1);
    box-shadow: 0 12px 40px rgba(108,92,231,0.1);
}

/* Catch-all: common dark rgba patterns used across many elements */
html[data-theme="light"] .swal-version-popup {
    border-color: rgba(0,0,0,0.08) !important;
}
html[data-theme="light"] .swal-version-popup .swal2-close {
    color: #8888a0 !important;
}
html[data-theme="light"] .swal-version-popup .swal2-close:hover {
    color: #1a1a2e !important;
}

/* ═══ LAYOUT FIX: Additional responsive breakpoints ═══ */
@media (max-width: 1024px) {
    .sort-artist { width: 120px; }
    .track-row-artist { width: 120px; }
}

@media (max-width: 900px) {
    .sort-artist { width: 100px; }
    .track-row-artist { width: 100px; }
    .track-row { padding: 9px 14px; }
    .tl-filters { gap: 10px; padding: 10px 12px; }
    .tl-filter-label { font-size: 0.65rem; }
    .tl-filter-input { width: 52px; height: 28px; font-size: 0.75rem; }
    .tl-filter-select { height: 28px; font-size: 0.75rem; min-width: 70px; }
    .tl-filter-apply { width: 28px; height: 28px; font-size: 0.7rem; }
    .tl-filter-clear { width: 24px; height: 24px; font-size: 0.6rem; }
}

@media (max-width: 768px) {
    .nav-bottom { padding: 6px 16px; }
    .nav-top { padding: 10px 16px; }
    .detail-inner {
        padding: 16px;
        gap: 16px;
        flex-direction: column;
    }
    .detail-info {
        grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
        gap: 10px;
    }
    .pagination-wrapper {
        margin-bottom: 90px;
        padding: 16px;
    }
    .pagination-custom .page-link {
        width: 36px;
        height: 36px;
        font-size: 0.78rem;
    }
    .active-filters-bar {
        padding: 12px 14px;
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        align-items: center;
    }
    .filter-chip {
        padding: 4px 10px;
        font-size: 0.7rem;
    }
    .track-sort-bar {
        padding: 10px 12px;
    }
}

@media (max-width: 480px) {
    .left-pane { padding: 8px; }
    .right-pane { padding: 8px; }
    .container-narrow { padding: 6px !important; margin: 6px auto !important; }
    .track-library-container { padding: 10px; }
    .track-row {
        grid-template-columns: 24px 1fr auto;
        padding: 8px 8px;
        gap: 1px 6px;
    }
    .track-row-play { width: 24px; }
    .track-row-num { width: 24px; font-size: 0.6rem; }
    .track-row-title { font-size: 0.74rem; line-height: 1.25; }
    .track-row-subtitle { font-size: 0.62rem; }
    .track-row-meta { gap: 3px; }
    .track-genre-pill { width: 60px; padding: 1px 5px; font-size: 0.55rem; }
    .track-bpm, .track-key { font-size: 0.58rem; }
    .track-row-actions { gap: 3px; }
    .btn-action,
    .btn-action-play {
        width: 24px !important;
        height: 24px !important;
        max-width: 24px !important;
        max-height: 24px !important;
        min-width: 24px !important;
        min-height: 24px !important;
        font-size: 0.6rem;
    }
    .sidebar-card { padding: 10px; margin-bottom: 16px; }
    .sidebar-track { padding: 6px 4px; }
    .pagination-wrapper { margin-bottom: 80px; padding: 10px; }
    .pagination-custom .page-link { width: 30px; height: 30px; font-size: 0.68rem; }
}
