:root{
  --accent:#ff2d78;
  --accent2:#00e5ff;
  --bg:#07080f;
  --bg2:#0d0f1c;
  --panel:#11142399;
  --txt:#eef0ff;
  --muted:#8a8fb5;
  --radius:18px;
  transition:--accent .8s;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
/* Scrollbars discrètes */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#ffffff18;border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:#ffffff35}
*{scrollbar-width:thin;scrollbar-color:#ffffff18 transparent}
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 60%),
    radial-gradient(900px 500px at -10% 30%, color-mix(in srgb, var(--accent2) 12%, transparent), transparent 60%),
    var(--bg);
  color:var(--txt);
  font-family:'Inter',sans-serif;
  min-height:100vh;
  transition:background 1.2s ease;
  overflow-x:hidden;
}
h1,h2,h3,.display{font-family:'Unbounded',sans-serif}

/* ===== POCHETTE EN FOND DE PAGE ===== */
.bgart{
  position:fixed;inset:-90px;z-index:-2;
  background-size:cover;background-position:center 30%;
  filter:blur(18px) saturate(1.4) brightness(.48);
  opacity:0;transition:opacity 1.6s ease;
  pointer-events:none;
}
.bgveil{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg, #07080f55 0%, #07080fa8 55%, #07080fe6 100%);
}

/* ===== TOP BAR ===== */
.topbar{
  position:sticky;top:0;z-index:90;
  display:flex;align-items:center;gap:20px;
  padding:14px 28px;
  background:color-mix(in srgb, var(--bg) 75%, transparent);
  backdrop-filter:blur(18px);
  border-bottom:1px solid #ffffff12;
}
.logo{display:flex;align-items:center;gap:10px;font-family:'Unbounded';font-weight:900;font-size:1.25rem;letter-spacing:-.5px;white-space:nowrap;color:var(--accent);text-decoration:none;transition:color .8s}
.logo em{font-style:normal;color:var(--accent2);transition:color .8s}
.logo img{width:38px;height:38px;border-radius:50%;object-fit:cover;box-shadow:0 0 0 2px color-mix(in srgb, var(--accent) 60%, transparent);transition:box-shadow .8s}
.nav{display:flex;gap:6px;margin-left:10px}
.nav a{
  color:var(--muted);text-decoration:none;font-size:.85rem;font-weight:600;
  padding:8px 14px;border-radius:99px;transition:.25s;
}
.nav a:hover,.nav a.on{color:var(--txt);background:#ffffff10}
.spacer{flex:1}
.livepill{
  display:flex;align-items:center;gap:8px;
  background:#ffffff0d;border:1px solid #ffffff1a;
  padding:7px 14px;border-radius:99px;font-size:.78rem;font-weight:700;
}
.dot{width:9px;height:9px;border-radius:50%;background:#ff3b3b;animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 #ff3b3b88}50%{box-shadow:0 0 0 7px #ff3b3b00}}
.listeners{font-size:.78rem;color:var(--muted);white-space:nowrap}
.listeners b{color:var(--txt)}

/* ===== RÉSEAUX SOCIAUX ===== */
.socials{display:flex;gap:10px;align-items:center}
.socials a{
  width:36px;height:36px;border-radius:50%;
  background:#ffffff0c;border:1px solid #ffffff1a;
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);transition:.25s;
}
.socials a:hover{
  color:#fff;border-color:var(--accent);
  background:color-mix(in srgb, var(--accent) 25%, transparent);
  transform:translateY(-2px);
}
.socials svg{width:17px;height:17px;fill:currentColor}
.socials.big{justify-content:center;margin:22px 0 6px}
.socials.big a{width:48px;height:48px}
.socials.big svg{width:22px;height:22px}

/* ===== HERO GRID ===== */
.hero{
  display:grid;grid-template-columns:1fr 1fr;gap:22px;
  max-width:1280px;margin:26px auto 0;padding:0 24px;
  align-items:stretch;
}

/* ===== PLAYER ===== */
.player{
  position:relative;
  background:linear-gradient(160deg, color-mix(in srgb, var(--accent) 9%, var(--bg2)), var(--bg2) 55%);
  border:1px solid #ffffff14;border-radius:26px;
  padding:34px 32px 30px;display:flex;flex-direction:column;gap:20px;
  align-items:center;justify-content:center;text-align:center;
  overflow:hidden;min-height:380px;
  transition:background 1.2s ease;
}
.player::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(460px 320px at 50% 38%, color-mix(in srgb, var(--accent) 20%, transparent), transparent 72%);
  pointer-events:none;transition:1.2s;
}
.vinyl{
  position:relative;width:215px;height:215px;flex-shrink:0;border-radius:50%;z-index:2;
  background:
    repeating-radial-gradient(circle at 50% 50%, #1a1a22 0px, #111118 2px, #1a1a22 4px),
    #14141c;
  box-shadow:0 30px 80px -20px color-mix(in srgb, var(--accent) 55%, transparent), 0 0 0 1px #ffffff14;
  display:flex;align-items:center;justify-content:center;
  transition:box-shadow 1.2s;
}
.vinyl.spin{animation:spin 3.2s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.label{
  width:46%;height:46%;border-radius:50%;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 50%, transparent);
  transition:box-shadow 1.2s;
}
.label img{width:100%;height:100%;object-fit:cover}
.pinfo{position:relative;z-index:2;width:100%;min-width:0;display:flex;flex-direction:column;align-items:center}
.onair{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.72rem;font-weight:800;letter-spacing:2.5px;
  color:var(--accent);text-transform:uppercase;transition:color .8s;
  position:relative;z-index:2;
}
.track{font-size:clamp(1.3rem,2vw,1.9rem);font-weight:900;line-height:1.15;margin-bottom:4px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.artist{font-size:1rem;color:var(--muted);font-weight:600;margin-bottom:14px}
.show-now{font-size:.8rem;color:var(--muted);margin-bottom:20px}
.show-now b{color:var(--txt)}
.controls{display:flex;align-items:center;justify-content:center;gap:22px;flex-wrap:wrap}
.play{
  width:84px;height:84px;border-radius:50%;border:none;cursor:pointer;
  background:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 55%, var(--accent2)));
  color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 45px -8px color-mix(in srgb, var(--accent) 80%, transparent);
  transition:transform .2s, box-shadow .8s, background .8s;
}
.play:hover{transform:scale(1.07)}
.play svg{width:34px;height:34px;fill:#fff}
.vu{display:flex;align-items:flex-end;gap:4px;height:54px}
.vu span{
  width:7px;border-radius:4px;height:8%;
  background:linear-gradient(to top, var(--accent), var(--accent2));
  transition:height .09s linear, background .8s;
}
/* volume */
.vol{display:flex;align-items:center;gap:10px}
.vol svg{width:21px;height:21px;fill:var(--muted);cursor:pointer;transition:fill .2s;flex-shrink:0}
.vol svg:hover{fill:var(--txt)}
input[type=range].volr{
  -webkit-appearance:none;appearance:none;
  width:120px;height:5px;border-radius:3px;
  background:linear-gradient(to right, var(--accent) 80%, #ffffff22 80%);
  outline:none;cursor:pointer;
}
input[type=range].volr::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:15px;height:15px;border-radius:50%;background:#fff;border:none;
  box-shadow:0 2px 10px -2px color-mix(in srgb, var(--accent) 90%, transparent);
  transition:transform .15s;
}
input[type=range].volr::-webkit-slider-thumb:hover{transform:scale(1.25)}
input[type=range].volr::-moz-range-thumb{
  width:15px;height:15px;border-radius:50%;background:#fff;border:none;
}
.mini .volr{width:80px}
.quality{display:flex;gap:8px;margin-top:18px;flex-wrap:wrap;justify-content:center}
.quality button{
  background:#ffffff0c;border:1px solid #ffffff1a;color:var(--muted);
  font-size:.7rem;font-weight:700;padding:6px 12px;border-radius:8px;cursor:pointer;transition:.2s;
}
.quality button.on,.quality button:hover{color:var(--txt);border-color:var(--accent);background:color-mix(in srgb, var(--accent) 18%, transparent)}

/* dedication overlay */
.dedic{
  position:absolute;left:50%;transform:translateX(-50%);top:-110px;z-index:5;
  background:color-mix(in srgb, var(--accent) 25%, #000c);
  backdrop-filter:blur(14px);
  border:1px solid color-mix(in srgb, var(--accent) 55%, transparent);
  padding:13px 20px;border-radius:14px;font-size:.86rem;
  width:max-content;max-width:86%;
  transition:top .6s cubic-bezier(.2,1.4,.4,1), opacity .6s;opacity:0;
}
.dedic.show{top:58px;opacity:1}
.dedic b{color:var(--accent2)}

/* ===== CHAT ===== */
.chat{
  background:var(--panel);backdrop-filter:blur(14px);
  border:1px solid #ffffff14;border-radius:26px;
  display:flex;flex-direction:column;overflow:hidden;min-height:640px;
}
.chat-frame{flex:1;border:none;width:100%;min-height:480px;background:#0d0f1c}
.chat-h{
  padding:16px 20px;border-bottom:1px solid #ffffff10;
  display:flex;align-items:center;justify-content:center;gap:10px;font-weight:800;font-size:.9rem;
}
.chat-h .dot{width:7px;height:7px}
.chat-count{margin-left:auto;font-size:.72rem;color:var(--muted);font-weight:600}
.cta-dedi{
  margin:12px 16px 14px;text-align:center;font-size:.76rem;color:var(--muted);
}
.cta-dedi a{color:var(--accent2);font-weight:700;text-decoration:none}

/* ===== SECTIONS ===== */
section{max-width:1280px;margin:60px auto 0;padding:0 24px}
.sec-h{display:flex;align-items:baseline;gap:16px;margin-bottom:24px}
.sec-h h2{font-size:1.5rem;font-weight:900}
.sec-h span{font-size:.8rem;color:var(--muted);font-weight:600}

/* ===== PAGES DE CONTENU (article / liste) ===== */
.narrow{max-width:840px;margin:46px auto 0;padding:0 24px}
.narrow > h1{
  font-family:'Unbounded';font-weight:900;font-size:2.2rem;line-height:1.12;margin:4px 0 22px;
}
.article{
  background:var(--panel);backdrop-filter:blur(14px);
  border:1px solid #ffffff12;border-radius:var(--radius);
  padding:34px 40px 40px;box-shadow:0 30px 70px -30px #000a;
  text-align:center;
}
.article .muted a{color:var(--accent2);text-decoration:none}
.article > h1{
  font-family:'Unbounded';font-weight:900;font-size:2.1rem;line-height:1.14;margin:10px 0 6px;
}
.hero-img{
  display:block;width:100%;max-height:430px;object-fit:cover;
  border-radius:16px;margin:22px 0 28px;border:1px solid #ffffff14;
  box-shadow:0 24px 60px -26px #000c;
}
.prose{font-size:1.06rem;line-height:1.78;color:#e7e8f2}
.prose > *:first-child{margin-top:0}
.prose p{margin:0 0 18px}
.prose h2{font-family:'Unbounded';font-size:1.4rem;font-weight:800;margin:34px 0 12px}
.prose h3{font-size:1.16rem;font-weight:800;margin:26px 0 10px}
.prose a{color:var(--accent2);text-decoration:underline;text-underline-offset:3px}
.prose ul,.prose ol{margin:0 0 18px;padding:0;list-style-position:inside}
.prose li{margin:6px 0}
.prose img{max-width:100%;height:auto;border-radius:14px;margin:18px 0}
.prose blockquote{
  margin:22px 0;padding:8px 20px;border-left:3px solid var(--accent);
  color:var(--muted);font-style:italic;
}

/* grille de cartes (liste artistes) */
.grid-cards{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));
  gap:16px;margin-top:24px;
}
@media (max-width:560px){
  .article{padding:24px 20px 28px}
  .narrow > h1,.article > h1{font-size:1.7rem}
  .grid-cards{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}
}

/* À PROPOS */
.about{
  position:relative;overflow:hidden;text-align:center;
  background:var(--panel);backdrop-filter:blur(10px);
  border:1px solid #ffffff12;border-radius:var(--radius);padding:34px 38px;
}
.about::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(var(--accent),var(--accent2));
}
.about .lead{font-size:1.6rem;font-weight:900;color:var(--txt);margin:0 0 18px;letter-spacing:-.5px}
.about .lead em{
  font-style:normal;
  background:linear-gradient(90deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.about p{margin:0 0 14px;line-height:1.75;color:#cfd3ef;font-size:1.04rem}
.about p:last-child{margin-bottom:0}
.about .hl{color:var(--txt);font-weight:700}

@media(max-width:820px){
  .about{padding:26px 24px}
  .about .lead{font-size:1.35rem}
}

/* C'ÉTAIT QUOI ? */
.hist{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px}
.hitem{
  display:flex;gap:12px;align-items:center;
  background:var(--panel);backdrop-filter:blur(10px);
  border:1px solid #ffffff12;border-radius:16px;padding:10px 14px;
  transition:.25s;
}
.hitem:hover{border-color:#ffffff2e;transform:translateY(-2px)}
.hitem img{width:48px;height:48px;border-radius:10px;object-fit:cover;background:#181a28;flex-shrink:0}
.hitem .hinfo{min-width:0;flex:1}
.hitem .ht{font-size:.84rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hitem .ha{font-size:.74rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hitem .hh{font-size:.7rem;color:var(--accent2);font-weight:700;white-space:nowrap;transition:color .8s}

/* EPG */
.epg{position:relative;display:flex;gap:14px;overflow-x:auto;padding:10px 4px 18px;scrollbar-width:thin}
.slot{
  flex:0 0 250px;background:var(--panel);border:1px solid #ffffff12;border-radius:var(--radius);
  padding:20px;position:relative;transition:.25s;overflow:hidden;
}
/* photo d'animateur en fond : floutée + assombrie pour garder le texte lisible */
.slot.has-photo::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:var(--photo) center/cover no-repeat;
  filter:blur(2.5px) brightness(.62) saturate(1.15);
  transform:scale(1.08);transition:.3s;
}
.slot.has-photo::after{
  content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg,#0003 0%,#0007 65%,#000b 100%);
}
.slot.has-photo:hover::before{filter:blur(1px) brightness(.72) saturate(1.2);transform:scale(1.04)}
.slot.has-photo > *{position:relative;z-index:1}
.slot.has-photo .day,.slot.has-photo .name,.slot.has-photo .time,.slot.has-photo .t{text-shadow:0 1px 4px #000a}
.slot:hover{transform:translateY(-4px);border-color:#ffffff30}
.slot.now{
  border-color:var(--accent);
  background:linear-gradient(160deg, color-mix(in srgb, var(--accent) 14%, var(--bg2)), var(--bg2));
  box-shadow:0 18px 50px -18px color-mix(in srgb, var(--accent) 60%, transparent);
}
.slot .day{font-size:.68rem;font-weight:800;letter-spacing:2px;color:var(--muted);text-transform:uppercase}
.slot .name{font-family:'Unbounded';font-weight:700;font-size:.95rem;margin:10px 0 6px;line-height:1.3}
.slot .time{font-size:.8rem;color:var(--accent2);font-weight:700}
.slot .tag{
  position:absolute;top:14px;right:14px;font-size:.62rem;font-weight:900;
  background:var(--accent);color:#fff;padding:4px 9px;border-radius:6px;letter-spacing:1px;
}

/* DÉDICACES */
.dwall{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.ditem{
  background:var(--panel);backdrop-filter:blur(10px);
  border:1px solid #ffffff12;border-left:3px solid var(--accent);
  border-radius:14px;padding:14px 16px;transition:.25s;
}
.ditem:hover{transform:translateY(-2px);border-color:#ffffff2e;border-left-color:var(--accent)}
.ditem .dwho{font-weight:800;font-size:.85rem;margin-bottom:5px}
.ditem .dmsg{font-size:.84rem;color:#c6cbe6;line-height:1.5}
.ditem .ddate{margin-top:8px;font-size:.68rem;color:var(--muted);font-weight:600}
.ditem.cta{
  border-left-color:var(--accent2);display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;gap:8px;
  border-style:dashed;background:transparent;
}
.ditem.cta a{color:var(--accent2);font-weight:800;text-decoration:none;font-size:.9rem}
/* PANNEAU ADMIN DÉDICACES (Ctrl+Shift+D) */
.admin-dedis{
  position:fixed;top:0;right:-420px;bottom:0;z-index:300;width:400px;
  background:#0d0f1c;border-left:1px solid #ffffff18;
  display:flex;flex-direction:column;transition:.35s cubic-bezier(.2,1.2,.4,1);
  overflow:hidden;
}
.admin-dedis.open{right:0}
.admin-hdr{
  padding:18px 20px 14px;border-bottom:1px solid #ffffff12;
  display:flex;align-items:center;gap:10px;flex-shrink:0;
}
.admin-hdr h4{font-family:'Unbounded';font-size:.95rem;flex:1}
.admin-hdr .badge{
  background:var(--accent);color:#fff;font-size:.68rem;font-weight:800;
  padding:3px 8px;border-radius:99px;
}
.admin-hdr button{background:none;border:none;color:var(--muted);cursor:pointer;font-size:1.3rem;line-height:1}
.admin-list{flex:1;overflow-y:auto;padding:12px}
.admin-item{
  background:#ffffff08;border:1px solid #ffffff12;border-radius:12px;
  padding:13px 14px;margin-bottom:10px;
}
.admin-item .awho{font-weight:800;font-size:.83rem;margin-bottom:4px}
.admin-item .amsg{font-size:.82rem;color:#c6cbe6;line-height:1.45;margin-bottom:10px}
.admin-item .adate{font-size:.68rem;color:var(--muted);margin-bottom:10px}
.admin-btns{display:flex;gap:8px}
.admin-btns button{flex:1;padding:7px 0;border-radius:8px;border:none;cursor:pointer;font-weight:700;font-size:.8rem}
.btn-approve{background:color-mix(in srgb,#00e5ff 18%,transparent);color:#00e5ff;border:1px solid #00e5ff44!important}
.btn-approve:hover{background:color-mix(in srgb,#00e5ff 28%,transparent)}
.btn-reject{background:color-mix(in srgb,#ff2d78 12%,transparent);color:#ff2d78;border:1px solid #ff2d7844!important}
.btn-reject:hover{background:color-mix(in srgb,#ff2d78 22%,transparent)}
.admin-empty{color:var(--muted);text-align:center;padding:40px 20px;font-size:.85rem}

/* FORMULAIRE DÉDICACES */
.dedi-backdrop{
  position:fixed;inset:0;z-index:200;background:#00000088;
  backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:.3s;
}
.dedi-backdrop.open{opacity:1;pointer-events:all}
.dedi-modal{
  position:fixed;left:50%;top:50%;transform:translate(-50%,-54%);z-index:201;
  width:min(520px,94vw);background:var(--bg2);
  border:1px solid #ffffff18;border-radius:24px;padding:30px 28px 24px;
  opacity:0;pointer-events:none;transition:.35s cubic-bezier(.2,1.3,.4,1);
}
.dedi-modal.open{opacity:1;pointer-events:all;transform:translate(-50%,-50%)}
.dedi-modal h3{font-family:'Unbounded';font-size:1.1rem;margin-bottom:20px}
.dedi-modal h3 em{color:var(--accent);font-style:normal}
.dform{display:flex;flex-direction:column;gap:12px}
.dform label{font-size:.72rem;font-weight:700;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;display:block;margin-bottom:4px}
.dform input,.dform textarea{
  width:100%;background:#ffffff08;border:1px solid #ffffff18;border-radius:10px;
  padding:11px 14px;color:var(--txt);font-family:'Inter';font-size:.9rem;outline:none;
  transition:.2s;
}
.dform input:focus,.dform textarea:focus{border-color:var(--accent);background:#ffffff0e}
.dform textarea{resize:vertical;min-height:80px}
.dform-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.dform-btns{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}
.dform-btns button{
  padding:10px 22px;border-radius:99px;border:none;cursor:pointer;font-weight:700;font-size:.86rem;
}
.btn-cancel{background:#ffffff12;color:var(--txt)}
.btn-cancel:hover{background:#ffffff20}
.btn-send{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff}
.btn-send:hover{opacity:.9}
.dedi-ok{
  text-align:center;padding:14px 0 4px;display:none;
}
.dedi-ok .big{font-size:2.2rem}
.dedi-ok p{color:var(--muted);font-size:.88rem;margin-top:6px}

/* ARTISTS */
.artists{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:16px}
.acard{
  aspect-ratio:3/4;border-radius:var(--radius);position:relative;overflow:hidden;
  display:flex;align-items:flex-end;padding:16px;cursor:pointer;
  border:1px solid #ffffff12;transition:.3s;
  background-size:cover;background-position:center 18%;
  text-decoration:none;color:inherit;
}
.acard:hover{transform:translateY(-6px) scale(1.02);border-color:#ffffff35}
.acard::before{content:"";position:absolute;inset:0;background:var(--g);opacity:.42;transition:.3s;mix-blend-mode:soft-light}
.acard:hover::before{opacity:.15}
.acard::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,#000c 10%,transparent 60%)}
.acard h3{position:relative;z-index:2;font-size:.92rem;font-weight:700;line-height:1.25}
.acard .genre{position:relative;z-index:2;font-size:.68rem;color:#fffa;font-weight:600;margin-top:3px}
.ainit{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);
  font-family:'Unbounded';font-weight:900;font-size:3.2rem;color:#ffffff22;z-index:1;
}

/* FOOTER */
footer{
  margin-top:80px;padding:40px 24px 120px;text-align:center;color:var(--muted);font-size:.8rem;
  border-top:1px solid #ffffff10;
}
footer .display{font-size:1rem;color:var(--txt);margin-bottom:8px}
.footer-sep{width:100%;max-width:900px;margin:28px auto;border:none;border-top:1px solid #ffffff10}
.footer-label{font-size:.65rem;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
/* Ils nous diffusent */
.diffuseurs{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;
  gap:10px 14px;max-width:1000px;margin:0 auto;
}
.diffuseurs a{
  display:flex;align-items:center;justify-content:center;
  background:#ffffff08;border:1px solid #ffffff0e;border-radius:10px;
  padding:7px 12px;transition:.2s;height:42px;
}
.diffuseurs a:hover{background:#ffffff16;border-color:#ffffff22}
.diffuseurs img{height:24px;width:auto;max-width:90px;object-fit:contain;filter:brightness(.7) grayscale(.3);transition:.2s}
.diffuseurs a:hover img{filter:brightness(1) grayscale(0)}
/* Droits */
.droits{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:12px 20px;max-width:600px;margin:0 auto}
.droits a{
  display:flex;align-items:center;justify-content:center;
  background:#ffffff06;border:1px solid #ffffff0e;border-radius:10px;
  padding:10px 18px;transition:.2s;height:60px;
}
.droits a:hover{background:#ffffff12}
.droits img{height:40px;width:auto;max-width:140px;object-fit:contain;filter:brightness(.65) grayscale(.4);transition:.2s}
.droits a:hover img{filter:brightness(.9) grayscale(0)}

/* ===== MINI PLAYER ===== */
.mini{
  position:fixed;left:50%;bottom:18px;transform:translate(-50%,90px);z-index:60;
  display:flex;align-items:center;gap:14px;
  background:color-mix(in srgb, var(--bg) 70%, transparent);
  backdrop-filter:blur(22px);
  border:1px solid #ffffff20;border-radius:99px;
  padding:10px 22px 10px 10px;
  box-shadow:0 18px 60px -10px #000c;
  transition:transform .45s cubic-bezier(.2,1.2,.4,1);
  max-width:92vw;
}
.mini.show{transform:translate(-50%,0)}
.mini .mplay{
  width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;flex-shrink:0;
  background:var(--accent);display:flex;align-items:center;justify-content:center;transition:background .8s;
}
.mini .mplay svg{width:17px;height:17px;fill:#fff}
.mini .mtrack{font-size:.8rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:280px}
.mini .msub{font-size:.68rem;color:var(--muted)}
.mini .vu{height:24px}
.mini .vu span{width:4px}

/* ===== MENU MOBILE (burger + drawers) ===== */
body.noscroll{overflow:hidden}

.burger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:42px;height:42px;flex-shrink:0;cursor:pointer;
  background:#ffffff0c;border:1px solid #ffffff1a;border-radius:12px;
}
.burger span{display:block;width:18px;height:2px;margin:0 auto;border-radius:2px;background:var(--txt);transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* voile partagé par les drawers */
.scrim{
  position:fixed;inset:0;z-index:64;
  background:#000a;backdrop-filter:blur(3px);
  opacity:0;pointer-events:none;transition:.3s;
}
.scrim.show{opacity:1;pointer-events:auto}

/* drawer de navigation (off-canvas, depuis la droite) */
.navdrawer{
  position:fixed;top:0;right:0;z-index:80;
  width:min(320px,84vw);height:100%;
  display:flex;flex-direction:column;gap:4px;
  padding:80px 18px 24px;
  background:color-mix(in srgb,var(--bg2) 94%,transparent);
  backdrop-filter:blur(22px);
  border-left:1px solid #ffffff14;
  box-shadow:-30px 0 70px -20px #000c;
  transform:translateX(105%);
  transition:transform .4s cubic-bezier(.2,.9,.3,1);
  overflow-y:auto;
}
.navdrawer.open{transform:translateX(0)}
.navdrawer a{
  color:var(--txt);text-decoration:none;font-weight:700;font-size:1rem;
  padding:14px 16px;border-radius:12px;transition:.2s;
}
.navdrawer a:hover,.navdrawer a.on{background:#ffffff10;color:var(--accent)}
.nd-sep{height:1px;background:#ffffff12;margin:12px 6px}
.nd-soc{display:flex;gap:12px;justify-content:center;margin-top:8px}

/* bouton flottant Tchat (mobile) */
.chatfab{
  display:none;align-items:center;gap:9px;
  position:fixed;right:16px;bottom:18px;z-index:66;
  padding:13px 18px;border:none;border-radius:99px;cursor:pointer;
  color:#fff;font-weight:800;font-size:.92rem;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  box-shadow:0 14px 34px -8px #000b;
  transition:transform .42s cubic-bezier(.2,1.1,.4,1),opacity .3s,bottom .42s cubic-bezier(.2,.9,.3,1);
}
.chatfab svg{width:20px;height:20px;fill:#fff}
.chatfab.lift{bottom:92px}                         /* remonte au-dessus du mini-player */
.chatfab.hide{transform:translateY(140px);opacity:0;pointer-events:none}

/* poignée de fermeture du tchat (mobile) */
.chat-close{display:none}

/* ===== RESPONSIVE ===== */
@media (max-width:980px){
  .hero{grid-template-columns:1fr}
  .nav{display:none}
  #topsoc{display:none}
  .burger{display:flex}
  .chatfab{display:flex}
  .player{flex-direction:column;text-align:center;padding:30px 22px;gap:24px}
  .vinyl{width:200px;height:200px}
  .controls{justify-content:center}
  .quality{justify-content:center}
  .dedic{width:88%;max-width:88%}
  .listeners{display:none}
  .topbar{padding:12px 16px;gap:10px}

  /* le tchat devient une feuille qui monte du bas */
  .chat{
    position:fixed;left:0;right:0;bottom:0;z-index:75;
    height:85vh;min-height:0;margin:0;
    border:none;border-top:1px solid #ffffff18;
    border-radius:22px 22px 0 0;
    transform:translateY(103%);
    transition:transform .42s cubic-bezier(.2,.9,.3,1);
    box-shadow:0 -24px 60px -12px #000c;
  }
  .chat.open{transform:translateY(0)}
  .chat-frame{min-height:0}
  .chat-count{display:none}
  .chat-h{position:relative;padding-right:52px}
  .chat-close{
    display:flex;align-items:center;justify-content:center;
    position:absolute;right:12px;top:50%;transform:translateY(-50%);
    width:32px;height:32px;border-radius:50%;cursor:pointer;
    background:#ffffff12;border:1px solid #ffffff22;color:var(--txt);
  }
  .chat-close svg{width:15px;height:15px;fill:currentColor}
}
@media (max-width:560px){
  .livepill{display:none}        /* on libère la barre pour le logo + burger */
}

/* ===== Page dédicaces autonome (/dedicaces) ===== */
.dedi-card{max-width:560px;margin:0 auto 30px;background:var(--panel);backdrop-filter:blur(14px);border:1px solid #ffffff14;border-radius:20px;padding:26px 24px}
.dedi-ok-banner{max-width:560px;margin:0 auto 18px;background:#39d98a1f;border:1px solid #39d98a66;border-radius:14px;padding:14px 18px;text-align:center;font-weight:600}
