/* ═══════════════════════════════════════════════════════════
   CAMPING DES ÉTOILES — PROGRAMME / EVENTS / SLIDER
   (s'ajoute aux variables --cde-* déjà définies dans camping-etoiles.css)
   ═══════════════════════════════════════════════════════════ */

:root{
  --cde-nuit:#0E2230;
  --cde-nuit-2:#163148;
  --cde-carte:#1D3A52;
  --cde-carte-hover:#244863;
  --cde-bordure:rgba(224,123,60,.22);
  --cde-bordure-claire:rgba(250,246,239,.08);
}

/* ═══ NAV — bouton Programme ═══ */
.cde-nav__programme{
  background:rgba(224,123,60,.12);
  border:1px solid rgba(224,123,60,.35);
  padding:6px 14px;
  border-radius:30px;
  color:var(--cde-orange-clair) !important;
  transition:var(--cde-tr);
}
.cde-nav__programme:hover{
  background:var(--cde-orange);
  border-color:var(--cde-orange);
  color:#fff !important;
}
.cde-nav__programme i{font-size:.8rem;margin-right:4px}

/* ═══ NEXT EVENT — encart après hero ═══ */
.cde-next{
  background:linear-gradient(180deg,var(--cde-bleu) 0%,#0f2835 100%);
  padding:clamp(40px,6vw,70px) 0;
  position:relative;overflow:hidden;
  font-family:var(--cde-fb);
}
.cde-next::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 60% 40% at 20% 30%, rgba(224,123,60,.14) 0%, transparent 60%),
    radial-gradient(ellipse 40% 30% at 80% 70%, rgba(255,215,0,.08) 0%, transparent 60%);
}
.cde-next__container{
  max-width:1100px;margin:0 auto;
  padding:0 clamp(20px,5vw,50px);
  position:relative;z-index:1;
}

.cde-next__card{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:32px;align-items:center;
  background:rgba(255,255,255,.04);
  border:1px solid var(--cde-bordure);
  border-radius:var(--cde-rg);
  padding:28px 32px;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  position:relative;overflow:hidden;
  transition:var(--cde-tr);
  cursor:pointer;
}
.cde-next__card:hover{
  transform:translateY(-2px);
  border-color:rgba(224,123,60,.45);
  background:rgba(255,255,255,.07);
}
/* (les 3 étoiles en haut à droite ont été retirées sur demande) */

/* Header de la section "Prochain événement" */
.cde-next__header{
  text-align:center;
  margin-bottom:32px;
}
.cde-next__header-kicker{
  font-family:var(--cde-fe);
  font-size:1.6rem;
  color:var(--cde-jaune-star);
  display:inline-block;
  margin-bottom:6px;
  letter-spacing:.04em;
}
.cde-next__header-title{
  font-family:var(--cde-ft);font-weight:700;
  font-size:clamp(1.6rem,3.5vw,2.4rem);
  color:#fff;line-height:1.2;
  margin-bottom:14px;
}
.cde-next__header-title em{
  color:var(--cde-orange-clair);font-style:italic;
}
.cde-next__header-line{
  width:80px;height:3px;margin:0 auto;
  background:linear-gradient(90deg,transparent,var(--cde-orange),transparent);
  border-radius:2px;
}

.cde-next__date{
  text-align:center;line-height:1;
  padding:18px 24px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--cde-r);
  min-width:120px;
}
.cde-next__day-num,
.cde-next__day-range{
  display:block;font-family:var(--cde-ft);font-weight:700;
  font-size:3rem;color:var(--cde-orange-clair);line-height:1;
}
.cde-next__day-range{font-size:2rem;letter-spacing:-.02em}
.cde-next__day-name{
  display:block;font-family:var(--cde-fe);
  font-size:1.4rem;color:var(--cde-jaune-star);margin-top:6px;
}
.cde-next__month{
  display:block;font-size:.72rem;text-transform:uppercase;
  letter-spacing:.12em;color:var(--cde-bleu-pale);margin-top:6px;
}

.cde-next__info{min-width:0}
.cde-next__kicker{
  font-family:var(--cde-fe);font-size:1.15rem;color:var(--cde-orange-doux);
  display:flex;align-items:center;gap:10px;margin-bottom:4px;
}
.cde-next__pulse{
  width:9px;height:9px;border-radius:50%;background:var(--cde-orange);
  box-shadow:0 0 0 0 rgba(224,123,60,.6);
  animation:cde-pulse 1.8s infinite;
  flex-shrink:0;
}
@keyframes cde-pulse{
  0%{box-shadow:0 0 0 0 rgba(224,123,60,.6)}
  70%{box-shadow:0 0 0 12px rgba(224,123,60,0)}
  100%{box-shadow:0 0 0 0 rgba(224,123,60,0)}
}
.cde-next__name{
  font-family:var(--cde-ft);font-weight:700;
  font-size:clamp(1.4rem,3vw,1.9rem);line-height:1.15;
  color:#fff;margin:4px 0 8px;
}
.cde-next__style{
  color:rgba(255,255,255,.75);font-size:.95rem;line-height:1.5;
}
.cde-next__style i{color:var(--cde-orange-clair);margin-right:8px}

.cde-next__cta{flex-shrink:0}

/* Bandeau activités permanentes */
.cde-next__strip{
  margin-top:18px;
  background:rgba(255,255,255,.04);
  border:1px dashed var(--cde-bordure-claire);
  border-radius:var(--cde-r);
  padding:14px 22px;
  display:flex;flex-wrap:wrap;gap:6px 18px;align-items:center;
  font-size:.82rem;color:var(--cde-bleu-pale);
}
.cde-next__strip-label{
  font-family:var(--cde-fe);font-size:1.15rem;color:var(--cde-orange-clair);
  padding-right:14px;border-right:1px solid var(--cde-bordure-claire);
  flex-shrink:0;
}
.cde-next__strip-item{
  display:inline-flex;align-items:center;gap:6px;
  white-space:nowrap;
}
.cde-next__strip-item i{color:var(--cde-vert-doux);font-size:.78rem}

@media(max-width:800px){
  .cde-next__card{grid-template-columns:auto 1fr;gap:18px;padding:22px}
  .cde-next__cta{grid-column:1 / -1;display:flex;justify-content:center;margin-top:6px}
  .cde-next__date{padding:14px 18px;min-width:94px}
  .cde-next__day-num{font-size:2.4rem}
  .cde-next__strip{justify-content:flex-start}
  .cde-next__strip-label{border-right:none;border-bottom:1px solid var(--cde-bordure-claire);padding:0 0 6px;margin-bottom:4px;width:100%}
}

/* ═══ AGENDA SECTION (slider home) ═══ */
.cde-agenda{
  padding:clamp(60px,8vw,100px) 0;
  background:var(--cde-creme);
  font-family:var(--cde-fb);
  position:relative;
}
.cde-agenda__head{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:28px;gap:20px;flex-wrap:wrap;
}
.cde-agenda__title{
  font-family:var(--cde-ft);font-weight:700;
  font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.2;color:var(--cde-noir);
}
.cde-agenda__title em{color:var(--cde-orange);font-style:italic}
.cde-agenda__sub{
  margin-top:10px;color:var(--cde-brun);font-size:1rem;
}
.cde-agenda__nav{display:flex;gap:10px;flex-shrink:0}
.cde-agenda__btn{
  width:46px;height:46px;border-radius:50%;
  background:#fff;border:1px solid var(--cde-sable);
  color:var(--cde-bleu);cursor:pointer;font-size:.95rem;
  display:flex;align-items:center;justify-content:center;
  transition:var(--cde-tr);
  box-shadow:0 2px 10px rgba(27,58,75,.06);
}
.cde-agenda__btn:hover{
  background:var(--cde-orange);color:#fff;border-color:var(--cde-orange);
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(224,123,60,.3);
}

.cde-agenda__track{
  display:flex;gap:18px;overflow-x:auto;
  padding:8px 2px 20px;
  scroll-snap-type:x mandatory;
  scrollbar-width:thin;scrollbar-color:var(--cde-orange-doux) transparent;
}
.cde-agenda__track::-webkit-scrollbar{height:6px}
.cde-agenda__track::-webkit-scrollbar-track{background:transparent}
.cde-agenda__track::-webkit-scrollbar-thumb{background:var(--cde-orange-doux);border-radius:3px}

.cde-agenda__cta{text-align:center;margin-top:20px}

/* Slide cards */
.cde-slide{
  flex:0 0 290px;
  scroll-snap-align:start;
  background:#fff;
  border-radius:var(--cde-r);
  overflow:hidden;
  box-shadow:0 6px 22px rgba(27,58,75,.1);
  transition:transform .3s, box-shadow .3s, border-color .3s;
  cursor:pointer;
  border:1px solid var(--cde-sable);
  display:flex;flex-direction:column;
}
.cde-slide:hover{
  transform:translateY(-5px);
  box-shadow:0 14px 36px rgba(27,58,75,.18);
  border-color:var(--cde-orange-doux);
}
.cde-slide__head{
  background:linear-gradient(135deg,var(--cde-bleu) 0%,var(--cde-bleu-clair) 100%);
  color:#fff;padding:18px 22px;position:relative;overflow:hidden;
}
.cde-slide__head::after{
  content:'★';position:absolute;top:10px;right:14px;
  color:var(--cde-jaune-star);opacity:.45;font-size:1rem;
}
.cde-slide__head--special{background:linear-gradient(135deg,#E07B3C 0%,#8B4513 100%)}
.cde-slide__head--block{background:linear-gradient(135deg,var(--cde-vert) 0%,var(--cde-bleu) 100%)}
.cde-slide__day-num{
  font-family:var(--cde-ft);font-weight:700;
  font-size:2.4rem;line-height:1;
}
.cde-slide__range{
  font-family:var(--cde-ft);font-weight:700;
  font-size:1.8rem;line-height:1;
}
.cde-slide__day-name{
  font-family:var(--cde-fe);font-size:1.3rem;color:var(--cde-jaune-star);margin-top:2px;
}
.cde-slide__month{
  font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;
  color:var(--cde-bleu-pale);margin-top:4px;
}

.cde-slide__body{padding:18px 22px;flex:1;display:flex;flex-direction:column}
.cde-slide__name{
  font-family:var(--cde-ft);font-weight:700;font-size:1.15rem;color:var(--cde-noir);
  line-height:1.25;margin-bottom:8px;
}
.cde-slide__style{
  font-size:.88rem;color:var(--cde-brun);font-style:italic;
  flex:1;line-height:1.5;
}
.cde-slide__foot{
  margin-top:14px;padding-top:14px;
  border-top:1px dashed var(--cde-sable);
  font-size:.8rem;color:var(--cde-orange);font-weight:600;
  display:flex;align-items:center;justify-content:space-between;
}
.cde-slide__foot i{font-size:.72rem;margin-left:4px}
.cde-slide__price{
  background:var(--cde-orange);color:#fff;
  padding:3px 10px;border-radius:20px;font-size:.72rem;
  font-weight:700;
}
.cde-slide__price--tag{background:var(--cde-vert);font-weight:600}

/* ═══ PROGRAMME OVERLAY (AJAX fullscreen) ═══ */
.cde-prog-overlay{
  position:fixed;inset:0;z-index:100000;
  visibility:hidden;opacity:0;
  transition:opacity .4s ease, visibility 0s linear .4s;
  pointer-events:none;
}
.cde-prog-overlay.cde-prog-overlay--open{
  visibility:visible;opacity:1;
  transition:opacity .4s ease, visibility 0s;
  pointer-events:all;
}
.cde-prog-overlay__backdrop{
  position:absolute;inset:0;
  background:rgba(8,18,28,.85);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.cde-prog-overlay__scroll{
  position:absolute;inset:0;
  overflow-y:auto;overflow-x:hidden;
  background:var(--cde-nuit);
  transform:translateY(24px);opacity:.6;
  transition:transform .5s cubic-bezier(.22,.68,0,1.15), opacity .4s ease;
}
.cde-prog-overlay--open .cde-prog-overlay__scroll{
  transform:translateY(0);opacity:1;
}

.cde-prog-overlay__close{
  position:fixed;top:20px;right:22px;z-index:10;
  width:46px;height:46px;border-radius:50%;
  background:rgba(27,58,75,.85);
  border:1px solid var(--cde-bordure);
  color:var(--cde-creme);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:var(--cde-tr);
  backdrop-filter:blur(10px);
  font-size:1.1rem;
}
.cde-prog-overlay__close:hover{
  background:var(--cde-orange);border-color:var(--cde-orange);color:#fff;
  transform:rotate(90deg);
}

.cde-prog-overlay__inner{
  color:var(--cde-creme);
  font-family:var(--cde-fb);
  min-height:100vh;
  padding-bottom:40px;
  position:relative;
}

.cde-prog-overlay__loader{
  min-height:80vh;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:16px;
  color:var(--cde-bleu-pale);
}
.cde-prog-overlay__spinner{
  width:40px;height:40px;border-radius:50%;
  border:3px solid var(--cde-bordure-claire);
  border-top-color:var(--cde-orange);
  animation:cde-spin 1s linear infinite;
}
@keyframes cde-spin{to{transform:rotate(360deg)}}

/* Starfield for the programme overlay (JS injects canvas) */
.cde-prog-overlay__starsbg{
  position:absolute;inset:0;pointer-events:none;z-index:0;
}

/* ═══ PROGRAMME CONTENT (inside overlay) ═══ */
.cde-prog{
  max-width:1200px;margin:0 auto;
  padding:0 clamp(20px,5vw,50px);
  position:relative;z-index:1;
}
.cde-prog__hero{
  padding:80px 0 50px;text-align:center;
}
.cde-prog__kicker{
  font-family:var(--cde-fe);font-size:1.5rem;
  color:var(--cde-orange-clair);margin-bottom:8px;
  display:inline-flex;align-items:center;gap:12px;
}
.cde-prog__kicker i{color:var(--cde-jaune-star);font-size:.9rem}
.cde-prog__title{
  font-family:var(--cde-ft);font-weight:700;
  font-size:clamp(2.2rem,5.5vw,3.8rem);
  line-height:1.1;color:#fff;margin-bottom:14px;
}
.cde-prog__title em{color:var(--cde-orange-clair);font-style:italic}
.cde-prog__sub{
  color:var(--cde-bleu-pale);font-size:1.02rem;
  max-width:640px;margin:0 auto;line-height:1.8;
}
.cde-prog__zigzag{
  width:100px;height:8px;margin:20px auto 0;
  background:repeating-linear-gradient(90deg,var(--cde-orange) 0,var(--cde-orange) 10px,transparent 10px,transparent 20px);
  border-radius:4px;opacity:.7;
}

.cde-prog__tabs{
  position:sticky;top:0;z-index:5;
  background:rgba(14,34,48,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  padding:14px 0;margin:0 -50px 30px;
  border-bottom:1px solid var(--cde-bordure-claire);
}
.cde-prog__tabs-inner{
  display:flex;flex-wrap:wrap;justify-content:center;gap:8px;
  max-width:1200px;margin:0 auto;padding:0 clamp(20px,5vw,50px);
}
.cde-prog__tab{
  background:transparent;border:1px solid var(--cde-bordure);
  color:var(--cde-bleu-pale);
  padding:8px 18px;border-radius:50px;
  font-family:var(--cde-fb);font-size:.82rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  cursor:pointer;transition:var(--cde-tr);
}
.cde-prog__tab:hover{border-color:var(--cde-orange);color:var(--cde-orange-clair)}
.cde-prog__tab--active{
  background:var(--cde-orange);border-color:var(--cde-orange);
  color:#fff;box-shadow:0 4px 16px rgba(224,123,60,.3);
}

.cde-prog__list{margin-bottom:40px}
.cde-prog__empty{
  text-align:center;padding:60px 20px;
  color:var(--cde-bleu-pale);font-size:1rem;
}
.cde-prog__month{margin-bottom:44px}
.cde-prog__month.cde-prog__month--hidden{display:none}
.cde-prog__month-title{
  display:flex;align-items:center;gap:16px;margin-bottom:22px;
}
.cde-prog__month-text{
  font-family:var(--cde-ft);font-weight:700;font-style:italic;
  font-size:clamp(1.6rem,3.2vw,2.2rem);color:var(--cde-orange-clair);
}
.cde-prog__month-text em{color:var(--cde-jaune-star);font-style:normal}
.cde-prog__month-line{
  flex:1;height:1px;
  background:linear-gradient(90deg,var(--cde-orange) 0,transparent 100%);
  opacity:.4;
}
.cde-prog__month-grid{display:grid;grid-template-columns:1fr;gap:12px}

/* ═══ EVENT CARD (programme) ═══ */
.cde-evt{
  display:grid;grid-template-columns:auto 1fr auto;
  align-items:center;gap:22px;
  background:var(--cde-carte);
  border:1px solid var(--cde-bordure-claire);
  border-radius:var(--cde-rg);
  padding:18px 24px;
  cursor:pointer;position:relative;overflow:hidden;
  transition:transform .25s, border-color .25s, box-shadow .25s;
}
.cde-evt::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:4px;
  background:var(--cde-orange);opacity:.5;transition:var(--cde-tr);
}
.cde-evt:hover{
  transform:translateY(-3px);
  border-color:var(--cde-bordure);
  box-shadow:0 14px 32px rgba(0,0,0,.35);
}
.cde-evt:hover::before{opacity:1;width:5px}
.cde-evt:focus{outline:2px solid var(--cde-orange);outline-offset:2px}

.cde-evt__date{text-align:center;line-height:1;min-width:68px}
.cde-evt__day-num{
  font-family:var(--cde-ft);font-weight:700;font-size:2.3rem;
  color:var(--cde-orange-clair);display:block;
}
.cde-evt__day-name{
  font-family:var(--cde-fe);font-size:1.2rem;
  color:var(--cde-jaune-star);display:block;margin-top:2px;
}
.cde-evt__month{
  font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;
  color:var(--cde-bleu-pale);display:block;margin-top:4px;
}

.cde-evt__info{min-width:0}
.cde-evt__name{
  font-family:var(--cde-ft);font-weight:700;
  font-size:clamp(1.05rem,2vw,1.35rem);
  color:#fff;line-height:1.2;margin-bottom:4px;
}
.cde-evt__style{
  color:var(--cde-bleu-pale);font-size:.9rem;font-style:italic;line-height:1.4;
}
.cde-evt__style i{color:var(--cde-orange-clair);margin-right:6px;font-size:.78rem}

.cde-evt__meta{
  display:flex;flex-direction:column;align-items:flex-end;gap:6px;
  font-size:.8rem;
}
.cde-evt__price,.cde-evt__tag{
  background:var(--cde-orange);color:#fff;
  padding:4px 12px;border-radius:20px;
  font-weight:700;font-size:.76rem;white-space:nowrap;
}
.cde-evt__tag{background:var(--cde-vert-doux);font-weight:600}
.cde-evt__free{
  color:var(--cde-vert-doux);font-size:.78rem;font-weight:600;white-space:nowrap;
}
.cde-evt__chevron{color:var(--cde-bleu-pale);opacity:.5;transition:var(--cde-tr);font-size:.85rem}
.cde-evt:hover .cde-evt__chevron{color:var(--cde-orange-clair);transform:translateX(4px);opacity:1}

.cde-evt--special::before{
  background:linear-gradient(180deg,var(--cde-orange) 0%,var(--cde-jaune-star) 100%);
}
.cde-evt--special{
  background:linear-gradient(135deg,var(--cde-carte) 0%,#3C2748 100%);
}
.cde-evt--block{
  grid-template-columns:1fr auto;
  background:linear-gradient(135deg,#1D3A52 0%,#2A4F1E 100%);
  border-color:rgba(107,175,94,.25);
}
.cde-evt--block::before{background:var(--cde-vert-doux);opacity:.8}
.cde-evt--block .cde-evt__name{color:var(--cde-jaune-star)}
.cde-evt__dates-range{
  font-family:var(--cde-fe);font-size:1.35rem;
  color:var(--cde-vert-doux);margin-bottom:4px;
  display:flex;align-items:center;gap:8px;
}
.cde-evt__dates-range i{font-size:.95rem}

/* ═══ ACTIVITÉS RÉCURRENTES ═══ */
.cde-prog__activities{
  margin:60px 0 40px;
  padding:60px 0;
  position:relative;
  border-top:1px solid var(--cde-bordure-claire);
  border-bottom:1px solid var(--cde-bordure-claire);
}
.cde-prog__activities-head{text-align:center;margin-bottom:36px}
.cde-prog__activities-kicker{
  font-family:var(--cde-fe);font-size:1.35rem;color:var(--cde-orange-clair);
}
.cde-prog__activities-title{
  font-family:var(--cde-ft);font-weight:700;font-style:italic;
  font-size:clamp(1.7rem,3.5vw,2.4rem);color:#fff;margin-top:4px;
}
.cde-prog__activities-title em{color:var(--cde-orange-clair);font-style:normal}
.cde-prog__activities-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:16px;
}
.cde-act{
  background:rgba(250,246,239,.04);
  border:1px solid var(--cde-bordure-claire);
  border-radius:var(--cde-r);
  padding:22px;
  transition:var(--cde-tr);
}
.cde-act:hover{
  background:rgba(250,246,239,.07);
  border-color:var(--cde-bordure);
  transform:translateY(-2px);
}
.cde-act__icon{
  width:46px;height:46px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(224,123,60,.15);color:var(--cde-orange-clair);
  font-size:1.1rem;margin-bottom:14px;
}
.cde-act__title{
  font-family:var(--cde-ft);font-weight:700;
  color:#fff;font-size:1.05rem;margin-bottom:4px;
}
.cde-act__when{
  font-family:var(--cde-fe);font-size:1.1rem;
  color:var(--cde-jaune-star);margin-bottom:8px;
}
.cde-act__desc{
  color:var(--cde-bleu-pale);font-size:.86rem;line-height:1.6;
}
.cde-act__foot{
  margin-top:14px;padding-top:12px;
  border-top:1px dashed var(--cde-bordure-claire);
  font-size:.78rem;color:var(--cde-orange-doux);
  display:flex;align-items:center;gap:8px;
}

/* ═══ PROGRAMME FOOTER ═══ */
.cde-prog__foot{
  padding:40px 0 50px;
  text-align:center;
  color:var(--cde-bleu-pale);font-size:.9rem;line-height:1.9;
}
.cde-prog__foot strong{color:var(--cde-jaune-star)}
.cde-prog__foot-contact{
  margin-top:20px;display:flex;justify-content:center;gap:24px;flex-wrap:wrap;
  font-size:.92rem;
}
.cde-prog__foot-contact a{color:var(--cde-orange-clair);text-decoration:none;font-weight:600}
.cde-prog__foot-contact a:hover{color:var(--cde-jaune-star)}
.cde-prog__foot-contact i{margin-right:6px}

/* ═══ EVENT DETAIL PANEL (overlay sur l'overlay) ═══ */
.cde-event-panel{
  position:fixed;inset:0;z-index:100001;
  visibility:hidden;opacity:0;
  transition:opacity .35s ease, visibility 0s linear .35s;
  pointer-events:none;
}
.cde-event-panel.cde-event-panel--open{
  visibility:visible;opacity:1;
  transition:opacity .35s ease, visibility 0s;
  pointer-events:all;
}
.cde-event-panel__backdrop{
  position:absolute;inset:0;
  background:rgba(5,12,20,.65);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.cde-event-panel__inner{
  position:absolute;top:0;right:0;height:100%;
  width:min(520px,100vw);
  background:var(--cde-nuit-2);
  border-left:1px solid var(--cde-bordure);
  box-shadow:-30px 0 60px rgba(0,0,0,.5);
  overflow-y:auto;
  transform:translateX(100%);
  transition:transform .45s cubic-bezier(.22,.68,0,1.15);
  padding:28px 32px 50px;
  color:var(--cde-creme);
  font-family:var(--cde-fb);
}
.cde-event-panel--open .cde-event-panel__inner{transform:translateX(0)}
.cde-event-panel__close{
  position:sticky;top:0;margin-left:auto;display:flex;
  width:40px;height:40px;border-radius:50%;
  background:rgba(250,246,239,.05);
  border:1px solid var(--cde-bordure-claire);
  color:var(--cde-bleu-pale);cursor:pointer;
  align-items:center;justify-content:center;
  transition:var(--cde-tr);margin-bottom:14px;
  backdrop-filter:blur(10px);
}
.cde-event-panel__close:hover{color:var(--cde-orange-clair);border-color:var(--cde-orange);transform:rotate(90deg)}

.cde-event-panel__loader{color:var(--cde-bleu-pale);padding:20px 0}

/* Event detail content */
.cde-edetail{animation:cde-fadeup .4s ease}
@keyframes cde-fadeup{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.cde-edetail__badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.cde-edetail__badge{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--cde-fe);font-size:1.1rem;color:var(--cde-jaune-star);
  background:rgba(255,215,0,.08);border:1px solid rgba(255,215,0,.2);
  padding:6px 14px;border-radius:30px;
}
.cde-edetail__badge i{font-size:.8rem}
.cde-edetail__badge--tag{color:var(--cde-orange-clair);background:rgba(224,123,60,.1);border-color:rgba(224,123,60,.3)}
.cde-edetail__title{
  font-family:var(--cde-ft);font-weight:700;
  font-size:clamp(1.6rem,4vw,2.2rem);line-height:1.15;
  color:#fff;margin-bottom:8px;
}
.cde-edetail__style{
  font-family:var(--cde-fe);font-size:1.3rem;
  color:var(--cde-orange-clair);margin-bottom:22px;line-height:1.4;
}
.cde-edetail__divider{height:1px;background:var(--cde-bordure-claire);margin:18px 0}
.cde-edetail__desc{color:var(--cde-creme);font-size:.94rem;line-height:1.8;margin-bottom:22px}
.cde-edetail__desc p{margin-bottom:12px}
.cde-edetail__meta{display:flex;flex-direction:column;gap:8px;margin-bottom:22px}
.cde-edetail__meta-row{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;background:rgba(250,246,239,.03);
  border-radius:var(--cde-r);font-size:.86rem;color:var(--cde-bleu-pale);
  line-height:1.4;
}
.cde-edetail__meta-row i{color:var(--cde-orange-clair);width:18px;text-align:center;font-size:.95rem;flex-shrink:0}
.cde-edetail__meta-row strong{color:var(--cde-creme)}
.cde-edetail__note{
  padding:16px 20px;
  background:rgba(224,123,60,.08);
  border-left:3px solid var(--cde-orange);
  border-radius:0 var(--cde-r) var(--cde-r) 0;
  font-size:.82rem;color:var(--cde-bleu-pale);line-height:1.7;
}
.cde-edetail__note strong{color:var(--cde-jaune-star);display:block;margin-bottom:4px}
.cde-edetail__note a{color:var(--cde-orange-clair);text-decoration:none}
.cde-edetail__note a:hover{color:var(--cde-jaune-star)}

/* ═══ RESPONSIVE ═══ */
@media(max-width:700px){
  .cde-evt{grid-template-columns:auto 1fr;gap:14px;padding:14px 16px}
  .cde-evt__meta{grid-column:1 / -1;flex-direction:row;align-items:center;justify-content:space-between;margin-top:6px}
  .cde-evt__chevron{display:none}
  .cde-agenda__track{padding-left:20px;padding-right:20px;margin:0 -20px}
  .cde-slide{flex:0 0 260px}
  .cde-prog-overlay__close{top:14px;right:14px;width:42px;height:42px}

  /* Onglets mois : scroll horizontal au lieu de wrap sur 2 lignes */
  .cde-prog__tabs{margin-left:-20px;margin-right:-20px;padding:12px 0}
  .cde-prog__tabs-inner{
    flex-wrap:nowrap;
    overflow-x:auto;
    justify-content:flex-start;
    padding:0 20px;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .cde-prog__tabs-inner::-webkit-scrollbar{display:none}
  .cde-prog__tab{flex-shrink:0}

  /* Hero programme — padding resserré */
  .cde-prog__hero{padding:60px 0 30px}
  .cde-prog{padding:0 18px}

  /* Panneau détail : plein écran propre */
  .cde-event-panel__inner{padding:24px 20px 60px}
}
@media(max-width:420px){
  .cde-evt{gap:12px;padding:13px 14px}
  .cde-evt__date{min-width:54px}
  .cde-evt__day-num{font-size:1.7rem}
  .cde-evt__day-name{font-size:1rem}
  .cde-evt__name{font-size:1.02rem;word-break:break-word;hyphens:auto}
  .cde-evt__style{font-size:.82rem}
  .cde-evt__dates-range{font-size:1.1rem}
  .cde-next__day-num{font-size:2.2rem}
  .cde-next__card{padding:18px}

  /* Block events (marché / festival) restent en 1 colonne */
  .cde-evt--block{grid-template-columns:1fr}
  .cde-evt--block .cde-evt__meta{justify-content:flex-start}
}

/* ═══ BODY LOCK when overlay open ═══ */
body.cde-prog-lock{overflow:hidden}

/* ═══ HERO FLOATING CTA — "Voir le programme de l'été" ═══ */
/* Injecté via JS dans .cde-hero, apparaît après 3s avec halo d'étoiles + pulse */
.cde-hero{position:relative} /* s'assurer que le parent est positionné */

.cde-hero-cta{
  position:absolute;
  bottom:clamp(1.5rem,5vw,4rem);
  left:50%;
  transform:translateX(-50%) translateY(30px);
  opacity:0;
  z-index:6;
  transition:opacity .9s ease, transform .9s cubic-bezier(.22,.68,0,1.15);
  pointer-events:none;
  filter:drop-shadow(0 10px 30px rgba(224,123,60,.4));
}
.cde-hero-cta--visible{
  opacity:1;
  transform:translateX(-50%) translateY(0);
  pointer-events:auto;
}

/* Halo de lumière chaude en arrière-plan */
.cde-hero-cta__halo{
  position:absolute;
  top:50%;left:50%;
  width:340px;height:180px;
  transform:translate(-50%,-50%);
  background:
    radial-gradient(ellipse closest-side, rgba(255,215,0,.28) 0%, rgba(224,123,60,.12) 45%, rgba(255,215,0,0) 75%);
  border-radius:50%;
  animation:cde-heroCta-halo 3.2s ease-in-out infinite;
  pointer-events:none;
  filter:blur(8px);
}
@keyframes cde-heroCta-halo{
  0%,100% {opacity:.55;transform:translate(-50%,-50%) scale(.95);}
  50%     {opacity:1;   transform:translate(-50%,-50%) scale(1.15);}
}

/* Petites étoiles autour du bouton qui scintillent */
.cde-hero-cta__star{
  position:absolute;
  color:var(--cde-jaune-star);
  pointer-events:none;
  font-size:1rem;
  opacity:0;
  animation:cde-heroCta-star 2.8s ease-in-out infinite;
  text-shadow:0 0 8px rgba(255,215,0,.8);
}
.cde-hero-cta__star--1{top:-18px;left:12%;font-size:1.1rem;animation-delay:0s}
.cde-hero-cta__star--2{top:-6px;right:8%;font-size:.85rem;animation-delay:.4s}
.cde-hero-cta__star--3{bottom:-14px;left:18%;font-size:.95rem;animation-delay:.8s}
.cde-hero-cta__star--4{bottom:-8px;right:14%;font-size:1.05rem;animation-delay:1.2s}
.cde-hero-cta__star--5{top:50%;left:-22px;font-size:.8rem;animation-delay:.6s}
.cde-hero-cta__star--6{top:30%;right:-18px;font-size:.9rem;animation-delay:1.5s}
@keyframes cde-heroCta-star{
  0%,100% {opacity:.2;transform:scale(.8) rotate(0deg);}
  50%     {opacity:1;  transform:scale(1.3) rotate(180deg);}
}

/* Bouton lui-même */
.cde-hero-cta__btn{
  position:relative;z-index:2;
  display:inline-flex;align-items:center;gap:12px;
  background:linear-gradient(135deg,var(--cde-orange) 0%,#F5A55C 100%);
  color:#fff !important;
  text-decoration:none !important;
  padding:13px 26px;
  border-radius:50px;
  font-family:var(--cde-fb);font-weight:700;
  font-size:clamp(.88rem,2vw,1rem);letter-spacing:.02em;
  box-shadow:0 8px 28px rgba(224,123,60,.5), inset 0 1px 0 rgba(255,255,255,.3);
  border:1px solid rgba(255,215,0,.35);
  animation:cde-heroCta-breath 2.6s ease-in-out infinite;
  transition:transform .25s ease, box-shadow .25s ease;
  white-space:nowrap;
}
.cde-hero-cta__btn:hover{
  transform:scale(1.05);
  box-shadow:0 14px 40px rgba(224,123,60,.7), inset 0 1px 0 rgba(255,255,255,.4);
  animation-play-state:paused;
}
.cde-hero-cta__btn i{font-size:.88em}
.cde-hero-cta__btn .fa-arrow-right{transition:transform .25s}
.cde-hero-cta__btn:hover .fa-arrow-right{transform:translateX(4px)}

@keyframes cde-heroCta-breath{
  0%,100% {transform:scale(1);    box-shadow:0 8px 28px rgba(224,123,60,.5),  inset 0 1px 0 rgba(255,255,255,.3);}
  50%     {transform:scale(1.03); box-shadow:0 14px 40px rgba(224,123,60,.7), inset 0 1px 0 rgba(255,255,255,.4);}
}

/* Respect prefers-reduced-motion */
@media (prefers-reduced-motion: reduce){
  .cde-hero-cta__btn,
  .cde-hero-cta__halo,
  .cde-hero-cta__star{animation:none}
  .cde-hero-cta{transition:opacity .4s ease}
}

/* Mobile: on masque entièrement le CTA flottant.
   Raison : injecté comme enfant de `.cde-hero` (qui est display:flex),
   le CTA devenait un flex item frère de `.cde-hero__content` et poussait
   tout le contenu vers la gauche, créant un décalage visible même quand
   le CTA était invisible (opacity:0 garde la place dans le flex).
   Les boutons du hero (Réserver, Découvrir) remplissent déjà ce rôle. */
@media(max-width:700px){
  .cde-hero-cta{display:none !important}
}

/* ═══ PROGRAMME HERO — bouton PDF ═══ */
.cde-prog__actions{
  margin-top:24px;
  display:flex;justify-content:center;gap:12px;flex-wrap:wrap;
}
.cde-prog__pdf-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:11px 22px;
  background:rgba(250,246,239,.06);
  border:1px solid var(--cde-bordure);
  border-radius:50px;
  color:var(--cde-orange-clair) !important;
  text-decoration:none !important;
  font-family:var(--cde-fb);font-weight:600;font-size:.9rem;
  transition:var(--cde-tr);
  backdrop-filter:blur(10px);
}
.cde-prog__pdf-btn:hover{
  background:var(--cde-orange);
  border-color:var(--cde-orange);
  color:#fff !important;
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(224,123,60,.35);
}
.cde-prog__pdf-btn i{font-size:1rem}
.cde-prog__foot-pdf{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:14px;font-size:.88rem;color:var(--cde-orange-clair);
  text-decoration:none;font-weight:600;
}
.cde-prog__foot-pdf:hover{color:var(--cde-jaune-star)}
