/* =========================================================
   BURNSFRED.CA — CLEAN REWORK FROM ORIGINAL FILES
   Objectif: garder ta base, réparer le UI, réduire les bugs
   ========================================================= */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
    -webkit-user-select:none;
    -moz-user-select:none;
    -ms-user-select:none;
    user-select:none;
}

:root{
    --red:#ff2b2b;
    --gold:#d7a84f;
    --bg:#000;
    --panel:#101010;
    --border:rgba(255,255,255,.11);
    --border-strong:rgba(255,255,255,.18);
    --muted:#9c9c9c;
    --text:#fff;
    --footer-h:76px;
    --font:'DM Sans',system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
    --display:'Bebas Neue',Impact,sans-serif;
}

html{
    scroll-behavior:smooth;
}

body{
    min-height:100svh;
    display:flex;
    flex-direction:column;
    background:
        radial-gradient(circle at 18% 0%,rgba(255,43,43,.055),transparent 26%),
        radial-gradient(circle at 72% 14%,rgba(215,168,79,.04),transparent 24%),
        #000;
    color:#fff;
    font-family:var(--font);
    overflow-x:hidden;
    padding-bottom:var(--footer-h);
    -webkit-touch-callout:none;
}

body::before{
    content:"";
    position:fixed;
    inset:0;
    z-index:999;
    pointer-events:none;
    opacity:.024;
    background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

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

img{
    max-width:100%;
    display:block;
    -webkit-user-drag:none;
    user-select:none;
}

/* =========================================================
   HEADER / FOOTER
   ========================================================= */

.site-header{
    position:fixed;
    top:0;
    left:0;
    right:0;
    z-index:5000;
    min-height:74px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    padding:22px clamp(20px,4vw,70px);
    background:linear-gradient(to bottom,rgba(0,0,0,.76),rgba(0,0,0,.16),transparent);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
}

.logo{
    color:#fff;
    font-family:var(--display);
    letter-spacing:.34em;
    font-size:1.05rem;
    white-space:nowrap;
}

.nav{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:clamp(18px,3vw,44px);
    flex-wrap:wrap;
}

.nav a{
    color:rgba(255,255,255,.84);
    text-transform:uppercase;
    letter-spacing:.24em;
    font-size:.70rem;
    font-weight:700;
    transition:.22s ease;
}

.nav a:hover{
    color:var(--red);
}

.site-footer{
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    z-index:4800;
    min-height:var(--footer-h);
    display:flex;
    align-items:center;
    justify-content:center;
    padding:16px clamp(20px,5vw,80px);
    border-top:1px solid rgba(255,255,255,.07);
    background:rgba(0,0,0,.90);
    backdrop-filter:blur(16px);
    -webkit-backdrop-filter:blur(16px);
}

.footer-inner{
    width:100%;
    max-width:1500px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    flex-wrap:wrap;
    color:#777;
    text-transform:uppercase;
    letter-spacing:.18em;
    font-size:.66rem;
    font-weight:700;
}

.footer-inner a{
    color:#aaa;
    transition:.22s ease;
}

.footer-inner a:hover{
    color:var(--red);
}

/* =========================================================
   INDEX / HERO
   ========================================================= */

.hero{
    position:relative;
    min-height:calc(100svh - var(--footer-h));
    display:grid;
    grid-template-columns:minmax(0,55vw) minmax(420px,45vw);
    align-items:stretch;
    background:#000;
    overflow:hidden;
    flex:1 0 auto;
}

.hero-bg{
    position:relative;
    width:100%;
    min-height:calc(100svh - var(--footer-h));
    overflow:hidden;
    background:#050505;
}

.hero-bg::after{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    background:
        linear-gradient(to right,rgba(0,0,0,.08),rgba(0,0,0,.22) 55%,rgba(0,0,0,.88) 100%),
        linear-gradient(to top,rgba(0,0,0,.46),transparent 48%);
}

.hero-photo{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center;
    display:block;
    filter:brightness(.90) contrast(1.07);
    transform:scale(1.015);
    animation:slowZoom 18s ease-in-out infinite alternate;
    pointer-events:none;
}

@keyframes slowZoom{
    from{transform:scale(1.015);}
    to{transform:scale(1.065);}
}

.hero::after{
    content:"";
    position:absolute;
    top:0;
    right:0;
    bottom:0;
    width:55vw;
    z-index:1;
    pointer-events:none;
    background:
        radial-gradient(circle at 45% 40%,rgba(255,43,43,.10),transparent 30%),
        linear-gradient(to right,rgba(0,0,0,.02),#000 33%,#000 100%);
}

.hero-content{
    position:relative;
    z-index:2;
    width:100%;
    max-width:660px;
    margin:0;
    padding:0 clamp(28px,5vw,90px);
    align-self:center;
    justify-self:start;
}

.hero-mini{
    color:var(--red);
    text-transform:uppercase;
    letter-spacing:.34em;
    font-size:.72rem;
    margin-bottom:22px;
    font-weight:800;
}

.brand{
    font-family:var(--display);
    line-height:.82;
    margin-bottom:28px;
}

.brand span,
.brand strong{
    display:block;
    font-size:clamp(5.2rem,8.6vw,11rem);
    font-weight:400;
}

.brand strong{
    color:#fff;
}

.hero-line,
.about-line{
    width:120px;
    height:2px;
    background:linear-gradient(to right,var(--red),transparent);
    margin:0 0 28px;
}

.tagline{
    color:#e0e0e0;
    font-size:clamp(.82rem,.9vw,1rem);
    line-height:1.9;
    letter-spacing:.10em;
    text-transform:uppercase;
    max-width:560px;
    margin-bottom:34px;
}

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

.hero-button,
.btn,
.empty-button,
.track-action-button,
.contact-button,
.soundcloud-link,
.show-more-button{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:44px;
    padding:0 20px;
    border:1px solid rgba(255,255,255,.15);
    border-radius:999px;
    color:#fff;
    text-transform:uppercase;
    letter-spacing:.18em;
    font-size:.70rem;
    font-weight:800;
    transition:.25s ease;
    background:rgba(255,255,255,.035);
    cursor:pointer;
}

.hero-button:hover,
.btn:hover,
.empty-button:hover,
.track-action-button:hover,
.contact-button:hover,
.soundcloud-link:hover,
.show-more-button:hover{
    border-color:var(--red);
    background:rgba(255,43,43,.13);
    transform:translateY(-2px);
}

.btn.primary,
.empty-button.primary,
.track-action-button.primary{
    background:#fff;
    color:#000;
    border-color:#fff;
}

/* =========================================================
   GENERAL PAGES
   ========================================================= */

.page{
    flex:1 0 auto;
    min-height:calc(100svh - var(--footer-h));
    padding:112px clamp(20px,5vw,80px) 120px;
    background:
        radial-gradient(circle at 18% 0%,rgba(255,43,43,.07),transparent 24%),
        #000;
}

.page-inner{
    max-width:1120px;
    margin:0 auto;
}

.eyebrow{
    color:var(--red);
    text-transform:uppercase;
    letter-spacing:.28em;
    font-size:.70rem;
    font-weight:800;
    margin-bottom:10px;
}

.page-title{
    font-family:var(--display);
    font-size:clamp(4rem,7vw,7.8rem);
    line-height:.86;
    margin-bottom:18px;
}

.lead,
.music-subtitle{
    color:#cfcfcf;
    max-width:650px;
    line-height:1.75;
    letter-spacing:.025em;
    font-size:.92rem;
}

/* =========================================================
   ABOUT
   ========================================================= */

.about-page{
    min-height:100svh;
    display:flex;
    flex-direction:column;
    overflow-x:hidden;
}

.about-hero{
    flex:1 0 auto;
    min-height:calc(100svh - var(--footer-h));
    display:grid;
    grid-template-columns:1.05fr .95fr;
    align-items:start;
    background:#000;
}

.about-photo-side{
    position:sticky;
    top:0;
    height:calc(100svh - var(--footer-h));
    min-height:calc(100svh - var(--footer-h));
    overflow:hidden;
    background:#050505;
}

.about-photo{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center;
    display:block;
    filter:brightness(.78) contrast(1.08);
    transform:scale(1.02);
    animation:slowZoom 18s ease-in-out infinite alternate;
    pointer-events:none;
}

.about-photo-side::after{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    background:
        linear-gradient(to right,rgba(0,0,0,.06),rgba(0,0,0,.32) 58%,rgba(0,0,0,.94)),
        linear-gradient(to top,rgba(0,0,0,.52),transparent 52%);
}

.about-text-side{
    min-height:calc(100svh - var(--footer-h));
    display:flex;
    align-items:center;
    justify-content:center;
    padding:clamp(90px,7vw,124px) clamp(28px,5vw,90px) 120px;
    background:
        radial-gradient(circle at 20% 8%,rgba(255,43,43,.08),transparent 28%),
        #000;
}

.about-text-content{
    width:100%;
    max-width:760px;
}

.about-title{
    font-family:var(--display);
    font-size:clamp(4.2rem,6.6vw,7.9rem);
    line-height:.86;
    margin:0 0 22px;
}

.about-text{
    color:#d5d5d5;
    font-size:clamp(.88rem,.88vw,.98rem);
    line-height:1.78;
}

.about-text p{
    margin-bottom:15px;
}

.about-signature{
    color:#fff;
    text-transform:uppercase;
    letter-spacing:.12em;
    font-weight:800;
    border-left:2px solid var(--red);
    padding-left:16px;
    margin-top:22px;
}

/* =========================================================
   CONTACT
   ========================================================= */

.contact-clean-page{
    display:flex;
    align-items:center;
}

.contact-clean-inner{
    width:min(860px,100%);
}

.contact-clean-card{
    width:min(760px,100%);
    margin:auto;
    border:1px solid rgba(255,255,255,.11);
    background:
        radial-gradient(circle at 0% 0%,rgba(255,43,43,.13),transparent 34%),
        radial-gradient(circle at 100% 0%,rgba(215,168,79,.09),transparent 30%),
        linear-gradient(145deg,rgba(255,255,255,.06),rgba(255,255,255,.015));
    border-radius:34px;
    padding:clamp(30px,5vw,58px);
    box-shadow:0 34px 120px rgba(0,0,0,.42);
}

.contact-clean-card p:not(.eyebrow){
    color:#d8d8d8;
    font-size:1.02rem;
    line-height:1.9;
    margin-bottom:30px;
    max-width:610px;
}

.instagram-hero-button{
    min-height:58px;
    width:fit-content;
    border-radius:999px;
    padding:0 24px;
    display:inline-flex;
    align-items:center;
    gap:16px;
    background:#fff;
    color:#000;
    text-transform:uppercase;
    letter-spacing:.13em;
    font-size:.72rem;
    font-weight:900;
    transition:.24s ease;
}

.instagram-hero-button span{
    width:30px;
    height:30px;
    border-radius:50%;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background:#000;
    color:#fff;
}

.instagram-hero-button:hover{
    transform:translateY(-3px);
    box-shadow:0 18px 45px rgba(0,0,0,.35);
}

/* =========================================================
   GALERIE
   ========================================================= */

.filters{
    margin:0 0 34px;
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

.filter-btn{
    border:1px solid rgba(255,255,255,.1);
    background:#111;
    color:#fff;
    padding:12px 18px;
    border-radius:999px;
    cursor:pointer;
    text-transform:uppercase;
    letter-spacing:.13em;
    font-size:.72rem;
    font-weight:800;
}

.filter-btn.active,
.filter-btn:hover{
    border-color:var(--red);
    background:rgba(255,43,43,.15);
}

.masonry{
    column-count:4;
    column-gap:18px;
}

.card{
    break-inside:avoid;
    margin-bottom:18px;
    position:relative;
    overflow:hidden;
    border-radius:22px;
    background:#111;
    cursor:pointer;
    border:1px solid rgba(255,255,255,.08);
    box-shadow:0 20px 70px rgba(0,0,0,.36);
}

.card img.main{
    width:100%;
    height:auto;
    display:block;
    object-fit:contain;
    transition:.5s ease;
    pointer-events:none;
}

.card:hover img.main{
    transform:scale(1.02);
}

.card::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(to top,rgba(0,0,0,.55),transparent 45%);
    pointer-events:none;
}

.watermark,
.photo-watermark{
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    pointer-events:none;
    z-index:2;
}

.watermark img,
.photo-watermark img{
    width:72%;
    max-width:560px;
    opacity:.30;
    pointer-events:none;
}

.text-watermark{
    position:absolute;
    inset:0;
    z-index:2;
    display:flex;
    align-items:center;
    justify-content:center;
    transform:rotate(-18deg);
    font-family:var(--display);
    font-size:clamp(2rem,5vw,5rem);
    letter-spacing:.12em;
    color:rgba(255,255,255,.28);
    pointer-events:none;
}

.label{
    position:absolute;
    left:16px;
    bottom:14px;
    z-index:3;
    font-size:.72rem;
    letter-spacing:.14em;
    text-transform:uppercase;
    font-weight:800;
}

.lightbox{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.95);
    display:none;
    align-items:center;
    justify-content:center;
    z-index:9999;
    padding:24px;
    backdrop-filter:blur(10px);
}

.lightbox.open{
    display:flex;
}

.lightbox-photo-wrap{
    position:relative;
    width:100%;
    height:100%;
    display:flex;
    align-items:center;
    justify-content:center;
}

.lightbox img.main{
    width:auto;
    height:auto;
    max-width:min(92vw,1400px);
    max-height:82vh;
    object-fit:contain;
    border-radius:16px;
    pointer-events:none;
    box-shadow:0 30px 120px rgba(0,0,0,.72);
}

.lightbox .watermark,
.lightbox .lightbox-watermark{
    position:absolute;
}

.lightbox .watermark img,
.lightbox .lightbox-watermark img{
    width:min(70vw,900px);
    max-height:55vh;
    object-fit:contain;
    opacity:.35;
}

.close{
    position:absolute;
    top:20px;
    right:20px;
    width:44px;
    height:44px;
    border-radius:50%;
    border:1px solid rgba(255,255,255,.16);
    background:#111;
    color:#fff;
    font-size:1.5rem;
    cursor:pointer;
    z-index:10000;
}

/* =========================================================
   PROJETS
   ========================================================= */

.project-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
    gap:22px;
    margin-top:40px;
}

.project-card{
    position:relative;
    min-height:330px;
    border:1px solid var(--border);
    background:#111;
    border-radius:26px;
    overflow:hidden;
    color:#fff;
    display:flex;
    align-items:flex-end;
    box-shadow:0 20px 70px rgba(0,0,0,.35);
}

.project-card img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    filter:brightness(.66);
    transition:.5s ease;
}

.project-card:hover img{
    transform:scale(1.04);
    filter:brightness(.82);
}

.project-card::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(to top,rgba(0,0,0,.84),transparent 55%);
}

.project-card-content{
    position:relative;
    z-index:2;
    padding:28px;
}

.project-type{
    display:inline-block;
    color:var(--red);
    text-transform:uppercase;
    letter-spacing:.22em;
    font-size:.68rem;
    font-weight:800;
    margin-bottom:14px;
}

.project-card h2{
    font-family:var(--display);
    font-size:3.4rem;
    line-height:.9;
    margin-bottom:10px;
}

.project-card p{
    color:#d0d0d0;
    line-height:1.7;
    text-transform:uppercase;
    letter-spacing:.14em;
    font-size:.72rem;
}

/* =========================================================
   MUSIQUE LISTING
   ========================================================= */

.music-showcase-page .page-inner{
    max-width:1180px;
}

.music-showcase-head{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:24px;
    margin-bottom:38px;
}

.soundcloud-link{
    white-space:nowrap;
    margin-top:14px;
}

.showcase-section-title{
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:20px;
    margin-bottom:18px;
}

.showcase-section-title span{
    color:var(--gold);
    text-transform:uppercase;
    letter-spacing:.24em;
    font-size:.68rem;
    font-weight:800;
}

.showcase-section-title.normal-title span{
    color:#d7d7d7;
}

.showcase-section-title p{
    color:#999;
    text-transform:uppercase;
    letter-spacing:.15em;
    font-size:.58rem;
}

.featured-showcase{
    margin-bottom:48px;
    padding:22px;
    border-radius:32px;
    border:1px solid rgba(215,168,79,.32);
    background:
        radial-gradient(circle at 12% 0%,rgba(215,168,79,.18),transparent 28%),
        radial-gradient(circle at 86% 34%,rgba(255,43,43,.12),transparent 32%),
        linear-gradient(145deg,rgba(255,255,255,.045),rgba(255,255,255,.01)),
        #060606;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.025),0 34px 120px rgba(0,0,0,.5);
}

.featured-showcase-grid{
    display:grid;
    grid-template-columns:1.25fr .85fr .85fr;
    gap:18px;
}

.featured-showcase-card{
    position:relative;
    min-height:280px;
    overflow:hidden;
    border-radius:24px;
    color:#fff;
    border:1px solid rgba(215,168,79,.26);
    background:#111;
    box-shadow:0 24px 90px rgba(0,0,0,.42);
    transition:.32s ease;
}

.main-featured-card{
    min-height:360px;
}

.featured-showcase-card:hover{
    transform:translateY(-4px);
    border-color:rgba(215,168,79,.65);
    box-shadow:0 0 64px rgba(215,168,79,.12),0 30px 100px rgba(0,0,0,.5);
}

.featured-showcase-card img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transition:.5s ease;
}

.featured-showcase-card:hover img{
    transform:scale(1.04);
}

.featured-showcase-card::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(to top,rgba(0,0,0,.9),rgba(0,0,0,.22) 54%,transparent);
    pointer-events:none;
}

.featured-card-content{
    position:absolute;
    left:0;
    right:0;
    bottom:0;
    z-index:2;
    padding:22px;
}

.featured-card-content span{
    display:block;
    color:var(--gold);
    text-transform:uppercase;
    letter-spacing:.22em;
    font-size:.58rem;
    font-weight:800;
    margin-bottom:10px;
}

.featured-card-content h2{
    font-family:var(--display);
    font-size:clamp(2.6rem,4.6vw,5.5rem);
    line-height:.86;
    margin-bottom:8px;
    overflow-wrap:anywhere;
}

.featured-card-content p{
    color:#d8d8d8;
    text-transform:uppercase;
    letter-spacing:.14em;
    font-size:.58rem;
    font-weight:700;
}

.cover-only-grid{
    display:grid;
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:20px;
}

.cover-track{
    position:relative;
    overflow:hidden;
    border-radius:22px;
    border:1px solid rgba(255,255,255,.08);
    background:#080808;
    color:#fff;
    box-shadow:0 22px 70px rgba(0,0,0,.38);
    transition:.28s ease;
}

.cover-track.is-hidden{
    display:none;
}

.cover-track:hover{
    transform:translateY(-4px);
    border-color:rgba(255,255,255,.15);
}

.cover-track-image{
    position:relative;
    aspect-ratio:1/1;
    background:#111;
    overflow:hidden;
}

.cover-track-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    pointer-events:none;
    transition:.45s ease;
}

.cover-track:hover .cover-track-image img{
    transform:scale(1.045);
}

.cover-track-image::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(to top,rgba(0,0,0,.78),rgba(0,0,0,.08) 62%,transparent);
    pointer-events:none;
}

.cover-track-caption{
    position:absolute;
    left:0;
    right:0;
    bottom:0;
    z-index:3;
    padding:14px 14px 16px;
    pointer-events:none;
}

.cover-track-caption h2{
    font-family:var(--display);
    font-size:2rem;
    line-height:.9;
    margin-bottom:4px;
    text-shadow:0 3px 20px rgba(0,0,0,.9);
    overflow-wrap:anywhere;
}

.cover-track-caption p{
    color:#d7d7d7;
    text-transform:uppercase;
    letter-spacing:.16em;
    font-size:.52rem;
    font-weight:700;
}

.cover-placeholder{
    width:100%;
    height:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:4rem;
    color:rgba(255,255,255,.18);
}

.show-more-wrap{
    display:flex;
    justify-content:center;
    margin-top:30px;
}

.show-more-button{
    gap:12px;
}

.show-more-button span{
    min-width:32px;
    height:28px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    background:rgba(255,255,255,.10);
}

/* =========================================================
   TRACK PAGE
   ========================================================= */

.track-experience-page{
    flex:1 0 auto;
    min-height:100svh;
    padding-bottom:230px;
    background:#000;
}

.featured-release-page,
.standard-track-page{
    position:relative;
    min-height:calc(100svh - var(--footer-h));
    overflow:hidden;
    padding:118px clamp(22px,5vw,84px) 70px;
    display:flex;
    align-items:center;
}

.release-background{
    position:absolute;
    inset:0;
    z-index:0;
    opacity:.34;
    filter:blur(56px) brightness(.72) saturate(1.18);
    transform:scale(1.16);
}

.release-background img{
    width:100%;
    height:100%;
    object-fit:cover;
}

.featured-release-page::before{
    content:"";
    position:absolute;
    inset:0;
    z-index:1;
    background:
        radial-gradient(circle at 16% 18%,rgba(215,168,79,.16),transparent 28%),
        radial-gradient(circle at 82% 26%,rgba(255,43,43,.13),transparent 28%),
        linear-gradient(90deg,#000 0%,rgba(0,0,0,.72) 48%,#000 100%);
}

.release-inner,
.standard-track-inner{
    position:relative;
    z-index:2;
    width:min(1200px,100%);
    margin:0 auto;
}

.track-back-link{
    width:max-content;
    color:#aaa;
    text-transform:uppercase;
    letter-spacing:.16em;
    font-size:.64rem;
    transition:.25s ease;
    display:inline-flex;
    margin-bottom:22px;
}

.track-back-link:hover{
    color:var(--gold);
}

.release-layout,
.standard-track-card{
    display:grid;
    grid-template-columns:minmax(280px,430px) minmax(0,1fr);
    gap:clamp(28px,5vw,62px);
    align-items:center;
}

.release-art,
.standard-art{
    position:relative;
    overflow:hidden;
    border-radius:34px;
    background:#111;
    border:1px solid rgba(215,168,79,.32);
    box-shadow:0 54px 170px rgba(0,0,0,.72),0 0 120px rgba(215,168,79,.10);
}

.release-art img,
.standard-art img{
    width:100%;
    aspect-ratio:1/1;
    object-fit:cover;
    display:block;
    pointer-events:none;
    transition:.55s ease;
}

.audio-is-playing .release-art img{
    transform:scale(1.025);
}

.featured-ribbon{
    position:absolute;
    top:18px;
    left:18px;
    z-index:3;
    padding:10px 13px;
    border-radius:999px;
    color:#111;
    background:linear-gradient(135deg,#ffe4a3,#d7a84f);
    text-transform:uppercase;
    letter-spacing:.14em;
    font-size:.58rem;
    font-weight:900;
}

.release-visualizer{
    position:absolute;
    left:18px;
    right:18px;
    bottom:18px;
    height:52px;
    display:flex;
    align-items:flex-end;
    gap:4px;
    z-index:4;
    opacity:.85;
}

.release-visualizer span{
    flex:1;
    height:9px;
    border-radius:999px;
    background:var(--gold);
    box-shadow:0 0 18px rgba(215,168,79,.62);
    opacity:.5;
}

.audio-is-playing .release-visualizer span{
    animation:featuredBars .75s ease-in-out infinite alternate;
}

.audio-is-playing .release-visualizer span:nth-child(2n){animation-duration:.45s;}
.audio-is-playing .release-visualizer span:nth-child(3n){animation-duration:.65s;}
.audio-is-playing .release-visualizer span:nth-child(5n){animation-duration:.9s;}

@keyframes featuredBars{
    from{height:8px; opacity:.42;}
    to{height:48px; opacity:1;}
}

.release-content,
.standard-content{
    min-width:0;
    padding:clamp(22px,3vw,34px);
    border-radius:34px;
    border:1px solid rgba(215,168,79,.18);
    background:
        radial-gradient(circle at 0% 0%,rgba(215,168,79,.13),transparent 28%),
        radial-gradient(circle at 100% 12%,rgba(255,43,43,.10),transparent 32%),
        linear-gradient(145deg,rgba(255,255,255,.06),rgba(255,255,255,.014));
    backdrop-filter:blur(18px);
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.025),0 35px 120px rgba(0,0,0,.42);
}

.track-kicker{
    color:var(--gold);
    text-transform:uppercase;
    letter-spacing:.28em;
    font-size:.68rem;
    font-weight:800;
    margin-bottom:16px;
}

.track-title,
.standard-content h1{
    font-family:var(--display);
    font-size:clamp(4.6rem,8vw,9rem);
    line-height:.82;
    margin-bottom:22px;
    overflow-wrap:anywhere;
}

.track-meta-row,
.release-info-grid,
.track-description-card,
.standard-description{
    display:none !important;
}

.premium-player-card,
.clean-player-card{
    border:1px solid rgba(215,168,79,.22);
    border-radius:26px;
    padding:17px;
    background:radial-gradient(circle at 0% 0%,rgba(215,168,79,.14),transparent 30%),rgba(0,0,0,.34);
}

.player-card-head,
.mini-now-playing{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    margin-bottom:13px;
}

.player-card-head span,
.mini-now-playing span{
    display:block;
    color:var(--gold);
    text-transform:uppercase;
    letter-spacing:.18em;
    font-size:.58rem;
    font-weight:900;
    margin-bottom:5px;
}

.player-card-head strong,
.mini-now-playing strong{
    display:block;
    font-size:.95rem;
    color:#fff;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}

.player-dot{
    width:10px;
    height:10px;
    border-radius:999px;
    background:var(--gold);
    box-shadow:0 0 24px rgba(215,168,79,.7);
    flex:0 0 10px;
}

.premium-player-card audio,
.clean-player-card audio,
#trackAudio{
    width:100%;
    height:38px;
    display:block;
}

body.track-is-featured #standardView,
body.track-is-standard #featuredView,
.dynamic-track-view[style*="display:none"]{
    display:none !important;
}

/* Fixed track player */
.fixed-music-player{
    position:fixed;
    left:50%;
    bottom:86px;
    transform:translateX(-50%);
    z-index:4900;
    width:min(760px,calc(100vw - 28px));
    display:grid;
    grid-template-columns:1fr auto;
    gap:14px;
    align-items:center;
    padding:14px;
    border:1px solid rgba(255,255,255,.12);
    border-radius:28px;
    background:
        radial-gradient(circle at 0% 0%,rgba(215,168,79,.16),transparent 34%),
        linear-gradient(145deg,rgba(255,255,255,.075),rgba(255,255,255,.018)),
        rgba(0,0,0,.90);
    backdrop-filter:blur(18px);
    box-shadow:0 24px 90px rgba(0,0,0,.62),inset 0 0 0 1px rgba(255,255,255,.025);
}

.fixed-player-info{
    min-width:0;
    display:flex;
    align-items:center;
    gap:13px;
}

.fixed-player-cover{
    width:54px;
    height:54px;
    flex:0 0 54px;
    border-radius:14px;
    overflow:hidden;
    background:#111;
    border:1px solid rgba(255,255,255,.1);
}

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

.fixed-player-text{
    min-width:0;
}

.fixed-player-text span{
    display:block;
    color:var(--gold);
    text-transform:uppercase;
    letter-spacing:.16em;
    font-size:.54rem;
    font-weight:900;
    margin-bottom:5px;
}

.fixed-player-text strong{
    display:block;
    color:#fff;
    font-size:.92rem;
    line-height:1.25;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}

.fixed-player-controls{
    display:flex;
    align-items:center;
    gap:10px;
}

.fixed-player-controls button{
    height:46px;
    min-width:132px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.12);
    color:#fff;
    background:rgba(255,255,255,.045);
    font-size:.58rem;
    font-weight:900;
    letter-spacing:.13em;
    text-transform:uppercase;
    cursor:pointer;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:9px;
    transition:.22s ease;
}

.fixed-player-controls button span{
    width:26px;
    height:26px;
    border-radius:999px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:rgba(255,255,255,.09);
    font-size:.9rem;
    letter-spacing:0;
    flex:0 0 26px;
}

.fixed-player-controls button:hover{
    transform:translateY(-2px);
    border-color:rgba(215,168,79,.58);
    background:rgba(215,168,79,.10);
}

/* =========================================================
   EMPTY / PROTECTION / TRANSITION
   ========================================================= */

.empty-state{
    min-height:44vh;
    width:100%;
    border-radius:34px;
    background:
        radial-gradient(circle at top left,rgba(255,43,43,.18),transparent 26%),
        linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.008)),
        #050505;
    padding:clamp(40px,6vw,90px);
    display:flex;
    align-items:center;
    justify-content:center;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.06),0 40px 120px rgba(0,0,0,.55);
    position:relative;
    overflow:hidden;
}

.empty-content{
    position:relative;
    z-index:3;
    max-width:760px;
    text-align:left;
}

.empty-title{
    font-family:var(--display);
    font-size:clamp(5rem,10vw,10rem);
    line-height:.82;
    margin-bottom:32px;
}

.empty-actions{
    display:flex;
    flex-wrap:wrap;
    gap:14px;
}

.protection-toast{
    position:fixed;
    left:50%;
    bottom:calc(var(--footer-h) + 18px);
    transform:translateX(-50%) translateY(20px);
    z-index:20000;
    background:rgba(10,10,10,.92);
    border:1px solid rgba(255,43,43,.45);
    color:#fff;
    padding:14px 18px;
    border-radius:999px;
    text-transform:uppercase;
    letter-spacing:.14em;
    font-size:.72rem;
    opacity:0;
    pointer-events:none;
    transition:.25s ease;
    box-shadow:0 14px 60px rgba(255,43,43,.16);
}

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

.page-transition{
    position:fixed;
    inset:0;
    z-index:99999;
    pointer-events:none;
    opacity:0;
    visibility:hidden;
    background:radial-gradient(circle at center,rgba(215,168,79,.18),transparent 28%),#000;
    transition:opacity .38s ease,visibility .38s ease;
}

.page-transition.active{
    opacity:1;
    visibility:visible;
}

.page-transition-logo{
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%,-50%);
    font-family:var(--display);
    font-size:clamp(3.5rem,8vw,8rem);
    letter-spacing:.08em;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */

@media(max-width:1200px){
    .masonry{
        column-count:3;
    }

    .cover-only-grid{
        grid-template-columns:repeat(4,minmax(0,1fr));
    }
}

@media(max-width:1050px){
    .hero{
        display:block;
        min-height:auto;
    }

    .hero-bg{
        height:66svh;
        min-height:66svh;
    }

    .hero::after{
        display:none;
    }

    .hero-bg::after{
        background:linear-gradient(to top,#000 0%,rgba(0,0,0,.22) 46%,transparent 100%);
    }

    .hero-content{
        max-width:none;
        padding:46px 24px 78px;
        background:#000;
    }

    .brand span,
    .brand strong{
        font-size:clamp(4.4rem,18vw,7.5rem);
    }

    .masonry{
        column-count:2;
    }

    .about-hero{
        display:block;
        min-height:auto;
    }

    .about-photo-side{
        position:relative;
        top:auto;
        height:56svh;
        min-height:56svh;
    }

    .about-photo-side::after{
        background:linear-gradient(to top,#000 0%,rgba(0,0,0,.18) 52%,transparent 100%);
    }

    .about-text-side{
        min-height:auto;
        padding:52px 24px 120px;
    }

    .about-title{
        font-size:clamp(4rem,17vw,6.5rem);
    }

    .featured-showcase-grid{
        grid-template-columns:1fr;
    }

    .featured-showcase-card,
    .main-featured-card{
        min-height:330px;
    }

    .cover-only-grid{
        grid-template-columns:repeat(3,minmax(0,1fr));
    }

    .release-layout,
    .standard-track-card{
        grid-template-columns:1fr;
        max-width:620px;
    }

    .release-art,
    .standard-art{
        max-width:520px;
    }
}

@media(max-width:760px){
    body{
        padding-bottom:calc(var(--footer-h) + 78px);
    }

    .site-header{
        position:fixed;
        min-height:66px;
        padding:18px 20px;
    }

    .nav{
        display:none;
    }

    .page{
        padding-top:98px;
    }

    .hero-bg{
        height:60svh;
        min-height:60svh;
    }

    .hero-actions,
    .about-actions{
        flex-direction:column;
        align-items:flex-start;
    }

    .hero-button,
    .btn,
    .instagram-hero-button{
        width:100%;
        max-width:310px;
    }

    .masonry{
        column-count:1;
    }

    .music-showcase-head{
        display:block;
    }

    .soundcloud-link{
        margin-top:20px;
    }

    .featured-showcase{
        padding:16px;
        border-radius:24px;
    }

    .featured-showcase-card,
    .main-featured-card{
        min-height:290px;
    }

    .cover-only-grid{
        grid-template-columns:repeat(2,minmax(0,1fr));
        gap:14px;
    }

    .cover-track-caption h2{
        font-size:1.55rem;
    }

    .cover-track-caption p{
        font-size:.46rem;
    }

    .featured-release-page,
    .standard-track-page{
        padding-top:98px;
        align-items:flex-start;
    }

    .release-content,
    .standard-content{
        padding:22px;
        border-radius:26px;
    }

    .track-title,
    .standard-content h1{
        font-size:clamp(4rem,18vw,7rem);
    }

    .release-art,
    .standard-art{
        border-radius:26px;
    }

    .fixed-music-player{
        bottom:calc(var(--footer-h) + 12px);
        grid-template-columns:1fr;
        gap:12px;
        padding:12px;
        border-radius:24px;
    }

    .fixed-player-controls{
        display:grid;
        grid-template-columns:1fr 1fr;
        width:100%;
    }

    .fixed-player-controls button{
        min-width:0;
        width:100%;
        height:44px;
        font-size:.54rem;
    }

    .track-experience-page{
        padding-bottom:270px;
    }

    .site-footer{
        min-height:var(--footer-h);
        padding:16px 20px;
    }

    .footer-inner{
        justify-content:center;
        text-align:center;
        gap:10px 16px;
    }
}

@media(max-width:430px){
    .cover-only-grid{
        grid-template-columns:1fr;
    }

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


/* =========================================================
   FIX — INDEX PHOTO = MÊME FORMAT QUE À PROPOS
   ========================================================= */

.hero{
    min-height:calc(100svh - var(--footer-h));
    display:grid;
    grid-template-columns:1.05fr .95fr;
    align-items:start;
    background:#000;
}

.hero-bg{
    position:relative;
    height:calc(100svh - var(--footer-h));
    min-height:calc(100svh - var(--footer-h));
    overflow:hidden;
    background:#050505;
}

.hero-photo{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center;
    filter:brightness(.78) contrast(1.08);
    transform:scale(1.02);
    animation:slowZoom 18s ease-in-out infinite alternate;
}

.hero-bg::after{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    background:
        linear-gradient(to right,rgba(0,0,0,.06),rgba(0,0,0,.32) 58%,rgba(0,0,0,.94)),
        linear-gradient(to top,rgba(0,0,0,.52),transparent 52%);
}

.hero::after{
    display:none !important;
}

.hero-content{
    position:relative;
    z-index:2;
    align-self:center;
    justify-self:center;
}

/* =========================================================
   FIX — MUSIQUE: CHANSONS NORMALES LIMITÉES À 5
   ========================================================= */

.cover-track.is-hidden{
    display:none !important;
}

.show-more-wrap{
    display:flex;
    justify-content:center;
    margin-top:30px;
}

.show-more-button{
    gap:12px;
}

.show-more-button span{
    min-width:32px;
    height:28px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    background:rgba(255,255,255,.10);
}


/* =========================================================
   MUSIQUE CLEAN — toutes les chansons + page featured séparée
   ========================================================= */
.music-clean-page .page{
    padding-top:118px;
}

.music-clean-inner{
    width:min(1380px,100%);
    margin:0 auto;
}

.music-clean-head{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:28px;
    margin-bottom:26px;
}

.music-clean-head .page-title{
    margin-bottom:14px;
}

.music-head-actions{
    display:flex;
    gap:12px;
    flex-wrap:wrap;
    justify-content:flex-end;
    padding-top:18px;
}

.featured-link{
    border-color:rgba(255,43,43,.5);
    color:#fff;
}

.music-search-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    margin:0 0 28px;
}

.music-search-input{
    width:min(560px,100%);
    min-height:54px;
    border:1px solid rgba(255,255,255,.16);
    border-radius:999px;
    background:rgba(255,255,255,.035);
    color:#fff;
    padding:0 22px;
    outline:none;
    font-family:var(--font);
    font-size:.88rem;
    transition:.22s ease;
    user-select:text;
}

.music-search-input:focus{
    border-color:rgba(255,43,43,.65);
    background:rgba(255,255,255,.055);
    box-shadow:0 0 0 4px rgba(255,43,43,.08);
}

.music-search-row span{
    color:#999;
    text-transform:uppercase;
    letter-spacing:.16em;
    font-size:.62rem;
    font-weight:900;
    white-space:nowrap;
}

.all-music-grid{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:18px;
}

.music-list-card{
    min-width:0;
    display:grid;
    grid-template-columns:150px minmax(0,1fr);
    gap:18px;
    align-items:center;
    min-height:184px;
    padding:16px;
    border-radius:26px;
    border:1px solid rgba(255,255,255,.10);
    background:linear-gradient(145deg,rgba(255,255,255,.06),rgba(255,255,255,.015)),#070707;
    box-shadow:0 24px 80px rgba(0,0,0,.38);
    transition:.24s ease;
}

.music-list-card:hover{
    transform:translateY(-3px);
    border-color:rgba(255,43,43,.46);
    background:linear-gradient(145deg,rgba(255,43,43,.08),rgba(255,255,255,.02)),#080808;
}

.music-list-cover{
    width:150px;
    aspect-ratio:1/1;
    border-radius:18px;
    overflow:hidden;
    background:#111;
    border:1px solid rgba(255,255,255,.08);
}

.music-list-cover img{
    width:100%;
    height:100%;
    object-fit:cover;
}

.music-list-content{
    min-width:0;
}

.music-card-topline{
    min-height:24px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    margin-bottom:8px;
}

.music-badge,
.music-date,
.music-tags span{
    display:inline-flex;
    align-items:center;
    width:max-content;
    max-width:100%;
    min-height:24px;
    padding:0 9px;
    border-radius:999px;
    background:rgba(255,255,255,.075);
    color:#bbb;
    text-transform:uppercase;
    letter-spacing:.10em;
    font-size:.52rem;
    font-weight:900;
}

.music-badge{
    background:rgba(255,43,43,.16);
    color:#ff4a4a;
}

.music-date{
    color:#888;
    flex:0 0 auto;
}

.music-list-content h2{
    font-family:var(--display);
    font-size:clamp(2.2rem,3vw,3.6rem);
    line-height:.88;
    margin:0 0 7px;
    overflow-wrap:normal;
    word-break:normal;
    hyphens:none;
}

.music-list-content p{
    color:#d9d9d9;
    text-transform:uppercase;
    letter-spacing:.13em;
    font-size:.62rem;
    font-weight:800;
    margin-bottom:12px;
}

.music-tags{
    display:flex;
    flex-wrap:wrap;
    gap:7px;
    margin-bottom:16px;
}

.music-card-play{
    display:inline-flex;
    align-items:center;
    gap:10px;
    color:#fff;
    text-transform:uppercase;
    letter-spacing:.14em;
    font-size:.62rem;
    font-weight:900;
}

.music-card-play span{
    width:30px;
    height:30px;
    border-radius:50%;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border:1px solid rgba(255,255,255,.24);
    font-size:.66rem;
}

@media(max-width:1180px){
    .all-music-grid{
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
}

@media(max-width:760px){
    .music-clean-head,
    .music-search-row{
        display:block;
    }

    .music-head-actions{
        justify-content:flex-start;
        padding-top:18px;
    }

    .music-search-input{
        width:100%;
    }

    .music-search-row span{
        display:block;
        margin-top:12px;
    }

    .all-music-grid{
        grid-template-columns:1fr;
    }

    .music-list-card{
        grid-template-columns:112px minmax(0,1fr);
        min-height:148px;
        gap:14px;
        padding:12px;
        border-radius:22px;
    }

    .music-list-cover{
        width:112px;
        border-radius:16px;
    }

    .music-list-content h2{
        font-size:2.2rem;
    }

    .music-tags{
        display:none;
    }
}

@media(max-width:430px){
    .music-list-card{
        grid-template-columns:1fr;
    }

    .music-list-cover{
        width:100%;
    }
}

/* =========================================================
   MUSIQUE — FEATURED DANS LA MEME GRILLE, MAIS DIFFERENCIABLE
   Objectif:
   - Les tags gardent le meme format.
   - Les cartes restent dans la meme grille.
   - Les tracks avec featured.txt ressortent clairement.
   ========================================================= */

.music-list-card{
    position:relative;
    isolation:isolate;
}

.music-list-card::before{
    content:"";
    position:absolute;
    inset:0;
    border-radius:inherit;
    pointer-events:none;
    opacity:0;
    transition:.24s ease;
}

/* Carte featured: meme layout, mais signature visuelle premium */
.music-list-card.is-featured-track{
    border-color:rgba(215,168,79,.48);
    background:
        radial-gradient(circle at 0% 0%,rgba(215,168,79,.16),transparent 38%),
        radial-gradient(circle at 100% 0%,rgba(255,43,43,.10),transparent 34%),
        linear-gradient(145deg,rgba(255,255,255,.075),rgba(255,255,255,.018)),
        #080808;
    box-shadow:
        inset 0 0 0 1px rgba(215,168,79,.08),
        0 0 34px rgba(215,168,79,.08),
        0 24px 86px rgba(0,0,0,.45);
}

.music-list-card.is-featured-track::before{
    opacity:1;
    border:1px solid rgba(215,168,79,.22);
    background:
        linear-gradient(90deg,rgba(215,168,79,.16),transparent 32%),
        linear-gradient(180deg,rgba(255,43,43,.08),transparent 55%);
}

.music-list-card.is-featured-track::after{
    content:"";
    position:absolute;
    left:0;
    top:18px;
    bottom:18px;
    width:3px;
    border-radius:999px;
    background:linear-gradient(to bottom,var(--gold),var(--red));
    box-shadow:0 0 22px rgba(215,168,79,.45);
    pointer-events:none;
}

.music-list-card.is-featured-track .music-list-cover{
    border-color:rgba(215,168,79,.48);
    box-shadow:
        0 0 0 1px rgba(215,168,79,.12),
        0 0 28px rgba(215,168,79,.12);
}

.music-list-card.is-featured-track h2{
    text-shadow:0 0 28px rgba(215,168,79,.12);
}

.music-list-card.is-featured-track:hover{
    border-color:rgba(215,168,79,.78);
    background:
        radial-gradient(circle at 0% 0%,rgba(215,168,79,.22),transparent 40%),
        radial-gradient(circle at 100% 0%,rgba(255,43,43,.14),transparent 36%),
        linear-gradient(145deg,rgba(255,255,255,.085),rgba(255,255,255,.02)),
        #090909;
    box-shadow:
        inset 0 0 0 1px rgba(215,168,79,.12),
        0 0 54px rgba(215,168,79,.16),
        0 30px 100px rgba(0,0,0,.55);
}

/* Main featured: encore un peu plus evident, sans changer la grille */
.music-list-card.is-main-featured-track{
    border-color:rgba(255,215,120,.72);
}

.music-list-card.is-main-featured-track::after{
    width:4px;
    background:linear-gradient(to bottom,#ffe3a0,#d7a84f,#ff2b2b);
}

/* Les pills/tags restent tous pareils: meme taille, rayon, typo */
.music-badge,
.music-date,
.music-tags span{
    min-height:24px;
    padding:0 9px;
    border-radius:999px;
    letter-spacing:.10em;
    font-size:.52rem;
    font-weight:900;
}

/* Seule la couleur du badge featured change pour etre identifiable */
.music-badge{
    background:rgba(255,43,43,.16);
    color:#ff4a4a;
    border:1px solid rgba(255,43,43,.20);
}

.music-list-card.is-featured-track .music-badge{
    background:rgba(215,168,79,.16);
    color:#ffd778;
    border-color:rgba(215,168,79,.28);
}

.music-list-card.is-featured-track .music-date,
.music-list-card.is-featured-track .music-tags span{
    background:rgba(255,255,255,.075);
    color:#bbb;
}

/* Evite les titres qui cassent trop agressivement */
.music-list-content h2{
    overflow-wrap:normal;
    word-break:normal;
    hyphens:none;
}

@media(max-width:760px){
    .music-list-card.is-featured-track::after{
        top:12px;
        bottom:12px;
    }
}


/* =========================================================
   PATCH FINAL COULEURS MUSIQUE
   Normal = gris | Featured = jaune | Main Featured = rouge
   Ce bloc doit rester en dernier.
   ========================================================= */

/* Normal */
.music-list-card{
    border-color:rgba(255,255,255,.12) !important;
    background:
        radial-gradient(circle at 12% 0%,rgba(185,190,200,.060),transparent 35%),
        linear-gradient(145deg,rgba(255,255,255,.055),rgba(255,255,255,.015)) !important;
    box-shadow:
        0 22px 68px rgba(0,0,0,.44),
        inset 0 0 0 1px rgba(255,255,255,.025) !important;
}

/* Featured = jaune/or */
.music-list-card.is-featured-track:not(.is-main-featured-track){
    border-color:rgba(215,168,79,.62) !important;
    background:
        radial-gradient(circle at 10% 0%,rgba(215,168,79,.24),transparent 38%),
        radial-gradient(circle at 100% 100%,rgba(215,168,79,.10),transparent 34%),
        linear-gradient(145deg,rgba(255,255,255,.070),rgba(255,255,255,.018)) !important;
    box-shadow:
        0 24px 82px rgba(0,0,0,.48),
        0 0 38px rgba(215,168,79,.24),
        inset 0 0 62px rgba(215,168,79,.070) !important;
}

/* Main Featured = rouge - priorité absolue */
.music-list-card.is-main-featured-track,
.music-list-card.is-featured-track.is-main-featured-track{
    border-color:rgba(255,43,43,.74) !important;
    background:
        radial-gradient(circle at 10% 0%,rgba(255,43,43,.30),transparent 40%),
        radial-gradient(circle at 100% 100%,rgba(255,43,43,.13),transparent 34%),
        linear-gradient(145deg,rgba(255,255,255,.085),rgba(255,255,255,.018)) !important;
    box-shadow:
        0 28px 92px rgba(0,0,0,.54),
        0 0 52px rgba(255,43,43,.36),
        0 0 130px rgba(255,43,43,.13),
        inset 0 0 78px rgba(255,43,43,.090) !important;
}

/* Liseré */
.music-list-card.is-featured-track,
.music-list-card.is-main-featured-track{
    position:relative;
    overflow:hidden;
}

.music-list-card.is-featured-track::before,
.music-list-card.is-main-featured-track::before{
    content:"";
    position:absolute;
    inset:0;
    border-radius:inherit;
    pointer-events:none;
    z-index:1;
}

.music-list-card.is-featured-track:not(.is-main-featured-track)::before{
    background:linear-gradient(135deg,rgba(215,168,79,.38),transparent 34%,transparent 72%,rgba(215,168,79,.16)) !important;
}

.music-list-card.is-main-featured-track::before{
    background:linear-gradient(135deg,rgba(255,43,43,.52),transparent 36%,transparent 72%,rgba(255,43,43,.18)) !important;
}

.music-list-card > *{
    position:relative;
    z-index:2;
}

/* Badges */
.music-badge{
    border:1px solid rgba(255,255,255,.14) !important;
    box-shadow:0 10px 26px rgba(0,0,0,.24) !important;
}

/* Featured badge jaune seulement si pas main */
.music-list-card.is-featured-track:not(.is-main-featured-track) .music-badge,
.music-badge.is-featured-badge{
    background:#d7a84f !important;
    color:#000 !important;
    border-color:#d7a84f !important;
}

/* Main badge rouge priorité absolue */
.music-list-card.is-main-featured-track .music-badge,
.music-badge.is-main-badge{
    background:#ff2b2b !important;
    color:#fff !important;
    border-color:#ff2b2b !important;
}

/* Admin conservé */
.admin-music-link{
    border-color:rgba(215,168,79,.46) !important;
    background:rgba(215,168,79,.10) !important;
    color:#ffe2a1 !important;
}

.admin-music-link:hover{
    background:#fff !important;
    color:#000 !important;
}

