/* index-main.css — all styles for index.html (dopamusic.fr public page) */

/* ── MAIN STYLES ─── */
*{margin:0;padding:0;box-sizing:border-box}
html{overflow-x:hidden;max-width:100vw}
:root{--bg:#0a0a0a;--card:#111;--card2:#181818;--border:#1f1f1f;--border2:#2a2a2a;--muted:#666;--red:#ef4444;--yellow:#f59e0b}
body{font-family:'Montserrat',sans-serif;background:var(--bg);color:#fff;padding:18px 0 20px;overflow-x:hidden}
.container{width:100%;max-width:420px}

.req-results,
.history-container {
  max-height: 300px;
  overflow-y: auto;
}

.text-mode-container {
  overflow-y: auto;
  max-height: 100%;
}


.profile{text-align:center;margin-bottom:18px;position:relative}
.profile::before{content:"";position:absolute;top:50%;left:50%;width:140px;height:140px;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,0.08),transparent 70%);z-index:1}
.profile img{width:150px;height:150px;border-radius:50%;object-fit:cover;border:1px solid #222;position:relative;z-index:2;box-shadow:0 10px 30px rgba(0,0,0,0.6)}
.name{font-weight:900;font-size:38px;margin-top:12px}
.subtitle{font-size:11px;color:var(--muted);margin-top:3px}

.socials{display:flex;gap:14px;justify-content:space-between;padding:12px 4px 18px}
.social{text-decoration:none;color:#bbb;font-size:10px;text-align:center;flex:1}
.circle{width:68px;height:68px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#111;border:1px solid #333;margin:0 auto 6px;transition:0.25s}
.circle i{font-size:26px;color:white}
.social:hover .circle,.social:active .circle{transform:scale(1.08);border-color:#555;background:#161616}

/* VIDEO SELFIE MODULE */
.vid-modal-sheet{width:100%;max-width:480px;background:#000;border-radius:0;padding:0;transform:translateY(100%);transition:transform 0.35s cubic-bezier(0.32,0.72,0,1);height:100%;overflow:hidden;position:relative;display:flex;flex-direction:column}
.modal-overlay.active .vid-modal-sheet{transform:translateY(0)}
#videoModal{flex-direction:column}
#videoModal.active{align-items:stretch;width:100%;height:100%}
#videoModal.active .vid-modal-sheet{border-radius:0}
#videoModal #videoSheet{width:100%;height:100%;min-height:0;flex:1}
.vid-header{padding:20px 20px 12px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.vid-title{font-size:18px;font-weight:900;color:#fff;letter-spacing:.3px}
.vid-close{background:rgba(255,255,255,.08);border:none;border-radius:50%;width:32px;height:32px;color:#aaa;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}
.vid-close:hover{background:rgba(255,255,255,.15);color:#fff}
.vid-camera-wrap{position:relative;width:100%;background:#000;overflow:hidden;flex:1;min-height:0}
.vid-camera-wrap video{width:100%;height:100%;display:block;object-fit:cover}
.vid-camera-wrap canvas{display:none}
.vid-overlay{position:absolute;inset:0;pointer-events:none}
.vid-rec-badge{position:absolute;top:14px;left:14px;display:flex;align-items:center;gap:6px;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);border:1px solid rgba(239,68,68,.4);border-radius:20px;padding:5px 12px;opacity:0;transition:opacity .3s}
.vid-rec-badge.show{opacity:1}
.vid-rec-dot{width:8px;height:8px;border-radius:50%;background:#ef4444;animation:bl 1s infinite}
.vid-rec-txt{font-size:11px;font-weight:900;color:#fff;letter-spacing:1px}
.vid-timer{position:absolute;top:14px;right:14px;font-size:22px;font-weight:900;color:#fff;font-family:monospace;text-shadow:0 2px 8px rgba(0,0,0,.8);opacity:0;transition:opacity .3s}
.vid-timer.show{opacity:1}
.vid-progress{position:absolute;bottom:0;left:0;height:3px;background:linear-gradient(90deg,#7c3aed,#ec4899);width:0%;transition:width .5s linear;border-radius:0}
.vid-corner{position:absolute;width:20px;height:20px;border-color:#fff;border-style:solid;opacity:.6}
.vid-corner.tl{top:16px;left:16px;border-width:2px 0 0 2px;border-radius:3px 0 0 0}
.vid-corner.tr{top:16px;right:16px;border-width:2px 2px 0 0;border-radius:0 3px 0 0}
.vid-corner.bl{bottom:6px;left:16px;border-width:0 0 2px 2px;border-radius:0 0 0 3px}
.vid-corner.br{bottom:6px;right:16px;border-width:0 2px 2px 0;border-radius:0 0 3px 0}
.vid-controls{padding:16px 20px 8px;flex-shrink:0}
.vid-cta{font-size:12px;color:#555;text-align:center;margin-bottom:14px;line-height:1.5}
.vid-btn-row{display:flex;align-items:center;justify-content:center;gap:16px}
.vid-btn-rec{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#ef4444,#dc2626);border:3px solid rgba(255,255,255,.2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 0 0 0 rgba(239,68,68,.4);position:relative}
.vid-btn-rec:hover{transform:scale(1.05);box-shadow:0 0 20px rgba(239,68,68,.5)}
.vid-btn-rec.recording{background:linear-gradient(135deg,#1a1a1a,#111);border-color:rgba(239,68,68,.6);animation:recPulse 1.5s ease-in-out infinite}
@keyframes recPulse{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.4)}50%{box-shadow:0 0 0 12px rgba(239,68,68,.0)}}
.vid-btn-rec-inner{width:28px;height:28px;border-radius:50%;background:#fff;transition:all .2s}
.vid-btn-rec.recording .vid-btn-rec-inner{border-radius:6px;width:22px;height:22px;background:#ef4444}
.vid-btn-send{flex:1;max-width:160px;padding:14px;background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none;border-radius:14px;color:#fff;font-size:14px;font-weight:900;cursor:pointer;font-family:'Montserrat',sans-serif;display:none;transition:all .2s}
.vid-btn-send:hover{background:linear-gradient(135deg,#6d28d9,#5b21b6);transform:translateY(-1px)}
.vid-btn-retry{padding:10px 16px;background:rgba(255,255,255,.06);border:1px solid #2a2a2a;border-radius:10px;color:#666;font-size:12px;font-weight:700;cursor:pointer;font-family:'Montserrat',sans-serif;display:none}
.vid-preview-wrap{position:relative;display:none}
.vid-preview-wrap video{width:100%;display:block;max-height:55vh;object-fit:cover;border-radius:0}
.vid-sending{text-align:center;padding:32px 20px;display:none;flex-direction:column;align-items:center;gap:12px}
.vid-sending-icon{font-size:48px;animation:sendFloat 1.5s ease-in-out infinite}
@keyframes sendFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.vid-success{text-align:center;padding:32px 20px;display:none;flex-direction:column;align-items:center;gap:10px}
.vid-no-cam{text-align:center;padding:32px 20px;color:#555;font-size:13px;line-height:1.6}

/* Notif modal iOS instructions */
.notif-btn-yes:active{opacity:.9}
.np-card{display:none}
.np-card.visible{display:block}
.np-card.npv2{display:block;background:transparent!important;border:none!important;box-shadow:none!important;overflow:hidden;margin:0;padding:0}
.np-card.npv2.np-hidden{display:none!important}
.np-top{display:flex;align-items:center;padding:10px 14px;border-bottom:1px solid var(--border);gap:8px;min-height:42px}
.np-pill{display:flex;align-items:center;gap:5px;background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.25);border-radius:20px;padding:3px 10px;flex-shrink:0}
.np-dot{width:5px;height:5px;border-radius:50%;background:var(--red);animation:blink 1.1s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.15}}
.np-pill-txt{font-size:9px;font-weight:700;letter-spacing:1.2px;color:var(--red);text-transform:uppercase}
.np-loc-center{display:flex;align-items:center;flex:1;min-width:0;margin-left:12px}
.np-loc-name-wrap{flex:1;min-width:0;position:relative}
.np-loc-name{font-size:13px;font-weight:900;color:#ccc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;cursor:default}
.np-loc-name-wrap.show-tip .np-tooltip{display:block}
.np-loc-name-wrap.truncated:hover .np-tooltip{display:block}
.np-tooltip{display:none;position:absolute;top:calc(100%+6px);left:0;background:#1c1c1c;border:1px solid #333;border-radius:8px;padding:6px 10px;font-size:11px;white-space:nowrap;z-index:100;color:#fff;pointer-events:none;box-shadow:0 4px 12px rgba(0,0,0,0.5)}
.np-loc-gap{width:12px;flex-shrink:0}
.np-loc-hours-wrap{display:flex;align-items:center;gap:4px;flex-shrink:0}
.np-loc-hours-wrap i{font-size:9px;color:#555}
.np-loc-hours{font-size:12px;color:#888;font-weight:700;white-space:nowrap}
.np-now-lbl{font-size:9px;color:#999;letter-spacing:.5px;text-transform:uppercase;font-weight:600;margin-left:auto;flex-shrink:0}

.np-track-row{display:flex;align-items:center;gap:12px;padding:12px 14px}
.np-vinyl svg{width:68px;height:68px;display:block}
.np-disc{transform-origin:34px 34px;animation:spin 4s linear infinite}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.npv2 .np-disc{transform-origin:90px 90px!important}
.np-meta{flex:1;min-width:0}
.np-title{font-size:15px;font-weight:900;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2;margin-bottom:2px}
.np-artist{font-size:12px;color:#bbb;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:8px}
.np-chips{display:flex;gap:5px;flex-wrap:wrap}
.np-chip{background:rgba(255,255,255,.08);border-radius:6px;padding:3px 8px;font-size:10px;font-weight:700;color:#fff}
.npv2 .np-chip{background:transparent;border:1px solid #2a2a2a;border-radius:20px;font-size:9px;letter-spacing:.8px;text-transform:uppercase;color:#666;padding:3px 10px}

.np-actions{display:grid;grid-template-columns:1fr 1fr 1fr;border-top:1px solid var(--border)}
.np-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:12px 6px;font-size:11px;font-weight:700;cursor:pointer;border:none;background:transparent;color:#fff;transition:background 0.15s;font-family:'Montserrat',sans-serif;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.np-btn+.np-btn{border-left:1px solid var(--border)}
.np-btn:active{background:var(--card2)}
.np-btn i{font-size:15px}
.np-btn.tips i{color:var(--yellow)}
.np-btn.disabled{opacity:0.35;cursor:not-allowed}
.np-btn.disabled:hover,.np-btn.disabled:active{background:transparent}
.np-btn.cooling{opacity:0.35;cursor:not-allowed;pointer-events:none}
.shout-timer{font-size:9px;color:#555;line-height:1}

/* LIVE AUTO */
.llc{background:var(--card);border:1px solid #1a1a1a;border-radius:18px;overflow:hidden;margin-bottom:10px;display:none;box-shadow:0 8px 32px rgba(0,0,0,0.5);min-height:0}
.llc.visible{display:block}
.llc-inner{padding:22px 16px 20px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px}
.llc-badge{display:flex;align-items:center;gap:6px;background:rgba(239,68,68,.12);border:1.5px solid rgba(239,68,68,.35);border-radius:20px;padding:4px 12px}
.llc-dot{width:6px;height:6px;border-radius:50%;background:var(--red);animation:blink 1.1s ease-in-out infinite;flex-shrink:0}
.llc-badge-txt{font-size:10px;font-weight:900;letter-spacing:1.5px;color:var(--red);text-transform:uppercase}
.llc-divider{width:40px;height:1px;background:#222}
.llc-name{font-size:16px;font-weight:900;color:#fff;line-height:1.2}
.llc-city{font-size:13px;color:#888;margin-top:-6px}
.llc-hours{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.05);border:1px solid #222;border-radius:8px;padding:5px 14px;font-size:13px;color:#777;font-weight:700}
.llc-hours i{font-size:11px;color:#444}

/* NEXT AFTER */
.na-card{display:none;margin-bottom:10px;background:#111;border:1px solid #1a1a1a;border-radius:14px;overflow:hidden;min-height:0}
.na-card.visible{display:block}
.na-top{padding:9px 14px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #1a1a1a}
.na-label{font-size:9px;font-weight:700;letter-spacing:1.5px;color:#444;text-transform:uppercase}
.na-date{font-size:12px;font-weight:900;color:#888}
.na-body{padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.na-venue{font-size:13px;font-weight:700;color:#bbb;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.na-hours{font-size:12px;color:#555;font-weight:600;flex-shrink:0}

/* PROCHAINE DATE */
.next-card{margin-bottom:10px;display:none;border-radius:18px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,0.6);min-height:0}
.next-card.visible{display:block}
.next-banner{background:linear-gradient(135deg,#1a1a1a 0%,#222 100%);border-bottom:1px solid #2a2a2a;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px;position:relative}
.next-banner::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#fff 0%,rgba(255,255,255,0.1) 100%)}
.next-banner-left{min-width:0;flex:1}
.next-banner-eyebrow{font-size:9px;font-weight:700;letter-spacing:2px;color:#555;text-transform:uppercase;margin-bottom:3px}
.next-banner-date{font-size:18px;font-weight:900;color:#fff;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.next-soon{font-size:11px;font-weight:900;color:#fff;letter-spacing:.5px;text-transform:uppercase;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.15);border-radius:8px;padding:5px 10px;white-space:nowrap;flex-shrink:0}
.next-body{background:#111;padding:14px 16px}
.next-info-row-main{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid #1a1a1a}
.next-venue-block{flex:1;min-width:0}
.next-venue-name{font-size:14px;font-weight:900;color:#fff;word-break:break-word;line-height:1.3}
.next-venue-city{font-size:11px;color:#444;margin-top:2px}
.next-hours-block{display:flex;align-items:center;gap:6px;flex-shrink:0;padding-top:2px}
.next-hours-block i{font-size:11px;color:#444}
.next-hours-txt{font-size:13px;color:#888;font-weight:700;white-space:nowrap}
.next-cd-label{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.next-cd-line{flex:1;height:1px;background:linear-gradient(to right,transparent,#2a2a2a)}
.next-cd-line.r{background:linear-gradient(to left,transparent,#2a2a2a)}
.next-cd-txt{font-size:9px;font-weight:700;color:#444;letter-spacing:1.5px;text-transform:uppercase;white-space:nowrap}
.next-countdown{display:flex;gap:5px;justify-content:center}

/* MENU */
.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.menu-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:18px 12px 14px;background:var(--card);border:1px solid #222;border-radius:16px;text-decoration:none;color:#fff;cursor:pointer;transition:all 0.2s cubic-bezier(0.34,1.56,0.64,1);box-shadow:0 4px 16px rgba(0,0,0,0.4),inset 0 1px 0 rgba(255,255,255,0.04);text-align:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation;position:relative;top:0}
.menu-btn:hover{background:#161616;border-color:#333;top:-3px;box-shadow:0 10px 28px rgba(0,0,0,0.5)}
.menu-btn:active{top:1px;background:#1c1c1c;box-shadow:0 2px 8px rgba(0,0,0,0.4)}
.menu-btn-icon{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);font-size:18px;transition:transform 0.2s}
.menu-btn:hover .menu-btn-icon{transform:scale(1.1)}
.menu-btn-label{font-size:12px;font-weight:700;color:#fff}
.menu-btn-soon{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#444;margin-top:-4px}
.booking-btn{background:#fff;color:#000;border:none;box-shadow:0 4px 16px rgba(255,255,255,0.12)}
.booking-btn:hover{background:#f0f0f0;box-shadow:0 10px 28px rgba(255,255,255,0.15)}
.booking-btn:active{background:#e0e0e0;top:1px}
.booking-btn .menu-btn-icon{background:rgba(0,0,0,0.07);border-color:rgba(0,0,0,0.1);color:#000}
.booking-btn .menu-btn-label{color:#000}
.disabled-btn{opacity:0.4;cursor:default;pointer-events:none}

/* MODALS */
.modal-overlay{position:fixed;inset:0;display:flex;justify-content:center;align-items:flex-end;background:rgba(0,0,0,0);opacity:0;visibility:hidden;transition:opacity 0.3s ease,visibility 0.3s;z-index:900}
/* Modale centrée (booking, contact, google) */
.modal-center-overlay{position:fixed;inset:0;display:flex;justify-content:center;align-items:center;background:rgba(0,0,0,0);opacity:0;visibility:hidden;transition:opacity .28s ease,visibility .28s;z-index:900;padding:20px}
.modal-center-overlay.active{opacity:1;visibility:visible;background:rgba(0,0,0,.75);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.modal-center-box{width:100%;max-width:400px;background:linear-gradient(145deg,#141414,#111);border:1px solid #252525;border-radius:24px;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.9),0 0 0 1px rgba(255,255,255,.04);transform:scale(.94) translateY(8px);transition:transform .32s cubic-bezier(.34,1.2,.64,1),opacity .28s ease;opacity:0;max-height:90vh;display:flex;flex-direction:column}
.modal-center-overlay.active .modal-center-box{transform:scale(1) translateY(0);opacity:1}
.modal-center-head{padding:22px 22px 0;display:flex;align-items:center;justify-content:space-between}
.modal-center-title{font-size:18px;font-weight:900;color:#fff;letter-spacing:-.2px}
.modal-center-close{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:#666;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;-webkit-tap-highlight-color:transparent}
.modal-center-close:active{background:rgba(255,255,255,.12);color:#fff}
.modal-center-body{padding:20px 22px 24px;overflow-y:auto}
.modal-center-body .input-group{background:#0d0d0d;border:1px solid #1f1f1f;border-radius:13px;margin-bottom:10px;display:flex;align-items:center;gap:12px;padding:14px 16px;transition:border-color .2s}
.modal-center-body .input-group:focus-within{border-color:#333}
.modal-center-body .input-group i{color:#444;font-size:14px;flex-shrink:0}
.modal-center-body .input-group input{background:none;border:none;outline:none;color:#fff;font-size:15px;font-family:'Montserrat',sans-serif;width:100%;font-weight:600}
.modal-center-body .input-group input::placeholder{color:#333}
.modal-center-body .btn-send{width:100%;padding:15px;background:#fff;color:#000;border:none;border-radius:13px;font-size:14px;font-weight:900;cursor:pointer;font-family:'Montserrat',sans-serif;margin-top:4px;box-shadow:0 4px 20px rgba(255,255,255,.1);transition:all .15s}
.modal-center-body .btn-send:active{transform:scale(.98)}
.modal-overlay.active{opacity:1;visibility:visible;background:rgba(0,0,0,0.75);backdrop-filter:blur(8px)}
.modal-sheet{width:100%;max-width:480px;background:#141414;border-radius:20px 20px 0 0;padding:0 0 env(safe-area-inset-bottom,20px);transform:translateY(100%);transition:transform 0.35s cubic-bezier(0.32,0.72,0,1);max-height:92vh;overflow-y:auto;position:relative}
.modal-overlay.active .modal-sheet{transform:translateY(0)}
.modal-handle-area{padding:12px 0 4px;cursor:grab;text-align:center;user-select:none;touch-action:none}
.modal-handle{width:36px;height:4px;background:#333;border-radius:2px;margin:0 auto}
.modal-close-btn{position:absolute;top:10px;right:14px;background:none;border:none;color:#555;font-size:20px;cursor:pointer;padding:6px;line-height:1;z-index:1;-webkit-tap-highlight-color:transparent}
.modal-close-btn:active{color:#888}
.modal-title{font-size:16px;font-weight:900;padding:4px 44px 14px 20px;border-bottom:1px solid var(--border)}
.modal-body{padding:18px 20px 0}

.req-search-wrap{position:relative;margin-bottom:16px}
.req-search-wrap.hidden{display:none}
.req-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#555;font-size:15px;pointer-events:none;transition:color .2s}
.req-search-wrap:focus-within .req-search-icon{color:#a78bfa}
.req-search{width:100%;padding:14px 14px 14px 44px;background:#1a1a1a;border:1.5px solid #2a2a2a;border-radius:14px;color:#fff;font-size:16px;font-family:'Montserrat',sans-serif;outline:none;-webkit-appearance:none;transition:border-color .2s,box-shadow .2s}
.req-search:focus{border-color:rgba(124,58,237,.5);box-shadow:0 0 0 3px rgba(124,58,237,.12)}
#inlineReqSearch:focus{border-color:rgba(124,58,237,.5);box-shadow:0 0 0 3px rgba(124,58,237,.12)}
#inlineReqResults .req-item{background:#080808;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:10px 12px;margin-bottom:5px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:all .15s;box-shadow:inset 0 0 20px rgba(180,30,30,.04)}
#inlineReqResults .req-item:active{background:#111;border-color:rgba(200,40,40,.15)}
#inlineReqResults .req-item img{width:40px;height:40px;border-radius:7px;object-fit:cover;flex-shrink:0}
#inlineReqResults .req-item-info{flex:1;min-width:0}
#inlineReqResults .req-item-title{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#inlineReqResults .req-item-artist{font-size:11px;color:#666;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.req-search::placeholder{color:#444}

/* ── NEW DESIGN v2 ── */
body{padding:0 0 20px}
.container{padding:0 16px;max-width:420px;margin:0 auto;width:100%}
.dopa-header{text-align:center;padding:12px 0 20px}
.dopa-header-name{font-size:58px;font-weight:900;letter-spacing:3px;line-height:1}
.dopa-header-sub{font-size:10px;color:#444;letter-spacing:2.5px;text-transform:uppercase;margin-top:8px;font-weight:700}
.socials-mini{display:none}
.socials-bottom{display:flex;align-items:center;justify-content:center;gap:28px;padding:32px 0 16px}
.socials-inline{display:none;flex-direction:column;align-items:center;gap:0;padding:8px 0 28px}
.socials-inline-icons{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:20px}
.socials-inline a{width:62px;height:62px;border-radius:50%;background:transparent;border:1px solid #2a2a2a;display:flex;align-items:center;justify-content:center;color:#888;font-size:32px;text-decoration:none;-webkit-tap-highlight-color:transparent;transition:all .2s}
.socials-inline a:active{color:#ccc;border-color:#555}
.profile-offline{text-align:center}
.profile-offline img{width:150px;height:150px;border-radius:50%;object-fit:cover;border:1px solid #222;box-shadow:0 10px 32px rgba(0,0,0,.7)}
.profile-top{text-align:center;padding:28px 0 0}
.profile-top img{width:170px;height:170px;border-radius:50%;object-fit:cover;border:1px solid #222;box-shadow:0 12px 36px rgba(0,0,0,.7)}
.social-bottom{width:52px;height:52px;border-radius:50%;background:transparent;border:1px solid #2a2a2a;display:flex;align-items:center;justify-content:center;color:#888;font-size:22px;text-decoration:none;-webkit-tap-highlight-color:transparent;transition:all .2s}
.social-bottom:active{color:#ccc;border-color:#555;background:rgba(255,255,255,.04)}
/* ── LIVE BAR ── */
.npv2-live-bar{display:none;flex-direction:row;align-items:center;justify-content:center;gap:8px;margin-bottom:0;animation:lbFadeIn .4s ease;flex-wrap:nowrap;width:100%;padding:0 8px;box-sizing:border-box}
@keyframes lbFadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.npv2-live-bar.show{display:flex;margin-bottom:20px}
.npv2-live-top{display:contents}
.npv2-live-pill{display:inline-flex;align-items:center;gap:5px;background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.35);border-radius:20px;padding:4px 10px;flex-shrink:0}
.npv2-live-dot{width:5px;height:5px;border-radius:50%;background:#ef4444;animation:blink 1.1s ease-in-out infinite}
.npv2-live-pill-txt{font-size:9px;font-weight:900;letter-spacing:1.5px;color:#ef4444;text-transform:uppercase}
.npv2-live-sep{display:block;width:1px;height:14px;background:#252525;flex-shrink:0}
.npv2-live-hours{display:flex;align-items:center;gap:4px;flex-shrink:0}
.npv2-live-hours i{font-size:9px;color:#555}
.npv2-live-hours span{font-size:14px;color:#888;font-weight:700;font-variant-numeric:tabular-nums}
.npv2-live-venue{font-size:17px;font-weight:900;color:#f0f0f0;letter-spacing:-.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;text-align:center;line-height:1.1}
.npv2-live-venue a{color:inherit;text-decoration:none}

/* ── NP CARD V2 ── */
.npv2{text-align:center;padding:0;position:relative;background:transparent!important;border:none!important;box-shadow:none!important;overflow:visible!important}
.npv2.offline{padding:0!important}
.npv2:not(.offline){padding-bottom:20px}
.npv2.offline .npv2-title,.npv2.offline .npv2-artist,.npv2.offline .npv2-chips,.npv2.offline .npv2-card{display:none!important}

/* card autour du vinyle + infos */
/* ══ PLATINE PIONEER CDJ ══ */
.npv2-card{background:linear-gradient(175deg,#151515 0%,#0c0c0c 100%);border:1px solid #1e1e1e;border-radius:18px;padding:14px 12px 14px;position:relative;overflow:visible!important;box-shadow:0 16px 48px rgba(0,0,0,.85),inset 0 1px 0 rgba(255,255,255,.04);-webkit-user-select:none;user-select:none}
.npv2-card::before{content:'';position:absolute;inset:0;border-radius:18px;background:linear-gradient(135deg,rgba(255,255,255,.03) 0%,transparent 45%);pointer-events:none}
/* LIVE badge sur la platine */
.deck-live-badge{position:absolute;top:10px;left:14px;z-index:5;display:none;align-items:center;gap:5px;background:rgba(239,68,68,.15);border:1.5px solid rgba(239,68,68,.4);border-radius:20px;padding:3px 10px}
.deck-live-badge.show{display:flex}
.deck-live-dot{width:5px;height:5px;border-radius:50%;background:#ef4444;animation:blink 1.1s ease-in-out infinite}
.deck-live-txt{font-size:9px;font-weight:900;letter-spacing:1.5px;color:#ef4444;text-transform:uppercase}
/* Layout corps : plateau + fader côté */
.deck-body{display:flex;align-items:center;gap:10px;justify-content:center;margin-left:64px}
.deck-headphone-wrap{display:none}
.deck-cable-svg{display:none}

/* ══ PADS SAMPLES PIONEER ══ */
.deck-pads{
  padding:10px 10px 6px;
  border-top:1px solid #1a1a1a;
  margin-top:8px;
}
.deck-pads-label{
  font-size:7px;
  font-weight:900;
  letter-spacing:2.5px;
  text-transform:uppercase;
  color:#2a2a2a;
  text-align:center;
  margin-bottom:8px;
}
.deck-pads-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:6px;
}
.deck-pad{
  position:relative;
  aspect-ratio:1;
  border-radius:5px;
  background:linear-gradient(165deg,#1c1c1c 0%,#111 100%);
  border:1px solid #2a2a2a;
  border-bottom:3px solid #0a0a0a;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:5px;
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04), 0 3px 8px rgba(0,0,0,.6);
  transition:all .08s;
  overflow:hidden;
}
.deck-pad:active{
  transform:translateY(1px);
  border-bottom-width:1px;
  box-shadow:inset 0 2px 6px rgba(0,0,0,.5), 0 1px 3px rgba(0,0,0,.5);
}
/* LED coin haut gauche */
.deck-pad-led{
  position:absolute;
  top:5px;left:5px;
  width:4px;height:4px;
  border-radius:50%;
  opacity:.5;
}
.deck-pad-icon{display:flex;align-items:center;justify-content:center;opacity:.85}
.deck-pad-label{
  font-family:'Montserrat',sans-serif;
  font-size:7px;
  font-weight:900;
  letter-spacing:1px;
  text-transform:uppercase;
  color:rgba(255,255,255,.5);
}

/* Couleurs par pad — style Pioneer */
.pad-dopa{
  background:linear-gradient(165deg,#1f1206 0%,#0f0a04 100%);
  border-color:#3a2a10;
  border-bottom-color:#1a1208;
}
.pad-dopa .deck-pad-led{background:#f59e0b;box-shadow:0 0 4px #f59e0b;opacity:1}
.pad-dopa .deck-pad-icon{opacity:1}
.pad-dopa .deck-pad-label{color:#f59e0b}
.pad-dopa:active{background:linear-gradient(165deg,#2a1a08,#1a1006)}

.pad-req{
  background:linear-gradient(165deg,#0a1020 0%,#060810 100%);
  border-color:#1a2a40;
  border-bottom-color:#08101e;
}
.pad-req .deck-pad-led{background:#3b82f6;box-shadow:0 0 4px #3b82f6;opacity:1}
.pad-req .deck-pad-label{color:#3b82f6}
.pad-req:active{background:linear-gradient(165deg,#0f1828,#080e1c)}

.pad-like{
  background:linear-gradient(165deg,#1a0810 0%,#0e0508 100%);
  border-color:#3a1020;
  border-bottom-color:#180810;
}
.pad-like .deck-pad-led{background:#ec4899;box-shadow:0 0 4px #ec4899;opacity:1}
.pad-like .deck-pad-label{color:#ec4899}
.pad-like:active{background:linear-gradient(165deg,#280f18,#180810)}

.pad-tips{
  background:linear-gradient(165deg,#0a1a0a 0%,#060e06 100%);
  border-color:#1a3a1a;
  border-bottom-color:#08180a;
}
.pad-tips .deck-pad-led{background:#22c55e;box-shadow:0 0 4px #22c55e;opacity:1}
.pad-tips .deck-pad-label{color:#22c55e}
.pad-tips:active{background:linear-gradient(165deg,#102810,#081808)}
/* cooling sync pour le pad DOPA */
.pad-dopa.cooling{opacity:.4;pointer-events:none}

/* ══ HOT CUES DRAWER ══ */
.hc-drawer-trigger{
  display:flex;align-items:center;justify-content:center;
  gap:10px;
  padding:12px;
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
  user-select:none;
  position:relative;
  min-height:44px;
}
.hc-drawer-trigger::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.015),transparent);
  pointer-events:none;
}
.hc-drawer-left{display:flex;align-items:center;gap:9px}
.hc-drawer-dots{display:flex;gap:5px;align-items:center;justify-content:center}
.hc-drawer-dot{
  width:8px;height:8px;border-radius:50%;
  box-shadow:0 0 5px currentColor;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1), opacity .3s;
}
.hc-drawer-label{
  font-size:9px;font-weight:900;letter-spacing:2.5px;
  text-transform:uppercase;color:#444;
  transition:color .35s;
}
.hc-drawer-trigger:hover .hc-drawer-label{color:#888}
.hc-drawer-chevron{
  width:20px;height:20px;display:flex;align-items:center;justify-content:center;
  transition:transform .55s cubic-bezier(.34,1.56,.64,1), opacity .35s;
  opacity:.5;
  position:absolute;right:12px;
}
.hc-drawer-chevron svg{display:block}

/* Tiroir sliding */
.hc-drawer-body{
  max-height:0;
  overflow:hidden;
  transition:max-height .65s cubic-bezier(.4,0,.2,1), opacity .4s ease;
  opacity:0;
}
.hc-drawer-body-inner{
  overflow:hidden;
}
.hc-drawer-body.open{
  max-height:200px;
  opacity:1;
}

/* Effets quand ouvert */
.hc-drawer-wrap.open .hc-drawer-label{color:#555}
.hc-drawer-wrap.open .hc-drawer-chevron{
  transform:rotate(180deg);opacity:.7;
}
.hc-drawer-wrap.open .hc-drawer-dot:nth-child(1){transform:scale(1.4);opacity:.9}
.hc-drawer-wrap.open .hc-drawer-dot:nth-child(2){transform:scale(1.2);opacity:.7;transition-delay:.04s}
.hc-drawer-wrap.open .hc-drawer-dot:nth-child(3){transform:scale(1);opacity:.5;transition-delay:.08s}

/* Lueur sur la grille quand ouverte */
.hc-drawer-wrap.open .deck-pads-grid{
  filter:drop-shadow(0 0 12px rgba(0,0,0,.8));
}

/* Séparateur décoratif entre trigger et grille */
.hc-drawer-separator{
  height:1px;
  margin:0 10px 8px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);
  transform:scaleX(0);
  transition:transform .5s cubic-bezier(.4,0,.2,1) .1s;
}
.hc-drawer-wrap.open .hc-drawer-separator{transform:scaleX(1)}


/* ══ BANDEAU LIVE VENUE ══ */
.live-venue-banner{
  display:none;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:16px;
  padding:12px 16px;
  background:linear-gradient(135deg,rgba(239,68,68,.08) 0%,rgba(239,68,68,.03) 100%);
  border:1px solid rgba(239,68,68,.18);
  border-radius:12px;
  position:relative;
  overflow:hidden;
}
.live-venue-banner.show{display:flex}
.live-venue-banner::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,transparent,rgba(239,68,68,.04),transparent);
  animation:liveShimmer 3s ease-in-out infinite;
}
@keyframes liveShimmer{
  0%,100%{transform:translateX(-100%)}
  50%{transform:translateX(100%)}
}
.lvb-left{min-width:0;flex:1}
.lvb-live-row{display:flex;align-items:center;gap:6px;margin-bottom:3px}
.lvb-dot{
  width:7px;height:7px;border-radius:50%;
  background:#ef4444;flex-shrink:0;
  box-shadow:0 0 0 0 rgba(239,68,68,.5);
  animation:lvbPulse 1.8s ease-out infinite;
}
@keyframes lvbPulse{
  0%{box-shadow:0 0 0 0 rgba(239,68,68,.5)}
  70%{box-shadow:0 0 0 8px rgba(239,68,68,0)}
  100%{box-shadow:0 0 0 0 rgba(239,68,68,0)}
}
.lvb-live-txt{font-size:11px;font-weight:900;letter-spacing:3px;color:#ef4444;text-transform:uppercase}
.lvb-venue{font-size:13px;font-weight:900;color:#fff;letter-spacing:-.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lvb-right{text-align:right;flex-shrink:0}
.lvb-hours{font-size:12px;font-weight:900;color:#ccc;letter-spacing:.5px}
.lvb-now{font-size:8px;font-weight:600;color:#555;letter-spacing:1px;text-transform:uppercase;margin-top:1px}

/* ══ CASQUE BG DERRIÈRE DEMANDE UN SON ══ */
.npv2-card{background:linear-gradient(175deg,#151515 0%,#0c0c0c 100%);border:1px solid #1e1e1e;border-radius:18px;padding:14px 12px 14px;position:relative;overflow:visible!important;box-shadow:0 16px 48px rgba(0,0,0,.85),inset 0 1px 0 rgba(255,255,255,.04);-webkit-user-select:none;user-select:none}
.inline-search-heading,.inline-search-box,#inlineReqResults,#inlineReqSelected{position:relative;z-index:1}
.deck-platter-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:176px;height:176px;overflow:visible}
/* Plateau */
.deck-platter{width:176px;height:176px;border-radius:50%;position:relative;flex-shrink:0;box-shadow:0 0 0 3px #0e0e0e,0 0 0 5px #1e1e1e,0 6px 24px rgba(0,0,0,.9)}
/* Vinyl */
.npv2-vinyl-wrap{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;line-height:0;z-index:2}
.npv2-vinyl-wrap svg{display:block;border-radius:50%}
.npv2-glow{position:absolute;inset:-20px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.05) 0%,transparent 65%);pointer-events:none;opacity:0;transition:opacity 1.5s}
.npv2-glow.on{opacity:1}
.npv2.offline .np-disc{animation-play-state:paused}
/* Tonearm collé au plateau */
.tonearm-wrap{position:absolute;top:-18px;right:-30px;width:70px;height:95px;pointer-events:none;z-index:10}
.tonearm-wrap svg{display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.7))}
@keyframes tonearmFloat{0%,100%{transform:rotate(0deg)}30%{transform:rotate(.5deg)}65%{transform:rotate(-.3deg)}}
.tonearm-group{transform-origin:55px 7px;animation:tonearmFloat 4.5s ease-in-out infinite}
/* Pitch fader vertical côté droit */
.pitch-col{display:flex;flex-direction:column;align-items:center;gap:3px;margin-left:14px}
.pitch-label{font-size:6px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#2a2a2a}
.pitch-bpm{font-size:9px;font-weight:900;color:#888;letter-spacing:.5px;font-variant-numeric:tabular-nums;margin-top:4px}
.pitch-track{width:6px;height:120px;background:linear-gradient(to bottom,#080808,#141414,#080808);border:1px solid #1e1e1e;border-radius:3px;position:relative;cursor:pointer;box-shadow:inset 0 1px 6px rgba(0,0,0,.95),inset 0 -1px 4px rgba(0,0,0,.8)}
.pitch-center-line{position:absolute;left:-3px;right:-3px;top:50%;height:1px;background:#2a2a2a;pointer-events:none}
.pitch-fader{width:22px;height:10px;background:linear-gradient(180deg,#484848 0%,#2e2e2e 40%,#383838 100%);border:1px solid #555;border-radius:3px;position:absolute;left:50%;transform:translateX(-50%);top:calc(50% - 5px);box-shadow:0 2px 8px rgba(0,0,0,.9),inset 0 1px 0 rgba(255,255,255,.12),inset 0 -1px 0 rgba(0,0,0,.5);cursor:grab;touch-action:none}
.pitch-fader::before{content:'';position:absolute;left:3px;right:3px;top:50%;height:1px;transform:translateY(-50%);background:rgba(255,255,255,.25)}
.pitch-val{display:none}
/* Track info */
.deck-track-info{text-align:center;padding:18px 2px 4px;position:relative;z-index:1;-webkit-user-select:none;user-select:none}
.npv2-title{font-size:17px;font-weight:900;color:#fff;line-height:1.2;margin-bottom:3px;letter-spacing:-.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.npv2-artist{font-size:12px;color:#aaa;font-weight:600;margin-bottom:0;letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.npv2-chips{display:flex;gap:5px;justify-content:center;flex-wrap:wrap;margin-top:12px}
.npv2-chip{font-size:9px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:#888;border:1px solid #2a2a2a;border-radius:20px;padding:3px 10px;background:#111}
.npv2 .np-chip{background:#111;border:1px solid #2a2a2a;border-radius:20px;font-size:9px;letter-spacing:.8px;text-transform:uppercase;color:#888;padding:3px 10px}
.dopa-btn-wrap{padding:0 0 28px;display:flex;justify-content:center}
.dopa-shout-btn{position:relative;width:100%;max-width:260px;height:72px;border:none;border-radius:22px;cursor:pointer;font-family:'Montserrat',sans-serif;overflow:hidden;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.dopa-shout-bg{position:absolute;inset:0;border-radius:22px;background:#111;border:1px solid #222;transition:all .12s}
.dopa-shout-shine{position:absolute;inset:0;border-radius:22px;background:linear-gradient(135deg,rgba(255,255,255,.05) 0%,transparent 55%);pointer-events:none}
.dopa-shout-btn:active .dopa-shout-bg{transform:scale(.97);background:#0d0d0d}
.dopa-shout-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:14px;height:100%;padding:0 24px}
.dopa-shout-icon{flex-shrink:0;width:40px;height:40px}
.dopa-shout-label{display:flex;flex-direction:column;align-items:flex-start}
.dopa-shout-txt{font-size:19px;font-weight:900;color:#fff;letter-spacing:.3px;line-height:1}
.dopa-shout-sub{font-size:9px;color:#333;font-weight:700;margin-top:4px;letter-spacing:.8px;text-transform:uppercase}
.dopa-shout-btn.admin-disabled{opacity:.25;pointer-events:none}
.inline-search-wrap{padding:0 0 24px;position:relative}
.inline-search-wrap::before{content:none}
.inline-search-eyebrow{display:none}
.inline-search-heading{text-align:center;margin-bottom:16px;padding:0 4px}
.ish-title{font-size:16px;font-weight:900;color:#fff;letter-spacing:-.3px;line-height:1.1;margin-bottom:6px}
/* ── CTA Demande un son ── */
.req-cta-block{position:relative;text-align:center;padding:18px 16px 14px;background:linear-gradient(160deg,#110a0a 0%,#160c0c 55%,#0e0808 100%);border:1px solid #2e1818;border-radius:18px;overflow:hidden}
.req-cta-block::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(239,68,68,.09) 0%,rgba(220,38,38,.04) 45%,transparent 75%);pointer-events:none}
.req-cta-block::after{content:'';position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(239,68,68,.7),rgba(220,38,38,.5),transparent)}
.req-cta-label{font-size:8px;font-weight:900;letter-spacing:3px;text-transform:uppercase;color:#ef4444;margin-bottom:6px}
.req-cta-title{font-size:16px;font-weight:900;color:#fff;letter-spacing:1.5px;text-transform:uppercase;line-height:1;margin-bottom:4px}
.req-cta-sub{font-size:10px;color:#555;font-weight:600;letter-spacing:.3px;margin-bottom:10px}
.req-cta-arrow{font-size:16px;color:#2a2a2a;animation:ctaArrowBounce .9s ease-in-out infinite;line-height:1;display:flex;align-items:center}
.req-cta-input-wrap{position:relative;margin-top:12px}
.req-cta-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#444;font-size:12px;pointer-events:none;z-index:1}
.req-cta-input{width:100%;padding:13px 16px 13px 40px;background:rgba(0,0,0,.55);border:1px solid #2e1414;border-radius:12px;color:#fff;font-size:14px;font-family:'Montserrat',sans-serif;outline:none;-webkit-appearance:none;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}
.req-cta-input::placeholder{color:#3a3a3a}
@keyframes ctaArrowBounce{0%,100%{transform:translateY(0);color:#2e1010}50%{transform:translateY(5px);color:#ef4444}}

.inline-search-box{position:relative}
.inline-search-box{position:relative}
.inline-search-box::after{content:'';position:absolute;inset:0;border-radius:16px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.03) 50%,transparent 100%);background-size:200% 100%;animation:inputShimmer 3s ease-in-out infinite;pointer-events:none}
@keyframes inputShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.inline-search-box input{width:100%;padding:15px 16px 15px 46px;background:#0d0d0d;border:1px solid #222;border-radius:16px;color:#fff;font-size:15px;font-family:'Montserrat',sans-serif;outline:none;-webkit-appearance:none;transition:border-color .25s,box-shadow .25s}
.inline-search-box input:focus{border-color:#3a3a3a;box-shadow:0 0 0 3px rgba(255,255,255,.05);animation:none}
.inline-search-box input:focus ~ .is-icon,.inline-search-box input:focus + .is-icon{color:#888}
.inline-search-box input:focus{border-color:#2a2a2a}
.inline-search-box input::placeholder{color:#444}
.inline-search-box .is-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#555;font-size:13px;pointer-events:none}
.inline-req-selected{margin-top:10px;background:#111;border:1px solid #2a2a2a;border-radius:16px;padding:14px 16px;display:none;box-shadow:0 4px 20px rgba(0,0,0,.5)}
.inline-req-row{display:flex;align-items:center;gap:12px}
.req-header-music{text-align:center;padding:4px 0 20px}
.req-header-music-icon{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,rgba(124,58,237,.2),rgba(236,72,153,.15));border:1px solid rgba(124,58,237,.3);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:22px}
.req-header-music-title{font-size:18px;font-weight:900;color:#fff;margin-bottom:4px}
.req-header-music-sub{font-size:12px;color:#555;line-height:1.5}
.req-results{display:flex;flex-direction:column;gap:6px}
.req-track{display:flex;align-items:center;gap:12px;background:#1a1a1a;border-radius:12px;padding:10px 12px;cursor:pointer;border:1px solid #222;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:all .15s}
.req-track:active,.req-track:hover{background:#222;border-color:#333}
.req-track img{width:48px;height:48px;border-radius:8px;object-fit:cover;flex-shrink:0}
.req-track-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff}
.req-track-artist{font-size:11px;color:#999;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.req-track-arrow{color:#333;font-size:11px;flex-shrink:0}
.req-selected{display:none;text-align:center;padding:8px 0}
.req-selected img{width:110px;height:110px;border-radius:16px;margin-bottom:14px;box-shadow:0 8px 24px rgba(0,0,0,.5)}
.req-selected-name{font-size:18px;font-weight:900;margin-bottom:3px}
.req-selected-artist{font-size:13px;color:#999;margin-bottom:20px}
.req-send-btn{width:100%;padding:16px;border:none;border-radius:14px;background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;font-weight:900;font-size:15px;cursor:pointer;font-family:'Montserrat',sans-serif;touch-action:manipulation;letter-spacing:.3px;box-shadow:0 4px 20px rgba(124,58,237,.35)}
.req-send-btn:active{opacity:.9}
.req-reset-btn{width:100%;padding:12px;border:1px solid #222;border-radius:10px;background:transparent;color:#555;font-size:13px;cursor:pointer;font-family:'Montserrat',sans-serif;margin-top:8px;touch-action:manipulation}

/* ÉTAPES REQUEST */
/* stepper retiré */
.req-confirm-card{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:14px;padding:14px;display:flex;gap:12px;align-items:center;margin-bottom:16px}
.req-confirm-card img{width:56px;height:56px;border-radius:10px;flex-shrink:0;object-fit:cover}
.req-confirm-track{font-size:14px;font-weight:900;color:#fff;margin-bottom:2px}
.req-confirm-artist{font-size:12px;color:#999}
.req-follow-box{background:linear-gradient(135deg,rgba(131,58,180,0.15),rgba(253,29,29,0.1));border:1px solid rgba(131,58,180,0.25);border-radius:14px;padding:18px;text-align:center;margin-bottom:14px}
.req-follow-icon{font-size:32px;margin-bottom:8px;display:none}
.req-follow-title{font-size:15px;font-weight:900;color:#fff;margin-bottom:6px}
.req-follow-sub{font-size:12px;color:#888;line-height:1.5;margin-bottom:16px}
.req-follow-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045);border:none;border-radius:12px;color:#fff;font-size:14px;font-weight:900;cursor:pointer;font-family:'Montserrat',sans-serif;text-decoration:none;touch-action:manipulation}
.req-follow-btn i{font-size:16px}
/* follow-block unifié */
.req-follow-block{border-radius:0;overflow:visible;margin-bottom:0;border:none}
.req-success-box{text-align:center;padding:16px 0}
.req-success-icon{font-size:48px;display:block;margin-bottom:12px;animation:successPop 0.4s cubic-bezier(0.34,1.56,0.64,1)}
@keyframes successPop{from{transform:scale(0.5);opacity:0}to{transform:scale(1);opacity:1}}
.req-success-title{font-size:18px;font-weight:900;color:#fff;margin-bottom:6px}
.req-success-sub{font-size:13px;color:#666;line-height:1.5}

.tips-header{text-align:center;padding:8px 0 20px}
.tips-header i{font-size:32px;color:var(--yellow);margin-bottom:8px;display:block}
.tips-header p{font-size:13px;color:var(--muted);line-height:1.6}
.tips-amounts{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.tip-btn{padding:18px 8px;border-radius:12px;background:#1c1c1c;border:1px solid var(--border2);color:#fff;font-size:18px;font-weight:900;cursor:pointer;font-family:'Montserrat',sans-serif;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.tip-btn:active,.tip-btn.selected{background:#292929;border-color:var(--yellow);color:var(--yellow)}
.tip-custom{display:flex;align-items:center;gap:8px;background:#1c1c1c;border:1px solid var(--border2);border-radius:10px;padding:12px 14px;margin-bottom:16px}
.tip-custom span{color:var(--muted);font-size:14px}
.tip-custom input{background:none;border:none;color:#fff;font-size:16px;font-weight:700;font-family:'Montserrat',sans-serif;outline:none;width:100%;-webkit-appearance:none}
.tip-paypal-btn{width:100%;padding:16px;border:none;border-radius:12px;background:#0070ba;color:#fff;font-weight:900;font-size:15px;cursor:pointer;font-family:'Montserrat',sans-serif;display:flex;align-items:center;justify-content:center;gap:8px;touch-action:manipulation}

.input-group{display:flex;align-items:center;background:#1c1c1c;border-radius:10px;padding:14px;margin-bottom:10px;border:1px solid var(--border2)}
.input-group i{margin-right:10px;opacity:.5;font-size:14px;flex-shrink:0}
.input-group input{background:none;border:none;color:white;width:100%;outline:none;font-family:'Montserrat',sans-serif;font-size:16px;-webkit-appearance:none}
.btn-send{background:#fff;color:#000;border:none;border-radius:10px;padding:15px;font-weight:900;width:100%;cursor:pointer;font-family:'Montserrat',sans-serif;font-size:15px;touch-action:manipulation}

/* IN-APP NOTIF POPUP */
.toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(0.85);background:rgba(12,12,12,0.97);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.1);border-radius:22px;padding:22px 28px;font-size:14px;font-weight:700;color:#fff;z-index:2000;text-align:center;line-height:1.5;max-width:280px;width:85%;opacity:0;pointer-events:none;transition:all 0.35s cubic-bezier(0.32,0.72,0,1);box-shadow:0 24px 60px rgba(0,0,0,0.7)}
.toast.show{opacity:1;transform:translate(-50%,-50%) scale(1)}
.toast-icon{font-size:28px;display:block;margin-bottom:8px}

.dj-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.96);z-index:3000;display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.4s;padding:24px}
.dj-overlay.show{opacity:1;pointer-events:all}
.dj-emoji{font-size:72px;animation:djbounce 0.6s ease infinite alternate;display:block;margin-bottom:12px}
@keyframes djbounce{from{transform:scale(1) rotate(-5deg)}to{transform:scale(1.15) rotate(5deg)}}
.dj-title{font-size:22px;font-weight:900;margin-bottom:8px;text-align:center}
.dj-sub{font-size:13px;color:#888;text-align:center;max-width:260px;line-height:1.6}
.dj-close{margin-top:28px;padding:14px 32px;background:#fff;color:#000;border:none;border-radius:12px;font-weight:900;font-size:15px;cursor:pointer;font-family:'Montserrat',sans-serif}
.dj-stars{font-size:26px;letter-spacing:4px;margin-bottom:8px}

.pwd-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.85);z-index:2500;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.3s;padding:20px}
.pwd-overlay.show{opacity:1;pointer-events:all}
.pwd-box{background:#141414;border:1px solid #2a2a2a;border-radius:20px;padding:28px 24px;width:100%;max-width:300px;text-align:center}
.pwd-title{font-size:15px;font-weight:900;margin-bottom:6px}
.pwd-sub{font-size:11px;color:#555;margin-bottom:16px}
.pwd-input{width:100%;padding:14px;background:#1c1c1c;border:1px solid #333;border-radius:10px;color:#fff;font-size:20px;font-weight:900;font-family:'Montserrat',sans-serif;outline:none;text-align:center;letter-spacing:4px;margin-bottom:12px;-webkit-appearance:none}
.pwd-btn{width:100%;padding:13px;background:#fff;color:#000;border:none;border-radius:10px;font-weight:900;font-size:15px;cursor:pointer;font-family:'Montserrat',sans-serif;touch-action:manipulation}
.pwd-cancel{margin-top:8px;background:none;border:none;color:#555;font-size:12px;cursor:pointer;font-family:'Montserrat',sans-serif;padding:8px;touch-action:manipulation}


/* VIDEO SHARE CTA ANIMATIONS */
@keyframes vidGlow{0%,100%{opacity:0}50%{opacity:.15}}
@keyframes floatDown{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}
@keyframes arrowBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(3px)}}
@keyframes pulseRing{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.5);opacity:0}}

/* ══ REQUEST MODAL — CENTRÉ & SOBRE ══ */
#requestModal{align-items:center;background:rgba(0,0,0,0)}
#requestModal.active{background:rgba(0,0,0,.85);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px)}
#requestSheet{
  border-radius:22px!important;
  background:linear-gradient(170deg,#0d0d0d 0%,#0a0a0a 100%)!important;
  border:1px solid rgba(255,255,255,.08)!important;
  box-shadow:0 2px 0 rgba(255,255,255,.04) inset,0 48px 120px rgba(0,0,0,.98),0 0 0 1px rgba(0,0,0,.5)!important;
  transform:scale(.93) translateY(0)!important;
  transition:transform .4s cubic-bezier(.34,1.15,.64,1),opacity .3s ease!important;
  opacity:0;
  max-width:400px!important;
  position:relative;
  overflow:hidden;
}
#requestSheet::before{
  content:'';position:absolute;top:0;left:20%;right:20%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);
  pointer-events:none;
}
#requestModal.active #requestSheet{transform:scale(1) translateY(0)!important;opacity:1;}
#requestSheet .modal-handle-area{display:none}
#requestSheet .modal-close-btn{
  top:14px!important;right:16px!important;
  width:28px;height:28px;
  background:rgba(255,255,255,.05)!important;
  border:1px solid rgba(255,255,255,.08)!important;
  border-radius:50%!important;
  color:#555!important;font-size:12px!important;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
#requestSheet .modal-close-btn:hover{background:rgba(255,255,255,.1)!important;color:#ccc!important}
#requestSheet .modal-title{
  font-size:14px!important;font-weight:900!important;
  padding:20px 50px 14px 22px!important;
  border-bottom:1px solid rgba(255,255,255,.06)!important;
  letter-spacing:.5px;color:#ccc!important;
}
#requestSheet .modal-body{padding:16px 20px 20px!important}
#requestSheet .req-follow-box{
  background:rgba(10,10,10,.8)!important;
  border:1px solid rgba(255,255,255,.07)!important;
  border-radius:14px!important;
}

/* ── VIDEO MODULE STYLES ─── */
.admin-disabled{opacity:0.3!important;cursor:not-allowed!important}
.blast-overlay{position:fixed;inset:0;z-index:1500;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s;background:rgba(0,0,0,0)}
.blast-overlay.show{opacity:1;pointer-events:all;background:rgba(0,0,0,.65);backdrop-filter:blur(14px)}
.blast-box{background:#141414;border:1px solid #2a2a2a;border-radius:24px;padding:32px 28px;text-align:center;transform:scale(.85);transition:transform .4s cubic-bezier(.34,1.56,.64,1);max-width:280px;width:90%}
.blast-overlay.show .blast-box{transform:scale(1)}
.blast-spinner{width:52px;height:52px;display:flex;align-items:center;justify-content:center;gap:7px;margin:0 auto 14px}
.blast-spinner span{width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#ec4899);display:inline-block;animation:bsdot .9s ease-in-out infinite}
.blast-spinner span:nth-child(2){animation-delay:.15s}
.blast-spinner span:nth-child(3){animation-delay:.3s}
@keyframes bsdot{0%,80%,100%{transform:scale(0.4);opacity:.3}40%{transform:scale(1);opacity:1}}
.blast-speaker{font-size:64px;display:none;animation:spkP .45s ease-in-out infinite alternate}
@keyframes spkP{from{transform:scale(1)}to{transform:scale(1.12)}}
.blast-waves{display:none;justify-content:center;gap:4px;margin:10px 0;height:28px;align-items:flex-end}
.blast-wave{width:5px;border-radius:3px;background:linear-gradient(to top,#7c3aed,#ec4899);animation:wA .55s ease-in-out infinite alternate}
.blast-wave:nth-child(1){height:12px}.blast-wave:nth-child(2){height:24px;animation-delay:.1s}
.blast-wave:nth-child(3){height:18px;animation-delay:.2s}.blast-wave:nth-child(4){height:28px;animation-delay:.05s}
.blast-wave:nth-child(5){height:16px;animation-delay:.15s}.blast-wave:nth-child(6){height:22px;animation-delay:.25s}
.blast-wave:nth-child(7){height:10px;animation-delay:.08s}
@keyframes wA{from{transform:scaleY(.3)}to{transform:scaleY(1)}}
.blast-title{font-size:16px;font-weight:900;color:#fff;margin-top:4px}
.blast-cd{font-size:42px;font-weight:900;color:#fff;font-variant-numeric:tabular-nums;margin:10px 0 2px;display:none}
.blast-cd-lbl{font-size:11px;color:#666;display:none;margin-bottom:4px}
.blast-bar-wrap{height:3px;background:#222;border-radius:2px;margin-top:14px;overflow:hidden}
.blast-bar{height:100%;background:linear-gradient(90deg,#7c3aed,#ec4899);border-radius:2px;width:0%}
.req-limit-overlay{position:fixed;inset:0;z-index:1500;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;background:rgba(0,0,0,0);padding-bottom:env(safe-area-inset-bottom,0px)}
.req-limit-overlay.show{opacity:1;pointer-events:all;background:rgba(0,0,0,.75);backdrop-filter:blur(18px)}
.req-limit-box{
  width:100%;max-width:420px;
  background:linear-gradient(160deg,#111 0%,#0d0d0d 100%);
  border:1px solid #252525;
  border-radius:28px 28px 0 0;
  padding:0 0 calc(env(safe-area-inset-bottom,0px) + 28px);
  text-align:center;
  transform:translateY(100%);
  transition:transform .45s cubic-bezier(.32,.72,0,1);
  overflow:hidden;
  position:relative;
}
.req-limit-overlay.show .req-limit-box{transform:translateY(0)}
/* Barre de progression en haut */
.req-limit-progress-rail{height:3px;background:#1a1a1a;width:100%;margin-bottom:0}
.req-limit-progress-fill{height:100%;background:linear-gradient(90deg,#f59e0b,#ef4444);border-radius:0;transition:width 1s linear;width:100%}
/* Handle */
.req-limit-handle{width:36px;height:4px;background:#2a2a2a;border-radius:2px;margin:14px auto 0}
/* Close */
.req-limit-close-btn{position:absolute;top:14px;right:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:13px;color:#555;cursor:pointer;-webkit-tap-highlight-color:transparent}
.burger-btn{position:fixed;top:16px;right:16px;z-index:700;width:44px;height:44px;border-radius:50%;background:#111;border:1px solid #222;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;box-shadow:0 4px 16px rgba(0,0,0,.4)}
.burger-btn i{font-size:16px;color:#fff}
.burger-menu{position:fixed;top:0;right:0;bottom:0;width:min(280px,85vw);background:#111;border-left:1px solid #1f1f1f;z-index:850;transform:translateX(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column;padding:60px 0 40px;overflow-y:auto}
.burger-menu.open{transform:translateX(0)}
.burger-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:840;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(4px)}
.burger-bg.open{opacity:1;pointer-events:all}
.burger-close{position:absolute;top:14px;right:14px;background:none;border:none;color:#555;font-size:22px;cursor:pointer;padding:6px}
.burger-ttl{font-size:11px;font-weight:700;letter-spacing:2px;color:#444;text-transform:uppercase;padding:0 20px 12px;border-bottom:1px solid #1a1a1a;margin-bottom:8px}
.bi{display:flex;align-items:center;gap:14px;padding:14px 20px;color:#ccc;text-decoration:none;font-size:14px;font-weight:700;cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:'Montserrat',sans-serif;-webkit-tap-highlight-color:transparent;transition:background .15s}
.bi:active{background:#1a1a1a}
.bi-white{background:#fff;color:#000;margin:16px 16px 0;border-radius:12px;padding:14px 16px}
.bi-white i{color:#000}.bi-white:active{background:#eee}
.bsep{height:1px;background:#1a1a1a;margin:6px 0}
.copt{display:flex;align-items:center;gap:14px;padding:15px;background:#1a1a1a;border:1px solid #222;border-radius:14px;text-decoration:none;color:#fff;-webkit-tap-highlight-color:transparent;margin-bottom:10px}
.copt:active{background:#222}
.copt-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.copt-lbl{font-size:14px;font-weight:900;color:#fff}
.copt-sub{font-size:11px;color:#555;margin-top:2px}

/* ── LIKE SYSTEM ── */
#likeCanvas{position:fixed;pointer-events:none;z-index:9000;display:none}
.like-ripple{position:absolute;top:50%;left:50%;width:140px;height:140px;margin:-70px 0 0 -70px;border-radius:50%;border:2px solid rgba(255,100,130,.6);transform:scale(.5);opacity:0;pointer-events:none;animation:likeRipple .6s ease-out forwards}
@keyframes likeRipple{0%{transform:scale(.5);opacity:.8}100%{transform:scale(1.6);opacity:0}}

@keyframes rlPulse{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}
@keyframes rlPulseDot{0%,100%{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1.1)}}
@keyframes rlSheen{0%{background-position:200% 0}50%{background-position:-100% 0}100%{background-position:-100% 0}}
@keyframes rlBtnShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes slideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
