/* ============ EXCELLENCE PODCAST — styles partagés ============ */
:root{
  --noir:#0a0a0c;
  --noir-2:#111114;
  --noir-3:#17171b;
  --blanc:#f6f4f0;
  --gris:#9b988f;
  --rouge:#e3242b;
  --rouge-fonce:#b81c22;
  --display:'Creato Display','Manrope',sans-serif;
  --sans:'Manrope',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0;background:var(--noir)}
body{color:var(--blanc);font-family:var(--sans);font-weight:400;line-height:1.6;overflow-x:hidden}
::selection{background:var(--rouge);color:#fff}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.tag{display:inline-flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--rouge);font-weight:700;margin-bottom:18px}
h1.page,h2.sec{font-family:var(--display);font-style:italic;font-weight:800;font-size:clamp(32px,5vw,54px);line-height:1.08;letter-spacing:-.01em}
h1.page{font-size:clamp(40px,6.5vw,72px)}
.muted{color:var(--gris)}
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.on{opacity:1;transform:none}
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 30px;border-radius:999px;font-weight:700;font-size:15px;letter-spacing:.02em;transition:all .35s ease;cursor:pointer;border:none;font-family:var(--sans)}
.btn-rouge{background:var(--rouge);color:#fff}
.btn-rouge:hover{background:var(--rouge-fonce);transform:translateY(-2px);box-shadow:0 14px 34px rgba(227,36,43,.35)}
.btn-ghost{border:1px solid rgba(246,244,240,.25);color:var(--blanc)}
.btn-ghost:hover{border-color:var(--blanc);transform:translateY(-2px)}
.spark{display:inline-block;color:var(--rouge);font-style:normal}

/* ---------- nav ---------- */
nav.site{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .4s,backdrop-filter .4s,border-color .4s;border-bottom:1px solid transparent}
nav.site.scrolled{background:rgba(10,10,12,.85);backdrop-filter:blur(14px);border-color:rgba(246,244,240,.08)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:72px;gap:18px}
.logo img{height:26px;width:auto;display:block}
.nav-links{display:flex;gap:28px;font-size:14px;font-weight:600;color:var(--gris)}
.nav-links a:hover,.nav-links a.act{color:var(--blanc)}
.nav-links a.act{position:relative}
.nav-links a.act::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--rouge)}
.nav-cta{padding:10px 22px;font-size:13px}
.burger{display:none;background:none;border:none;cursor:pointer;width:40px;height:40px;position:relative;z-index:102}
.burger span{display:block;width:22px;height:2px;background:var(--blanc);margin:5px auto;transition:all .3s}
.mobile-menu{display:none;position:fixed;inset:0;background:rgba(10,10,12,.97);z-index:101;flex-direction:column;align-items:center;justify-content:center;gap:26px;font-size:20px;font-weight:700}
.mobile-menu.open{display:flex}
@media(max-width:880px){.nav-links,.nav-cta{display:none}.burger{display:block}}

/* ---------- page hero (sous-pages) ---------- */
.page-hero{padding:150px 0 60px;text-align:center}
.page-hero p.lead{max-width:620px;margin:20px auto 0;color:var(--gris);font-size:17px}

/* ---------- stats ---------- */
.stats-row{display:flex;gap:clamp(30px,6vw,90px);flex-wrap:wrap;justify-content:center}
.stat .num{font-family:var(--display);font-style:italic;font-weight:800;font-size:clamp(34px,4.6vw,58px);line-height:1}
.stat .num em{font-style:normal;color:var(--rouge)}
.stat .lbl{font-size:13px;color:var(--gris);margin-top:8px;letter-spacing:.04em}

/* ---------- marquee ---------- */
.marquee{border-top:1px solid rgba(246,244,240,.08);border-bottom:1px solid rgba(246,244,240,.08);padding:18px 0;overflow:hidden;background:var(--noir-2)}
.marquee-track{display:flex;gap:48px;white-space:nowrap;animation:scrollx 36s linear infinite;width:max-content}
.marquee-track span{font-family:var(--display);font-style:italic;font-weight:800;font-size:20px;color:var(--gris)}
.marquee-track .dot{color:var(--rouge);font-style:normal}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- cartes épisode ---------- */
.eps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.ep-card{position:relative;border-radius:14px;overflow:hidden;background:var(--noir-2);border:1px solid rgba(246,244,240,.07);transition:transform .45s cubic-bezier(.16,1,.3,1),border-color .45s,box-shadow .45s;cursor:pointer;display:block}
.ep-card:hover{transform:translateY(-8px);border-color:rgba(227,36,43,.5);box-shadow:0 24px 60px rgba(0,0,0,.5)}
.ep-thumb{aspect-ratio:16/9;overflow:hidden;position:relative;background:var(--noir-3)}
.ep-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.ep-card:hover .ep-thumb img{transform:scale(1.06)}
.ep-thumb .mini-play{position:absolute;inset:0;margin:auto;width:54px;height:54px;border-radius:50%;background:rgba(227,36,43,.92);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .35s}
.ep-card:hover .mini-play{opacity:1}
.ep-dur{position:absolute;bottom:10px;right:10px;background:rgba(10,10,12,.85);font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:6px}
.ep-type{position:absolute;top:10px;left:10px;display:inline-flex;align-items:center;gap:6px;background:rgba(10,10,12,.85);backdrop-filter:blur(4px);font-size:10.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;border-radius:999px;border:1px solid rgba(246,244,240,.15)}
.ep-type svg{width:11px;height:11px;fill:var(--rouge)}
.ep-body{padding:20px 22px 24px}
.ep-body .no{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--rouge);font-weight:700}
.ep-body h4,.ep-body h3{font-size:16.5px;font-weight:700;line-height:1.35;margin:9px 0 7px;font-family:var(--sans);font-style:normal}
.ep-body .guest{font-size:13px;color:var(--gris)}
@media(max-width:980px){.eps-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.eps-grid{grid-template-columns:1fr}}

/* ---------- bibliothèque ---------- */
.lib-tools{display:flex;gap:14px;flex-wrap:wrap;align-items:center;justify-content:center;margin:10px 0 44px}
.lib-search{flex:1;min-width:240px;max-width:380px;display:flex;align-items:center;gap:10px;border:1px solid rgba(246,244,240,.16);border-radius:999px;padding:0 20px;background:var(--noir-2)}
.lib-search input{flex:1;background:none;border:none;outline:none;color:var(--blanc);font-family:var(--sans);font-size:14.5px;padding:13px 0}
.filters{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.fbtn{padding:9px 18px;border-radius:999px;border:1px solid rgba(246,244,240,.16);background:none;color:var(--gris);font-family:var(--sans);font-weight:700;font-size:13px;cursor:pointer;transition:all .25s}
.fbtn:hover{color:var(--blanc);border-color:rgba(246,244,240,.4)}
.fbtn.act{background:var(--rouge);border-color:var(--rouge);color:#fff}
.lib-empty{text-align:center;color:var(--gris);padding:70px 0;display:none}

/* ---------- modal lecteur ---------- */
.modal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:22px}
.modal.open{display:flex}
.modal-bg{position:absolute;inset:0;background:rgba(5,5,6,.92);backdrop-filter:blur(6px)}
.modal-box{position:relative;width:min(960px,100%);background:var(--noir-2);border:1px solid rgba(246,244,240,.1);border-radius:16px;overflow:hidden;animation:modalin .35s cubic-bezier(.16,1,.3,1)}
@keyframes modalin{from{opacity:0;transform:translateY(26px) scale(.98)}to{opacity:1;transform:none}}
.modal-player{aspect-ratio:16/9;background:#000}
.modal-player iframe{width:100%;height:100%;border:0;display:block}
.modal-player.audio{aspect-ratio:auto;height:232px}
.modal-info{padding:20px 26px 24px;display:flex;justify-content:space-between;gap:18px;align-items:flex-start;flex-wrap:wrap}
.modal-info .no{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--rouge);font-weight:700}
.modal-info h3{font-size:19px;font-weight:800;margin-top:6px}
.modal-info .guest{color:var(--gris);font-size:14px;margin-top:3px}
.modal-close{position:absolute;top:14px;right:14px;z-index:2;width:40px;height:40px;border-radius:50%;background:rgba(10,10,12,.8);border:1px solid rgba(246,244,240,.2);color:var(--blanc);font-size:18px;cursor:pointer;transition:all .25s}
.modal-close:hover{background:var(--rouge);border-color:var(--rouge)}
.modal-share{display:flex;gap:10px;align-items:center}
.modal-share button,.modal-share a{font-size:12.5px;font-weight:700;padding:9px 16px;border-radius:999px;border:1px solid rgba(246,244,240,.2);background:none;color:var(--blanc);cursor:pointer;font-family:var(--sans);transition:all .25s}
.modal-share button:hover,.modal-share a:hover{border-color:var(--rouge);color:var(--rouge)}

/* ---------- sections génériques ---------- */
.section{padding:clamp(70px,10vh,120px) 0}
.section.alt{background:var(--noir-2);border-top:1px solid rgba(246,244,240,.07);border-bottom:1px solid rgba(246,244,240,.07)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,80px);align-items:center}
@media(max-width:880px){.two-col{grid-template-columns:1fr}}
.photo-frame{position:relative;border-radius:18px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.55)}
.photo-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,12,.45),transparent 45%)}

/* ---------- partenariat ---------- */
.pt-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.pt-card{position:relative;border:1px solid rgba(246,244,240,.09);border-radius:16px;padding:30px 26px;background:var(--noir-2);display:flex;flex-direction:column;transition:transform .45s cubic-bezier(.16,1,.3,1),border-color .45s}
.pt-card:hover{transform:translateY(-7px);border-color:rgba(227,36,43,.55)}
.pt-card.star{border-color:rgba(227,36,43,.55);background:linear-gradient(160deg,rgba(227,36,43,.1),var(--noir-2) 55%)}
.pt-card .pt-tag{position:absolute;top:-11px;right:18px;background:var(--rouge);color:#fff;font-size:10.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:4px 12px;border-radius:999px}
.pt-card h4{font-family:var(--display);font-style:italic;font-size:23px;font-weight:800;margin-bottom:4px}
.pt-card .pt-sub{font-size:12.5px;color:var(--rouge);font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:18px}
.pt-card ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:13.5px;color:var(--gris);flex:1}
.pt-card li{padding-left:20px;position:relative}
.pt-card li::before{content:"✦";position:absolute;left:0;color:var(--rouge);font-size:11px;top:2px}
@media(max-width:1020px){.pt-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.pt-grid{grid-template-columns:1fr}}

/* ---------- tableau comparaison ---------- */
.cmp{width:100%;border-collapse:collapse;font-size:14px}
.cmp th,.cmp td{padding:15px 16px;text-align:left;border-bottom:1px solid rgba(246,244,240,.09)}
.cmp th{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gris)}
.cmp tr.hl{background:linear-gradient(90deg,rgba(227,36,43,.12),transparent)}
.cmp tr.hl td:first-child{color:var(--rouge);font-weight:800}
.cmp-scroll{overflow-x:auto;border:1px solid rgba(246,244,240,.09);border-radius:14px;background:var(--noir-2)}
.cmp-scroll table{min-width:640px}

/* ---------- formulaires ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-grid .full{grid-column:1/-1}
@media(max-width:640px){.form-grid{grid-template-columns:1fr}}
.field label{display:block;font-size:12.5px;font-weight:700;letter-spacing:.04em;color:var(--gris);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;background:var(--noir);border:1px solid rgba(246,244,240,.16);border-radius:10px;color:var(--blanc);font-family:var(--sans);font-size:14.5px;padding:13px 15px;outline:none;transition:border-color .25s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--rouge)}
.field textarea{resize:vertical;min-height:100px}
.form-note{font-size:12.5px;color:var(--gris);margin-top:14px}
.form-ok{display:none;background:rgba(39,174,96,.12);border:1px solid rgba(39,174,96,.45);color:#7ee2a8;padding:14px 18px;border-radius:10px;margin-top:16px;font-size:14px}
.form-err{display:none;background:rgba(227,36,43,.1);border:1px solid rgba(227,36,43,.45);color:#ff8e93;padding:14px 18px;border-radius:10px;margin-top:16px;font-size:14px}

/* ---------- don ---------- */
.don-box{background:var(--noir);border:1px solid rgba(246,244,240,.1);border-radius:20px;padding:36px;box-shadow:0 30px 80px rgba(0,0,0,.45)}
.don-box h4{font-family:var(--display);font-style:italic;font-weight:800;font-size:24px;margin-bottom:22px}
.chips{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.chip{padding:10px 20px;border-radius:999px;border:1px solid rgba(246,244,240,.2);background:none;color:var(--blanc);font-family:var(--sans);font-weight:700;font-size:14px;cursor:pointer;transition:all .25s}
.chip:hover{border-color:var(--rouge)}
.chip.sel{background:var(--rouge);border-color:var(--rouge)}
.don-amount{display:flex;align-items:center;gap:10px;border:1px solid rgba(246,244,240,.18);border-radius:12px;padding:4px 18px;margin-bottom:22px}
.don-amount input{flex:1;background:none;border:none;outline:none;color:var(--blanc);font-family:var(--sans);font-size:20px;font-weight:700;padding:12px 0}
.don-amount span{color:var(--gris);font-weight:700;font-size:14px}
.don-box .btn{width:100%;justify-content:center}
.secure{display:flex;align-items:center;gap:8px;justify-content:center;margin-top:16px;font-size:12.5px;color:var(--gris)}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin:0 auto}
.faq details{border-bottom:1px solid rgba(246,244,240,.1);padding:4px 0}
.faq summary{cursor:pointer;font-weight:700;font-size:16.5px;padding:18px 30px 18px 0;list-style:none;position:relative}
.faq summary::after{content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);color:var(--rouge);font-size:22px;font-weight:400;transition:transform .3s}
.faq details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq details p{color:var(--gris);padding-bottom:20px;font-size:14.5px}

/* ---------- newsletter ---------- */
.nl{display:flex;gap:12px;flex-wrap:wrap;max-width:520px}
.nl input{flex:1;min-width:220px;background:var(--noir);border:1px solid rgba(246,244,240,.18);border-radius:999px;color:var(--blanc);font-family:var(--sans);font-size:14.5px;padding:14px 22px;outline:none}
.nl input:focus{border-color:var(--rouge)}

/* ---------- CTA bandeau ---------- */
.cta-band{text-align:center;padding:clamp(70px,10vh,120px) 24px;background:radial-gradient(ellipse at 50% 120%,rgba(227,36,43,.18),transparent 60%)}
.cta-band h2{font-family:var(--display);font-style:italic;font-weight:800;font-size:clamp(30px,4.6vw,50px);max-width:760px;margin:0 auto 30px}

/* ---------- footer ---------- */
footer.site{padding:60px 0 40px;border-top:1px solid rgba(246,244,240,.07)}
.foot-grid{display:flex;justify-content:space-between;gap:34px;flex-wrap:wrap;align-items:flex-start}
.foot-brand p{color:var(--gris);font-size:14px;max-width:300px;margin-top:14px}
.foot-brand .logo img{height:30px}
.foot-col h5{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gris);margin-bottom:14px}
.foot-col a{display:block;font-size:14.5px;color:var(--blanc);opacity:.85;margin-bottom:9px;transition:color .25s}
.foot-col a:hover{color:var(--rouge);opacity:1}
.foot-bottom{margin-top:46px;padding-top:24px;border-top:1px solid rgba(246,244,240,.07);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:13px;color:var(--gris)}
.foot-bottom a{color:var(--blanc)}
