:root{--bg:#050611;--card:#111326cc;--card2:#171a32;--txt:#f5f7ff;--muted:#a8b0d0;--cyan:#20e7ff;--pink:#ff2a6d;--gold:#ffd166;--ok:#4dff91;--bad:#ff5b5b;--line:#ffffff18;--radius:22px;--shadow:0 20px 80px #0008}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:radial-gradient(circle at top,#111a3a 0,#050611 45%,#020309 100%);color:var(--txt);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;min-height:100vh;padding-bottom:82px}.bg-orb{position:fixed;border-radius:999px;filter:blur(70px);opacity:.35;z-index:-1}.orb1{width:260px;height:260px;background:var(--cyan);top:40px;left:-80px}.orb2{width:320px;height:320px;background:var(--pink);bottom:30px;right:-90px}.topbar{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;align-items:center;padding:14px clamp(16px,4vw,46px);background:#050611cc;backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}.brand{text-decoration:none;color:var(--txt);font-weight:900;letter-spacing:.08em;display:flex;flex-direction:column}.brand span{font-size:22px}.brand span::after{content:'X';color:var(--pink)}.brand small{font-size:10px;color:var(--cyan)}.desktop-nav{display:flex;gap:16px}.desktop-nav a,.mobile-nav a{color:var(--muted);text-decoration:none;font-weight:700}.desktop-nav a:hover,.mobile-nav a:hover{color:var(--cyan)}.container{width:min(1180px,94vw);margin:0 auto;padding:26px 0}.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center;min-height:70vh}.hero-card,.card,.admin-card,.track-card,.feature-card{background:linear-gradient(180deg,var(--card),#090b18cc);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;position:relative;overflow:hidden}.hero-card::before,.track-card::before,.feature-card::before{content:'';position:absolute;inset:-2px;background:linear-gradient(135deg,#20e7ff44,#ff2a6d33,transparent 55%);z-index:-1}.eyebrow{color:var(--cyan);font-weight:900;text-transform:uppercase;letter-spacing:.14em;font-size:13px}.title{font-size:clamp(38px,8vw,84px);line-height:.9;margin:10px 0;font-weight:1000}.gradient{background:linear-gradient(90deg,var(--cyan),#fff,var(--pink));-webkit-background-clip:text;color:transparent}.lead{color:var(--muted);font-size:clamp(16px,2vw,20px);line-height:1.6}.countdown{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:22px 0}.count-box{background:#0008;border:1px solid var(--line);border-radius:18px;text-align:center;padding:14px}.count-box b{font-size:clamp(28px,5vw,48px);display:block}.count-box span{color:var(--muted);font-size:12px;text-transform:uppercase}.btns{display:flex;gap:12px;flex-wrap:wrap}.btn,button,input[type=submit]{border:0;border-radius:16px;padding:13px 18px;font-weight:900;color:#061018;background:var(--cyan);text-decoration:none;cursor:pointer;box-shadow:0 0 30px #20e7ff30}.btn.secondary{background:#ffffff12;color:var(--txt);border:1px solid var(--line)}.btn.danger{background:var(--pink);color:white}.btn.gold{background:var(--gold);color:#201400}.hero-img{width:100%;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow);aspect-ratio:9/14;object-fit:contain;background:#02030a;padding:6px}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:18px 0}.stat{background:#ffffff0b;border:1px solid var(--line);border-radius:18px;padding:16px}.stat b{font-size:28px}.stat span{display:block;color:var(--muted)}.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.form{display:grid;gap:14px}.field label{font-weight:800;display:block;margin-bottom:6px}.field input,.field textarea,.field select{width:100%;background:#060817;border:1px solid var(--line);color:var(--txt);border-radius:14px;padding:13px}.field textarea{min-height:130px;resize:vertical}.hint{font-size:13px;color:var(--muted)}.track-card video,.track-card img,.feature-card video{width:100%;border-radius:18px;background:#000;aspect-ratio:9/16;object-fit:cover}.track-meta{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}.pill{border:1px solid var(--line);background:#ffffff0d;border-radius:999px;padding:6px 10px;color:var(--muted);font-size:13px}.searchbar{display:flex;gap:10px;margin:16px 0}.searchbar input{flex:1;background:#060817;border:1px solid var(--line);color:var(--txt);border-radius:16px;padding:14px}.ranking-row{display:grid;grid-template-columns:60px 1fr auto auto auto;gap:12px;align-items:center;padding:14px;border-bottom:1px solid var(--line)}.rank{font-size:28px;font-weight:1000;color:var(--gold)}.admin-layout{display:grid;grid-template-columns:240px 1fr;gap:20px}.admin-menu{position:sticky;top:88px;align-self:start}.admin-menu a{display:block;padding:12px;border-radius:12px;text-decoration:none;color:var(--muted)}.admin-menu a:hover{background:#ffffff10;color:var(--cyan)}table{width:100%;border-collapse:collapse;background:#ffffff08;border-radius:18px;overflow:hidden}th,td{padding:12px;border-bottom:1px solid var(--line);text-align:left}th{color:var(--cyan)}.notice{padding:14px;border-radius:16px;background:#20e7ff12;border:1px solid #20e7ff40;margin:12px 0}.error{background:#ff2a6d18;border-color:#ff2a6d55}.success{background:#4dff9118;border-color:#4dff9155}.mobile-nav{display:none}.footer{text-align:center;color:var(--muted);padding:30px}.warning-modal{position:fixed;inset:0;background:#000b;display:grid;place-items:center;z-index:99}.modal-card{width:min(420px,92vw);background:var(--card2);border:1px solid var(--line);border-radius:24px;padding:24px;box-shadow:var(--shadow)}@media(max-width:820px){.desktop-nav{display:none}.hero,.grid,.grid2,.admin-layout{grid-template-columns:1fr}.stats{grid-template-columns:repeat(2,1fr)}.countdown{grid-template-columns:repeat(4,1fr);gap:6px}.count-box{padding:10px 4px}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:#060817ee;backdrop-filter:blur(16px);border-top:1px solid var(--line);z-index:50;justify-content:space-around;padding:8px 6px calc(8px + env(safe-area-inset-bottom))}.mobile-nav a{font-size:20px;text-align:center}.mobile-nav span{display:block;font-size:10px}.ranking-row{grid-template-columns:42px 1fr;gap:8px}.ranking-row .hide-mobile{display:none}.container{padding:18px 0}.hero-card,.card,.admin-card,.track-card,.feature-card{padding:18px}.searchbar{position:sticky;top:60px;z-index:15;background:#050611cc;padding:8px;border-radius:16px}.btns .btn,.btns button{flex:1;text-align:center}.hero-img{aspect-ratio:auto;max-height:72vh;object-fit:contain;padding:6px}.title{font-size:48px}}

/* V6 — lisibilité admin + branding propre */
.brand-pro{min-width:230px;gap:2px;line-height:1;text-transform:uppercase;letter-spacing:.08em}.brand .brand-kicker{font-size:10px;color:var(--muted);font-weight:800}.brand .brand-main{font-size:clamp(18px,3vw,26px);font-weight:1000;letter-spacing:.05em}.brand .brand-main::after{content:''}.brand-red{color:var(--pink)}.brand .brand-sub{font-size:11px;color:var(--cyan);font-weight:900;letter-spacing:.18em}.admin-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:8px}.admin-card{overflow:visible}.admin-search{position:relative;top:auto;background:transparent;padding:0}.user-list{display:grid;gap:16px;margin-top:18px}.user-card-admin{background:linear-gradient(180deg,#171a32,#0b0d1d);border:1px solid var(--line);border-radius:22px;padding:18px;display:grid;gap:16px;box-shadow:0 14px 42px #0005}.user-card-admin.primary-admin{border-color:#ffd16655;background:linear-gradient(180deg,#211b35,#0b0d1d)}.user-main{display:flex;gap:14px;align-items:flex-start;min-width:0}.avatar-badge{width:48px;height:48px;flex:0 0 48px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--cyan),var(--pink));color:#030511;font-weight:1000;font-size:24px;box-shadow:0 0 28px #20e7ff33}.user-id-block{min-width:0}.user-id-block h3{margin:0 0 8px;font-size:24px;line-height:1.1;overflow-wrap:anywhere}.user-line{color:var(--muted);line-height:1.45;overflow-wrap:anywhere}.user-line strong{color:var(--txt)}.user-info-grid{display:grid;grid-template-columns:repeat(4,minmax(120px,1fr));gap:10px}.user-info-grid div{background:#0005;border:1px solid var(--line);border-radius:16px;padding:12px}.user-info-grid span{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;font-weight:800}.user-info-grid b{display:block;margin-top:4px;font-size:16px;overflow-wrap:anywhere}.user-actions{border-top:1px solid var(--line);padding-top:14px}.admin-action-form{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.mini-field{display:flex;align-items:center;gap:8px;background:#0005;border:1px solid var(--line);border-radius:14px;padding:8px 10px;color:var(--muted);font-weight:800}.mini-field input{width:54px;background:#060817;border:1px solid var(--line);border-radius:10px;color:var(--txt);padding:10px;text-align:center}.gold-pill{border-color:#ffd16666;color:#ffd166;background:#ffd16614}table{display:block;overflow-x:auto;white-space:nowrap}td,th{vertical-align:middle}.admin-menu h2{margin-top:0}.admin-menu a{font-size:15px}
@media(max-width:820px){.topbar{align-items:center;padding:12px 14px}.brand-pro{min-width:0}.brand .brand-main{font-size:20px}.brand .brand-sub{font-size:10px}.brand .brand-kicker{font-size:9px}.user-info-grid{grid-template-columns:repeat(2,1fr)}.user-main{align-items:center}.admin-action-form button{flex:1 1 140px}.mini-field{width:100%;justify-content:space-between}.mini-field input{width:72px}.user-card-admin{padding:14px}.user-id-block h3{font-size:21px}}
@media(max-width:520px){.user-info-grid{grid-template-columns:1fr}.avatar-badge{width:42px;height:42px;flex-basis:42px;border-radius:14px;font-size:20px}.brand .brand-main{font-size:18px}.topbar{gap:10px}.container{width:min(100% - 22px,1180px)}}

/* V7 — branding propre + avatars + partage */
.brand span::after{content:''!important}.clean-brand{gap:7px;line-height:1.05;text-transform:none;letter-spacing:0;min-width:260px}.clean-brand .brand-kicker{font-size:12px!important;color:#aeb7dc!important;text-transform:uppercase;letter-spacing:.22em!important;font-weight:900}.clean-brand .brand-main{display:flex!important;gap:0!important;align-items:center;font-size:clamp(26px,4vw,38px)!important;font-weight:1000!important;letter-spacing:.04em!important;color:#fff}.clean-brand .brand-red{color:#ff2a6d!important}.clean-brand .brand-sub{display:flex!important;align-items:center;gap:10px;font-size:clamp(18px,2.5vw,25px)!important;color:#f5f7ff!important;font-weight:950!important;letter-spacing:.02em!important}.badge-mini{display:inline-flex!important;align-items:center;justify-content:center;background:linear-gradient(135deg,#20e7ff,#0b89ff);color:#fff!important;border:1px solid #7cecff66;border-radius:9px;padding:4px 8px;font-size:.82em!important;font-weight:1000!important;box-shadow:0 0 24px #20e7ff33}.topbar{min-height:110px}.avatar-img{object-fit:cover!important;padding:0!important}.account-profile-row{display:flex;gap:16px;align-items:center;margin:12px 0 18px}.account-avatar{width:74px!important;height:74px!important;flex:0 0 74px;border-radius:22px!important}.profile-form{margin-top:14px}.share-card{margin:18px 0;background:linear-gradient(180deg,#111326cc,#080a16cc);border:1px solid var(--line);border-radius:22px;padding:20px;display:flex;align-items:center;justify-content:space-between;gap:16px;box-shadow:var(--shadow)}.share-card p{margin:6px 0 0;color:var(--muted)}.share-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.share-actions .btn,.share-actions button{padding:11px 14px;border-radius:14px}.mini-field-wide{flex:1 1 260px}.mini-field-wide input{width:100%;min-width:220px;text-align:left}.edit-user-form{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--line)}
@media(max-width:820px){.topbar{min-height:92px}.clean-brand{min-width:0}.clean-brand .brand-kicker{font-size:9px!important}.clean-brand .brand-main{font-size:25px!important}.clean-brand .brand-sub{font-size:17px!important}.share-card{display:block}.share-actions{justify-content:stretch;margin-top:14px}.share-actions a,.share-actions button{flex:1 1 130px;text-align:center}.account-profile-row{align-items:flex-start}.account-avatar{width:58px!important;height:58px!important;flex-basis:58px}}
@media(max-width:520px){.topbar{min-height:88px}.clean-brand .brand-main{font-size:22px!important}.clean-brand .brand-sub{font-size:15px!important}.badge-mini{padding:3px 7px}.clean-brand .brand-kicker{letter-spacing:.16em!important}}


/* V8 — partage complet TikTok / Instagram / accueil */
.share-card{align-items:center!important}.share-actions{gap:9px!important}.share-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line);border-radius:14px;padding:11px 14px;text-decoration:none;color:#fff;font-weight:950;cursor:pointer;box-shadow:0 12px 32px #0005;background:#ffffff12;white-space:nowrap}.share-btn span{width:22px;height:22px;border-radius:8px;display:inline-grid;place-items:center;background:#0005;font-weight:1000}.share-btn.fb{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.share-btn.x{background:linear-gradient(135deg,#202436,#050611)}.share-btn.wa{background:linear-gradient(135deg,#19c37d,#0d8f5a)}.share-btn.tk{background:linear-gradient(135deg,#111827,#ff2a6d 48%,#20e7ff)}.share-btn.ig{background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045)}.share-btn.copy{background:linear-gradient(135deg,#20e7ff,#0b89ff);color:#061018}.share-home-btn{background:linear-gradient(135deg,#ff2a6d,#20e7ff)!important;color:white!important}#home-share .share-card{margin-top:16px;padding:16px}#home-share .share-card p{font-size:14px}
@media(max-width:820px){.share-actions{display:grid!important;grid-template-columns:1fr 1fr}.share-actions .share-btn{width:100%;min-height:46px}.share-card{padding:16px!important}.share-card b{font-size:17px}}
@media(max-width:460px){.share-actions{grid-template-columns:1fr}.share-btn{justify-content:flex-start!important}.share-btn span{margin-right:2px}}

/* V9 — partage propre en popup */
.share-mini-panel{margin:18px 0;background:linear-gradient(180deg,#111326cc,#080a16cc);border:1px solid var(--line);border-radius:22px;padding:18px;display:flex;align-items:center;justify-content:space-between;gap:14px;box-shadow:var(--shadow)}
.share-mini-panel p{margin:5px 0 0;color:var(--muted)}
.share-clean-row{margin:14px 0;display:flex;justify-content:flex-start}.share-clean-row .btn{width:auto}.share-modal[hidden]{display:none}.share-modal{position:fixed;inset:0;z-index:120;display:grid;place-items:center;padding:18px}.share-modal-backdrop{position:absolute;inset:0;background:#000c;backdrop-filter:blur(8px)}.share-modal-card{position:relative;width:min(520px,94vw);background:linear-gradient(180deg,#15182f,#070914);border:1px solid #ffffff22;border-radius:26px;padding:22px;box-shadow:0 30px 100px #000}.share-modal-close{position:absolute;top:12px;right:12px;width:40px;height:40px;border-radius:14px;border:1px solid var(--line);background:#ffffff12;color:#fff;font-size:26px;line-height:1;cursor:pointer}.share-modal-head{display:flex;gap:14px;align-items:center;margin-bottom:18px}.share-modal-icon{width:52px;height:52px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg,var(--pink),var(--cyan));font-size:26px;box-shadow:0 0 34px #20e7ff33}.share-modal-head h2{margin:0 0 4px;font-size:24px}.share-modal-head p{margin:0;color:var(--muted)}.share-modal-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.share-modal-actions .share-btn{width:100%;min-height:50px}.share-modal-note{margin-top:14px;text-align:center}.share-card{display:none!important}
@media(max-width:560px){.share-mini-panel{display:block}.share-mini-panel .btn{width:100%;margin-top:12px}.share-modal-actions{grid-template-columns:1fr}.share-modal-card{padding:18px}.share-modal-head h2{font-size:21px}}


/* V10 — bannières visuelles modifiables par page */
.page-banner{position:relative;margin:0 auto 22px;width:min(1180px,100%);min-height:250px;border:1px solid var(--line);border-radius:28px;overflow:hidden;box-shadow:var(--shadow);background:#080a16}
.page-banner img{width:100%;height:100%;min-height:250px;display:block;object-fit:cover}
.page-banner:after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,#050611ee 0%,#050611aa 43%,#05061122 100%)}
.page-banner-overlay{position:absolute;z-index:2;inset:0;display:flex;flex-direction:column;justify-content:center;padding:28px clamp(22px,5vw,68px);max-width:850px}
.page-banner-overlay .eyebrow{display:inline-flex;align-self:flex-start;margin-bottom:12px;background:linear-gradient(135deg,var(--cyan),#0b89ff);color:#03111b;border-radius:999px;padding:8px 13px;font-weight:1000;letter-spacing:.04em;text-transform:uppercase;box-shadow:0 0 30px #20e7ff33}
.page-banner-overlay h1{margin:0;font-size:clamp(34px,6vw,76px);line-height:.95;font-weight:1000;letter-spacing:-.04em;text-transform:uppercase;text-shadow:0 8px 30px #000}
.page-banner-overlay p{margin:14px 0 0;color:#d7ddff;font-size:clamp(16px,2.2vw,24px);line-height:1.35;max-width:760px;text-shadow:0 6px 22px #000}
.compact-intro{margin-top:0}.banner-admin-box{border:1px solid var(--line);background:#0004;border-radius:20px;padding:16px;margin:14px 0}.banner-admin-box h3{margin:0 0 12px}.account-head{margin-top:0}
@media(max-width:820px){.page-banner{min-height:230px;border-radius:22px;margin-bottom:18px}.page-banner img{min-height:230px}.page-banner:after{background:linear-gradient(90deg,#050611f5 0%,#050611bb 68%,#05061155 100%)}.page-banner-overlay{padding:22px}.page-banner-overlay h1{font-size:38px}.page-banner-overlay p{font-size:16px}.page-banner-overlay .eyebrow{font-size:12px;padding:7px 10px}}
@media(max-width:520px){.page-banner{min-height:210px}.page-banner img{min-height:210px}.page-banner-overlay h1{font-size:32px}.page-banner-overlay p{font-size:14px}.page-banner-overlay{padding:18px}.topbar{position:relative}}


.inline-form{display:inline-flex;margin:0}.tiktok-btn{background:linear-gradient(135deg,#111827,#ff0069 45%,#00f2ea)!important;color:white!important}.page-banner{margin-bottom:22px}.share-home-btn{white-space:nowrap}.track-card .btns{flex-wrap:wrap}.creator-link-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.admin-card table small{color:#aeb7d9}.follow-pill{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:8px 12px;display:inline-flex}
@media(max-width:700px){.page-banner{min-height:160px}.page-banner img{object-position:center}.btns .btn,.btns button{width:100%;justify-content:center}.inline-form{width:100%}.inline-form button{width:100%}}

/* V13 — écoute plus propre, cartes compactes, commentaires admin/modo */
.listen-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px;align-items:start;margin-top:18px}.track-card-small{padding:14px;border-radius:18px}.track-card-small video{aspect-ratio:9/14;max-height:340px;object-fit:cover;border-radius:14px}.track-card-small h3{font-size:17px;line-height:1.2;margin:11px 0 4px}.track-card-small p{font-size:13px;line-height:1.35}.track-card-body{display:grid;gap:6px}.track-card-small .track-meta{gap:5px}.track-card-small .pill{font-size:11px;padding:5px 7px}.track-card-small .btns{gap:8px}.track-card-small .btns .btn,.track-card-small .btns button{padding:10px 12px;border-radius:12px;font-size:13px}.feature-card-compact{padding:16px;border-radius:20px;margin:18px 0}.feature-inline{display:grid;grid-template-columns:minmax(150px,230px) 1fr;gap:18px;align-items:center}.feature-inline video{width:100%;max-height:300px;aspect-ratio:9/14;object-fit:cover;border-radius:16px}.feature-info h2{margin:6px 0 4px}.track-detail-video video{max-height:620px;object-fit:contain}.comment-row{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.comment-row form{margin:0}.comment-row .btn{padding:9px 12px}.admin-list{display:grid;gap:12px}.admin-row-card{border:1px solid var(--line);background:#ffffff08;border-radius:18px;padding:15px;display:flex;justify-content:space-between;gap:14px;align-items:flex-start}.admin-row-card p{margin:10px 0 0;color:#d8ddff}.admin-row-card a{color:var(--cyan);text-decoration:none}.admin-row-card form{flex-shrink:0}.mail-confirm-help{font-size:13px;color:var(--muted);margin-top:8px}
@media(max-width:980px){.listen-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}.feature-inline{grid-template-columns:170px 1fr}.track-card-small video{max-height:300px}}
@media(max-width:700px){.listen-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.track-card-small{padding:10px}.track-card-small video{max-height:260px}.track-card-small p{font-size:12px}.feature-inline{grid-template-columns:1fr}.feature-inline video{max-height:360px;object-fit:contain}.admin-row-card,.comment-row{display:block}.admin-row-card form,.comment-row form{margin-top:10px}.track-detail-video video{max-height:72vh}}
@media(max-width:420px){.listen-grid{grid-template-columns:1fr}.track-card-small video{max-height:360px}}

/* V14 — cartes compactes, admin morceaux, classement avatars, mails */
.compact-track-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px}.track-card-small{padding:12px}.track-card-small video{max-height:270px;aspect-ratio:9/13;object-fit:cover}.is-featured-small{border-color:#ffd16688;box-shadow:0 0 0 1px #ffd16633,0 18px 60px #0007}.featured-ribbon{position:absolute;top:10px;left:10px;z-index:2;background:linear-gradient(135deg,#ffd166,#ff2a6d);color:#050611;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:1000}.creator-mini-line{display:flex;gap:9px;align-items:center;min-width:0}.creator-mini-line span{min-width:0;display:block}.creator-mini-line b{display:block;overflow-wrap:anywhere;line-height:1.15}.creator-mini-line small{display:block;color:var(--muted);font-size:12px;overflow-wrap:anywhere}.avatar-mini{width:34px;height:34px;flex:0 0 34px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,var(--cyan),var(--pink));color:#02040b;font-weight:1000}.ranking-card-pro{padding:10px}.ranking-row-pro{grid-template-columns:78px 54px 1fr auto auto;border-radius:18px;border:1px solid var(--line);margin:10px 0;background:#ffffff08}.ranking-row-pro .btn{padding:10px 13px}.rank-pro{font-size:18px;display:flex;flex-direction:column;align-items:center;gap:2px;color:#fff}.rank-pro span{font-size:24px;color:var(--gold)}.rank-pro small{font-size:22px}.ranking-avatar{width:50px;height:50px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--cyan),var(--pink));font-weight:1000;color:#02040b;object-fit:cover}.ranking-main b{font-size:17px;display:block}.ranking-main span{color:var(--muted);font-size:13px}.ranking-stats{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.ranking-stats span{background:#0006;border:1px solid var(--line);border-radius:12px;padding:7px 10px;color:var(--muted)}.podium-1{background:linear-gradient(135deg,#ffd16618,#ffffff08)}.podium-2{background:linear-gradient(135deg,#dce3ff16,#ffffff08)}.podium-3{background:linear-gradient(135deg,#ff9e6416,#ffffff08)}.admin-filters{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0}.admin-filters input,.admin-filters select{background:#060817;border:1px solid var(--line);color:var(--txt);border-radius:14px;padding:12px;min-width:220px}.check-filter{display:flex;align-items:center;gap:8px;background:#ffffff08;border:1px solid var(--line);border-radius:14px;padding:10px 12px}.admin-track-grid{display:grid;gap:14px}.admin-track-card{display:grid;grid-template-columns:118px 1fr;gap:16px;background:#ffffff08;border:1px solid var(--line);border-radius:20px;padding:14px;align-items:start}.admin-track-card video{width:118px;max-height:165px;border-radius:14px;background:#000;object-fit:cover}.admin-track-info p{margin:8px 0;color:#d8ddff}.admin-track-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.admin-track-actions button{padding:10px 12px;border-radius:12px}.mail-template-card{border:1px solid var(--line);background:#ffffff07;border-radius:20px;padding:16px;margin:14px 0}.mail-send-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}.mail-send-row label{margin:0;background:#0005;border:1px solid var(--line);border-radius:12px;padding:10px 12px}.mail-send-row button{margin-left:auto}.avatar-img.avatar-mini,.avatar-img.ranking-avatar{object-fit:cover;padding:0}
@media(max-width:900px){.ranking-row-pro{grid-template-columns:55px 44px 1fr}.ranking-stats{grid-column:3 / -1;justify-content:flex-start}.ranking-row-pro .btn{grid-column:3 / -1}.admin-track-card{grid-template-columns:90px 1fr}.admin-track-card video{width:90px;max-height:130px}.compact-track-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.track-card-small video{max-height:230px}.ranking-avatar{width:44px;height:44px;border-radius:14px}.rank-pro span{font-size:19px}}
@media(max-width:460px){.compact-track-grid{grid-template-columns:1fr}.track-card-small video{max-height:330px}.admin-track-card{grid-template-columns:1fr}.admin-track-card video{width:100%;max-height:260px}.admin-filters input,.admin-filters select{min-width:100%;width:100%}}

/* V15 admin/creator video editing */
.admin-edit-track{margin-top:10px;border:1px solid rgba(255,255,255,.10);border-radius:16px;background:rgba(255,255,255,.035);padding:10px}
.admin-edit-track summary{cursor:pointer;font-weight:900;color:#fff}
.admin-track-edit-form{display:grid;gap:10px;margin-top:10px}
.admin-track-edit-form label{display:grid;gap:6px;font-weight:800;color:#fff}
.admin-track-edit-form input,.admin-track-edit-form textarea{width:100%;box-sizing:border-box;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.25);color:#fff;padding:10px}
.admin-track-edit-form textarea{resize:vertical}
.admin-track-edit-form .hint{font-size:.82rem;color:#bfc7ff;font-weight:500}


/* V16 - Admin accordéons propres */
.accordion-list{display:grid;gap:12px;margin-top:16px}
.admin-accordion{background:linear-gradient(180deg,#111326dd,#090b18ee);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 10px 38px #0005}
.admin-accordion>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px}
.admin-accordion>summary::-webkit-details-marker{display:none}
.admin-accordion>summary:hover{background:#ffffff08}
.summary-left{display:flex;align-items:center;gap:12px;min-width:0}
.summary-left strong{display:block;max-width:520px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.summary-left small{display:block;color:var(--muted);font-size:12px;max-width:620px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.summary-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.accordion-body{border-top:1px solid var(--line);padding:16px;background:#05061166}
.user-accordion.primary-admin{border-color:#ffd16677}
.stacked-actions{display:grid;gap:12px;margin-top:14px}
.track-thumb-wrap{width:82px;height:52px;border-radius:12px;overflow:hidden;background:#03040b;border:1px solid var(--line);flex:0 0 auto}
.track-thumb-wrap video{width:100%;height:100%;object-fit:cover;display:block}
.track-admin-body{display:grid;grid-template-columns:220px 1fr;gap:16px;align-items:start}
.track-admin-preview video{width:100%;max-height:160px;object-fit:contain;background:#03040b;border:1px solid var(--line);border-radius:16px}
.nested-edit{margin:12px 0;background:#ffffff08;border:1px solid var(--line);border-radius:14px;padding:10px}
.nested-edit summary{cursor:pointer;font-weight:900}
.mail-icon{display:grid;place-items:center;width:38px;height:38px;border-radius:12px;background:#ffffff10;border:1px solid var(--line)}
.table-wrap{overflow:auto}
.comments-by-track{display:grid;gap:12px}
.comment-admin-main{display:flex;gap:12px;align-items:flex-start}
.comment-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
@media(max-width:760px){
  .admin-accordion>summary{align-items:flex-start;flex-direction:column}
  .summary-right{justify-content:flex-start}
  .summary-left strong,.summary-left small{max-width:78vw}
  .track-admin-body{grid-template-columns:1fr}
  .comment-row{flex-direction:column}
}


.copy-protect-toast{position:fixed;left:50%;bottom:82px;transform:translateX(-50%);z-index:99999;background:rgba(10,10,18,.94);border:1px solid rgba(255,255,255,.16);box-shadow:0 16px 40px rgba(0,0,0,.45);color:#fff;padding:12px 16px;border-radius:16px;font-size:14px;font-weight:700;text-align:center;max-width:min(92vw,420px);backdrop-filter:blur(12px)}


/* V18 — limite globale de votes par votant */
.vote-quota-box{margin:10px 0;padding:12px 14px;border-radius:16px;background:linear-gradient(135deg,rgba(32,231,255,.14),rgba(255,42,109,.10));border:1px solid rgba(32,231,255,.35);color:#f5f7ff;font-weight:900;line-height:1.35}
.my-votes-card{overflow:visible}.my-votes-list{display:grid;gap:10px;margin-top:12px}.my-vote-row{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--txt);background:#ffffff08;border:1px solid var(--line);border-radius:16px;padding:10px}.my-vote-row:hover{border-color:rgba(32,231,255,.55);background:#20e7ff12}.my-vote-row span{min-width:0}.my-vote-row b{display:block;overflow-wrap:anywhere}.my-vote-row small{display:block;color:var(--muted);font-size:12px;overflow-wrap:anywhere}


/* V20 — alerte Live TikTok administrable */
.tiktok-live-banner{margin:0 0 18px;display:flex;align-items:center;gap:14px;padding:14px 16px;border:1px solid rgba(255,0,105,.45);border-radius:20px;background:linear-gradient(135deg,rgba(255,0,105,.18),rgba(0,242,234,.10),rgba(255,255,255,.06));box-shadow:0 14px 50px rgba(255,0,105,.14);position:relative;overflow:hidden}
.tiktok-live-banner:before{content:'';position:absolute;inset:-40% -10%;background:radial-gradient(circle at 20% 50%,rgba(255,0,105,.28),transparent 35%),radial-gradient(circle at 80% 50%,rgba(0,242,234,.22),transparent 35%);pointer-events:none}
.tiktok-live-banner>*{position:relative;z-index:1}.live-dot{width:14px;height:14px;border-radius:999px;background:#ff0050;box-shadow:0 0 0 0 rgba(255,0,80,.8);animation:livePulse 1.4s infinite;flex:0 0 auto}.live-copy{display:grid;gap:3px;min-width:0;flex:1}.live-copy strong{font-size:17px;color:#fff}.live-copy span{color:#dce4ff;font-size:14px;line-height:1.35}.tiktok-live-btn{background:linear-gradient(135deg,#111827,#ff0069 48%,#00f2ea)!important;color:#fff!important;white-space:nowrap}@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(255,0,80,.75)}70%{box-shadow:0 0 0 12px rgba(255,0,80,0)}100%{box-shadow:0 0 0 0 rgba(255,0,80,0)}}
@media(max-width:720px){.tiktok-live-banner{align-items:flex-start;flex-direction:column;border-radius:18px}.tiktok-live-btn{width:100%;justify-content:center}.live-dot{position:absolute;top:18px;right:18px}.live-copy{padding-right:28px}}

.comment-deleted{opacity:.72;border-style:dashed}
.comment-deleted p{font-style:italic;color:var(--muted)}
.danger-pill{border-color:rgba(255,80,120,.45);background:rgba(255,80,120,.12);color:#ffd5df}
.success-pill{border-color:rgba(80,255,170,.35);background:rgba(80,255,170,.10);color:#d9ffe9}


/* V24 — mise en avant équitable + images aléatoires */
.featured-spotlight{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:center;border:1px solid rgba(255,255,255,.16);background:linear-gradient(135deg,rgba(255,0,80,.18),rgba(32,231,255,.12));box-shadow:0 20px 70px rgba(0,0,0,.35)}
.featured-spotlight video{width:100%;max-height:270px;object-fit:cover;border-radius:20px;border:1px solid rgba(255,255,255,.18);background:#03040b}.featured-label{display:inline-flex;gap:8px;padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.12);font-weight:900;color:#fff}.featured-copy h2{font-size:clamp(1.4rem,4vw,2.5rem);margin:.45rem 0}.featured-copy p{color:rgba(255,255,255,.82)}
.admin-accordion{border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:10px 14px;margin:10px 0;background:rgba(255,255,255,.045)}.admin-accordion summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:10px}.admin-accordion summary::-webkit-details-marker{display:none}.admin-thumb-wide{width:100%;max-width:420px;max-height:160px;object-fit:cover;border-radius:14px;border:1px solid rgba(255,255,255,.12);margin:10px 0}.featured-history-user{font-size:.95rem}
@media(max-width:760px){.featured-spotlight{grid-template-columns:1fr}.featured-spotlight video{max-height:230px}.featured-spotlight .btns{display:flex;flex-wrap:wrap}.admin-accordion summary{align-items:flex-start;flex-direction:column}}

/* V25 - Modérateurs & permissions */
.permission-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px;margin:12px 0}
.perm-check{display:flex;gap:10px;align-items:flex-start;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);border-radius:14px;padding:10px;color:#fff}
.perm-check input{width:auto;margin-top:3px}.moderator-permissions-form h3{margin:12px 0 6px}.gold-pill{background:rgba(255,197,66,.16);border-color:rgba(255,197,66,.40);color:#ffd77a}

/* V27 admin accordéons & nettoyage */
.admin-accordion{background:rgba(12,14,30,.86);border:1px solid rgba(255,255,255,.10);border-radius:18px;padding:16px;margin:14px 0;box-shadow:0 10px 30px rgba(0,0,0,.25)}
.admin-accordion summary{cursor:pointer;list-style:none;font-size:1.05rem;color:#fff;display:flex;align-items:center;gap:10px}
.admin-accordion summary::-webkit-details-marker{display:none}
.admin-accordion[open] summary{margin-bottom:14px}
.nested-accordion{background:rgba(255,255,255,.035);border-radius:14px;padding:12px;margin:10px 0}
.danger-zone{border-color:rgba(255,50,80,.45)!important;box-shadow:0 0 0 1px rgba(255,50,80,.15),0 14px 35px rgba(0,0,0,.30)}
.stacked-actions{display:flex;flex-direction:column;gap:12px}
.mini-field-wide input{max-width:360px}
@media(max-width:720px){
 .admin-accordion{padding:12px;border-radius:14px}
 .admin-accordion summary{font-size:.98rem}
}


/* V28 — popup connexion administrable + compte à rebours ON/OFF */
.login-popup-backdrop{position:fixed;inset:0;z-index:999999;background:rgba(0,0,0,.72);display:grid;place-items:center;padding:18px;backdrop-filter:blur(8px)}
.login-popup-card{width:min(560px,94vw);background:linear-gradient(145deg,#111326,#070813);border:1px solid rgba(255,255,255,.16);border-radius:26px;box-shadow:0 26px 90px rgba(0,0,0,.65);padding:22px;text-align:center;color:#fff;animation:popupIn .18s ease-out}
.login-popup-card h2{margin:12px 0 8px;font-size:clamp(1.35rem,4vw,2.2rem)}
.login-popup-card p{color:#dfe7ff;line-height:1.5;font-size:1rem}
.login-popup-img{width:100%;max-height:260px;object-fit:contain;border-radius:20px;border:1px solid rgba(255,255,255,.14);background:#050611;margin-bottom:12px}
@keyframes popupIn{from{transform:translateY(12px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
@media(max-width:720px){.login-popup-card{border-radius:20px;padding:16px}.login-popup-img{max-height:210px}}


/* V29 - Aperçus images admin + accordéons plus propres */
.admin-image-preview{display:grid;gap:8px;margin:10px 0 12px;padding:10px;border:1px solid rgba(255,255,255,.14);border-radius:16px;background:rgba(255,255,255,.06)}
.admin-image-preview span{font-size:.84rem;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.06em}
.admin-image-preview img{width:100%;max-width:520px;max-height:220px;object-fit:contain;background:#03040b;border:1px solid rgba(255,255,255,.12);border-radius:14px;display:block}
.admin-accordion[open]>summary{background:linear-gradient(90deg,rgba(32,231,255,.12),rgba(255,42,109,.09))}
.admin-accordion summary::after{content:'+';font-weight:1000;color:var(--cyan);font-size:1.25rem}
.admin-accordion[open]>summary::after{content:'−';color:var(--pink)}
.nested-accordion summary::after{font-size:1rem}
@media(max-width:760px){
  .admin-image-preview img{max-height:180px}
}


/* V41 - MP3 lives, countdown global, avatars créateurs, badge admin */
.global-countdown{display:flex;gap:12px;align-items:center;justify-content:space-between;margin:12px 0 18px;padding:12px 16px;border:1px solid rgba(255,255,255,.16);border-radius:18px;background:linear-gradient(135deg,rgba(229,9,20,.18),rgba(128,0,255,.14));box-shadow:0 10px 35px rgba(0,0,0,.22)}
.global-countdown b{font-size:1rem}.global-countdown span{opacity:.95}.global-countdown strong{color:#fff;font-size:1.08em}
.admin-alert-pill{display:inline-flex!important;align-items:center;gap:6px;padding:7px 11px;border-radius:999px;background:#e50914;color:#fff!important;font-weight:900;box-shadow:0 0 18px rgba(229,9,20,.35)}
.audio-cover-card{display:grid;gap:10px;align-items:center;background:rgba(255,255,255,.05);border-radius:18px;overflow:hidden;padding:10px}.audio-cover-card img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:14px}.audio-cover-card audio{width:100%}.track-card-small .audio-cover-card{padding:0;background:transparent}.track-card-small .audio-cover-card img{border-radius:18px 18px 0 0}.track-thumb-wrap .audio-cover-card{width:120px;padding:0}.track-thumb-wrap .audio-cover-card audio{display:none}.track-thumb-wrap .audio-cover-card img{width:120px;height:72px;aspect-ratio:auto}.track-admin-preview .audio-cover-card audio{display:block}.creator-hero-line{display:flex;align-items:center;gap:14px;margin-bottom:10px}.avatar-big{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.32);box-shadow:0 0 25px rgba(229,9,20,.25)}.soft-card{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.1)}.disabled{opacity:.65;pointer-events:none}.launch-countdown-box{margin:12px 0 18px;padding:14px;border-radius:18px;background:rgba(229,9,20,.10);border:1px solid rgba(229,9,20,.25)}
@media(max-width:720px){.global-countdown{display:block}.global-countdown span{display:block;margin-top:4px}.creator-hero-line{align-items:flex-start}.avatar-big{width:58px;height:58px}}


/* V49 - badge 1er plus pro + bannières fallback propres */
.clean-brand .brand-sub{gap:0!important}
.clean-brand .brand-sub .challenge-rank{display:inline-flex;align-items:flex-end;gap:10px;color:#f5f7ff!important}
.challenge-rank{display:inline-flex;align-items:center;gap:10px}
.challenge-rank-num,.first-rank-num{display:inline-block;line-height:1;font-weight:1000}
.challenge-rank sup,.first-rank-text sup{font-size:.52em;line-height:1;position:relative;top:-.55em;margin-left:1px;font-weight:1000;text-transform:lowercase}
.challenge-rank-label{display:inline-block;line-height:1.1}
.challenge-rank--header .challenge-rank-num{font-size:1.22em}
.challenge-rank--header{font-size:clamp(18px,2.5vw,25px);font-weight:950;letter-spacing:.02em}
.challenge-rank--header .challenge-rank-label{font-size:1em}
.challenge-rank--banner{font-size:1rem;gap:8px;color:#03111b}
.challenge-rank--banner .challenge-rank-num{font-size:1.12em}
.challenge-rank--banner .challenge-rank-label{font-size:1em}
.title-v42 .mini-line{display:inline-flex;align-items:flex-end;gap:6px}
.first-rank-text{display:inline-flex;align-items:flex-end;gap:0;line-height:1;font-weight:1000}
.first-rank-text .first-rank-num{font-size:1.05em}
.page-banner{background:linear-gradient(180deg,#0a0d1c,#080a16)}
.page-banner img{filter:saturate(1.05) brightness(.95)}
.page-banner:after{background:linear-gradient(90deg,#050611f4 0%,#050611d0 38%,#05061166 72%,rgba(5,6,17,.18) 100%)}
.page-banner-overlay{max-width:760px}
.page-banner-overlay h1,.page-banner-overlay p{display:block}
.page-banner-overlay .eyebrow.eyebrow-rank{background:linear-gradient(135deg,var(--cyan),#ffd166,#ff4fa3);color:#03111b;gap:0;padding:10px 15px}
.page-banner-overlay .eyebrow.eyebrow-rank .challenge-rank{gap:8px}
@media(max-width:820px){
  .challenge-rank--header{font-size:17px}
  .challenge-rank--header .challenge-rank-num{font-size:1.16em}
  .page-banner-overlay .eyebrow.eyebrow-rank{padding:8px 12px}
}


/* V50 - bannières pages plus propres + badge 1er simple */
.clean-brand .brand-sub{display:flex!important;align-items:center;gap:10px;font-size:clamp(18px,2.5vw,25px)!important;color:#f5f7ff!important;font-weight:950!important;letter-spacing:.02em!important}
.badge-mini-header{padding:5px 10px;border-radius:12px;font-size:.84em!important;line-height:1!important;box-shadow:0 0 18px #20e7ff33}
.mini-rank-badge{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#20e7ff,#ffd166,#ff4fa3);color:#061018;border-radius:12px;padding:6px 12px;font-size:.5em;font-weight:1000;line-height:1;box-shadow:0 0 24px rgba(32,231,255,.22);margin-right:10px;transform:translateY(-6px)}
.page-banner.page-banner-compact{min-height:168px;max-height:190px;border-radius:24px;overflow:hidden}
.page-banner.page-banner-compact img{min-height:168px;height:190px;object-fit:cover;object-position:center}
.page-banner.page-banner-compact:after{background:linear-gradient(90deg,rgba(5,6,17,.24) 0%,rgba(5,6,17,.1) 100%)}
.page-banner.page-banner-compact .page-banner-overlay.compact-only{inset:0;display:flex;justify-content:flex-start;align-items:flex-start;padding:20px 22px;max-width:none}
.page-banner.page-banner-compact .eyebrow.eyebrow-compact{display:inline-flex;align-self:flex-start;background:linear-gradient(135deg,#20e7ff,#ffd166,#ff4fa3);color:#061018;border-radius:999px;padding:9px 16px;font-size:15px;font-weight:1000;letter-spacing:.02em;text-transform:none;box-shadow:0 0 28px rgba(32,231,255,.24)}
.page-banner.page-banner-compact h1,.page-banner.page-banner-compact p{display:none!important}
@media(max-width:820px){
  .badge-mini-header{padding:4px 8px;font-size:.8em!important;border-radius:10px}
  .mini-rank-badge{padding:5px 10px;font-size:.48em;transform:translateY(-4px);margin-right:8px}
  .page-banner.page-banner-compact{min-height:128px;max-height:148px;border-radius:20px}
  .page-banner.page-banner-compact img{min-height:128px;height:148px}
  .page-banner.page-banner-compact .page-banner-overlay.compact-only{padding:14px 16px}
  .page-banner.page-banner-compact .eyebrow.eyebrow-compact{font-size:12px;padding:7px 12px}
}


/* V51 - bannière écoute/classement/compte avec texte propre */
.page-banner.page-banner-compact .banner-mini-copy{display:flex;flex-direction:column;gap:6px;margin-top:12px;max-width:700px}
.page-banner.page-banner-compact .banner-mini-copy strong{display:block;color:#ffffff;font-size:26px;font-weight:1000;line-height:1.05;text-shadow:0 8px 20px rgba(0,0,0,.45)}
.page-banner.page-banner-compact .banner-mini-copy span{display:block;color:#eef3ff;font-size:18px;line-height:1.35;text-shadow:0 6px 18px rgba(0,0,0,.45)}
@media(max-width:820px){
  .page-banner.page-banner-compact .banner-mini-copy{margin-top:10px;gap:4px;max-width:100%}
  .page-banner.page-banner-compact .banner-mini-copy strong{font-size:19px}
  .page-banner.page-banner-compact .banner-mini-copy span{font-size:13px;line-height:1.25}
}


/* V52 - bannières image pure sans texte qui se mélange */
.page-banner.page-banner-clean{
  display:block;
  position:relative;
  width:min(1180px,100%);
  height:clamp(155px,18vw,235px);
  min-height:0!important;
  max-height:none!important;
  margin:0 auto 24px!important;
  border:1px solid rgba(255,255,255,.14);
  border-radius:26px;
  overflow:hidden;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  background-color:#080a16;
  box-shadow:0 20px 70px rgba(0,0,0,.42);
}
.page-banner.page-banner-clean::after{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(5,6,17,.10),rgba(5,6,17,.02)),
    radial-gradient(circle at 18% 50%,rgba(32,231,255,.14),transparent 42%),
    radial-gradient(circle at 82% 50%,rgba(255,42,109,.12),transparent 44%);
  pointer-events:none;
}
.page-banner.page-banner-clean img,
.page-banner.page-banner-clean .page-banner-overlay,
.page-banner.page-banner-clean .compact-only,
.page-banner.page-banner-clean .eyebrow,
.page-banner.page-banner-clean .banner-mini-copy{
  display:none!important;
}
.page-banner.page-banner-clean + .compact-intro{
  margin-top:0!important;
  clear:both;
}
@media(max-width:820px){
  .page-banner.page-banner-clean{
    height:140px;
    border-radius:20px;
    margin-bottom:18px!important;
  }
}


/* V53 - vraie bannière image visible sur les pages */
.page-banner.page-banner-clean{
  display:block;
  position:relative;
  width:min(1180px,100%);
  height:clamp(155px,18vw,235px);
  min-height:155px!important;
  margin:0 auto 24px!important;
  border:1px solid rgba(255,255,255,.14);
  border-radius:26px;
  overflow:hidden;
  background:#080a16!important;
  background-image:none!important;
  box-shadow:0 20px 70px rgba(0,0,0,.42);
}
.page-banner.page-banner-clean .page-banner-clean-img{
  display:block!important;
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  object-position:center!important;
}
.page-banner.page-banner-clean::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(5,6,17,.06),rgba(5,6,17,0));
  pointer-events:none;
}
.page-banner.page-banner-clean img:not(.page-banner-clean-img),
.page-banner.page-banner-clean .page-banner-overlay,
.page-banner.page-banner-clean .compact-only,
.page-banner.page-banner-clean .eyebrow,
.page-banner.page-banner-clean .banner-mini-copy{
  display:none!important;
}
@media(max-width:820px){
  .page-banner.page-banner-clean{
    height:140px;
    min-height:140px!important;
    border-radius:20px;
    margin-bottom:18px!important;
  }
}


/* V54 - textes administrables Salle d'écoute */
.page-banner.page-banner-clean{position:relative;}
.page-banner.page-banner-clean .page-banner-note{
  position:absolute;
  left:22px;
  top:22px;
  z-index:2;
  max-width:min(760px,calc(100% - 44px));
  padding:10px 14px;
  border-radius:16px;
  background:rgba(4,6,16,.72);
  border:1px solid rgba(255,255,255,.16);
  color:#fff;
  font-weight:900;
  font-size:clamp(15px,1.7vw,22px);
  line-height:1.25;
  text-shadow:0 4px 15px rgba(0,0,0,.55);
  backdrop-filter:blur(8px);
}
.listen-intro-text{white-space:normal;}
@media(max-width:820px){
  .page-banner.page-banner-clean .page-banner-note{left:14px;top:14px;max-width:calc(100% - 28px);font-size:14px;padding:8px 10px;border-radius:12px;}
}


/* V55 - correction affichage image bannière Salle d'écoute */
.page-banner.page-banner-clean{
  display:block!important;
  position:relative!important;
  width:min(1180px,100%)!important;
  height:clamp(155px,18vw,235px)!important;
  min-height:155px!important;
  margin:0 auto 24px!important;
  border:1px solid rgba(255,255,255,.14)!important;
  border-radius:26px!important;
  overflow:hidden!important;
  background-color:#080a16!important;
  background-size:cover!important;
  background-position:center!important;
  background-repeat:no-repeat!important;
  box-shadow:0 20px 70px rgba(0,0,0,.42)!important;
}
.page-banner.page-banner-clean > img.page-banner-clean-img{
  display:block!important;
  position:absolute!important;
  inset:0!important;
  z-index:0!important;
  width:100%!important;
  height:100%!important;
  min-height:0!important;
  max-height:none!important;
  object-fit:cover!important;
  object-position:center!important;
  opacity:1!important;
  filter:none!important;
}
.page-banner.page-banner-clean::after{
  content:''!important;
  position:absolute!important;
  inset:0!important;
  z-index:1!important;
  background:linear-gradient(90deg,rgba(5,6,17,.18),rgba(5,6,17,.02))!important;
  pointer-events:none!important;
}
.page-banner.page-banner-clean .page-banner-note{
  position:absolute!important;
  left:22px!important;
  top:22px!important;
  z-index:3!important;
  max-width:min(760px,calc(100% - 44px))!important;
  padding:10px 14px!important;
  border-radius:16px!important;
  background:rgba(4,6,16,.72)!important;
  border:1px solid rgba(255,255,255,.16)!important;
  color:#fff!important;
  font-weight:900!important;
  font-size:clamp(15px,1.7vw,22px)!important;
  line-height:1.25!important;
  text-shadow:0 4px 15px rgba(0,0,0,.55)!important;
  backdrop-filter:blur(8px)!important;
}
.listen-intro-text{white-space:pre-line!important;}
@media(max-width:820px){
  .page-banner.page-banner-clean{height:140px!important;min-height:140px!important;border-radius:20px!important;margin-bottom:18px!important;}
  .page-banner.page-banner-clean .page-banner-note{left:14px!important;top:14px!important;max-width:calc(100% - 28px)!important;font-size:14px!important;padding:8px 10px!important;border-radius:12px!important;}
}


/* V60 - public, règles inscriptions, bouton public visible, Snapchat */
.voter-home-btn{background:linear-gradient(135deg,#8b5cf6,#20e7ff)!important;color:#fff!important;border:1px solid rgba(124,236,255,.38)!important;box-shadow:0 0 28px rgba(32,231,255,.28),0 0 18px rgba(139,92,246,.22)!important}
.voter-home-btn.disabled{opacity:.82!important;filter:saturate(1.1)}
.voter-home-btn .status-pill{background:rgba(255,255,255,.18)!important;color:#fff!important}
.rules-box{margin:18px 0;padding:18px;border:1px solid rgba(255,209,102,.32);border-radius:20px;background:linear-gradient(135deg,rgba(255,209,102,.10),rgba(32,231,255,.08));box-shadow:0 14px 44px rgba(0,0,0,.25)}
.rules-box h2{margin:0 0 10px;color:#ffd166}.rules-box div{color:#eef3ff;line-height:1.65;font-size:1rem}.share-btn.sc{background:linear-gradient(135deg,#fffc00,#ffe600)!important;color:#111!important}.share-btn.sc span{background:#111;color:#fffc00}
.admin-card + .admin-accordion,.admin-accordion + .admin-accordion{margin-top:16px!important;display:block!important;clear:both!important}

/* V61 - règlement officiel complet */
.official-rules-box{background:linear-gradient(180deg,var(--card),#080a16cc);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;margin:18px 0;white-space:normal}
.official-rules-box h2{margin-top:0}
.official-rules-box div{color:#eef3ff;line-height:1.65;font-size:1rem}
.official-rules-compact div{max-height:360px;overflow:auto}
.rules-official-link{margin:14px 0 0}
.footer a{color:var(--cyan);text-decoration:none;font-weight:800}
@media(max-width:820px){.official-rules-box{padding:18px}.mobile-nav{gap:4px}.mobile-nav a{font-size:18px}}


/* V62 - Salle d’écoute aléatoire + présentation mode TikTok */
.random-feed-note{margin:10px 0 0;color:#ffd166;font-weight:800}
.tiktok-listen-feed{display:grid;gap:26px;width:min(560px,100%);margin:24px auto 0}
.tiktok-track-card{padding:0;overflow:hidden;border-radius:28px;background:linear-gradient(180deg,rgba(18,20,42,.96),rgba(5,6,17,.98));border:1px solid rgba(255,255,255,.14);box-shadow:0 24px 80px rgba(0,0,0,.55)}
.tiktok-media-zone{position:relative;background:#000;min-height:420px;display:grid;place-items:center}
.tiktok-media-zone video{width:100%;height:min(72vh,690px);max-height:690px;aspect-ratio:9/16;object-fit:cover;border-radius:0;background:#000}
.tiktok-media-zone .audio-cover-card{width:100%;height:min(72vh,690px);max-height:690px;min-height:420px;padding:0;border-radius:0;background:#03040b;display:grid;grid-template-rows:1fr auto}
.tiktok-media-zone .audio-cover-card img{width:100%;height:100%;aspect-ratio:auto;object-fit:cover;border-radius:0;filter:saturate(1.08) contrast(1.05)}
.tiktok-media-zone .audio-cover-card audio{width:calc(100% - 24px);margin:0 12px 12px;position:relative;z-index:2}
.tiktok-media-zone::after{content:'';position:absolute;inset:auto 0 0 0;height:42%;background:linear-gradient(180deg,transparent,rgba(0,0,0,.74));pointer-events:none}
.tiktok-side-actions{position:absolute;right:12px;bottom:18px;z-index:4;display:grid;gap:10px}
.tiktok-side-actions span{width:54px;min-height:54px;border-radius:18px;background:rgba(6,8,20,.72);border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(10px);display:grid;place-items:center;font-size:20px;box-shadow:0 12px 34px rgba(0,0,0,.35)}
.tiktok-side-actions b{display:block;font-size:12px;color:#fff;line-height:1;margin-top:-7px}
.tiktok-track-info{padding:18px 18px 20px;position:relative;z-index:3}
.tiktok-track-info .creator-mini-line{align-items:center}.tiktok-track-info .creator-mini-line b{font-size:1.18rem}.tiktok-track-info p{color:#dfe6ff;line-height:1.45;margin:.35rem 0 .55rem}.tiktok-track-info .btns{gap:10px}.tiktok-track-info .btns .btn{flex:1 1 auto;text-align:center}.tiktok-btn{background:linear-gradient(135deg,#111,#ff0050,#00f2ea)!important;color:white!important}
@media(max-width:700px){.tiktok-listen-feed{width:100%;gap:18px}.tiktok-media-zone{min-height:360px}.tiktok-media-zone video,.tiktok-media-zone .audio-cover-card{height:68vh;min-height:360px}.tiktok-side-actions{right:9px;bottom:14px}.tiktok-side-actions span{width:48px;min-height:48px;border-radius:16px}.tiktok-track-info{padding:15px}.tiktok-track-info .btns .btn{flex:1 1 100%}}
