*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* New premium palette — evergreen / porcelain / sage / champagne */
  --evergreen:#0A1F1C; --evergreen-800:#102B27; --evergreen-700:#1F3A36; --evergreen-600:#2C4D47;
  --porcelain:#F4F1EA; --porcelain-50:#FAF8F3; --porcelain-100:#F4F1EA; --porcelain-200:#E8E2D4;
  --sage:#A8C7C2; --sage-100:#DCE8E5; --sage-300:#A8C7C2; --sage-500:#7AA9A2;
  --champagne:#D4B896; --champagne-100:#EDDFC8; --champagne-300:#D4B896; --champagne-500:#B8985F;
  --mid:#6B7976;
  --line:rgba(10,31,28,0.10); --lw:rgba(244,241,234,0.12);

  /* Aliases for backwards compatibility with old class names */
  --ink:var(--evergreen); --cream:var(--porcelain); --w:#FFFFFF;
  --teal:var(--evergreen-700); --teal-mid:var(--sage-500); --teal-light:var(--sage-100);
  --gold:var(--champagne-500);

  --ff:'Fraunces',serif; --fb:'Inter Tight',system-ui,sans-serif;
}

html{scroll-behavior:smooth}
body{font-family:var(--fb);background:var(--porcelain);color:var(--evergreen);-webkit-font-smoothing:antialiased;line-height:1.6;font-feature-settings:'ss01','cv11'}

/* Display font helper */
.font-display, .h1, .h2, .h3, .page-h1, .zone-h, .cta-banner h3, .nav-name, .footer-brand-name{
  font-family:var(--ff); font-optical-sizing:auto; font-variation-settings:"SOFT" 50;
}

/* NAV */
nav.site-nav{position:sticky;top:0;z-index:400;height:64px;padding:0 44px;display:flex;align-items:center;justify-content:space-between;background:rgba(244,241,234,.85);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
.nav-brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.nav-name{font-size:16px;font-weight:500;color:var(--evergreen);letter-spacing:-.01em}
.nav-links{display:flex;gap:30px}
.nav-links a{font-size:13px;color:var(--mid);text-decoration:none;transition:color .2s}
.nav-links a:hover{color:var(--evergreen)}
.nav-r{display:flex;align-items:center;gap:14px}
.nav-tel{font-size:13px;color:var(--mid);font-variant-numeric:tabular-nums}
.nav-rdv{background:var(--evergreen);color:var(--porcelain);font-size:13px;font-weight:500;padding:10px 20px;border-radius:99px;text-decoration:none;font-family:var(--fb);display:inline-flex;align-items:center;gap:8px;transition:transform .2s,background .2s}
.nav-rdv:hover{background:var(--evergreen-700);transform:translateY(-1px)}

.eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mid);margin-bottom:14px}
.eyebrow::before{content:'';width:24px;height:1px;background:currentColor}

/* Container */
.container{max-width:1280px;margin:0 auto;padding:0 44px}
.section-pad{padding:96px 0}

/* HERO */
.page-hero{background:var(--evergreen);color:var(--porcelain);padding:120px 0 96px;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:-120px;right:-120px;width:480px;height:480px;border-radius:50%;background:radial-gradient(closest-side,rgba(168,199,194,.18),transparent 70%);pointer-events:none}
.page-hero::after{content:'';position:absolute;bottom:-180px;left:-100px;width:420px;height:420px;border-radius:50%;background:radial-gradient(closest-side,rgba(212,184,150,.12),transparent 70%);pointer-events:none}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:12px;color:rgba(244,241,234,.45);margin-bottom:24px;position:relative;letter-spacing:.04em}
.breadcrumb a{color:rgba(244,241,234,.45);text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:var(--porcelain)}
.breadcrumb-sep{opacity:.4}
.page-h1{font-size:clamp(48px,5.5vw,84px);font-weight:300;line-height:1.02;letter-spacing:-.025em;margin-bottom:24px;position:relative;max-width:880px;text-wrap:balance}
.page-h1 strong{font-weight:500;font-style:italic;color:var(--champagne-300)}
.page-hero-sub{font-size:17px;color:rgba(244,241,234,.65);line-height:1.7;max-width:620px;margin-bottom:36px;position:relative}
.hero-cta-row{display:flex;gap:12px;flex-wrap:wrap;position:relative}
.btn-teal{display:inline-flex;align-items:center;gap:10px;background:var(--champagne);color:var(--evergreen);font-size:14px;font-weight:500;padding:14px 26px;border-radius:99px;text-decoration:none;font-family:var(--fb);transition:transform .2s,background .2s}
.btn-teal:hover{background:var(--champagne-100);transform:translateY(-1px)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--porcelain);font-size:13px;padding:13px 24px;border-radius:99px;text-decoration:none;font-family:var(--fb);border:1px solid rgba(244,241,234,.18);transition:background .2s,border-color .2s}
.btn-ghost:hover{background:rgba(244,241,234,.06);border-color:rgba(244,241,234,.32)}

/* Headings */
.h2{font-size:clamp(32px,3.6vw,52px);font-weight:300;letter-spacing:-.02em;line-height:1.05;margin-bottom:20px;color:var(--evergreen);text-wrap:balance}
.h2 strong{font-weight:500;font-style:italic}
.h3{font-size:24px;font-weight:500;letter-spacing:-.018em;margin-bottom:12px;color:var(--evergreen)}
.lead{font-size:16px;color:var(--mid);line-height:1.75;max-width:720px;margin-bottom:32px}
.body-p{font-size:15px;color:var(--evergreen);line-height:1.8;margin-bottom:16px;opacity:.82}

/* Two-col content */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.two-col.alt{grid-template-columns:1.3fr 1fr}

/* Feature list — bento-style cards on porcelain background */
.feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:24px}
.feat-card{background:var(--porcelain-50);border:1px solid var(--line);padding:28px 30px;border-radius:24px;transition:border-color .25s,background .25s,transform .25s}
.feat-card:hover{background:#fff;border-color:rgba(10,31,28,.16);transform:translateY(-2px)}
.feat-card-icon{width:44px;height:44px;border-radius:12px;background:var(--sage-100);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.feat-card-icon svg{width:20px;height:20px;stroke:var(--evergreen-700);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.feat-card-title{font-size:16px;font-weight:500;color:var(--evergreen);margin-bottom:8px}
.feat-card-desc{font-size:13.5px;color:var(--mid);line-height:1.7}

/* Steps process — editorial numbered list */
.steps{counter-reset:step;display:flex;flex-direction:column;gap:0;margin-top:28px}
.step{display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:flex-start;padding:28px 0;border-top:1px solid var(--line)}
.step:first-child{border-top:none;padding-top:8px}
.step-n{counter-increment:step;font-family:var(--ff);font-size:14px;font-weight:500;color:var(--champagne-500);font-variant-numeric:tabular-nums;padding-top:6px;letter-spacing:.04em}
.step-n::before{content:counter(step,decimal-leading-zero)}
.step-content h4{font-family:var(--ff);font-size:22px;font-weight:400;letter-spacing:-.015em;margin-bottom:8px;color:var(--evergreen)}
.step-content p{font-size:14.5px;color:var(--mid);line-height:1.75;max-width:62ch}

/* Geographic zone */
.zone{background:var(--evergreen);color:var(--porcelain);padding:88px 0;position:relative;overflow:hidden}
.zone::before{content:'';position:absolute;top:-100px;right:10%;width:380px;height:380px;border-radius:50%;background:radial-gradient(closest-side,rgba(168,199,194,.14),transparent 70%);pointer-events:none}
.zone-h{font-size:clamp(28px,3vw,42px);font-weight:300;letter-spacing:-.02em;color:var(--porcelain);margin-bottom:18px;position:relative;text-wrap:balance}
.zone-h strong{font-weight:500;font-style:italic;color:var(--champagne-300)}
.zone-p{color:rgba(244,241,234,.6);font-size:15px;line-height:1.75;max-width:720px;margin-bottom:28px;position:relative}
.zone-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;position:relative}
.zone-tag{padding:8px 16px;border:1px solid rgba(244,241,234,.18);border-radius:99px;font-size:12px;color:rgba(244,241,234,.75);background:transparent;transition:background .2s}
.zone-tag:hover{background:rgba(244,241,234,.06)}
.zone-tag.primary{background:var(--champagne);border-color:var(--champagne);color:var(--evergreen);font-weight:500}

/* FAQ */
.faq-wrap{max-width:880px;margin:0 auto}
.faq-item{border-top:1px solid var(--line)}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:26px 0;cursor:pointer;font-family:var(--ff);font-size:18px;font-weight:400;letter-spacing:-.015em;color:var(--evergreen);transition:color .2s;list-style:none;-webkit-appearance:none}
.faq-q::-webkit-details-marker{display:none}
.faq-q:hover{color:var(--champagne-500)}
.faq-q-icon{width:32px;height:32px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .3s,background .3s,border-color .3s}
.faq-q-icon::before{content:'+';font-family:var(--fb);font-size:18px;font-weight:300;color:var(--mid);line-height:1}
details[open] .faq-q-icon{transform:rotate(45deg);background:var(--evergreen);border-color:var(--evergreen)}
details[open] .faq-q-icon::before{color:var(--porcelain)}
.faq-a{padding:0 0 26px;font-size:14.5px;color:var(--mid);line-height:1.8;max-width:780px}

/* CTA banner */
.cta-banner{background:var(--evergreen);color:var(--porcelain);padding:80px 0;text-align:center;position:relative;overflow:hidden}
.cta-banner::before{content:'';position:absolute;inset:-1px;background:radial-gradient(60% 80% at 50% 100%,rgba(212,184,150,.18),transparent 70%);pointer-events:none}
.cta-banner h3{font-size:clamp(32px,3.4vw,52px);font-weight:300;letter-spacing:-.02em;margin-bottom:16px;color:var(--porcelain);line-height:1.05;position:relative;text-wrap:balance}
.cta-banner h3 strong{font-weight:500;font-style:italic;color:var(--champagne-300)}
.cta-banner p{font-size:15px;color:rgba(244,241,234,.7);max-width:580px;margin:0 auto 32px;line-height:1.7;position:relative}
.cta-banner .btn-teal{position:relative;background:var(--champagne);color:var(--evergreen)}
.cta-banner .btn-teal:hover{background:var(--champagne-100)}

/* Footer */
footer.site-footer{background:var(--evergreen);color:rgba(244,241,234,.6);padding:64px 0 28px;border-top:1px solid var(--lw)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:56px;margin-bottom:48px}
.footer-brand-name{font-size:20px;font-weight:500;color:var(--porcelain);margin-bottom:12px;letter-spacing:-.012em}
.footer-brand p{font-size:13.5px;line-height:1.7;color:rgba(244,241,234,.55);max-width:32ch}
.footer-col h5{font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--sage-300);margin-bottom:16px}
.footer-col a, .footer-col span{display:block;font-size:13.5px;color:rgba(244,241,234,.6);text-decoration:none;margin-bottom:10px;line-height:1.6;transition:color .2s}
.footer-col a:hover{color:var(--porcelain)}
.footer-bottom{border-top:1px solid var(--lw);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-bottom-l{font-size:11px;color:rgba(244,241,234,.4);letter-spacing:.04em}
.footer-bottom-r{display:flex;gap:24px}
.footer-bottom-r a{font-size:11px;color:rgba(244,241,234,.4);text-decoration:none;transition:color .2s;letter-spacing:.04em}
.footer-bottom-r a:hover{color:rgba(244,241,234,.75)}

/* Section alternation backgrounds */
.section-pad.bg-soft{background:var(--porcelain-50)}
.section-pad.bg-white{background:#fff}

/* Media figure — illustration block within service pages */
.media-figure{margin:48px auto;border-radius:24px;overflow:hidden;position:relative;background:var(--evergreen-700);max-width:1200px}
.media-figure img{width:100%;height:auto;display:block;aspect-ratio:16/9;object-fit:cover}
.media-figure figcaption{position:absolute;bottom:18px;left:18px;background:rgba(244,241,234,.92);backdrop-filter:blur(10px);padding:9px 14px;border-radius:99px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--evergreen);display:inline-flex;align-items:center;gap:8px}
.media-figure figcaption::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--champagne-500)}
.media-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:16px;max-width:1280px;margin:48px auto;padding:0 44px}
.media-grid .media-figure{margin:0}
.media-grid .media-figure img{aspect-ratio:auto;height:100%;min-height:320px}

/* Instagram widget — service page footer block */
.ig-section{background:var(--evergreen);color:var(--porcelain);padding:80px 0;position:relative;overflow:hidden;border-top:1px solid var(--lw)}
.ig-section::before{content:'';position:absolute;top:-160px;right:10%;width:380px;height:380px;border-radius:50%;background:radial-gradient(closest-side,rgba(168,199,194,.14),transparent 70%);pointer-events:none}
.ig-section::after{content:'';position:absolute;bottom:-200px;left:5%;width:420px;height:420px;border-radius:50%;background:radial-gradient(closest-side,rgba(212,184,150,.10),transparent 70%);pointer-events:none}
.ig-wrap{max-width:1180px;margin:0 auto;padding:0 44px;position:relative}
.ig-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:18px;padding-bottom:22px;border-bottom:1px solid var(--lw);margin-bottom:22px}
.ig-id{display:flex;align-items:center;gap:16px}
/* Avatar IG identique à _avatar-final.html (V6) — fond evergreen, dent porcelain, Cabinet Élysée 2 */
.ig-avatar{position:relative;width:68px;height:68px;border-radius:50%;display:grid;place-items:center;background:var(--evergreen);border:3px solid var(--porcelain);overflow:hidden;flex-shrink:0;box-shadow:0 0 0 1px rgba(10,31,28,.08)}
.ig-avatar .mark{display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1;padding:4px;gap:2px}
.ig-avatar .mark svg{width:18px;height:20px;display:block}
.ig-avatar .top{font-family:var(--fb);font-weight:500;text-transform:uppercase;font-size:5.2px;letter-spacing:.22em;color:var(--porcelain);display:flex;align-items:center;justify-content:center;gap:3px}
.ig-avatar .top::before,.ig-avatar .top::after{content:'';height:1px;background:currentColor;opacity:.55;display:inline-block;width:5px}
.ig-avatar .nm{font-family:var(--ff);font-weight:500;letter-spacing:-.012em;font-size:11px;color:var(--porcelain);margin-top:1px}
.ig-avatar .nm em{font-style:italic;font-weight:400;color:var(--champagne)}
.ig-name{font-family:var(--ff);font-size:18px;font-weight:500;color:var(--porcelain);letter-spacing:-.012em;line-height:1.2}
.ig-bio{font-size:12.5px;color:rgba(244,241,234,.55);margin-top:3px}
.ig-follow{background:var(--porcelain);color:var(--evergreen);font-size:13px;font-weight:500;padding:9px 18px;border-radius:99px;text-decoration:none;display:inline-flex;align-items:center;gap:7px;font-family:var(--fb);transition:transform .15s}
.ig-follow:hover{transform:translateY(-1px)}
.ig-stats{display:flex;gap:20px;font-size:12.5px;color:rgba(244,241,234,.55);margin-bottom:24px}
.ig-stats strong{font-family:var(--ff);font-size:15px;font-weight:500;color:var(--porcelain);font-variant-numeric:tabular-nums;margin-right:4px}
.ig-stats .sep{color:rgba(244,241,234,.25)}
.ig-stats a{color:var(--champagne-300);text-decoration:none}
.ig-stats a:hover{text-decoration:underline}
.ig-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.ig-tile{position:relative;aspect-ratio:1/1;border-radius:14px;overflow:hidden;background:var(--evergreen-700);cursor:pointer;display:block}
.ig-tile img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.ig-tile:hover img{transform:scale(1.08)}
.ig-tile-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(10,31,28,.8) 100%);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:14px}
.ig-tile:hover .ig-tile-overlay{opacity:1}
.ig-tile-cap{font-size:11.5px;color:var(--porcelain);display:flex;align-items:center;gap:6px}
.ig-tile-cap svg{width:11px;height:11px;color:var(--champagne);flex-shrink:0;fill:currentColor}
.ig-foot{margin-top:24px;text-align:center}
.ig-foot a{font-size:13px;color:rgba(244,241,234,.7);text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:color .15s}
.ig-foot a:hover{color:var(--champagne)}

@media(max-width:880px){
  .media-grid{grid-template-columns:1fr;padding:0 24px}
  .ig-grid{grid-template-columns:repeat(3,1fr);gap:6px}
  .ig-section{padding:64px 0}
}

/* Reveal */
.reveal-up{opacity:0;transform:translateY(28px);transition:opacity .85s cubic-bezier(.22,1,.36,1),transform .85s cubic-bezier(.22,1,.36,1)}
.reveal-up.show{opacity:1;transform:none}

/* Soft scroll-snap for service pages — body class triggers snap on the scroll container.
   Uses :has() for html (modern browsers); body fallback covers others.
   `proximity` snap = guides without forcing, so varying-height sections stay readable. */
html:has(body.snap-page),
body.snap-page{scroll-snap-type:y proximity;scroll-behavior:smooth}
body.snap-page > section,
body.snap-page > footer{scroll-snap-align:start;scroll-snap-stop:normal}
body.snap-page > section{scroll-margin-top:64px}

/* Praticiens cards — used on implants/parodo pages to highlight specialists with Doctolib link */
.praticien-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:8px}
.praticien-card{display:grid;grid-template-columns:auto 1fr;gap:24px;padding:24px 26px;background:var(--porcelain-50);border:1px solid var(--line);border-radius:20px;text-decoration:none;color:inherit;transition:transform .25s,border-color .25s,background .25s,box-shadow .25s;align-items:center}
.praticien-card:hover{transform:translateY(-3px);border-color:var(--evergreen);background:#fff;box-shadow:0 18px 40px -22px rgba(10,31,28,.18)}
.praticien-photo{width:104px;height:104px;border-radius:50%;overflow:hidden;background:var(--evergreen-700);flex-shrink:0;border:2px solid var(--line);transition:border-color .25s}
.praticien-card:hover .praticien-photo{border-color:var(--champagne-300)}
.praticien-photo img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;filter:grayscale(18%);transition:filter .3s}
.praticien-card:hover .praticien-photo img{filter:none}
.praticien-body{display:flex;flex-direction:column;gap:4px;min-width:0}
.praticien-eyebrow{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--champagne-500);font-weight:500}
.praticien-name{font-family:var(--ff);font-size:21px;font-weight:500;letter-spacing:-.018em;color:var(--evergreen);margin:2px 0 4px}
.praticien-bio{font-size:13px;color:var(--mid);line-height:1.65;margin:0}
.praticien-arrow{margin-top:8px;font-size:12px;color:var(--evergreen);font-weight:500;display:inline-flex;align-items:center;gap:4px;align-self:flex-start;transition:gap .2s,color .2s}
.praticien-arrow::after{content:"→";transition:transform .25s}
.praticien-card:hover .praticien-arrow{color:var(--champagne-500)}
.praticien-card:hover .praticien-arrow::after{transform:translateX(4px)}
@media(max-width:880px){
  .praticien-grid{grid-template-columns:1fr}
  .praticien-card{grid-template-columns:auto 1fr;padding:20px;gap:18px}
  .praticien-photo{width:84px;height:84px}
  .praticien-name{font-size:18px}
}

/* Right-side dot-nav (jauge) — injected by service-nav.js */
.dot-nav{position:fixed;right:24px;top:50%;transform:translateY(-50%);z-index:40;display:flex;flex-direction:column;gap:14px;padding:12px 8px;border-radius:99px;backdrop-filter:blur(6px);transition:background .3s}
.dot-nav .dot{position:relative;display:flex;align-items:center;justify-content:flex-end;text-decoration:none;cursor:pointer;height:14px}
.dot-nav .dot-bar{display:block;width:6px;height:6px;border-radius:99px;background:rgba(10,31,28,.22);transition:all .35s cubic-bezier(.22,1,.36,1)}
.dot-nav .dot:hover .dot-bar{background:rgba(10,31,28,.55);height:14px}
.dot-nav .dot.active .dot-bar{width:6px;height:30px;background:var(--evergreen)}
.dot-nav .dot-label{position:absolute;right:18px;top:50%;transform:translateY(-50%) translateX(8px);font-family:var(--fb);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--evergreen);background:rgba(244,241,234,.95);backdrop-filter:blur(8px);padding:5px 10px;border-radius:99px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s,transform .25s cubic-bezier(.22,1,.36,1);box-shadow:0 4px 14px -4px rgba(10,31,28,.15)}
.dot-nav .dot:hover .dot-label{opacity:1;transform:translateY(-50%) translateX(0)}
.dot-nav.on-dark .dot-bar{background:rgba(244,241,234,.32)}
.dot-nav.on-dark .dot:hover .dot-bar{background:rgba(244,241,234,.6)}
.dot-nav.on-dark .dot.active .dot-bar{background:var(--champagne-300)}
.dot-nav.on-dark .dot-label{color:var(--evergreen);background:rgba(244,241,234,.95)}
@media(max-width:880px){.dot-nav{display:none}}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .reveal-up{opacity:1;transform:none}
  html:has(body.snap-page),body.snap-page{scroll-snap-type:none}
}

@media(max-width:880px){
  .two-col, .two-col.alt, .feat-grid, .footer-grid{grid-template-columns:1fr;gap:36px}
  .nav-links{display:none}
  .container{padding:0 20px}
  nav.site-nav{padding:0 18px;padding-top:env(safe-area-inset-top,0)}
  .section-pad{padding:56px 0}
  .page-hero{padding:84px 0 56px}
  .page-h1{font-size:clamp(34px,9vw,52px);line-height:1.05}
  .h2{font-size:clamp(26px,6vw,36px)}
  .lead{font-size:15px}
  .body-p{font-size:14.5px}
  .nav-rdv{padding:8px 14px;font-size:12.5px;white-space:nowrap}
  .nav-tel{display:none}
  .feat-card{padding:20px 22px;border-radius:18px}
  .step{padding:20px 0;gap:18px}
  .step-content h4{font-size:18px}
  .step-content p{font-size:13.5px}
  .zone{padding:64px 0}
  .zone-tag{font-size:11.5px;padding:6px 12px}
  .cta-banner{padding:56px 0}
  .cta-banner h3{font-size:clamp(26px,7vw,38px)}
  .faq-q{font-size:16px;padding:20px 0;gap:12px}
  .faq-a{font-size:14px;padding:0 0 20px}
  .ig-section{padding:56px 0}
  .ig-wrap{padding:0 18px}
  .ig-head{padding-bottom:18px;margin-bottom:18px}
  .ig-grid{gap:6px}
  .media-figure{border-radius:18px;margin:32px auto}
  .media-grid{margin:32px auto;padding:0 18px;gap:12px}
  .praticien-card{padding:18px;gap:16px}
  .praticien-photo{width:80px;height:80px}
  .praticien-name{font-size:17px}
  .praticien-bio{font-size:12.5px}
  /* Tap targets minimum 44px sur tous les liens cliquables clés */
  a.btn-teal, a.btn-ghost, a.nav-rdv, .faq-q, .ig-tile, .praticien-card{min-height:44px}
  /* Safe-area pour notch iPhone */
  body{padding-bottom:env(safe-area-inset-bottom,0)}
  /* Hamburger mobile : bouton injecté par service-nav.js */
  .nav-burger{display:grid !important;place-items:center;width:40px;height:40px;border-radius:50%;background:none;border:none;cursor:pointer;color:var(--evergreen);transition:background .15s}
  .nav-burger:hover{background:rgba(10,31,28,.05)}
  .nav-burger svg{width:22px;height:22px}
  .mobile-menu{position:fixed;top:64px;left:0;right:0;background:var(--porcelain);border-top:1px solid var(--line);box-shadow:0 12px 24px -10px rgba(10,31,28,.14);z-index:399;display:none}
  body.mobile-menu-open .mobile-menu{display:block !important;max-height:calc(100vh - 64px);overflow-y:auto}
  .mobile-menu nav{display:flex;flex-direction:column;padding:8px 18px 16px}
  .mobile-menu nav a{display:block;padding:14px 4px;font-size:15px;color:var(--evergreen);text-decoration:none;border-bottom:1px solid var(--line);font-weight:500}
  .mobile-menu nav a:last-of-type{border-bottom:none}
  .mobile-menu nav a:hover{color:var(--champagne-500)}
  .mobile-menu .tel{display:flex;align-items:center;gap:8px;padding:12px 4px;margin-top:6px;border-top:1px solid var(--line);font-size:14px;color:var(--mid);text-decoration:none}
}
.nav-burger{display:none}
@media(min-width:881px){.mobile-menu{display:none !important}}

/* ============================================================
   MOBILE STICKY CTA BAR (Tel + RDV + Itinéraire) — pages services + institut
   Visible <769px uniquement. Identique à la home.
   ============================================================ */
.mobile-cta-bar{position:fixed;bottom:0;left:0;right:0;display:none;z-index:80;background:rgba(10,31,28,.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid rgba(244,241,234,.12);padding:10px 12px calc(10px + env(safe-area-inset-bottom,0));box-shadow:0 -8px 24px -8px rgba(0,0,0,.25)}
.mobile-cta-bar-inner{display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:8px;max-width:540px;margin:0 auto}
.mobile-cta-bar a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:9px 4px;border-radius:999px;text-decoration:none;font-family:var(--fb);font-size:11.5px;font-weight:500;min-height:50px;transition:background .15s}
.mobile-cta-bar a.tel{background:rgba(244,241,234,.08);color:#F4F1EA;border:1px solid rgba(244,241,234,.18)}
.mobile-cta-bar a.tel:active{background:rgba(244,241,234,.15)}
.mobile-cta-bar a.rdv{background:#D4B896;color:#0A1F1C;font-weight:600}
.mobile-cta-bar a.rdv:active{background:#B8985F}
.mobile-cta-bar a.maps{background:rgba(244,241,234,.08);color:#F4F1EA;border:1px solid rgba(244,241,234,.18)}
.mobile-cta-bar a.maps:active{background:rgba(244,241,234,.15)}
.mobile-cta-bar svg{width:16px;height:16px}
.mobile-cta-bar .cta-label{line-height:1;letter-spacing:.02em}
@media(max-width:768px){
  .mobile-cta-bar{display:block}
  /* Reserve space pour la barre */
  body.snap-page,body{padding-bottom:calc(64px + env(safe-area-inset-bottom,0)) !important}
}
