:root{--bg:#4a5558;--bg2:#3c4649;--card:#1c1c1c;--card2:#222;--border:#333;--border2:#444;--text:#fff;--text2:#ddd;--text3:#999;--text4:#666;--accent:#00bfa5;--accent2:#009688;--red:#ff0055;--buy:#00bfa5;--buy-hover:#009688;--nav-h:64px;--radius:10px;--radius-lg:16px;--trans:0.2s ease;}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Barlow',sans-serif;background:var(--bg);color:var(--text);line-height:1.55;overflow-x:hidden;min-height:100vh;font-size:14px;}
a{text-decoration:none;color:inherit;}ul{list-style:none;}img{display:block;max-width:100%;}button{cursor:pointer;font-family:inherit;border:none;}
::-webkit-scrollbar{width:6px;height:6px;}::-webkit-scrollbar-track{background:var(--bg2);}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}

/* NAV */
.site-nav{position:fixed;top:0;left:0;right:0;height:64px;z-index:1000;display:flex;align-items:center;background:#526065;border-bottom:1px solid rgba(0,0,0,.15);}
.nav-inner{width:100%;max-width:1400px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:160px 1fr 120px;align-items:center;gap:20px;height:100%;}
.nav-logo{display:flex;flex-direction:column;line-height:1;flex-shrink:0;text-decoration:none;}
.nav-logo .logo-iam{font-size:.55rem;font-weight:700;letter-spacing:3px;color:var(--text3);text-transform:uppercase;}
.nav-logo .logo-ghost{font-size:1.4rem;font-weight:900;color:var(--text);letter-spacing:-0.5px;line-height:1;}
.nav-logo .logo-producer{font-size:.48rem;font-weight:600;letter-spacing:4px;color:var(--text3);text-transform:uppercase;}
.nav-links{display:flex;align-items:center;justify-content:center;gap:4px;margin:0;padding:0;list-style:none;}
.nav-links>li>a{display:inline-block;padding:7px 11px;color:var(--text2);font-size:.82rem;font-weight:500;letter-spacing:.3px;text-transform:uppercase;transition:color var(--trans);white-space:nowrap;border-radius:6px;}
.nav-links>li>a:hover,.nav-links>li>a.active{color:var(--text);background:rgba(255,255,255,.07);}
.nav-drop{position:relative;}
.nav-drop-menu{position:absolute;top:calc(100% + 4px);left:0;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:8px;min-width:200px;max-height:420px;overflow-y:auto;opacity:0;visibility:hidden;transform:translateY(-6px);transition:all .18s ease;z-index:200;box-shadow:0 20px 60px rgba(0,0,0,.5);}
.nav-drop:hover .nav-drop-menu{opacity:1;visibility:visible;transform:translateY(0);}
.nav-drop-menu a{display:block;padding:8px 12px;color:var(--text3);font-size:.82rem;font-weight:500;border-radius:8px;transition:all var(--trans);}
.nav-drop-menu a:hover{color:var(--text);background:rgba(255,255,255,.06);}
.nav-drop-menu .drop-sep{border:none;border-top:1px solid var(--border);margin:5px 0;}
.nav-right{display:flex;align-items:center;gap:6px;flex-shrink:0;margin-left:auto;}
.nav-icon-btn{position:relative;display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:rgba(0,0,0,.25);color:var(--text);transition:all var(--trans);font-size:.95rem;text-decoration:none;}
.nav-icon-btn:hover{background:rgba(0,0,0,.4);}
.cart-badge{position:absolute;top:-2px;right:-2px;background:var(--accent);color:#fff;font-size:.58rem;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.nav-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 18px;border-radius:20px;font-size:.82rem;font-weight:600;transition:all var(--trans);white-space:nowrap;border:1px solid transparent;}
.nav-btn-ghost{background:rgba(0,0,0,.25);border-color:rgba(255,255,255,.2);color:var(--text);}
.nav-btn-ghost:hover{background:rgba(0,0,0,.4);}
.nav-btn-primary{background:var(--accent);color:#fff;}
.nav-btn-primary:hover{background:var(--accent2);}
.avatar-wrap{display:flex;align-items:center;gap:7px;padding:4px 10px 4px 4px;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.15);border-radius:30px;transition:all var(--trans);cursor:pointer;}
.avatar-wrap:hover{background:rgba(0,0,0,.4);}
.avatar-circle{width:30px;height:30px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#fff;flex-shrink:0;}
.avatar-name{font-size:.78rem;font-weight:600;color:var(--text);max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.mobile-btn{display:none;align-items:center;justify-content:center;width:38px;height:38px;background:rgba(0,0,0,.25);border-radius:50%;color:var(--text);font-size:1rem;border:none;}
.mob-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(4px);z-index:1100;opacity:0;visibility:hidden;transition:all .3s;}
.mob-overlay.open{opacity:1;visibility:visible;}
.mob-sidebar{position:fixed;top:0;left:-290px;width:270px;height:100vh;background:var(--card);border-right:1px solid var(--border);z-index:1200;transition:left .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;display:flex;flex-direction:column;}
.mob-sidebar.open{left:0;}
.mob-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border);}
.mob-close{width:32px;height:32px;border-radius:8px;background:rgba(255,255,255,.05);border:1px solid var(--border);color:var(--text3);display:flex;align-items:center;justify-content:center;font-size:.9rem;}
.mob-nav{padding:10px;flex:1;}
.mob-nav a{display:flex;align-items:center;gap:11px;padding:10px 13px;color:var(--text3);font-size:.88rem;font-weight:500;border-radius:9px;transition:all var(--trans);margin-bottom:1px;}
.mob-nav a:hover{color:var(--text);background:rgba(255,255,255,.06);}
.mob-nav a i{width:18px;font-size:.85rem;color:var(--text4);}
.mob-nav .mob-section{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text4);padding:12px 13px 5px;}
.mob-nav hr{border:none;border-top:1px solid var(--border);margin:6px 0;}
.mob-foot{padding:14px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:7px;}
.mob-foot a{display:flex;align-items:center;justify-content:center;padding:10px;border-radius:9px;font-size:.85rem;font-weight:600;text-align:center;}
.mob-login{background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--text);}
.mob-register{background:var(--accent);color:#fff;}
.main-wrap{padding-top:64px;}

/* GENRES TAB */
.genres-tab{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:500;}
.genres-tab-btn{display:block;background:var(--accent);color:#fff;font-size:.65rem;font-weight:800;letter-spacing:3px;text-transform:uppercase;padding:14px 7px;border-radius:8px 0 0 8px;writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);cursor:pointer;transition:all var(--trans);text-decoration:none;}
.genres-tab-btn:hover{background:var(--accent2);}

/* HERO */
.hero-section{text-align:center;padding:60px 20px 40px;background:var(--bg);}
.hero-title{font-size:clamp(3rem,8vw,7rem);font-weight:900;line-height:1;text-transform:uppercase;letter-spacing:-2px;margin-bottom:16px;}
.hero-title .t-white{color:var(--text);}
.hero-title .t-gray{color:rgba(255,255,255,.35);}
.hero-title .t-cyan{color:var(--accent);}
.hero-sub{color:var(--text3);font-size:.9rem;margin-bottom:28px;line-height:1.7;}
.hero-search{position:relative;max-width:500px;margin:0 auto 24px;}
.hero-search input{width:100%;padding:14px 50px 14px 20px;background:#1a1a1a;border:none;border-radius:30px;color:var(--text);font-size:.9rem;outline:none;font-family:inherit;}
.hero-search button{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:transparent;color:var(--text3);font-size:.9rem;display:flex;align-items:center;justify-content:center;}
.hero-badges{display:flex;flex-direction:column;gap:10px;align-items:flex-start;max-width:500px;margin:0 auto;}
.hero-badge-row{display:flex;align-items:center;gap:14px;}
.badge-pill{padding:6px 18px;border-radius:20px;font-size:.78rem;font-weight:700;white-space:nowrap;}
.badge-premium{background:rgba(255,255,255,.15);color:var(--text);}
.badge-supersale{background:var(--accent);color:#fff;}
.badge-totalsale{background:var(--red);color:#fff;}
.hero-badge-desc{color:var(--text3);font-size:.82rem;}

/* FILTER BAR */
.filter-bar{display:flex;align-items:center;gap:10px;padding:12px 20px;flex-wrap:wrap;}
.filter-select{appearance:none;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.15);border-radius:20px;color:var(--text);padding:7px 30px 7px 14px;font-size:.8rem;font-weight:600;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23aaa'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;min-width:90px;}
.filter-select:focus{outline:none;border-color:var(--accent);}
.filter-hide-sold{display:flex;align-items:center;gap:7px;margin-left:auto;font-size:.82rem;color:var(--text3);cursor:pointer;}
.filter-hide-sold input{accent-color:var(--accent);}

/* SONG CARDS */
/* SONG CARDS */
.songs-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 10px;
    padding: 20px 10px;
    max-width: 1400px;
    margin: 0 auto;
}

@media (max-width: 1400px) {
    .songs-grid { grid-template-columns: repeat(5, 1fr); gap: 10px; }
}
@media (max-width: 1100px) {
    .songs-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 850px) {
    .songs-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px) {
    .songs-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
}
@media (max-width: 380px) {
    .songs-grid { grid-template-columns: repeat(2, 1fr); gap: 6px; }
}

.song-card {
    position: relative;
    transition: transform 0.3s cubic-bezier(0.2, 0, 0.2, 1), box-shadow 0.3s ease;
    min-height: 0;
    display: flex;
    flex-direction: column;
    margin-top: 14px;
}

.song-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 30px 60px rgba(0,0,0,0.5) !important;
}

.song-card .card-badge-label {
    position: absolute;
    top: -12px;
    left: 18px;
    padding: 5px 12px;
    background: #1c2b2e !important;
    border: 1px solid rgba(255,255,255,0.25) !important;
    border-radius: 7px;
    color: #fff;
    font-size: 0.62rem;
    font-weight: 800;
    letter-spacing: 1.5px;
    z-index: 10;
    box-shadow: 0 4px 12px rgba(0,0,0,0.4);
}
.badge-hot { background: #00bcd4 !important; border-color: #00e5ff !important; }
.badge-totalsale { background: #f50057 !important; border-color: #ff4081 !important; }

.song-card:hover .play-overlay {
    opacity: 1 !important;
}

.song-card:hover .card-img-area img {
    transform: scale(1.05);
}

.play-overlay {
    transition: opacity 0.3s ease !important;
}
.card-play-bar{position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--buy);}
.card-sold-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3);}
.card-sold-text{font-size:3.5rem;font-weight:900;color:var(--red);text-transform:uppercase;letter-spacing:-2px;transform:rotate(-15deg);opacity:.9;font-style:italic;}
.card-body{padding:8px 8px 4px;}
.card-genres{display:flex;flex-direction:column;gap:0px;min-height:50px;}
.card-genres span{color:#8a9ea5;font-size:.7rem;text-align:center;font-weight:400;line-height:1.55;}
.card-price-wrap{text-align:center;margin:5px 0 6px;}
.card-price{font-size:1rem;font-weight:800;color:#fff;}
.card-old-price{font-size:.8rem;color:var(--text4);text-decoration:line-through;margin-right:6px;}
.card-discount{background:var(--accent);color:#fff;font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:10px;}
.card-info-btn{display:inline-block;padding:5px 18px;border-radius:20px;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.75);font-size:.72rem;font-weight:500;margin:3px auto 8px;text-align:center;cursor:pointer;transition:all .2s;}
.card-info-btn:hover{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.35);}
.card-actions{display:flex;align-items:center;gap:8px;padding:0 6px 8px;}
.card-wish-btn{width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:.85rem;flex-shrink:0;transition:all var(--trans);cursor:pointer;}
.card-wish-btn:hover,.card-wish-btn.active{background:rgba(245,0,87,.15);border-color:#f50057;color:#f50057;}
.card-buy-btn{flex:1;padding:9px 0;background:#00bfa5;color:#fff;border-radius:8px;font-size:.78rem;font-weight:800;text-align:center;letter-spacing:.8px;text-transform:uppercase;transition:all var(--trans);display:block;text-decoration:none;border:none;cursor:pointer;}
.card-buy-btn:hover{background:#009688;box-shadow:0 4px 16px rgba(0,191,165,.35);}

/* FOOTER */
.site-footer{background:#2d3a3e;border-top:1px solid rgba(255,255,255,.05);}
.footer-main{max-width:1400px;margin:0 auto;padding:48px 24px 36px;display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;}
.footer-logo-wrap{display:flex;flex-direction:column;gap:16px;}
.footer-logo{display:flex;flex-direction:column;line-height:1;text-decoration:none;}
.footer-logo .fl-iam{font-size:.55rem;font-weight:700;letter-spacing:3px;color:var(--text4);text-transform:uppercase;}
.footer-logo .fl-ghost{font-size:1.4rem;font-weight:900;color:var(--text);}
.footer-logo .fl-prod{font-size:.48rem;font-weight:600;letter-spacing:4px;color:var(--text4);text-transform:uppercase;}
.footer-links-cols{display:flex;gap:60px;flex-wrap:wrap;}
.footer-col h4{font-size:.72rem;font-weight:600;color:var(--text4);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;}
.footer-col ul{display:flex;flex-direction:column;gap:9px;}
.footer-col ul a{color:var(--text4);font-size:.82rem;transition:color var(--trans);}
.footer-col ul a:hover{color:var(--text2);}
.footer-social-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;}
.footer-social-row a{color:var(--text4);font-size:1.1rem;transition:color var(--trans);}
.footer-social-row a:hover{color:var(--text);}
.footer-bottom{border-top:1px solid var(--border);padding:16px 24px;text-align:center;}
.footer-bottom p{color:var(--text4);font-size:.78rem;}

/* LOGIN/REGISTER */
.auth-wrap{min-height:calc(100vh - var(--nav-h));display:flex;align-items:center;justify-content:center;padding:40px 20px;}
.auth-card{background:var(--card);border-radius:16px;width:100%;max-width:480px;overflow:hidden;}
.auth-tabs{display:flex;}
.auth-tab{flex:1;padding:16px;text-align:center;font-size:.9rem;font-weight:600;color:var(--text3);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--trans);background:transparent;border-top:none;border-left:none;border-right:none;}
.auth-tab.active{color:var(--accent);border-bottom-color:var(--accent);}
.auth-body{padding:28px;}
.auth-body label{font-size:.82rem;color:var(--text3);display:block;margin-bottom:6px;}
.auth-body input[type=text],.auth-body input[type=email],.auth-body input[type=password]{width:100%;padding:12px 16px;background:#111;border:1px solid var(--border);border-radius:30px;color:var(--text);font-size:.9rem;outline:none;font-family:inherit;margin-bottom:16px;}
.auth-body input:focus{border-color:var(--accent);}
.auth-submit{width:100%;padding:13px;background:var(--buy);color:#fff;border-radius:30px;font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;transition:all var(--trans);}
.auth-submit:hover{background:var(--buy-hover);}
.auth-forgot{text-align:right;margin:-10px 0 16px;}
.auth-forgot a{color:var(--accent);font-size:.8rem;}
.auth-link{color:var(--accent);font-size:.8rem;}

/* BLOG */
.blog-card{background:var(--card);border-radius:12px;overflow:hidden;display:flex;gap:0;margin-bottom:12px;transition:transform var(--trans);}
.blog-card:hover{transform:translateX(4px);}
.blog-thumb{width:120px;flex-shrink:0;position:relative;}
.blog-thumb img{width:100%;height:100%;object-fit:cover;}
.blog-info{padding:16px 18px;display:flex;align-items:center;}
.blog-info h3{font-size:.9rem;font-weight:600;color:var(--text2);line-height:1.4;}
.tag-pill{display:inline-block;padding:5px 14px;background:var(--card2);border:1px solid var(--border);border-radius:20px;font-size:.75rem;color:var(--text3);margin:3px;}

/* GENRES PAGE */
.genres-hero{text-align:center;padding:50px 20px 36px;}
.genres-hero h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:900;text-transform:uppercase;letter-spacing:-1px;}
.genres-hero h1 .t-cyan{color:var(--accent);}
.genre-btn{display:block;width:100%;padding:12px 16px;background:rgba(0,0,0,.3);border:none;border-radius:8px;color:var(--text2);font-size:.82rem;text-align:center;cursor:pointer;transition:all var(--trans);text-decoration:none;}
.genre-btn:hover{background:rgba(0,0,0,.5);color:var(--text);}
.genres-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:0 20px 40px;}

/* RESPONSIVE */
@media(max-width:1024px){.nav-links{display:none;}.mobile-btn{display:flex;}.nav-btn{display:none;}.genres-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:768px){.songs-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));}.footer-main{flex-direction:column;}.footer-links-cols{gap:30px;}.genres-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:480px){.hero-title{font-size:3rem;letter-spacing:-1px;}.nav-logo .logo-ghost{font-size:1.2rem;}.genres-grid{grid-template-columns:1fr 1fr;}}

/* ===== BOOTSTRAP GLOBAL OVERRIDES ===== */
.input-group-text{background:#111 !important;border:1px solid rgba(255,255,255,.12) !important;color:#aaa !important;border-radius:10px 0 0 10px !important;}
.form-control,.form-select{background:#111 !important;border:1px solid rgba(255,255,255,.12) !important;color:#fff !important;border-radius:0 10px 10px 0 !important;}
.form-select{border-radius:10px !important;}
.form-control:focus,.form-select:focus{border-color:#00bcd4 !important;box-shadow:0 0 0 0.2rem rgba(0,188,212,.25) !important;background:#111 !important;color:#fff !important;}
.form-control::placeholder{color:#666 !important;}
.input-group:focus-within .input-group-text{border-color:#00bcd4 !important;color:#00bcd4 !important;}
.btn-primary{background:#00e5ff !important;border-color:#00e5ff !important;color:#1c282b !important;}
.btn-primary:hover{background:#00b8d4 !important;border-color:#00b8d4 !important;}
.btn-outline-secondary{border-color:rgba(255,255,255,.2) !important;color:#aaa !important;}
.btn-outline-secondary:hover{background:rgba(255,255,255,.08) !important;color:#fff !important;border-color:rgba(255,255,255,.3) !important;}
.text-primary{color:#00e5ff !important;}
.text-muted{color:#8a9ea5 !important;}
.card{background:#1f2b2f !important;border:1px solid #2e3c40 !important;}
.modal-content{background:#1f2b2f !important;border:1px solid #2e3c40 !important;}
.modal-header,.modal-footer{border-color:#2e3c40 !important;}
.dropdown-menu{background:#1f2b2f !important;border:1px solid #2e3c40 !important;}
.dropdown-item{color:#ddd !important;}
.dropdown-item:hover{background:rgba(255,255,255,.06) !important;color:#fff !important;}
.table{color:#ddd !important;}
.table-dark{background:#1a2124 !important;}
.table > :not(caption) > * > *{background:transparent !important;border-color:#2e3c40 !important;}
.nav-tabs{border-color:#2e3c40;}
.nav-tabs .nav-link{color:#aaa;}
.nav-tabs .nav-link.active{background:#1f2b2f;border-color:#2e3c40;color:#fff;}
.nav-tabs .nav-link:hover{color:#fff;border-color:#2e3c40;}
.badge.bg-primary{background:#26a69a !important;}
.badge.bg-danger{background:#f50057 !important;}
.badge.bg-success{background:#26a69a !important;}
.alert-danger{background:rgba(245,0,87,.1) !important;border-color:rgba(245,0,87,.3) !important;color:#ff5c8d !important;}
.alert-success{background:rgba(38,166,154,.1) !important;border-color:rgba(38,166,154,.3) !important;color:#4dd0c4 !important;}
.alert-warning{background:rgba(255,193,7,.1) !important;border-color:rgba(255,193,7,.3) !important;color:#ffd54f !important;}
.alert-info{background:rgba(0,188,212,.1) !important;border-color:rgba(0,188,212,.3) !important;color:#4dd0e1 !important;}
/* Ensure no white backgrounds leak */
body,html{background-color:#526065 !important;}