/* =================================================================
   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:1280px;
  --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:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-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:700;line-height:1.1;letter-spacing:-.03em;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.25rem;height:4.75rem}
.nav__links{flex-shrink:0;white-space:nowrap}
.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:.66rem;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);line-height:1;white-space:nowrap}
@media (max-width:1400px){.site-header .nav__phone{display:none}}
.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:1200px){
  .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}
}
@media (max-width:400px){
  .nav{gap:.5rem}
  .brand{font-size:1.02rem;gap:.5rem;min-width:0}
  .brand span{min-width:0;overflow:hidden}
  .brand__mark{width:32px;height:32px}
}

/* ---------- 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:normal;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:#fce8e8;color:#b3261e;font-weight:600;font-size:.95rem;padding:.45rem .9rem;border-radius:var(--radius-pill);border:1px solid rgba(179,38,30,.25)}
.urgent-badge .dot{width:.6rem;height:.6rem;border-radius:50%;background:#d93025;animation:pulseDot 2.2s ease-in-out infinite}
@keyframes pulseDot{0%,100%{box-shadow:0 0 0 0 rgba(217,48,37,.5)}50%{box-shadow:0 0 0 7px rgba(217,48,37,0)}}

@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)}}

/* ---------- Hero variante sombre (portrait praticien) ---------- */
.hero--dark{background:linear-gradient(105deg,#0f2244 0%,#173159 46%,#1f3d6c 100%)}
.hero--dark h1{color:#fff}
.hero--dark h1 em{color:#9dc0f0;background:linear-gradient(100deg,#9dc0f0 38%,#ffffff 50%,#9dc0f0 62%);background-size:220% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shine 5s ease-in-out infinite}
@keyframes shine{0%{background-position:160% 0}55%,100%{background-position:-60% 0}}
@media (prefers-reduced-motion:reduce){.hero--dark h1 em{animation:none;background:none;-webkit-text-fill-color:#9dc0f0}}
.hero--dark .hero__lead{color:var(--ink-on-deep-soft)}
.hero--dark .hero__trust li{color:#c6d3e9}
.hero--dark .hero__trust svg{color:#9dc0f0}
.hero--dark .hero__actions .btn{--btn-bg:#fff;--btn-fg:var(--primary-strong);--btn-bd:#fff}
.hero--dark .hero__actions .btn:hover{--btn-bg:#e9f0fb;--btn-bd:#e9f0fb;color:var(--primary-strong)}
.hero--dark .hero__actions .btn--ghost{--btn-bg:transparent;--btn-fg:#fff;--btn-bd:rgba(255,255,255,.5)}
.hero--dark .hero__actions .btn--ghost:hover{--btn-bg:rgba(255,255,255,.12);--btn-bd:#fff;color:#fff}
.hero--dark .hero__photo{display:block;width:100%;height:auto;border-radius:var(--radius-lg);-webkit-mask-image:linear-gradient(90deg,transparent,#000 14%);mask-image:linear-gradient(90deg,transparent,#000 14%)}
.hero--dark .hero__cap{margin-top:1rem;font-size:1.02rem;font-weight:600;color:#eaf0fb}
.hero--dark .hero__cap span{font-weight:500;color:#9dc0f0}
@media (max-width:880px){.hero--dark .hero__photo{-webkit-mask-image:none;mask-image:none}.hero--dark .hero__cap{text-align:center}}

/* ---------- 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,#ffffff 0%,#eaf1fb 100%);position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 85% at 90% 0%,rgba(79,124,240,.16),transparent 70%);pointer-events:none}
.page-hero .container{position:relative;z-index:1}
.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;color:var(--ink)}
.page-hero p{font-size:var(--fs-500);color:var(--ink-soft);margin-top:1rem}
.page-hero .eyebrow{color:var(--accent-deep)}
.page-hero .breadcrumb,.page-hero .breadcrumb a{color:var(--ink-soft)}
.page-hero .breadcrumb a:hover,.page-hero .breadcrumb [aria-current]{color:var(--ink)}
.page-hero .breadcrumb li+li::before{color:var(--border-strong)}
.page-hero .hero__actions .btn{--btn-bg:var(--primary);--btn-fg:#fff;--btn-bd:var(--primary)}
.page-hero .hero__actions .btn:hover{--btn-bg:var(--primary-strong);--btn-bd:var(--primary-strong);color:#fff}
.page-hero .hero__actions .btn--ghost{--btn-bg:transparent;--btn-fg:var(--primary);--btn-bd:var(--border-strong)}
.page-hero .hero__actions .btn--ghost:hover{--btn-bg:var(--surface);--btn-bd:var(--primary);color:var(--primary)}
.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{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}
.layout-aside aside,.layout-aside>div:last-child{position:sticky;top:6rem;align-self:start}
.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)}
.site-footer .brand__mark{background:#fff;border-radius:50%;padding:3px;box-sizing:border-box}
.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}



/* ---------- Avis patients (marquee) ---------- */
.reviews{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.reviews__track{display:flex;gap:1.4rem;width:max-content;animation:reviewScroll 75s linear infinite}
.reviews:hover .reviews__track,.reviews:focus-within .reviews__track{animation-play-state:paused}
.review-card{flex:0 0 330px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:var(--shadow-sm)}
.review-card__stars{color:#f5a623;letter-spacing:2px;font-size:1.05rem;line-height:1}
.review-card__text{color:var(--ink);line-height:1.55;font-size:.97rem;margin:0}
.review-card__who{display:flex;align-items:center;gap:.7rem;margin-top:auto}
.review-card__avatar{width:42px;height:42px;border-radius:50%;background:var(--primary-tint);color:var(--primary-strong);display:grid;place-items:center;font-weight:700;font-size:.95rem;flex:none}
.review-card__id{display:flex;flex-direction:column;line-height:1.25}
.review-card__id strong{font-weight:600}
.review-card__id small{color:var(--ink-soft);font-size:.82rem}
@keyframes reviewScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.reviews{overflow-x:auto}.reviews__track{animation:none}}

/* ---------- Bandeau cookies (barre horizontale) ---------- */
.consent{max-width:660px;left:1rem;right:1rem;margin-inline:auto;padding:.6rem .7rem .6rem 1.15rem;gap:.7rem 1rem;flex-wrap:nowrap;align-items:center}
.consent__txt{font-size:.9rem;flex:1 1 auto;line-height:1.4}
.consent .btn{min-height:40px;padding:.45rem 1.05rem;font-size:.92rem;white-space:nowrap}
@media (max-width:620px){.consent{flex-wrap:wrap}.consent__actions{flex:1 1 100%}.consent__actions .btn{flex:1}}

/* badge urgences cliquable (appel) */
a.urgent-badge{text-decoration:none;cursor:pointer;transition:background .2s,transform .15s}
a.urgent-badge:hover{background:#f9dada;transform:translateY(-1px)}

/* ---------- Blog / actualités ---------- */
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.4rem}
.post-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.6rem;text-decoration:none;color:inherit;transition:transform .2s var(--ease-out),box-shadow .2s var(--ease-out)}
.post-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.post-card__meta{display:flex;align-items:center;gap:.6rem;font-size:.85rem;color:var(--ink-soft);margin-bottom:.8rem}
.post-card__tag{background:var(--primary-tint);color:var(--primary-strong);font-weight:600;padding:.18rem .65rem;border-radius:999px;font-size:.78rem}
.post-card h3{font-size:var(--fs-500)}
.post-card p{color:var(--ink-soft);font-size:.97rem;margin-top:.5rem;flex:1}
.post-card__more{margin-top:1.1rem;font-weight:600;color:var(--primary);display:inline-flex;align-items:center;gap:.4rem}
.post-card__more svg{width:18px;height:18px}
.page-hero .article-meta{display:flex;flex-wrap:wrap;gap:.5rem .9rem;align-items:center;color:var(--ink-soft);font-size:.95rem;margin-top:.9rem}
.article-validated{display:inline-flex;align-items:center;gap:.35rem;color:var(--success);font-weight:600}
.article-sources{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem 1.4rem;margin-top:2.4rem}
.article-sources h2{font-size:var(--fs-500);margin-bottom:.5rem}
