/* ===========================================================================
   accueil.css — habillage « magazine éditorial » de la page d'accueil.
   Chargé UNIQUEMENT sur l'accueil. Le contenu est scopé sous .home ; la topbar
   et le footer utilisent des classes propres (.topbar, .site-pied) qui
   n'existent nulle part ailleurs. Aucune autre page n'est affectée.
   =========================================================================== */
:root{
  --violet-debut:#667eea; --violet-fin:#764ba2; --violet:#6b4fd0;
  --degrade:linear-gradient(135deg,var(--violet-debut),var(--violet-fin));
  --or:#f6b73c; --encre:#1d1b27; --texte2:#2a2735; --doux:#6f6c82;
  --blanc:#ffffff; --fond-doux:#f6f5fb; --bordure2:#eceaf4;
  --titre:"Bricolage Grotesque",system-ui,sans-serif;
  --corps:"Hanken Grotesk",system-ui,sans-serif;
  --max:1180px; --rayon2:18px; --rayon-s:12px;
  --ombre2:0 8px 30px rgba(36,28,68,.10); --ombre-fort:0 22px 50px rgba(36,28,68,.20);
}
body{background:var(--blanc)}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}

/* topbar (hors .home) */
.topbar{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--bordure2)}
.topbar__in{display:flex;align-items:center;gap:24px;min-height:68px;position:relative;z-index:2}
.marque{font-family:var(--titre);font-weight:800;font-size:1.3rem;letter-spacing:-.02em;color:var(--encre);text-decoration:none}
.marque b{background:var(--degrade);-webkit-background-clip:text;background-clip:text;color:transparent}
.topnav{display:flex;gap:26px;margin-left:8px}
.topnav a{font-weight:600;font-size:.95rem;color:var(--texte2);padding:6px 2px;text-decoration:none;position:relative;z-index:2}
.topnav a:hover{color:var(--violet)}
.topbar__droite{margin-left:auto;display:flex;align-items:center;gap:14px}
.recherche-top{display:flex;align-items:center;gap:8px;background:var(--fond-doux);border:1px solid var(--bordure2);
  border-radius:999px;padding:8px 14px;color:var(--doux);font-size:.9rem}
.recherche-top input{border:0;background:transparent;outline:0;font-family:var(--corps);font-size:.9rem;width:150px;color:var(--texte2)}
.pro-lien{font-weight:700;font-size:.9rem;color:var(--violet);text-decoration:none}

/* base .home */
.home{color:var(--texte2);font-family:var(--corps);line-height:1.6}
.home h1,.home h2,.home h3,.home h4{font-family:var(--titre);color:var(--encre);line-height:1.08;margin:0;font-weight:800;letter-spacing:-.01em}
.home a{color:inherit;text-decoration:none}
.home img{display:block;max-width:100%}
.home-sec{padding:64px 0}

.home .eyebrow{font-family:var(--corps);font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--violet);display:inline-flex;align-items:center;gap:9px}
.home .eyebrow::before{content:"";width:26px;height:2px;border-radius:2px;background:var(--degrade)}
.home .arr{display:inline-grid;place-items:center;min-width:34px;height:34px;padding:0 9px;border-radius:999px;
  background:rgba(255,255,255,.16);border:1.5px solid rgba(255,255,255,.55);color:#fff;font-family:var(--titre);font-weight:700;font-size:.8rem}
.home .arr--clair{background:#f1eefb;border-color:transparent;color:var(--violet)}
.home .btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--corps);font-weight:700;font-size:.95rem;
  padding:13px 22px;border-radius:999px;border:0;cursor:pointer;transition:.18s;text-decoration:none}
.home .btn--plein{background:var(--degrade);color:#fff;box-shadow:0 8px 20px rgba(107,79,208,.32)}
.home .btn--plein:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(107,79,208,.42)}
.home .lien-tout{font-weight:700;color:var(--violet);font-size:.92rem;display:inline-flex;align-items:center;gap:6px}
.home .lien-tout span{transition:.18s}.home .lien-tout:hover span{transform:translateX(4px)}
.home .sec-tete{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:30px}
.home .sec-tete h2{font-size:clamp(1.6rem,3.2vw,2.2rem)}
.home .sec-tete .eyebrow{margin-bottom:12px}

/* hero */
.home .hero{position:relative;min-height:72vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.home .hero__img{position:absolute;inset:0;background-size:cover;background-position:center}
.home .hero__img.ph-lumieres{background:
  radial-gradient(900px 500px at 70% 10%,rgba(255,255,255,.18),transparent 60%),
  linear-gradient(135deg,#5566c4,#7a4ea0 55%,#3a2c63)}
.home .hero__img.ph-lumieres::after{content:"";position:absolute;inset:0;background:
  radial-gradient(2px 2px at 20% 30%,rgba(255,255,255,.7),transparent),
  radial-gradient(2px 2px at 80% 20%,rgba(255,255,255,.55),transparent),
  radial-gradient(1.5px 1.5px at 60% 60%,rgba(255,255,255,.5),transparent),
  radial-gradient(1.5px 1.5px at 35% 75%,rgba(255,255,255,.45),transparent),
  radial-gradient(2px 2px at 90% 70%,rgba(255,255,255,.5),transparent)}
.home .hero__voile{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,14,40,.82) 0%,rgba(20,14,40,.30) 45%,rgba(20,14,40,.05) 75%)}
.home .hero__in{position:relative;width:100%;max-width:var(--max);margin:0 auto;padding:0 24px 56px}
.home .hero__meta{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.home .hero .eyebrow{color:#fff}.home .hero .eyebrow::before{background:#fff;opacity:.9}
.home .hero__titre{font-size:clamp(2.4rem,6vw,4.4rem);max-width:16ch;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.home .hero__sous{margin:16px 0 24px;font-size:1.1rem;max-width:46ch;color:rgba(255,255,255,.92)}
.home .hero__infos{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.home .hero__date{font-weight:600;color:rgba(255,255,255,.9)}

/* à la une */
.home .une{display:grid;grid-template-columns:1.6fr 1fr;gap:22px}
.home .une__col{display:flex;flex-direction:column;gap:22px}
.home .h-carte{position:relative;border-radius:var(--rayon2);overflow:hidden;color:#fff;display:flex;align-items:flex-end;
  box-shadow:var(--ombre2);transition:.2s;isolation:isolate;text-decoration:none}
.home .h-carte:hover{transform:translateY(-4px);box-shadow:var(--ombre-fort)}
.home .h-carte__img{position:absolute;inset:0;z-index:-2;transition:.4s;background-size:cover;background-position:center}
.home .h-carte:hover .h-carte__img{transform:scale(1.05)}
.home .h-carte::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(to top,rgba(18,12,36,.86),rgba(18,12,36,.15) 60%,transparent)}
.home .h-carte__in{padding:22px}
.home .une__grande{min-height:460px}
.home .une__grande .h-carte__titre{font-size:1.9rem;max-width:18ch}
.home .une__petite{min-height:219px}
.home .une__petite .h-carte__titre{font-size:1.2rem}
.home .h-carte__haut{position:absolute;top:18px;left:18px;right:18px;display:flex;justify-content:space-between;align-items:flex-start}
.home .h-badge{font-family:var(--corps);font-weight:700;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
  color:#3a2600;background:var(--or);padding:6px 12px;border-radius:999px;box-shadow:0 4px 12px rgba(246,183,60,.4)}
.home .h-carte__cat{font-family:var(--corps);font-weight:700;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.92);margin-bottom:8px;display:block}
.home .h-carte__titre{font-family:var(--titre);font-weight:800;line-height:1.1}
.home .h-carte__meta{margin-top:10px;font-size:.86rem;color:rgba(255,255,255,.85)}

/* placeholders dégradés */
.ph-lumieres{background:linear-gradient(135deg,#667eea,#764ba2)}
.ph-saone{background:linear-gradient(135deg,#f6a26b,#b5497e)}
.ph-fourviere{background:linear-gradient(135deg,#cda45e,#8a5a2b)}
.ph-confluence{background:linear-gradient(135deg,#5b7fd6,#2e3a7a)}
.ph-teteor{background:linear-gradient(135deg,#6fae6a,#2f6b54)}
.ph-croix{background:linear-gradient(135deg,#dd8a68,#9c4b3b)}
.ph-presquile{background:linear-gradient(135deg,#8e88bf,#4b4670)}
.ph-halles{background:linear-gradient(135deg,#e0876e,#a83f5b)}

/* newsletter */
.home .nl{background:var(--degrade);color:#fff;border-radius:24px;padding:40px;display:flex;align-items:center;
  justify-content:space-between;gap:30px;flex-wrap:wrap;position:relative;overflow:hidden}
.home .nl::before{content:"";position:absolute;right:-60px;top:-60px;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.22),transparent 70%)}
.home .nl__txt{position:relative}
.home .nl__txt h2{color:#fff;font-size:1.7rem;max-width:18ch}
.home .nl__txt p{margin:8px 0 0;color:rgba(255,255,255,.9)}
.home .nl__form{position:relative;display:flex;flex-direction:column;gap:10px;min-width:300px}
.home .nl__champs{display:flex;gap:10px}
.home .nl__champs input{flex:1;border:0;border-radius:999px;padding:14px 18px;font-family:var(--corps);font-size:.95rem;outline:0}
.home .nl__btn{background:#fff;color:var(--violet);font-weight:700;border:0;border-radius:999px;padding:0 22px;cursor:pointer}
.home .nl__note{font-size:.82rem;color:rgba(255,255,255,.85);margin:0}
.home .nl__note a{color:#fff;text-decoration:underline}

/* agenda scroller */
.home .agenda-sec{background:var(--fond-doux)}
.home .scroller{display:flex;gap:18px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory}
.home .event{flex:none;width:230px;background:#fff;border:1px solid var(--bordure2);border-radius:var(--rayon-s);
  overflow:hidden;scroll-snap-align:start;transition:.18s;text-decoration:none;color:inherit}
.home .event:hover{transform:translateY(-3px);box-shadow:var(--ombre2)}
.home .event__img{height:120px;position:relative;background-size:cover;background-position:center}
.home .event__date{position:absolute;left:12px;bottom:-18px;background:#fff;border-radius:12px;box-shadow:var(--ombre2);width:52px;text-align:center;padding:6px 0;line-height:1}
.home .event__jour{font-family:var(--titre);font-weight:800;font-size:1.3rem;color:var(--encre)}
.home .event__mois{font-family:var(--corps);font-weight:700;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--violet)}
.home .event__in{padding:26px 16px 16px}
.home .event__cat{font-weight:700;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--violet)}
.home .event__titre{font-family:var(--titre);font-weight:700;font-size:1.05rem;margin:6px 0 8px;line-height:1.18}
.home .event__lieu{font-size:.84rem;color:var(--doux);display:flex;align-items:center;gap:7px;margin:0}

/* articles */
.home .grille3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.home .art{transition:.18s}
.home .art__img{height:200px;border-radius:var(--rayon-s);overflow:hidden;margin-bottom:16px;position:relative;transition:.3s;background-size:cover;background-position:center}
.home .art:hover .art__img{transform:translateY(-3px);box-shadow:var(--ombre2)}
.home .art__cat{font-weight:700;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--violet)}
.home .art__titre{font-family:var(--titre);font-weight:800;font-size:1.22rem;margin:8px 0 8px;line-height:1.16}
.home .art:hover .art__titre a{color:var(--violet)}
.home .art__extrait{font-size:.92rem;color:var(--doux);margin:0}
.home .art__meta{margin-top:12px;font-size:.8rem;color:var(--doux)}

/* annuaire vignettes */
.home .adr-sec{background:var(--fond-doux)}
.home .adr{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.home .adr__c{background:#fff;border:1px solid var(--bordure2);border-radius:var(--rayon-s);padding:22px;display:flex;align-items:center;gap:14px;transition:.18s;text-decoration:none}
.home .adr__c:hover{border-color:#e0d9f7;transform:translateY(-3px);box-shadow:var(--ombre2)}
.home .adr__ico{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;font-size:1.4rem;background:#f1eefb;flex:none}
.home .adr__nom{font-family:var(--titre);font-weight:700;font-size:1rem;color:var(--encre)}
.home .adr__nb{font-size:.82rem;color:var(--doux)}

/* cta pro */
.home .cta-pro__box{background:linear-gradient(135deg,#f1eefb,#f6f5fb);border:1px solid var(--bordure2);border-radius:24px;
  padding:44px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.home .cta-pro__box h2{font-size:1.7rem;max-width:20ch}
.home .cta-pro__box p{margin:8px 0 0;color:var(--doux);max-width:48ch}

/* calendrier */
.home .cal-filtres{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:26px}
.home .cal-filtres__lbl{font-weight:700;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--doux)}
.home .theme-pille{display:inline-flex;align-items:center;gap:7px;border:1.5px solid var(--bordure2);background:#fff;border-radius:999px;
  padding:7px 14px;font-family:var(--corps);font-weight:600;font-size:.85rem;color:var(--texte2);cursor:pointer;transition:.15s}
.home .theme-pille:hover{border-color:#d9d2f0}
.home .theme-pille .pt{width:10px;height:10px;border-radius:50%}
.home .theme-pille.actif{color:#fff;border-color:transparent}
.home .cal-arr{margin-left:auto;display:flex;align-items:center;gap:8px}
.home .cal-arr select{font-family:var(--corps);font-size:.9rem;padding:9px 14px;border-radius:999px;border:1.5px solid var(--bordure2);background:#fff;color:var(--texte2);cursor:pointer;outline:0}
.home .cal-layout{display:grid;grid-template-columns:1.55fr 1fr;gap:26px;align-items:start}
.home .cal{border:1px solid var(--bordure2);border-radius:var(--rayon2);padding:18px;background:#fff;box-shadow:var(--ombre2)}
.home .cal__tete{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.home .cal__mois{font-family:var(--titre);font-weight:800;font-size:1.3rem;color:var(--encre);text-transform:capitalize}
.home .cal__nav{display:flex;gap:8px}
.home .cal__nav button{width:38px;height:38px;border-radius:10px;border:1px solid var(--bordure2);background:#fff;cursor:pointer;font-size:1.2rem;line-height:1;color:var(--violet);transition:.15s}
.home .cal__nav button:hover{background:var(--fond-doux);border-color:#d9d2f0}
.home .cal__grille{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.home .cal__jourlbl{text-align:center;font-weight:700;font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;color:var(--doux);padding:4px 0}
.home .cal__case{aspect-ratio:1/1;border-radius:10px;border:1px solid transparent;background:var(--fond-doux);padding:7px;display:flex;flex-direction:column;gap:5px;transition:.15s;min-height:58px}
.home .cal__case--vide{background:transparent}
.home .cal__case--events{cursor:pointer;background:#fff;border-color:var(--bordure2)}
.home .cal__case--events:hover{border-color:var(--violet);box-shadow:var(--ombre2)}
.home .cal__case--actif{border-color:var(--violet);box-shadow:0 0 0 2px rgba(107,79,208,.18)}
.home .cal__num{font-family:var(--titre);font-weight:700;font-size:.9rem;color:var(--texte2)}
.home .cal__case--auj .cal__num{background:var(--degrade);color:#fff;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:.78rem}
.home .cal__pts{display:flex;flex-wrap:wrap;gap:4px;margin-top:auto}
.home .cal__pt{width:9px;height:9px;border-radius:50%;border:0;cursor:pointer;padding:0;transition:.15s}
.home .cal__pt:hover{transform:scale(1.4)}
.home .cal__plus{font-size:.62rem;color:var(--doux);font-weight:700}
.home .cal-panel{position:sticky;top:88px;border:1px solid var(--bordure2);border-radius:var(--rayon2);overflow:hidden;background:#fff;box-shadow:var(--ombre2)}
.home .cal-detail__img{height:120px;position:relative;background-size:cover;background-position:center}
.home .cal-detail__theme{position:absolute;left:14px;bottom:14px;font-family:var(--corps);font-weight:700;font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:#fff;padding:5px 12px;border-radius:999px;display:flex;align-items:center;gap:7px;box-shadow:0 4px 12px rgba(0,0,0,.2)}
.home .cal-detail__theme .pt{width:8px;height:8px;border-radius:50%;background:#fff}
.home .cal-detail__in{padding:18px}
.home .cal-detail__titre{font-family:var(--titre);font-weight:800;font-size:1.28rem;color:var(--encre);line-height:1.14}
.home .cal-detail__meta{margin:13px 0;display:flex;flex-direction:column;gap:9px;font-size:.9rem;color:var(--texte2)}
.home .cal-detail__meta div{display:flex;align-items:center;gap:9px}
.home .cal-detail__desc{font-size:.91rem;color:var(--doux);margin-bottom:16px}
.home .cal-panel__sep{height:1px;background:var(--bordure2)}
.home .cal-avenir{padding:16px 18px}
.home .cal-avenir__t{font-weight:700;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--doux);margin-bottom:12px}
.home .cal-liste{display:flex;flex-direction:column;gap:5px;max-height:286px;overflow-y:auto}
.home .cal-item{display:flex;align-items:center;gap:12px;padding:9px 10px;border-radius:10px;cursor:pointer;transition:.14s;border:1px solid transparent}
.home .cal-item:hover{background:var(--fond-doux)}
.home .cal-item--actif{border-color:var(--violet);background:#f6f3fe}
.home .cal-item__date{flex:none;width:42px;text-align:center}
.home .cal-item__j{font-family:var(--titre);font-weight:800;font-size:1.1rem;color:var(--encre);line-height:1}
.home .cal-item__m{font-size:.6rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--doux)}
.home .cal-item__pt{width:8px;height:8px;border-radius:50%;flex:none}
.home .cal-item__txt{min-width:0}
.home .cal-item__titre{font-weight:600;font-size:.88rem;color:var(--texte2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.home .cal-item__lieu{font-size:.76rem;color:var(--doux)}

/* footer magazine (hors .home) */
.site-pied{background:#191527;color:#cfc9e0;padding:60px 0 30px}
.site-pied__grille{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:34px}
.site-pied .marque{color:#fff;display:inline-block;margin-bottom:12px}
.site-pied__tag{font-size:.9rem;color:#9d97b5;max-width:34ch}
.site-pied h4{color:#fff;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;margin-bottom:16px;font-family:var(--corps)}
.site-pied ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.site-pied ul a{color:#cfc9e0;font-size:.92rem;text-decoration:none}.site-pied ul a:hover{color:#fff}
.site-pied__mini input{width:100%;border:0;border-radius:999px;padding:12px 16px;font-family:var(--corps);margin-bottom:10px;outline:0}
.site-pied__bas{border-top:1px solid #2c2741;margin-top:40px;padding-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.84rem;color:#8b85a6}

@media(max-width:900px){
  .recherche-top{display:none}
  .topbar__in{flex-wrap:wrap;padding:10px 0;gap:6px 18px}
  .topnav{margin-left:0;gap:18px}
  .home .une{grid-template-columns:1fr}
  .home .grille3{grid-template-columns:1fr 1fr}
  .home .adr{grid-template-columns:1fr 1fr}
  .home .cal-layout{grid-template-columns:1fr}
  .home .cal-panel{position:static}
  .home .cal-arr{margin-left:0}
  .site-pied__grille{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .home-sec{padding:46px 0}
  .home .grille3,.home .adr,.site-pied__grille{grid-template-columns:1fr}
  .home .nl,.home .cta-pro__box{padding:28px}
  .home .hero{min-height:64vh}
}
@media(prefers-reduced-motion:reduce){.home *{transition:none!important}}
.home :focus-visible{outline:3px solid var(--violet);outline-offset:2px;border-radius:6px}
