/* =================================================================
   Centre d'Ophtalmologie de Sartrouville, design system
   Codes et couleurs MedKey. Polices auto-hébergées (RGPD), WCAG AA+
   ================================================================= */

/* ---------- Fonts (self-hosted) : Inter + Fraunces (MedKey) ---------- */
@font-face{font-family:"Inter";src:url("../fonts/inter-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:"Inter";src:url("../fonts/inter-400-ext.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap;unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:"Inter";src:url("../fonts/inter-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:"Inter";src:url("../fonts/inter-500-ext.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:"Inter";src:url("../fonts/inter-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:"Inter";src:url("../fonts/inter-600-ext.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:"Inter";src:url("../fonts/inter-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:"Inter";src:url("../fonts/inter-700-ext.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap;unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-500-ext.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-600-ext.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}

/* ---------- Tokens (palette MedKey) ---------- */
:root{
  --bg:#ffffff;
  --surface:#f7f8fa;
  --surface-2:#f1f3f6;
  --surface-deep:#233458;
  --surface-deep-2:#1a2540;
  --ink:#1a2230;
  --ink-soft:#5e6b7e;
  --ink-on-deep:#f3f6fb;
  --ink-on-deep-soft:#b7c2d6;
  --primary:#3f63a8;
  --primary-strong:#345389;
  --primary-tint:#e9eef7;
  --brand:#6e8fce;
  --accent:#6e8fce;
  --accent-deep:#3f63a8;
  --accent-tint:#e9eef7;
  --warn:#8a5a12;
  --warn-tint:#f6efdf;
  --success:#2e7d5b;
  --danger:#c0392b;
  --border:rgba(26,34,48,.12);
  --border-strong:rgba(26,34,48,.20);

  --radius-sm:10px; --radius:16px; --radius-lg:20px; --radius-pill:999px;
  --shadow-sm:0 1px 2px rgba(26,34,48,.05), 0 2px 6px rgba(26,34,48,.04);
  --shadow:0 4px 12px rgba(26,34,48,.07), 0 12px 28px rgba(26,34,48,.06);
  --shadow-lg:0 10px 30px rgba(26,34,48,.10), 0 30px 60px rgba(26,34,48,.08);

  --maxw:1180px;
  --gutter:clamp(1.1rem, 4vw, 2.4rem);
  --section-y:clamp(3.5rem, 8vw, 6.5rem);

  /* fluid type scale, ratio ~1.25 */
  --fs-300:0.875rem;
  --fs-400:1.0625rem;            /* body base 17px (Inter) */
  --fs-500:clamp(1.15rem,1.03rem + .5vw,1.35rem);
  --fs-600:clamp(1.35rem,1.18rem + .85vw,1.8rem);
  --fs-700:clamp(1.6rem,1.3rem + 1.5vw,2.35rem);
  --fs-800:clamp(2rem,1.45rem + 2.6vw,3.2rem);
  --fs-900:clamp(2.4rem,1.65rem + 3.7vw,4.2rem);

  --z-dropdown:100; --z-sticky:200; --z-backdrop:300; --z-modal:400; --z-toast:500;

  --ease-out:cubic-bezier(.16,1,.3,1);
  --font-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-head:"Fraunces",Georgia,"Times New Roman",serif;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:5.5rem}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--font-body);
  font-size:var(--fs-400);
  line-height:1.62;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,picture{display:block;max-width:100%;height:auto}
a{color:var(--primary);text-underline-offset:.18em;text-decoration-thickness:.08em}
a:hover{color:var(--primary-strong)}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:600;line-height:1.14;letter-spacing:-.005em;text-wrap:balance;color:var(--ink)}
p{text-wrap:pretty}
strong{font-weight:600}
ul,ol{padding-left:1.2em}
:focus-visible{outline:3px solid var(--primary);outline-offset:2px;border-radius:4px}
::selection{background:var(--accent-tint);color:var(--ink)}

.skip-link{position:absolute;left:.5rem;top:-3rem;background:var(--primary);color:#fff;padding:.6rem 1rem;border-radius:8px;z-index:var(--z-toast);transition:top .2s}
.skip-link:focus{top:.5rem;color:#fff}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:var(--section-y)}
.section--surface{background:var(--surface)}
.section--tint{background:linear-gradient(180deg,var(--bg),var(--surface))}
.eyebrow{font-family:var(--font-body);font-weight:600;font-size:var(--fs-300);letter-spacing:.04em;text-transform:uppercase;color:var(--accent-deep);display:inline-flex;align-items:center;gap:.5rem}
.section-head{max-width:62ch;margin-bottom:clamp(2rem,4vw,3rem)}
.section-head h2{font-size:var(--fs-800);margin-top:.5rem}
.section-head p{font-size:var(--fs-500);color:var(--ink-soft);margin-top:.9rem}
.lead{font-size:var(--fs-500);color:var(--ink-soft)}

/* ---------- Buttons ---------- */
.btn{
  --btn-bg:var(--primary);--btn-fg:#fff;--btn-bd:var(--primary);
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--font-body);font-weight:600;font-size:1.0625rem;line-height:1;
  padding:.9rem 1.5rem;min-height:52px;border-radius:var(--radius-sm);
  background:var(--btn-bg);color:var(--btn-fg);border:1.5px solid var(--btn-bd);
  cursor:pointer;text-decoration:none;white-space:nowrap;
  transition:transform .25s var(--ease-out),box-shadow .25s var(--ease-out),background .2s,color .2s,border-color .2s;
  box-shadow:var(--shadow-sm);
}
.btn:hover{--btn-bg:var(--primary-strong);--btn-bd:var(--primary-strong);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow)}
.btn:active{transform:translateY(0)}
.btn svg{width:1.2em;height:1.2em;flex:none}
.btn--ghost{--btn-bg:transparent;--btn-fg:var(--primary);--btn-bd:var(--border-strong)}
.btn--ghost:hover{--btn-bg:var(--primary-tint);--btn-fg:var(--primary-strong);--btn-bd:var(--primary);color:var(--primary-strong)}
.btn--on-deep{--btn-bg:#fff;--btn-fg:var(--primary-strong);--btn-bd:#fff}
.btn--on-deep:hover{--btn-bg:var(--accent);--btn-fg:#fff;--btn-bd:var(--accent);color:#fff}
.btn--lg{font-size:1.15rem;padding:1.05rem 1.9rem;min-height:60px}
.btn--block{width:100%}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:var(--z-sticky);background:rgba(255,255,255,.82);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s,background .3s}
.site-header.is-scrolled{border-bottom-color:var(--border);box-shadow:var(--shadow-sm);background:rgba(255,255,255,.93)}
.nav{display:flex;align-items:center;gap:1.5rem;height:4.75rem}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--font-head);font-weight:600;font-size:1.2rem;color:var(--ink);text-decoration:none;letter-spacing:-.01em;flex:none}
.brand:hover{color:var(--ink)}
.brand__mark{width:38px;height:38px;flex:none}
.brand small{display:block;font-family:var(--font-body);font-weight:500;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);line-height:1}
.nav__links{display:flex;align-items:center;gap:.35rem;margin-left:auto}
.nav__links a{font-weight:500;font-size:1rem;color:var(--ink);text-decoration:none;padding:.55rem .7rem;border-radius:8px;white-space:nowrap;transition:background .2s,color .2s}
.nav__links a:hover,.nav__links a[aria-current="page"]{background:var(--primary-tint);color:var(--primary-strong)}
.nav__cta{display:flex;align-items:center;gap:.6rem;flex:none}
.nav__phone{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;color:var(--ink);text-decoration:none;font-size:1rem;padding:.5rem .6rem;border-radius:8px}
.nav__phone:hover{color:var(--primary);background:var(--primary-tint)}
.nav__phone svg{width:1.1em;height:1.1em;color:var(--primary)}
.nav__toggle{display:none;align-items:center;justify-content:center;width:48px;height:48px;border:1px solid var(--border-strong);border-radius:10px;background:var(--bg);cursor:pointer;color:var(--ink)}
.nav__toggle svg{width:24px;height:24px}

@media (max-width:980px){
  .nav__links,.nav .nav__phone{display:none}
  .nav__toggle{display:inline-flex}
  .nav{gap:.75rem}
  .nav__links.is-open{display:flex;position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:stretch;gap:.15rem;background:var(--bg);border-bottom:1px solid var(--border);box-shadow:var(--shadow);padding:.75rem var(--gutter) 1.25rem}
  .nav__links.is-open a{padding:.85rem .75rem;font-size:1.1rem}
}
@media (max-width:600px){
  .site-header .nav__cta>.btn{display:none}
  .brand small{font-size:.66rem}
}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--surface),var(--bg) 70%)}
.hero__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;padding-block:clamp(2.8rem,6vw,5rem)}
.hero__content{max-width:38rem}
.hero h1{font-size:var(--fs-900);letter-spacing:-.01em}
.hero h1 em{font-style:italic;color:var(--primary)}
.hero__lead{font-size:var(--fs-500);color:var(--ink-soft);margin-top:1.25rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.9rem}
.hero__trust{display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;margin-top:1.9rem;list-style:none;padding:0}
.hero__trust li{display:flex;align-items:center;gap:.5rem;font-weight:500;color:var(--ink-soft);font-size:1rem}
.hero__trust svg{width:1.25rem;height:1.25rem;color:var(--primary);flex:none}
.hero__visual{position:relative}
.hero__visual svg{width:100%;height:auto;filter:drop-shadow(0 24px 50px rgba(63,99,168,.18))}

.urgent-badge{display:inline-flex;align-items:center;gap:.55rem;background:var(--warn-tint);color:var(--warn);font-weight:600;font-size:.95rem;padding:.45rem .9rem;border-radius:var(--radius-pill);border:1px solid rgba(138,90,18,.22)}
.urgent-badge .dot{width:.6rem;height:.6rem;border-radius:50%;background:var(--warn)}

@media (max-width:880px){
  .hero__inner{grid-template-columns:1fr;gap:2rem}
  .hero__visual{order:-1;max-width:420px;margin-inline:auto}
}

/* Hero entrance: transform-only (opacity reste à 1) pour ne pas pénaliser le LCP */
@media (prefers-reduced-motion:no-preference){
  .hero__content>*{animation:heroUp .6s var(--ease-out) both}
  .hero__content>*:nth-child(2){animation-delay:.06s}
  .hero__content>*:nth-child(3){animation-delay:.10s}
  .hero__content>*:nth-child(4){animation-delay:.16s}
  .hero__content>*:nth-child(5){animation-delay:.22s}
  .hero__content>*:nth-child(6){animation-delay:.28s}
}
@keyframes heroUp{from{transform:translateY(14px)}to{transform:translateY(0)}}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:clamp(1rem,2.5vw,1.6rem)}
.grid--3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid--2{grid-template-columns:repeat(auto-fit,minmax(330px,1fr))}
.grid--4{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}

.patho-card{position:relative;display:flex;flex-direction:column;gap:.65rem;padding:1.6rem;background:var(--surface-on,#fff);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:var(--ink);overflow:hidden;transition:transform .3s var(--ease-out),box-shadow .3s var(--ease-out),border-color .3s,background .3s}
.patho-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(63,99,168,.45);background:var(--surface-2)}
.patho-card__icon{width:48px;height:48px;display:grid;place-items:center;border-radius:12px;background:var(--primary-tint);color:var(--primary);flex:none}
.patho-card__icon svg{width:26px;height:26px}
.patho-card h3{font-size:var(--fs-500);margin-top:.3rem}
.patho-card p{color:var(--ink-soft);font-size:1rem}
.patho-card__more{margin-top:auto;font-weight:600;color:var(--primary);display:inline-flex;align-items:center;gap:.4rem}
.patho-card:hover .patho-card__more{gap:.65rem}
.patho-card__more svg{width:1.1em;height:1.1em;transition:transform .25s}

/* feature / value items */
.feature{display:flex;gap:1rem;align-items:flex-start}
.feature__icon{width:46px;height:46px;flex:none;display:grid;place-items:center;border-radius:12px;background:var(--primary-tint);color:var(--primary)}
.feature__icon svg{width:24px;height:24px}
.feature h3{font-size:var(--fs-500);margin-bottom:.25rem}
.feature p{color:var(--ink-soft);font-size:1.02rem}

/* tech plateau chips */
.tech-list{display:flex;flex-wrap:wrap;gap:.6rem;list-style:none;padding:0}
.tech-list li{display:inline-flex;align-items:center;gap:.55rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius-pill);padding:.6rem 1.05rem;font-weight:500;font-size:1rem}
.tech-list svg{width:1.15rem;height:1.15rem;color:var(--primary);flex:none}

/* ---------- Practical info ---------- */
.info-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
@media (max-width:860px){.info-grid{grid-template-columns:1fr}}
.hours-table{width:100%;border-collapse:collapse;font-size:1.05rem}
.hours-table th,.hours-table td{text-align:left;padding:.7rem 0;border-bottom:1px solid var(--border)}
.hours-table th{font-weight:600;color:var(--ink)}
.hours-table td{color:var(--ink-soft);text-align:right;font-variant-numeric:tabular-nums}
.info-line{display:flex;gap:.85rem;align-items:flex-start;margin-bottom:1.1rem}
.info-line svg{width:1.4rem;height:1.4rem;color:var(--primary);flex:none;margin-top:.15rem}
.info-line>div{min-width:0}
.info-line a{font-weight:600;text-decoration:none;overflow-wrap:anywhere}
.map-frame{border:0;width:100%;height:100%;min-height:320px;border-radius:var(--radius);filter:saturate(.92)}
.map-wrap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-sm);min-height:320px;height:100%}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:var(--surface-deep);color:var(--ink-on-deep);border-radius:var(--radius-lg);padding:clamp(2.2rem,5vw,3.6rem);text-align:center}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 120% at 12% -10%,rgba(63,99,168,.65),transparent 55%),radial-gradient(70% 120% at 100% 120%,rgba(110,143,206,.45),transparent 55%);pointer-events:none}
.cta-band>*{position:relative}
.cta-band h2{color:#fff;font-size:var(--fs-800)}
.cta-band p{color:var(--ink-on-deep-soft);font-size:var(--fs-500);max-width:46ch;margin:.9rem auto 0}
.cta-band .hero__actions{justify-content:center;margin-top:2rem}

/* ---------- Breadcrumb ---------- */
.breadcrumb{font-size:.95rem;color:var(--ink-soft);padding-block:1.1rem}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem;padding:0}
.breadcrumb a{text-decoration:none}
.breadcrumb li+li::before{content:"›";margin-right:.4rem;color:var(--border-strong)}

/* ---------- Article (pathology pages) ---------- */
.page-hero{background:linear-gradient(180deg,var(--surface),var(--bg));border-bottom:1px solid var(--border)}
.page-hero__inner{padding-block:clamp(1.5rem,4vw,3rem) clamp(2rem,5vw,3.5rem);max-width:60ch}
.page-hero h1{font-size:var(--fs-800);margin-top:.4rem}
.page-hero p{font-size:var(--fs-500);color:var(--ink-soft);margin-top:1rem}
.prose{max-width:68ch}
.prose>*+*{margin-top:1.1rem}
.prose h2{font-size:var(--fs-700);margin-top:2.4rem}
.prose h3{font-size:var(--fs-600);margin-top:1.8rem}
.prose ul,.prose ol{padding-left:1.3em}
.prose li+li{margin-top:.4rem}
.prose strong{color:var(--ink)}
.callout{background:var(--primary-tint);border:1px solid rgba(63,99,168,.22);border-radius:var(--radius);padding:1.25rem 1.4rem;display:flex;gap:.9rem}
.callout svg{width:1.5rem;height:1.5rem;color:var(--primary);flex:none;margin-top:.1rem}
.callout p{margin:0}
.layout-aside{display:grid;grid-template-columns:1fr 320px;gap:clamp(2rem,5vw,3.5rem);align-items:start}
@media (max-width:920px){.layout-aside{grid-template-columns:1fr}}
.aside-card{position:sticky;top:6rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}
.aside-card h3{font-size:var(--fs-500);margin-bottom:.4rem}
.aside-card p{color:var(--ink-soft);font-size:1rem;margin-bottom:1.1rem}

/* FAQ */
.faq details{border:1px solid var(--border);border-radius:var(--radius);padding:.4rem 1.2rem;background:#fff;transition:border-color .2s}
.faq details+details{margin-top:.8rem}
.faq details[open]{border-color:rgba(63,99,168,.45)}
.faq summary{cursor:pointer;font-weight:600;font-family:var(--font-head);font-size:var(--fs-500);padding:.85rem 0;list-style:none;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--primary);transition:transform .25s;flex:none}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details>p{padding-bottom:1rem;color:var(--ink-soft);margin:0}

/* ---------- Footer ---------- */
.site-footer{background:var(--surface-deep-2);color:var(--ink-on-deep-soft);padding-block:clamp(3rem,6vw,4.5rem) 2rem;margin-top:0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1.1fr;gap:2rem}
@media (max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}
.site-footer h2{color:#fff;font-family:var(--font-body);font-weight:600;font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:1rem;margin-top:0}
.site-footer a{color:var(--ink-on-deep-soft);text-decoration:none}
.site-footer a:hover{color:#fff}
.footer-links{list-style:none;padding:0;display:flex;flex-direction:column;gap:.6rem}
.footer-brand .brand{color:#fff;margin-bottom:1rem}
.footer-brand .brand small{color:var(--ink-on-deep-soft)}
.footer-brand p{color:var(--ink-on-deep-soft);max-width:32ch}
.footer-bottom{border-top:1px solid rgba(255,255,255,.14);margin-top:2.5rem;padding-top:1.5rem;display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;justify-content:space-between;font-size:.9rem;color:var(--ink-on-deep-soft)}

/* ---------- Sticky mobile action bar ---------- */
.mobile-bar{position:fixed;left:0;right:0;bottom:0;z-index:var(--z-sticky);display:none;gap:.6rem;padding:.6rem .8rem calc(.6rem + env(safe-area-inset-bottom));background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-top:1px solid var(--border);box-shadow:0 -4px 20px rgba(26,34,48,.1)}
.mobile-bar .btn{flex:1;min-height:54px;padding:.8rem 1rem;font-size:1.05rem}
@media (max-width:980px){.mobile-bar{display:flex}body{padding-bottom:calc(6rem + env(safe-area-inset-bottom))}}
@media (max-width:380px){.mobile-bar .btn{padding:.7rem .5rem;font-size:.95rem;gap:.35rem}.btn--lg{white-space:normal;line-height:1.2;text-align:center}}

/* ---------- Reveal motion (progressive enhancement: hidden only when JS confirmed) ---------- */
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal.is-in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* filet bleu sous le titre du hero (dégradé MedKey) */
.spectrum-rule{height:5px;width:clamp(120px,28%,220px);border-radius:99px;margin-top:1.6rem;background:linear-gradient(90deg,var(--primary),var(--brand) 60%,#a9c0e6)}

.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* utility */
.text-center{text-align:center}
.mx-auto{margin-inline:auto}
.mt-2{margin-top:2rem}
.stack-sm>*+*{margin-top:.6rem}

/* ---------- Zones desservies (liens communes) ---------- */
.town-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.8rem}
.town-link{display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:1rem 1.25rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:var(--ink);font-weight:600;transition:border-color .2s,transform .25s var(--ease-out),box-shadow .25s,color .2s}
.town-link:hover{border-color:rgba(63,99,168,.45);transform:translateY(-2px);box-shadow:var(--shadow-sm);color:var(--primary-strong)}
.town-link svg{width:1.15em;height:1.15em;color:var(--primary);flex:none;transition:transform .2s}
.town-link:hover svg{transform:translateX(3px)}

/* ---------- Bandeau de consentement (CNIL) ---------- */
.consent{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:var(--z-modal);max-width:700px;margin-inline:auto;background:#fff;border:1px solid var(--border-strong);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:1.1rem 1.25rem;display:flex;flex-wrap:wrap;gap:.85rem 1.3rem;align-items:center;justify-content:space-between}
.consent__txt{flex:1 1 300px;font-size:.97rem;line-height:1.5;color:var(--ink-soft);margin:0}
.consent__actions{display:flex;gap:.6rem;flex:none}
.consent .btn{min-height:46px;padding:.6rem 1.2rem;font-size:1rem;box-shadow:none}
.consent-reopen{cursor:pointer;appearance:none;background:none;border:0;padding:0;margin:0;font:inherit;color:inherit;text-decoration:underline}
.consent-reopen:hover{color:#fff}
@media (max-width:980px){.consent{bottom:calc(6rem + .8rem + env(safe-area-inset-bottom))}}
@media (max-width:560px){.consent__actions{flex:1 1 100%}.consent__actions .btn{flex:1}}



/* ---------- Étapes numérotées (style ClearVision) ---------- */
.steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}
.step{display:grid;grid-template-columns:auto 1fr;gap:1.3rem;padding:1.3rem 0;border-top:1px solid var(--border)}
.step:first-child{border-top:0;padding-top:.2rem}
.step__num{font-family:var(--font-head);font-weight:600;font-size:1.9rem;color:var(--primary);line-height:1}
.step h3{font-size:var(--fs-500);margin-bottom:.2rem}
.step p{color:var(--ink-soft);font-size:1rem;margin:0}

