/* =============================================================
   MIST NORMANDIE — DESIGN SYSTEM v2
   Couleurs officielles (charte PDF juin 2024) : bleu #3E4982 · orange #E94E1B
   secondaires #A69DCD #E4E1F2 #EE6F5F #F6A124 · vert santé #6FBF8A (parcimonie)
   Titres Mulish · Corps Inter (substitut web d'Arial). Direction "Frenchy serious 2026" :
   échelle typo harmonisée, dégradés subtils, glassmorphisme, profondeur, micro-interactions.
   ============================================================= */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400..700;1,9..144,400..600&display=swap');

:root {
  /* — Couleurs officielles — */
  --blue:#3E4982; --blue-deep:#2A3265; --blue-soft:#A69DCD; --blue-pale:#E4E1F2; --blue-mist:#F2F0F9;
  --orange:#E94E1B; --orange-soft:#EE6F5F; --orange-pale:#FDEEE9;
  --green:#6FBF8A; --green-pale:#E5F4EB;
  --yellow:#F6A124; --yellow-pale:#FEF3DF;
  --ink:#1F2444; --ink-soft:#4A5076; --ink-muted:#8B91AE; --line:#E7E6F2;
  --bg:#FFFFFF; --bg-soft:#FAF7F2; --bg-mist:#F2F0F9; --cream-2:#F4EFE6;

  /* — Dégradés (modernité 2026) — */
  --grad-brand: linear-gradient(120deg, #3E4982 0%, #5560A8 55%, #6E79C2 100%);
  --grad-accent: linear-gradient(120deg, #E94E1B 0%, #F6A124 100%);
  --grad-mesh:
    radial-gradient(60% 80% at 12% 18%, rgba(166,157,205,.30), transparent 60%),
    radial-gradient(55% 70% at 88% 22%, rgba(233,78,27,.14), transparent 62%),
    radial-gradient(70% 90% at 70% 95%, rgba(111,191,138,.16), transparent 60%);
  --grad-card: linear-gradient(180deg, #FFFFFF 0%, #FBFBFE 100%);

  /* — Verre (glassmorphisme) — */
  --glass-bg: rgba(255,255,255,.62);
  --glass-border: rgba(255,255,255,.7);
  --glass-blur: saturate(160%) blur(16px);

  /* — Typo — */
  --display:'Mulish','Century Gothic','AppleGothic',sans-serif;
  --body:'Inter',Arial,'Helvetica Neue',sans-serif;
  --serif:'Fraunces',Georgia,serif; /* signature éditoriale — gros titres hero + citations */

  /* — Échelle typographique HARMONISÉE (ratio ~1.2, poids cohérents) — */
  --fs-eyebrow:12.5px;
  --fs-h1:clamp(33px, 4.4vw, 52px);
  --fs-h2:clamp(27px, 3.1vw, 38px);
  --fs-h3:clamp(21px, 2.1vw, 27px);
  --fs-h4:19px;
  --fs-lead:clamp(17px, 1.4vw, 19px);
  --fs-body:16.5px;
  --fs-small:13.5px;

  /* — Rayons — */
  --r-s:14px; --r-m:22px; --r-l:30px; --r-xl:42px; --r-pill:999px;

  /* — Ombres multi-couches (profondeur teintée bleu) — */
  --shadow-soft:0 2px 8px -3px rgba(31,36,68,.08), 0 8px 24px -12px rgba(62,73,130,.16);
  --shadow-med:0 4px 12px -4px rgba(31,36,68,.10), 0 20px 48px -18px rgba(62,73,130,.24);
  --shadow-glow:0 18px 50px -20px rgba(62,73,130,.45);
  --shadow-accent:0 14px 34px -14px rgba(233,78,27,.45);

  --maxw:1200px; --gutter:clamp(20px,4vw,48px);
}

/* ===== RESET / BASE ===== */
*,*::before,*::after{box-sizing:border-box}*{margin:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);font-size:var(--fs-body);line-height:1.6;color:var(--ink);background:var(--bg-soft);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}

/* ===== TYPOGRAPHIE (harmonisée) ===== */
h1,h2,h3,h4,h5,h6,.display{font-family:var(--display);color:var(--ink);letter-spacing:-.022em;line-height:1.12}
.h1,h1{font-size:var(--fs-h1);font-weight:800;line-height:1.06;letter-spacing:-.03em}
.h2,h2{font-size:var(--fs-h2);font-weight:800;letter-spacing:-.025em}
.h3,h3{font-size:var(--fs-h3);font-weight:800;letter-spacing:-.02em}
.h4,h4{font-size:var(--fs-h4);font-weight:700}
.h5,h5{font-size:16px;font-weight:700}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:800;font-size:var(--fs-eyebrow);letter-spacing:.16em;text-transform:uppercase;color:var(--orange)}
.eyebrow::before{content:"";width:22px;height:2px;border-radius:2px;background:var(--orange)}
.eyebrow.no-line::before{display:none}
.lead{font-size:var(--fs-lead);line-height:1.55;color:var(--ink-soft);font-weight:400}
.muted{color:var(--ink-muted)}.small{font-size:var(--fs-small)}
/* Signature éditoriale Fraunces — à poser sur les gros titres hero + citations (.display-serif) */
.display-serif{font-family:var(--serif);font-weight:500;letter-spacing:-.02em;line-height:1.04}
.display-serif em,.display-serif .it{font-style:italic;font-weight:400}
/* Chiffre clé */
.stat-num{font-family:var(--display);font-weight:900;font-size:clamp(38px,4.4vw,52px);line-height:1}
.stat-num .plus,.stat-num .unit{color:var(--orange)}
/* Lien-texte (≠ bouton-pilule .btn-link) : pour les liens secondaires inline */
.link-text{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:800;font-size:14px;color:var(--blue);text-decoration:underline;text-decoration-color:rgba(62,73,130,.35);text-underline-offset:4px;text-decoration-thickness:2px;transition:color .2s,text-decoration-color .2s}
.link-text:hover{color:var(--orange);text-decoration-color:var(--orange)}
.text-gradient{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent}
.text-gradient-accent{background:var(--grad-accent);-webkit-background-clip:text;background-clip:text;color:transparent}
/* Mots-clés de titre — surlignage marqueur orange (option A, recommandé) */
.hl{background:linear-gradient(transparent 60%, rgba(233,78,27,.24) 60%);border-radius:3px;padding:0 .05em}
/* Mots-clés de titre — soulignage épais orange (option B) */
.ul-accent{background:linear-gradient(var(--orange),var(--orange)) no-repeat;background-position:0 100%;background-size:100% .14em;padding-bottom:.06em}

/* ===== BOUTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--display);font-weight:800;font-size:15px;padding:13px 24px;border-radius:var(--r-pill);line-height:1;transition:transform .18s cubic-bezier(.4,0,.2,1),box-shadow .25s,background .2s,filter .2s}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--grad-brand);color:#fff;box-shadow:var(--shadow-soft)}
.btn-primary:hover{box-shadow:var(--shadow-glow)}
.btn-accent{background:var(--orange);color:#fff;box-shadow:var(--shadow-accent)}
.btn-accent:hover{background:#d6451a}
.btn-green{background:var(--green);color:#0f3322}
.btn-ghost{background:#fff;color:var(--blue);border:1.5px solid var(--blue-pale);box-shadow:var(--shadow-soft)}
.btn-ghost:hover{border-color:var(--blue)}
.btn-glass{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);color:var(--blue)}
/* "vrai bouton" léger : pilule contournée qui se remplit au survol */
.btn-link{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:800;font-size:14px;color:var(--blue);background:transparent;border:1.6px solid var(--blue-pale);padding:8px 15px;border-radius:var(--r-pill);transition:transform .16s ease,background .2s,color .2s,border-color .2s}
.btn-link:hover{background:var(--blue);color:#fff;border-color:var(--blue);transform:translateY(-2px)}
.btn-sm{padding:9px 16px;font-size:13.5px}.btn-lg{padding:16px 30px;font-size:16px}

/* ===== BADGES / CHIPS ===== */
.badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:800;font-size:12px;padding:5px 12px;border-radius:var(--r-pill)}
.badge-blue{background:var(--blue-pale);color:var(--blue)}
.badge-green{background:var(--green-pale);color:#2f7d54}
.badge-orange{background:var(--orange-pale);color:var(--orange)}
.badge-yellow{background:var(--yellow-pale);color:#9a6200}
.badge-muted{background:var(--bg-mist);color:var(--ink-muted)}
.badge-glass{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);color:var(--blue)}
.badge-dot::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.chip{font-family:var(--display);font-weight:800;font-size:13px;padding:9px 17px;border-radius:var(--r-pill);background:#fff;color:var(--ink-soft);border:1.5px solid var(--line);cursor:pointer;transition:.18s}
.chip:hover{border-color:var(--blue-soft);color:var(--blue)}
.chip.on{background:var(--grad-brand);color:#fff;border-color:transparent;box-shadow:var(--shadow-soft)}

/* ===== CARTES (raffinées) ===== */
.card{position:relative;background:var(--grad-card);border:1px solid var(--line);border-radius:var(--r-l);padding:28px;box-shadow:var(--shadow-soft);transition:transform .22s cubic-bezier(.4,0,.2,1),box-shadow .3s}
/* reflet interne en haut */
.card::before{content:"";position:absolute;inset:0 0 auto 0;height:1px;border-radius:var(--r-l) var(--r-l) 0 0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.9),transparent)}
.card-hover:hover{transform:translateY(-6px);box-shadow:var(--shadow-med)}
.card-blue{background:var(--grad-brand);border-color:transparent;color:#fff}
.card-blue::before{background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent)}
.card-mist{background:var(--bg-mist);border-color:transparent}
/* bordure dégradée (technique robuste padding-box / border-box) */
.card-gradient{position:relative;border:1.5px solid transparent;border-radius:var(--r-l);padding:28px;box-shadow:var(--shadow-soft);background:linear-gradient(var(--bg),var(--bg)) padding-box,linear-gradient(135deg,var(--blue-soft),var(--orange-soft)) border-box}
/* verre */
.glass{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--r-l);box-shadow:var(--shadow-med)}
/* conteneur d'icône */
.icon-box{width:54px;height:54px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;background:var(--blue-pale);color:var(--blue);box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
.icon-box.accent{background:var(--orange-pale);color:var(--orange)}
.icon-box.green{background:var(--green-pale);color:#2f7d54}
.icon-box.grad{background:var(--grad-brand);color:#fff}

/* ===== CARTE ÉVÉNEMENT (image + encart date superposé) ===== */
.ecard{padding:0;overflow:hidden;display:flex;flex-direction:column}
.ecard .ecard-media{position:relative;aspect-ratio:16/10;background:var(--blue-mist);display:flex;align-items:center;justify-content:center;color:var(--blue-soft);border-radius:var(--r-l) var(--r-l) 0 0;overflow:hidden}
.ecard .ecard-date{position:absolute;top:14px;right:14px;background:#fff;border-radius:14px;padding:9px 13px;text-align:center;line-height:1.05;font-family:var(--display);box-shadow:var(--shadow-soft);min-width:64px}
.ecard .ecard-date .dow{display:block;font-size:11px;font-weight:700;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.06em}
.ecard .ecard-date .day{display:block;font-size:26px;font-weight:900;color:var(--ink);margin:2px 0}
.ecard .ecard-date .moy{display:block;font-size:11px;font-weight:700;color:var(--ink-muted)}
.ecard .ecard-body{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1}
.ecard .ecard-loc{font-size:14px;font-weight:700;color:var(--ink-soft);margin-top:5px}
.ecard .ecard-foot{margin-top:auto;padding-top:16px}

/* ===== FORMULAIRES ===== */
.field{display:flex;flex-direction:column;gap:7px}
.label{font-family:var(--display);font-weight:700;font-size:12.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft)}
.input,.select,.textarea{width:100%;font-family:var(--body);font-size:15px;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:var(--r-s);padding:13px 16px;transition:border-color .2s,box-shadow .2s}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 4px var(--blue-pale)}
.textarea{min-height:110px;resize:vertical}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234A5076' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}

/* ===== SECTIONS / HELPERS ===== */
.section{padding:clamp(48px,7vw,96px) 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:36px;flex-wrap:wrap}
.ph{background:repeating-linear-gradient(45deg,#eceaf6,#eceaf6 10px,#e4e1f2 10px,#e4e1f2 20px);border-radius:var(--r-m);display:flex;align-items:center;justify-content:center;color:#9a93c4;font-weight:700;font-size:13px;border:1px dashed #c9c4e6}
.mesh{background:var(--grad-mesh),var(--bg)}
.section-cream{background:var(--cream-2)}
.section-blue{background:radial-gradient(60% 80% at 12% 12%,rgba(166,157,205,.30),transparent 60%),radial-gradient(55% 70% at 92% 28%,rgba(62,73,130,.10),transparent 62%),var(--blue-mist)}
/* Section foncée (façon header Événement : navy + halos) — fond clair par défaut, foncé en option */
.section-dark,.cta-band{position:relative;overflow:hidden;color:#fff;background:radial-gradient(55% 90% at 85% 15%,rgba(111,191,138,.22),transparent 60%),radial-gradient(50% 80% at 8% 95%,rgba(233,78,27,.18),transparent 60%),var(--grad-brand)}
.section-dark .lead,.cta-band .lead,.card-blue .lead{color:#dfe1f3}
.section-dark .eyebrow,.cta-band .eyebrow,.card-blue .eyebrow{color:#ffd9b0}
/* Texte secondaire lisible sur fonds foncés (corrige le gris .muted sur bleu/dégradé) */
.section-dark .muted,.cta-band .muted,.card-blue .muted{color:#cfd3ee}
.section-dark .small.muted,.cta-band .small.muted,.card-blue .small.muted{color:#cfd3ee}
.grid{display:grid;gap:22px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-asym{grid-template-columns:1.5fr 1fr}

/* ===== LOGO ===== */
.logo-mark{height:42px;width:auto}
.site-logo{height:52px;width:auto;display:block}
.logo-lockup{display:inline-flex;align-items:center;gap:12px;flex-shrink:0}
.logo-lockup .txt{font-family:var(--display);font-weight:900;font-size:19px;color:var(--blue);letter-spacing:-.02em;line-height:1.05;white-space:nowrap}
.logo-lockup .txt small{display:block;font-family:var(--body);font-weight:600;font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);margin-top:3px}

/* ===== CHROME PARTAGÉ (topbar / header / footer) ===== */
.topbar{background:var(--blue-deep);color:#dfe1f3;font-size:13px}
.topbar .container{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:40px;flex-wrap:wrap;max-width:1360px;padding-left:30px;padding-right:30px}
.topbar a{color:#cfd1e8}.topbar a:hover{color:#fff}
.topbar .dot{width:7px;height:7px;border-radius:50%;background:var(--green);display:inline-block;margin-right:7px}
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--line)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:78px;max-width:1360px;padding-left:30px;padding-right:30px}
.nav-links{display:flex;align-items:center;gap:2px;font-family:var(--display);font-weight:700;font-size:15.5px}
.nav-item{position:relative;display:flex;align-items:center}
.nav-top{position:relative;display:inline-flex;align-items:center;gap:4px;color:var(--ink);padding:9px 13px;border-radius:var(--r-pill);white-space:nowrap;transition:color .16s,background .16s}
.nav-top:hover{color:var(--blue);background:var(--blue-mist)}
.nav-top .caret{display:none}
.nav-item:hover .nav-top .caret,.nav-item:focus-within .nav-top .caret{transform:rotate(180deg);opacity:.9}
.nav-top[aria-current]{color:var(--blue)}
.nav-top[aria-current]::after{content:"";position:absolute;left:15px;right:15px;bottom:5px;height:2.5px;background:var(--orange);border-radius:2px}
.nav-toggle,.nav-cta-mobile{display:none}
.nav-right{display:flex;align-items:center;gap:12px}

/* ----- Méga-menu (desktop : panneaux flottants au survol/focus) ----- */
.mega{position:absolute;top:calc(100% + 16px);left:0;width:max-content;background:#fff;border:1px solid var(--line);border-radius:var(--r-l);box-shadow:0 26px 64px -20px rgba(35,40,80,.34),0 8px 24px -14px rgba(35,40,80,.22);opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .2s ease,transform .22s cubic-bezier(.2,.7,.3,1),visibility .2s;z-index:60}
.mega.mega-right{left:auto;right:0}
.mega::before{content:"";position:absolute;top:-16px;left:0;right:0;height:16px}
.mega::after{content:"";position:absolute;top:-6px;left:36px;width:12px;height:12px;background:#fff;border-left:1px solid var(--line);border-top:1px solid var(--line);transform:rotate(45deg)}
.mega.mega-right::after{left:auto;right:36px}
.nav-item:hover .mega,.nav-item:focus-within .mega{opacity:1;visibility:visible;transform:translateY(0)}
.mega-inner{display:flex;gap:16px;padding:16px}
.mega-cols{display:grid;grid-template-columns:repeat(2,minmax(216px,1fr));gap:3px;align-content:start}
.mega-link{display:flex;gap:12px;align-items:flex-start;padding:11px 12px;border-radius:14px;transition:background .15s}
.mega-link:hover{background:var(--blue-mist)}
.mega-ico{flex-shrink:0;width:38px;height:38px;border-radius:11px;background:var(--blue-mist);color:var(--blue);display:flex;align-items:center;justify-content:center;transition:.16s}
.mega-ico svg{width:19px;height:19px}
.mega-link:hover .mega-ico{background:var(--blue);color:#fff;transform:translateY(-1px)}
.mega-txt{min-width:0}
.mega-txt strong{display:block;font-weight:800;font-size:14.5px;color:var(--ink);line-height:1.2}
.mega-txt small{display:block;font-family:var(--body);font-weight:500;font-size:12.5px;color:var(--ink-muted);margin-top:3px;line-height:1.34}
.mega-feat{display:flex;flex-direction:column;width:214px;flex-shrink:0;padding:20px;border-radius:16px;background:var(--grad-brand);color:#fff;overflow:hidden;position:relative}
.mega-feat::after{content:"";position:absolute;right:-34px;bottom:-34px;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.10)}
.mega-feat-eye{font-family:var(--body);font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.09em;color:#ffd9b0}
.mega-feat strong{font-size:18px;line-height:1.18;margin:9px 0 7px}
.mega-feat small{font-family:var(--body);font-weight:500;font-size:13px;color:#e9eafb;flex-grow:1;line-height:1.45}
.mega-feat-go{margin-top:16px;font-weight:800;font-size:13.5px;color:#fff;display:inline-flex;gap:6px;align-items:center}
.mega-feat-go span{transition:transform .18s}
.mega-feat:hover .mega-feat-go span{transform:translateX(4px)}
.nav-burger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer}
.nav-burger i{width:24px;height:2.5px;background:var(--blue);border-radius:2px;transition:.2s}
.site-footer{background:var(--blue-deep);color:#cfd1e8;padding:56px 0 26px;font-size:14px}
.site-footer .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:36px}
.site-footer h4{font-family:var(--display);color:#fff;font-size:13px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:14px}
.site-footer a{display:block;color:#bcbedd;margin-bottom:9px}.site-footer a:hover{color:#fff}
.site-footer .bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:18px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:12.5px;color:#9a9cc4}

/* ===== FAQ ACCORDÉON (composant uniforme) ===== */
.faq{display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--grad-card);border:1px solid var(--line);border-radius:var(--r-m);overflow:hidden;transition:box-shadow .25s}
.faq-item[open]{box-shadow:var(--shadow-soft)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;font-family:var(--display);font-weight:800;font-size:16px;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-family:var(--display);font-weight:800;font-size:22px;color:var(--orange);transition:transform .2s}
.faq-item[open] summary::after{content:"−"}
.faq-item .faq-a{padding:0 22px 20px;color:var(--ink-soft);font-size:15px;line-height:1.6}

/* ===== RESPONSIVE (mobile-first soigné) ===== */
/* ----- Nav tablette + mobile : tiroir plein écran + accordéons (<=1199px) ----- */
@media (max-width:1199px){
  .nav-burger{display:flex}
  .site-header .nav-right .btn-primary{display:none}
  .nav-links{position:fixed;left:0;right:0;top:74px;flex-direction:column;align-items:stretch;gap:0;background:#fff;padding:8px 20px 24px;box-shadow:var(--shadow-med);border-bottom:1px solid var(--line);overflow-y:auto;-webkit-overflow-scrolling:touch;display:none}
  .nav-links.open{display:flex}
  .nav-item{position:relative;display:block;width:100%;border-bottom:1px solid var(--line)}
  .nav-top{display:block;padding:15px 54px 15px 6px;font-size:16.5px;border-radius:0}
  .nav-top:hover{background:none}
  .nav-top .caret{display:none}
  .nav-top[aria-current]::after{left:6px;right:auto;width:22px;bottom:9px}
  .nav-toggle{position:absolute;top:6px;right:0;display:flex;align-items:center;justify-content:center;width:46px;height:46px;background:none;border:none;color:var(--ink-soft);cursor:pointer;border-radius:10px}
  .nav-toggle:hover{background:var(--blue-mist);color:var(--blue)}
  .nav-toggle svg{width:20px;height:20px;transition:transform .25s}
  .nav-item.open .nav-toggle svg{transform:rotate(180deg)}
  .mega{position:static;width:auto;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;border-radius:0;background:none;max-height:0;overflow:hidden;transition:max-height .32s ease;z-index:auto}
  .mega::before,.mega::after{display:none}
  .nav-item.open .mega{max-height:1600px}
  .mega-inner{flex-direction:column;gap:8px;padding:2px 0 14px}
  .mega-cols{grid-template-columns:1fr;gap:2px}
  .mega-link{padding:10px}
  .mega-ico{width:34px;height:34px}
  .mega-feat{width:100%}
  .nav-cta-mobile{display:block;width:100%;text-align:center;margin-top:18px}
  body.nav-open{overflow:hidden}
  .nav-burger.open i:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .nav-burger.open i:nth-child(2){opacity:0}
  .nav-burger.open i:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
}
@media (max-width:880px){
  .site-footer .cols{grid-template-columns:1fr 1fr}
}
@media (min-width:881px){ .hide-desktop{display:none!important} }
@media (max-width:900px){
  .grid-3,.grid-4{grid-template-columns:1fr 1fr}
  .hide-mobile{display:none!important}
}
@media (max-width:600px){
  :root{--fs-body:16px}
  .grid-2,.grid-3,.grid-4,.grid-asym{grid-template-columns:1fr}
  .card,.card-gradient{padding:22px}
  .btn{width:100%}
  .btn.btn-auto{width:auto}
}

/* ===== CARROUSEL (hero actus, etc.) ===== */
.carousel-slides{position:relative}
.carousel-slides>*{display:none}
.carousel-slides>.is-active{display:block;animation:carFade .5s ease}
@keyframes carFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.carousel-dots{display:flex;gap:9px;align-items:center;justify-content:center;margin-top:18px}
.carousel-dot{position:relative;width:9px;height:9px;padding:0;border:0;border-radius:var(--r-pill);background:var(--blue-pale);cursor:pointer;overflow:hidden;transition:width .35s ease,background .2s}
.carousel-dot:hover{background:var(--blue-soft)}
.carousel-dot.is-active{width:34px;background:var(--blue-pale)}
.carousel-dot.is-active::after{content:"";position:absolute;inset:0;border-radius:inherit;background:var(--orange);transform-origin:left;transform:scaleX(0);animation:dotFill 5500ms linear forwards}
@keyframes dotFill{to{transform:scaleX(1)}}
.carousel-arrow{width:32px;height:32px;padding:0;border-radius:var(--r-pill);background:#fff;border:1.5px solid var(--line);color:var(--blue);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .16s,background .16s}
.carousel-arrow:hover{border-color:var(--blue);background:var(--blue-mist)}
.carousel-arrow svg{width:16px;height:16px}

/* ===== Galerie « MIST sur le terrain » ===== */
.terrain-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.terrain-item{position:relative;margin:0;border-radius:var(--r-l);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow-soft)}
.terrain-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s ease}
.terrain-item:hover img{transform:scale(1.06)}
.terrain-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:32px 16px 14px;color:#fff;font-family:var(--display);font-weight:800;font-size:14.5px;background:linear-gradient(transparent,rgba(31,36,68,.82));display:flex;align-items:center;gap:8px}
.terrain-item figcaption::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--orange);flex-shrink:0}
@media(max-width:900px){.terrain-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.terrain-grid{grid-template-columns:1fr}}
/* Carte actu en hero */
.hero-news{max-width:480px;width:100%;margin-left:auto}
.hero-news .news-card{overflow:hidden;padding:0}
.hero-news .news-media{aspect-ratio:16/10;border-radius:0;margin:0;border:0}
.hero-news .news-body{padding:20px 22px 22px}

/* ===== CHATBOT (bouton flottant) ===== */
.chatbot-fab{position:fixed;right:clamp(16px,3vw,26px);bottom:clamp(16px,3vw,26px);z-index:80;width:60px;height:60px;border-radius:var(--r-pill);background:var(--grad-brand);color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow-glow);cursor:pointer;transition:transform .2s,box-shadow .25s}
.chatbot-fab:hover{transform:translateY(-3px) scale(1.05)}
.chatbot-fab svg{width:26px;height:26px}
.chatbot-fab::after{content:"";position:absolute;inset:-5px;border-radius:inherit;border:2px solid var(--orange-soft);opacity:.55;animation:cfPulse 2.6s ease-out infinite;pointer-events:none}
@keyframes cfPulse{0%{transform:scale(1);opacity:.55}70%{transform:scale(1.28);opacity:0}100%{opacity:0}}
@media (max-width:600px){.chatbot-fab{width:54px;height:54px}.chatbot-fab svg{width:24px;height:24px}}


/* ===== Galerie photo réutilisable ([data-gallery]) ===== */
.gallery-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:30px;flex-wrap:wrap}
.gallery-track{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding-bottom:8px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.gallery-track::-webkit-scrollbar{display:none}
.gallery-card{flex:0 0 clamp(238px,30%,316px);scroll-snap-align:start;position:relative;margin:0;border-radius:var(--r-l);overflow:hidden;aspect-ratio:1/1;box-shadow:var(--shadow-soft);background:#ece9f4}
.gallery-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.gallery-card:hover img{transform:scale(1.05)}
.gallery-card figcaption{position:absolute;left:0;right:0;bottom:0;padding:40px 16px 14px;color:#fff;font-family:'Mulish',Inter,sans-serif;font-weight:700;font-size:13.5px;line-height:1.3;background:linear-gradient(transparent,rgba(31,36,68,.86))}
.gallery-controls{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-top:24px}
.gallery-dots{display:flex;gap:8px;align-items:center}
.gallery-dot{width:9px;height:9px;padding:0;border:none;border-radius:50%;background:#cfd3ea;cursor:pointer;transition:width .25s,background .25s}
.gallery-dot.is-active{background:var(--blue);width:28px;border-radius:5px}
.gallery-arrows{display:flex;gap:10px}
.gallery-arrow{width:46px;height:46px;border-radius:50%;border:1.5px solid var(--blue);background:#fff;color:var(--blue);display:grid;place-items:center;cursor:pointer;transition:background .2s,color .2s}
.gallery-arrow:hover{background:var(--blue);color:#fff}
@media(max-width:600px){.gallery-card{flex-basis:80%}.gallery-arrow{width:42px;height:42px}}


/* ===== Page événement (détail) ===== */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--ink-muted);font-weight:600}
.breadcrumb a{color:var(--ink-muted);text-decoration:none}
.breadcrumb a:hover{color:var(--blue)}
.breadcrumb .sep{opacity:.5}
.rule{border:none;border-top:1px solid var(--line);margin:24px 0}

.countdown{display:flex;gap:12px;flex-wrap:wrap;margin:26px 0 22px}
.cd-box{min-width:74px;padding:12px 10px;background:#fff;border:1px solid var(--line);border-radius:var(--r-m);text-align:center;box-shadow:var(--shadow-soft)}
.cd-num{display:block;font-family:var(--display);font-weight:800;font-size:26px;line-height:1;color:var(--blue);font-variant-numeric:tabular-nums}
.cd-lbl{display:block;margin-top:5px;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-muted);font-weight:700}

.event-meta{display:flex;flex-wrap:wrap;gap:12px 22px;margin:4px 0 16px}
.event-meta .em{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--ink-soft);font-weight:600}
.event-meta .em svg{width:18px;height:18px;color:var(--blue);flex-shrink:0}
.event-meta .em strong{color:var(--ink);font-weight:800}
.event-meta strong.is-full{color:#C0392B}

.event-notice{font-size:14px;color:var(--ink-muted);margin:0 0 18px;font-style:italic}
.is-full .event-notice{color:#C0392B;font-style:normal;font-weight:600}
.event-cta{display:flex;gap:12px;flex-wrap:wrap}
.event-hero-img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--r-xl);box-shadow:var(--shadow-med);display:block}
.event-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.event-list li{position:relative;padding-left:28px;color:var(--ink-soft)}
.event-list li::before{content:"";position:absolute;left:0;top:7px;width:14px;height:14px;border-radius:50%;background:var(--green-pale);box-shadow:inset 0 0 0 2px var(--green)}

/* Modale d'inscription */
.modal{position:fixed;inset:0;z-index:1000;display:none;align-items:flex-start;justify-content:center;padding:5vh 18px;background:rgba(28,32,58,.55);backdrop-filter:blur(3px);overflow-y:auto}
.modal.is-open{display:flex}
.modal-card{position:relative;width:100%;max-width:560px;background:#fff;border-radius:var(--r-xl);box-shadow:var(--shadow-med);padding:clamp(24px,4vw,38px);animation:modalIn .25s ease}
@keyframes modalIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.modal-x{position:absolute;top:14px;right:14px;width:38px;height:38px;border:none;border-radius:50%;background:var(--bg-soft);color:var(--ink);font-size:22px;line-height:1;cursor:pointer;transition:background .2s}
.modal-x:hover{background:var(--line)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.modal-success{text-align:center;padding:8px 4px}
.success-check{width:64px;height:64px;margin:0 auto;border-radius:50%;background:var(--green-pale);color:var(--green);display:grid;place-items:center}
.success-check svg{width:30px;height:30px}
.event-recap{display:flex;flex-direction:column;gap:4px;text-align:left;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r-m);padding:16px 18px;margin-bottom:18px;font-size:14px;color:var(--ink-soft)}
.event-recap strong{color:var(--ink)}
.modal-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}

/* Bascule de démo (maquette uniquement) */
.demo-toggle{position:fixed;left:18px;bottom:18px;z-index:900;background:var(--ink);color:#fff;border:none;border-radius:var(--r-pill);padding:10px 16px;font-size:13px;font-weight:700;cursor:pointer;box-shadow:var(--shadow-med);opacity:.9;transition:opacity .2s}
.demo-toggle:hover{opacity:1}
@media(max-width:560px){.cd-box{min-width:0;flex:1}.demo-toggle{left:10px;bottom:10px;font-size:12px;padding:8px 12px}}


/* ===== Médecins du centre ===== */
.doctors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(252px,1fr));gap:16px}
.doctor-card{display:flex;gap:15px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r-l);padding:15px 17px;box-shadow:var(--shadow-soft);transition:box-shadow .2s,transform .2s}
.doctor-card:hover{box-shadow:var(--shadow-med);transform:translateY(-2px)}
.doctor-avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;flex-shrink:0;display:block;background:#ECE7F6}
.doctor-info{min-width:0}
.doctor-name{font-family:var(--display);font-weight:800;font-size:15.5px;color:var(--ink);margin:0;line-height:1.2}
.doctor-meta{font-size:13px;color:var(--ink-muted);margin:4px 0 5px}
.doctor-tel{font-size:14.5px;font-weight:800;color:var(--blue);text-decoration:none}
.doctor-tel:hover{color:var(--orange)}


/* ===== Page détail offre d'emploi ===== */
.offer-hero{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-top:14px}
.offer-layout{display:grid;grid-template-columns:1fr 340px;gap:48px;align-items:start}
.offer-main > h2:first-child{margin-top:0}
.offer-main p{line-height:1.7}
.offer-aside{position:sticky;top:96px}
.offer-card{display:flex;flex-direction:column;gap:6px}
.info-list{display:flex;flex-direction:column;margin-bottom:8px}
.info-item{display:flex;flex-direction:column;gap:2px;padding:12px 0;border-bottom:1px solid var(--line)}
.info-item:first-child{padding-top:0}
.info-label{font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-muted);font-weight:700}
.info-val{font-size:14.5px;color:var(--ink);font-weight:600;line-height:1.4}
.share-row{display:flex;align-items:center;gap:10px;margin-top:18px}
.share-label{font-size:12.5px;color:var(--ink-muted);font-weight:700}
.share-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--blue);transition:background .2s,color .2s,border-color .2s}
.share-btn svg{width:16px;height:16px}
.share-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.taleez-frame{position:relative;width:100%;background:#fff;border:1px solid var(--line);border-radius:var(--r-l);overflow:hidden;box-shadow:var(--shadow-soft)}
.taleez-frame iframe{width:100%;height:760px;border:0;display:block}
@media(max-width:860px){.offer-layout{grid-template-columns:1fr}.offer-aside{position:static}.taleez-frame iframe{height:680px}}
.taleez-frame{min-height:420px}
.taleez-frame::before{content:"Formulaire de candidature sécurisé — propulsé par Taleez";position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:24px;color:var(--ink-muted);font-size:14px;z-index:0}
.taleez-frame iframe{position:relative;z-index:1;background:transparent}

/* ===== Trouver une MIST (catalogue + carte) ===== */
.finder-filters{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px;max-width:780px}
.finder-filters .select{min-width:170px}
.finder-filters .f-search{flex:1;min-width:230px}
.finder-layout{display:grid;grid-template-columns:1.15fr .85fr;gap:32px;align-items:start}
.finder-map-wrap{position:sticky;top:90px}
#finder-map{height:clamp(440px,72vh,640px);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-soft);z-index:1}
.finder-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.finder-card{display:flex;flex-direction:column;gap:8px;padding:18px;background:#fff;border:1px solid var(--line);border-radius:var(--r-l);text-decoration:none;transition:box-shadow .2s,transform .2s,border-color .2s}
.finder-card:hover{box-shadow:var(--shadow-soft);transform:translateY(-2px);border-color:var(--blue)}
.finder-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.finder-card-top h3{font-family:var(--display);font-size:15.5px;font-weight:800;color:var(--ink);margin:0;line-height:1.25}
.finder-addr{font-size:13px;color:var(--ink-muted);margin:0;flex-grow:1;line-height:1.45}
.finder-link{font-size:13px;font-weight:800;color:var(--orange)}
@media(max-width:880px){.finder-layout{grid-template-columns:1fr}.finder-map-wrap{position:static;order:-1;margin-bottom:6px}#finder-map{height:340px}.finder-grid{grid-template-columns:1fr}}


/* ===== Finder v2 : filtres en ligne (PC) + cartes horizontales ===== */
.finder-filters{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.finder-filters .input,.finder-filters .select{width:auto}
.finder-filters .f-search{flex:1 1 240px;min-width:220px}
.finder-filters .select{flex:0 0 auto;min-width:185px}
.finder-grid{display:flex;flex-direction:column;gap:14px}
.finder-card{display:flex;background:#fff;border:1px solid var(--line);border-radius:var(--r-l);overflow:hidden;transition:box-shadow .2s,border-color .2s}
.finder-card:hover{box-shadow:var(--shadow-soft);border-color:var(--blue)}
.finder-thumb-link{flex:0 0 36%;max-width:210px;display:block}
.finder-thumb{width:100%;height:100%;min-height:158px;object-fit:cover;display:block}
.finder-body{flex:1;min-width:0;padding:15px 18px;display:flex;flex-direction:column;gap:7px}
.finder-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.finder-card-top h3{font-family:var(--display);font-size:15.5px;font-weight:800;margin:0;line-height:1.25}
.finder-card-top h3 a{color:var(--ink);text-decoration:none}
.finder-card-top h3 a:hover{color:var(--blue)}
.finder-addr{font-size:13px;color:var(--ink-muted);margin:0;line-height:1.45}
.finder-tel{font-size:13.5px;color:var(--blue);font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:6px;width:fit-content}
.finder-tel:hover{text-decoration:underline}
.finder-actions{display:flex;gap:18px;align-items:center;margin-top:auto;padding-top:4px}
.finder-link{font-size:13px;font-weight:800;color:var(--orange);text-decoration:none}
.finder-itin{font-size:13px;font-weight:700;color:var(--ink-soft);text-decoration:none;display:inline-flex;align-items:center;gap:5px}
.finder-itin:hover{color:var(--blue)}
@media(max-width:520px){.finder-card{flex-direction:column}.finder-thumb-link{flex:none;max-width:none}.finder-thumb{min-height:160px}}

/* ===== Partage offre v2 ===== */
.share-block{margin-top:18px}
.share-block .share-label{display:block;margin-bottom:9px}
.share-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:0}
.share-btn .ic-ok{display:none}
.share-btn.is-ok{background:var(--green);color:#fff;border-color:var(--green)}
.share-btn.is-ok .ic-d{display:none}
.share-btn.is-ok .ic-ok{display:block}

/* ===== Finder v3 : catalogue sur 2 colonnes, cartes verticales ===== */
.finder-layout{grid-template-columns:1.35fr .85fr}
.finder-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.finder-card{flex-direction:column}
.finder-thumb-link{flex:none;max-width:none;width:100%}
.finder-thumb{aspect-ratio:16/10;min-height:0;height:auto}
.finder-body{padding:14px 16px}
@media(max-width:900px){
  .finder-layout{grid-template-columns:1fr}
  .finder-map-wrap{position:static;order:-1;margin-bottom:8px}
  #finder-map{height:340px}
  .finder-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){.finder-grid{grid-template-columns:1fr}}


/* ===== Trouver ma MIST v4 : carte + villes-boutons (clic = encart) — retour 2A ===== */
.finder-territory{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:start}
#finder-map{height:clamp(380px,52vw,540px);min-height:380px;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-soft);z-index:1}
.finder-side{display:flex;flex-direction:column;gap:18px}
.finder-search{position:relative;display:flex;align-items:center}
.finder-search svg{position:absolute;left:16px;width:18px;height:18px;color:var(--ink-muted);pointer-events:none}
.finder-search-input{width:100%;font-family:var(--body);font-size:15px;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:var(--r-pill);padding:12px 18px 12px 44px;transition:border-color .2s,box-shadow .2s}
.finder-search-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 4px var(--blue-pale)}
.finder-group-title{margin:0 0 12px;color:var(--blue)}
.finder-pills{display:flex;gap:9px;flex-wrap:wrap}
.finder-pill{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:800;font-size:13px;padding:8px 15px;border-radius:var(--r-pill);background:var(--blue-pale);color:var(--blue);border:1.5px solid transparent;cursor:pointer;transition:background .16s,color .16s,transform .16s,box-shadow .16s}
.finder-pill:hover,.finder-pill:focus-visible{background:var(--blue);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-soft);outline:none}
.finder-pill.is-active{background:var(--orange);color:#fff;box-shadow:var(--shadow-accent);transform:none}
.finder-pill.is-siege::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--orange);flex-shrink:0}
.finder-pill:hover.is-siege::before,.finder-pill.is-active.is-siege::before{background:#fff}
.finder-side-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.finder-legend{text-align:center;margin-top:20px}
/* Encart riche (photo + adresse + actions) dans la popup Leaflet */
.finder-pop{font-family:var(--display);min-width:200px}
.finder-pop img{width:100%;height:108px;object-fit:cover;border-radius:12px;margin-bottom:9px;display:block;background:#ece9f4}
.finder-pop .fp-name{color:var(--blue);font-size:14.5px;font-weight:800;display:block;line-height:1.2}
.finder-pop .fp-addr{color:var(--ink-soft);font-family:var(--body);font-size:12.5px;display:block;margin:4px 0 6px;line-height:1.42}
.finder-pop .fp-tel{color:var(--blue);font-weight:800;font-size:13px;text-decoration:none;display:block;margin-bottom:8px}
.finder-pop .fp-tel:hover{color:var(--orange)}
.finder-pop .fp-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.finder-pop .fp-go{color:var(--orange);font-weight:800;font-size:12.5px;text-decoration:none}
.finder-pop .fp-itin{color:var(--ink-soft);font-weight:700;font-size:12.5px;text-decoration:none;display:inline-flex;align-items:center;gap:5px}
.finder-pop .fp-itin:hover,.finder-pop .fp-go:hover{text-decoration:underline}
/* Tag ville au survol (tooltip Leaflet) */
.leaflet-tooltip.finder-tip{background:#fff;color:var(--blue);border:1px solid var(--line);font-family:var(--display);font-weight:800;font-size:12px;padding:4px 10px;border-radius:9px;box-shadow:var(--shadow-soft)}
.leaflet-tooltip.finder-tip.leaflet-tooltip-top::before{border-top-color:#fff}
@media(max-width:900px){
  .finder-territory{grid-template-columns:1fr;gap:22px}
  #finder-map{order:-1;height:clamp(300px,62vw,380px);min-height:300px}
}


/* ===== Recherche site (loupe header + overlay « palette ») ===== */
.nav-search-btn{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:var(--r-pill);background:var(--blue-mist);color:var(--blue);border:1.5px solid transparent;cursor:pointer;transition:background .16s,color .16s,border-color .16s,transform .16s;flex-shrink:0}
.nav-search-btn:hover{background:#fff;border-color:var(--blue-pale);color:var(--orange);transform:translateY(-1px)}
.nav-search-btn svg{width:19px;height:19px}
.site-search{position:fixed;inset:0;z-index:1100;display:flex;align-items:flex-start;justify-content:center;padding:11vh 18px 24px;background:rgba(28,32,58,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.site-search[hidden]{display:none}
.site-search-panel{width:100%;max-width:580px;background:#fff;border-radius:var(--r-l);box-shadow:0 30px 80px -24px rgba(28,32,58,.55);overflow:hidden;animation:ssIn .22s ease}
@keyframes ssIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
.site-search-field{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line)}
.site-search-field>svg{width:21px;height:21px;color:var(--ink-muted);flex-shrink:0}
.site-search-field input{flex:1;min-width:0;border:none;outline:none;background:none;font-family:var(--body);font-size:17px;color:var(--ink)}
.site-search-field input::placeholder{color:var(--ink-muted)}
.site-search-esc{flex-shrink:0;font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-muted);background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;padding:6px 10px;cursor:pointer;transition:background .15s,color .15s}
.site-search-esc:hover{background:var(--line);color:var(--ink)}
.site-search-results{max-height:min(56vh,420px);overflow-y:auto;padding:8px}
.site-search-item{display:flex;align-items:baseline;justify-content:space-between;gap:14px;padding:12px 14px;border-radius:14px;text-decoration:none;transition:background .14s}
.site-search-item:hover,.site-search-item.is-active{background:var(--blue-mist)}
.site-search-item .ss-t{font-family:var(--display);font-weight:700;font-size:15px;color:var(--ink);line-height:1.25}
.site-search-item:hover .ss-t,.site-search-item.is-active .ss-t{color:var(--blue)}
.site-search-item .ss-s{flex-shrink:0;font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-muted)}
.site-search-empty{padding:22px 16px;color:var(--ink-muted);font-size:14px;text-align:center}
body.search-open{overflow:hidden}
@media(max-width:1199px){
  .site-header .nav-right .nav-search-btn{display:inline-flex}
  .site-search{padding-top:8vh}
}
@media(max-width:600px){
  .nav-search-btn{width:40px;height:40px}
  .site-search-field input{font-size:16px}
}


/* ===== Frise chronologique (Qui sommes-nous) ===== */
.timeline{position:relative;margin:0;padding:0;list-style:none}
.timeline::before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:linear-gradient(var(--blue-soft),var(--orange-soft))}
.tl-item{position:relative;padding:0 0 24px 34px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{content:"";position:absolute;left:1px;top:2px;width:15px;height:15px;border-radius:50%;background:#fff;border:3px solid var(--blue)}
.tl-item.is-now::before{border-color:var(--orange)}
.tl-year{font-family:var(--display);font-weight:900;font-size:15px;color:var(--orange);letter-spacing:.01em}
.tl-title{font-family:var(--display);font-weight:800;font-size:16.5px;color:var(--ink);margin:2px 0 5px;line-height:1.2}
.tl-text{font-size:14px;color:var(--ink-soft);line-height:1.5;margin:0}

/* ===== Boutons-villes synchronisés à la carte (mist-normandie #26) ===== */
a.badge[data-centre]{cursor:pointer;transition:background .16s,color .16s,transform .16s,box-shadow .16s}
a.badge[data-centre]:hover,a.badge[data-centre]:focus-visible{background:var(--blue);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-soft);outline:none}
a.badge.badge-blue[data-centre].is-active{background:var(--orange);color:#fff;box-shadow:var(--shadow-accent);transform:none}
