/* ==========================================================================
   REGEN ESTHETIC CENTRE — Feuille de style principale
   Charte : doré #E6C371 · rose nude #D1A5AF · rose poudré #F9EEF6 · noir #000
   Typo   : Playfair Display (titres) · Cormorant Garamond (texte)
   ========================================================================== */

/* ---------- Polices (Google Fonts) ---------- */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Cormorant:wght@300;400;500;600&display=swap');

/* ---------- Variables ---------- */
:root{
  --gold:#E6C371;
  --gold-deep:#cda94f;
  --nude:#D1A5AF;
  --nude-soft:#e7c8cd;
  --blush:#F9EEF6;
  --blush-deep:#f3e1ea;
  --ink:#3D3B3A;
  --ink-soft:#6b6766;
  --black:#1a1817;
  --white:#ffffff;
  --cream:#fdfbf9;

  --font-display:'Playfair Display', serif;
  --font-body:'Cormorant Garamond', serif;
  --font-sub:'Cormorant', serif;

  --maxw:1280px;
  --gutter:clamp(1.25rem, 4vw, 4rem);
  --radius:2px;
  --shadow-soft:0 18px 50px -28px rgba(61,59,58,.45);
  --shadow-card:0 24px 60px -34px rgba(61,59,58,.55);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  font-size:1.18rem;
  font-weight:400;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ---------- Typographie ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:1.12;color:var(--black)}
h1{font-size:clamp(2.6rem,6vw,5rem);letter-spacing:-.5px}
h2{font-size:clamp(2rem,4vw,3.2rem)}
h3{font-size:clamp(1.4rem,2.5vw,1.9rem)}
.overline{
  font-family:var(--font-sub);
  text-transform:uppercase;
  letter-spacing:.42em;
  font-size:.78rem;
  font-weight:500;
  color:var(--gold-deep);
  display:inline-block;
}
.script{font-style:italic;font-family:var(--font-display);color:var(--nude)}

/* ---------- Layout utils ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(4.5rem,6vw,5rem)}
.center{text-align:center}
.lead{font-size:clamp(1.15rem,1.6vw,1.4rem);color:var(--ink-soft);max-width:60ch}
.center .lead{margin-inline:auto}

/* ---------- Boutons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--font-sub);
  text-transform:uppercase;letter-spacing:.18em;font-size:.82rem;font-weight:500;
  padding:1.05em 2.4em;
  border:1px solid var(--ink);
  color:var(--ink);
  background:transparent;
  transition:all .45s var(--ease);
  position:relative;overflow:hidden;
}
.btn::after{
  content:"";position:absolute;inset:0;background:var(--ink);
  transform:translateY(101%);transition:transform .45s var(--ease);z-index:-1;
}
.btn:hover{color:var(--cream)}
.btn:hover::after{transform:translateY(0)}
.btn--gold{border-color:var(--gold-deep);color:var(--ink)}
.btn--gold::after{background:var(--gold)}
.btn--gold:hover{color:var(--black);border-color:var(--gold)}
.btn--solid{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.btn--solid::after{background:var(--gold)}
.btn--solid:hover{color:var(--black)}
.btn--light{border-color:rgba(255,255,255,.6);color:#fff}
.btn--light::after{background:#fff}
.btn--light:hover{color:var(--ink)}

/* ==========================================================================
   HEADER / NAV
   ========================================================================== */
.header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background .5s var(--ease), box-shadow .5s var(--ease), padding .5s var(--ease);
  padding-block:1.4rem;
}
.header.scrolled{
  background:rgba(253,251,249,.92);
  backdrop-filter:blur(14px);
  box-shadow:0 1px 0 rgba(61,59,58,.08);
  padding-block:.7rem;
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.brand{display:flex;align-items:center;gap:.7rem;line-height:1}
.brand__logo{height:60px;width:auto;transition:height .5s var(--ease)}
.header.scrolled .brand__logo{height:46px}

.menu{display:flex;align-items:center;gap:2.2rem}
.menu a{
  font-family:var(--font-sub);font-size:.92rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink);position:relative;padding-block:.4rem;
  transition:color .3s;
}
.menu a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold-deep);
  transition:width .4s var(--ease);
}
.menu a:hover::after,.menu a.active::after{width:100%}
.menu a.active{color:var(--gold-deep)}

/* Dropdown traitements */
.has-sub{position:relative}
.submenu{
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(10px);
  background:var(--white);box-shadow:var(--shadow-card);
  min-width:280px;padding:1rem 0;opacity:0;visibility:hidden;
  transition:all .35s var(--ease);border-top:2px solid var(--gold);
}
.has-sub:hover .submenu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.submenu a{display:block;padding:.6rem 1.6rem;font-size:.85rem;text-transform:none;letter-spacing:.04em}
.submenu a::after{display:none}
.submenu a:hover{background:var(--blush);color:var(--gold-deep)}

.nav-cta{display:flex;align-items:center;gap:1.2rem}
.burger{display:none;flex-direction:column;gap:5px;width:30px;z-index:1100}
.burger span{height:1.5px;width:100%;background:var(--ink);transition:.4s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Mobile drawer */
.mobile-menu{
  position:fixed;inset:0;background:var(--cream);z-index:1050;
  padding:7rem var(--gutter) 3rem;
  transform:translateX(100%);transition:transform .55s var(--ease);
  overflow-y:auto;
}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu a{
  display:block;font-family:var(--font-display);font-size:1.8rem;
  padding:.55rem 0;border-bottom:1px solid rgba(61,59,58,.1);color:var(--ink);
}
.mobile-menu .sub-link{font-size:1.15rem;font-family:var(--font-body);padding-left:1.2rem;color:var(--ink-soft);border:none}
.mobile-menu .mm-label{font-family:var(--font-sub);text-transform:uppercase;letter-spacing:.3em;
  font-size:.7rem;color:var(--gold-deep);margin-top:1.5rem;display:block}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{
  position:relative;min-height:50svh;display:flex;align-items:center;
  background:linear-gradient(105deg,var(--blush) 0%,#fff 42%,var(--blush-deep) 100%);
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 20%,rgba(230,195,113,.18),transparent 45%),
             radial-gradient(circle at 10% 90%,rgba(209,165,175,.22),transparent 40%);
}
.hero__grid{
  position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;
  align-items:center;width:100%;
}
.hero__content{padding-block:8rem}
.hero h1{margin:.6rem 0 1.4rem}
.hero h1 em{font-style:italic;color:var(--gold-deep)}
.hero__quote{
  font-style:italic;font-size:1.25rem;color:var(--ink-soft);
  border-left:2px solid var(--gold);padding-left:1.3rem;margin:2rem 0;max-width:46ch;
}
.hero__quote cite{display:block;font-style:normal;font-size:.85rem;letter-spacing:.15em;
  text-transform:uppercase;color:var(--nude);margin-top:.6rem;font-family:var(--font-sub)}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2.4rem}
.hero__visual{position:relative;align-self:stretch;min-height:60vh}
.hero__arch{
  position:absolute;inset:0;
  border-radius:45% 45% 6px 6px/45% 45% 6px 6px;
  background:linear-gradient(160deg,var(--nude-soft),var(--blush));
  box-shadow:var(--shadow-card);overflow:hidden;
}
.hero__arch img{width:100%;height:100%;object-fit:cover;mix-blend-mode:multiply;opacity:.92}
.hero__badge{
  position:absolute;bottom:-26px;left:-26px;background:var(--white);
  padding:1.3rem 1.6rem;box-shadow:var(--shadow-card);max-width:230px;
  border-bottom:3px solid var(--gold);
}
.hero__badge strong{font-family:var(--font-display);font-size:1.05rem;color:var(--ink);display:block}
.hero__badge span{font-size:.95rem;color:var(--ink-soft)}
.hero__scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  font-family:var(--font-sub);font-size:.7rem;letter-spacing:.35em;text-transform:uppercase;
  color:var(--ink-soft);display:flex;flex-direction:column;align-items:center;gap:.6rem;
}
.hero__scroll::after{content:"";width:1px;height:42px;background:var(--gold-deep);animation:scrollLine 2s var(--ease) infinite}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ==========================================================================
   INTRO / SPLIT
   ========================================================================== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split--reverse .split__media{order:2}
.split__media{position:relative}
.split__media img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:2px;box-shadow:var(--shadow-soft)}
.split__media .frame{
  position:absolute;inset:18px -18px -18px 18px;border:1px solid var(--gold);z-index:-1;
}
.split__body .overline{margin-bottom:1rem}
.split__body h2{margin-bottom:1.4rem}
.split__body p+p{margin-top:1.1rem}
.split__body .btn{margin-top:2rem}

/* ==========================================================================
   TREATMENTS GRID
   ========================================================================== */
.treat-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:1.6rem;margin-top:3.5rem;
}
.treat-card{
  position:relative;background:var(--white);padding:2.4rem 2rem;
  border:1px solid rgba(61,59,58,.08);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s;
  overflow:hidden;
}
.treat-card::before{
  content:"";position:absolute;top:0;left:0;width:100%;height:3px;
  background:linear-gradient(90deg,var(--gold),var(--nude));
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);
}
.treat-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-card);border-color:transparent}
.treat-card:hover::before{transform:scaleX(1)}
.treat-card__num{font-family:var(--font-display);font-size:.85rem;color:var(--gold-deep);letter-spacing:.1em}
.treat-card h3{margin:.8rem 0 .7rem;font-size:1.35rem}
.treat-card p{font-size:1.02rem;color:var(--ink-soft);line-height:1.55}
.treat-card__link{
  display:inline-flex;align-items:center;gap:.5em;margin-top:1.2rem;
  font-family:var(--font-sub);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink);transition:gap .3s,color .3s;
}
.treat-card:hover .treat-card__link{gap:.9em;color:var(--gold-deep)}

/* Carte de soin avec image */
.treat-card--img{padding:0;display:flex;flex-direction:column}
.treat-card--img .treat-card__img{aspect-ratio:3/2;overflow:hidden}
.treat-card--img .treat-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.treat-card--img:hover .treat-card__img img{transform:scale(1.06)}
.treat-card--img .treat-card__inner{padding:1.8rem 1.7rem 2rem}
.treat-card--img .treat-card__num{color:var(--gold-deep)}
.treat-card--img h3{margin:.5rem 0 .6rem}

/* ==========================================================================
   STATS / VALUES
   ========================================================================== */
.values{background:var(--ink);color:var(--blush)}
.values h2{color:var(--white)}
.values .overline{color:var(--gold)}
.values .lead{color:rgba(249,238,246,.75)}
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;margin-top:3.5rem}
.value-item{text-align:center;padding:2rem 1rem;position:relative}
.value-item:not(:last-child)::after{content:"";position:absolute;right:0;top:20%;height:60%;width:1px;background:rgba(230,195,113,.3)}
.value-item .ic{font-family:var(--font-display);font-size:2.6rem;color:var(--gold);display:block;margin-bottom:.6rem}
.value-item h3{color:var(--white);font-size:1.3rem;margin-bottom:.6rem}
.value-item p{color:rgba(249,238,246,.7);font-size:1.02rem}

/* ==========================================================================
   STATS COUNTER
   ========================================================================== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.stat__num{font-family:var(--font-display);font-size:clamp(2.4rem,5vw,3.6rem);color:var(--gold-deep);line-height:1}
.stat__label{font-family:var(--font-sub);text-transform:uppercase;letter-spacing:.2em;font-size:.78rem;color:var(--ink-soft);margin-top:.6rem}

/* ==========================================================================
   CTA BANNER
   ========================================================================== */
.cta-band{
  position:relative;background:linear-gradient(120deg,var(--nude),var(--gold));
  text-align:center;color:var(--white);overflow:hidden;
}
.cta-band::before{content:"";position:absolute;inset:0;background:rgba(26,24,23,.12)}
.cta-band .wrap{position:relative}
.cta-band h2{color:#fff;margin-bottom:1rem}
.cta-band p{color:rgba(255,255,255,.9);max-width:50ch;margin:0 auto 2rem}

/* ==========================================================================
   CTA SPLIT — texte à gauche, image à droite (côte à côte)
   ========================================================================== */
.cta-split{
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:stretch;
  overflow:hidden;
}
.cta-split__text{
  background:linear-gradient(120deg,var(--nude),var(--gold));
  color:var(--white);
  padding:clamp(3rem,6vw,6rem);
  display:flex;flex-direction:column;justify-content:center;
  text-align:center;
  position:relative;
}
.cta-split__text::before{content:"";position:absolute;inset:0;background:rgba(26,24,23,.10)}
.cta-split__text>*{position:relative}
.cta-split__text .overline{color:rgba(255,255,255,.85);margin-bottom:1rem}
.cta-split__text h2{color:#fff;margin-bottom:1rem}
.cta-split__text p{color:rgba(255,255,255,.92);max-width:42ch;margin:0 auto 2rem}
.cta-split__text .btn{align-self:center}
.cta-split__img{position:relative;overflow:hidden;min-height:420px}
.cta-split__img img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;
}
@media (max-width:768px){
  .cta-split{grid-template-columns:1fr}
  .cta-split__img{min-height:300px;order:-1}
}

/* ==========================================================================
   COLLAB / LOGOS
   ========================================================================== */
.collab{text-align:center}
.collab__logos{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;
  gap:clamp(1.5rem,3vw,2.5rem);margin-top:3.5rem;
}
.collab__item{
  display:flex;flex-direction:column;align-items:center;gap:1.1rem;
  flex:0 0 auto;
}
.collab__card{
  width:180px;height:180px;
  background:var(--white);
  border:1px solid rgba(61,59,58,.08);
  border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  padding:1rem;
  overflow:hidden;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.collab__card:hover{transform:translateY(-6px);box-shadow:var(--shadow-card)}
.collab__card img{
  max-height:100%;max-width:100%;width:auto;height:auto;object-fit:contain;
  transition:transform .4s var(--ease);
}
.collab__item figcaption{
  font-family:var(--font-sub);text-transform:uppercase;letter-spacing:.18em;
  font-size:.74rem;color:var(--ink-soft);
  transition:color .3s;
}
.collab__item:hover figcaption{color:var(--gold-deep)}

/* Réglage individuel de chaque logo (ajuste les chiffres à ton goût) */
.logo-mommy{transform:scale(3.5)}
.logo-aura{transform:scale(4)}
.logo-imsarm{transform:scale(4.4)}
.logo-deleo{transform:scale(1)}


/* ==========================================================================
   FOOTER
   ========================================================================== */
.footer{background:var(--black);color:var(--blush);padding-block:5rem 2rem}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:3rem}
.footer__brand .brand__name{color:#fff}
.footer p{color:rgba(249,238,246,.6);font-size:1rem;margin-top:1rem;max-width:34ch}
.footer h4{font-family:var(--font-sub);text-transform:uppercase;letter-spacing:.25em;font-size:.78rem;
  color:var(--gold);margin-bottom:1.3rem;font-weight:500}
.footer ul li{margin-bottom:.7rem}
.footer ul a{color:rgba(249,238,246,.7);font-size:1.02rem;transition:color .3s,padding .3s}
.footer ul a:hover{color:var(--gold);padding-left:5px}
.footer__contact li{color:rgba(249,238,246,.7);font-size:1.02rem;margin-bottom:.7rem}
.footer__bottom{
  margin-top:3.5rem;padding-top:1.8rem;border-top:1px solid rgba(249,238,246,.12);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  font-size:.88rem;color:rgba(249,238,246,.5);
}
.footer__bottom a{color:rgba(249,238,246,.5)}
.footer__bottom a:hover{color:var(--gold)}

/* ==========================================================================
   PAGE HEADER (sous-pages)
   ========================================================================== */
.page-hero{
  padding:11rem var(--gutter) 2rem;text-align:center;
  background:linear-gradient(160deg,var(--blush),#fff);position:relative;overflow:hidden;
}
.page-hero::before{content:"";position:absolute;top:-30%;right:-10%;width:50%;height:160%;
  background:radial-gradient(circle,rgba(230,195,113,.15),transparent 70%)}
.page-hero .overline{margin-bottom:1rem}
.page-hero h1{position:relative}
.page-hero p{position:relative;margin:1.3rem auto 0;max-width:55ch;color:var(--ink-soft);font-size:1.2rem}
.breadcrumb{position:relative;font-family:var(--font-sub);font-size:.8rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-soft);margin-top:1.5rem}
.breadcrumb a:hover{color:var(--gold-deep)}

/* ==========================================================================
   TEAM
   ========================================================================== */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2.5rem;margin-top:3.5rem}
.team-card{text-align:center}
.team-card__photo{
  aspect-ratio:3/4;background:linear-gradient(160deg,var(--nude-soft),var(--blush));
  border-radius:200px 200px 4px 4px;overflow:hidden;margin-bottom:1.5rem;position:relative;
}
.team-card__photo img{width:100%;height:100%;object-fit:cover}
.team-card h3{font-size:1.4rem}
.team-card .role{font-family:var(--font-sub);text-transform:uppercase;letter-spacing:.18em;
  font-size:.78rem;color:var(--gold-deep);margin-top:.4rem;display:block}

/* ==========================================================================
   CONTACT
   ========================================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem)}
.contact-info h3{margin-bottom:1.5rem}
.contact-info .info-row{display:flex;gap:1rem;margin-bottom:1.6rem;align-items:flex-start}
.contact-info .info-row .ic{font-family:var(--font-display);color:var(--gold-deep);font-size:1.3rem;flex:none;width:2rem}
.contact-info .info-row strong{display:block;font-family:var(--font-display);color:var(--ink);font-size:1.1rem}
.contact-info .info-row span{color:var(--ink-soft);font-size:1.05rem}
.form-field{margin-bottom:1.4rem}
.form-field label{display:block;font-family:var(--font-sub);text-transform:uppercase;
  letter-spacing:.12em;font-size:.78rem;color:var(--ink-soft);margin-bottom:.5rem}
.form-field input,.form-field textarea,.form-field select{
  width:100%;padding:.95rem 1.1rem;border:1px solid rgba(61,59,58,.2);
  background:var(--white);font-family:var(--font-body);font-size:1.08rem;color:var(--ink);
  transition:border-color .3s,box-shadow .3s;
}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(230,195,113,.18);
}
.form-note{font-size:.95rem;color:var(--ink-soft);margin-top:1rem}

/* ==========================================================================
   MODAL PRISE DE RDV (choix médecin)
   ========================================================================== */
.rdv-overlay{
  position:fixed;inset:0;z-index:2000;background:rgba(26,24,23,.55);
  backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;
  padding:1.5rem;opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s;
}
.rdv-overlay.open{opacity:1;visibility:visible}
.rdv-modal{
  background:var(--cream);max-width:640px;width:100%;padding:clamp(2rem,5vw,3.5rem);
  position:relative;transform:translateY(20px) scale(.98);transition:transform .45s var(--ease);
  border-top:3px solid var(--gold);box-shadow:var(--shadow-card);
}
.rdv-overlay.open .rdv-modal{transform:none}
.rdv-modal .overline{margin-bottom:.6rem}
.rdv-modal h3{margin-bottom:.4rem}
.rdv-modal>p{color:var(--ink-soft);margin-bottom:2rem}
.rdv-close{position:absolute;top:1.1rem;right:1.3rem;font-size:1.8rem;line-height:1;color:var(--ink-soft);transition:color .3s,transform .3s}
.rdv-close:hover{color:var(--gold-deep);transform:rotate(90deg)}
.rdv-choice{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.rdv-card{
  display:block;padding:1.8rem 1.5rem;background:var(--white);border:1px solid rgba(61,59,58,.1);
  text-align:center;transition:transform .4s var(--ease),box-shadow .4s,border-color .4s;
}
.rdv-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-card);border-color:var(--gold)}
.rdv-card .doc{font-family:var(--font-display);font-size:1.3rem;color:var(--ink);display:block;margin-bottom:.3rem}
.rdv-card .spec{font-family:var(--font-sub);text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--gold-deep);display:block;margin-bottom:.4rem}
.rdv-card .loc{font-size:.98rem;color:var(--ink-soft);display:block;margin-bottom:1.2rem}
.rdv-card .pill{display:inline-block;font-family:var(--font-sub);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--white);background:var(--ink);padding:.55em 1.4em;transition:background .3s}
.rdv-card:hover .pill{background:var(--gold-deep)}

/* ==========================================================================
   CARTES MÉDECINS (page équipe)
   ========================================================================== */
.doctor{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:center;margin-bottom:clamp(3rem,7vw,6rem)}
.doctor:last-child{margin-bottom:0}
.doctor--reverse .doctor__media{order:2}
.doctor__media{position:relative}
.doctor__media img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center top;box-shadow:var(--shadow-soft)}
.doctor__media .frame{position:absolute;inset:16px -16px -16px 16px;border:1px solid var(--gold);z-index:-1}
.doctor__body .overline{margin-bottom:.8rem}
.doctor__body h3{font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:.3rem}
.doctor__body .doctor__spec{font-family:var(--font-sub);text-transform:uppercase;letter-spacing:.16em;font-size:.82rem;color:var(--gold-deep);display:block;margin-bottom:1.5rem}
.doctor__cv{list-style:none;margin:1.5rem 0}
.doctor__cv li{position:relative;padding-left:1.6rem;margin-bottom:.7rem;color:var(--ink-soft);font-size:1.05rem;line-height:1.45}
.doctor__cv li::before{content:"✦";position:absolute;left:0;color:var(--gold-deep);font-size:.8rem;top:.25rem}
.doctor__contact{font-size:1rem;color:var(--ink-soft);margin:1.2rem 0 1.8rem;line-height:1.7}
.doctor__contact strong{color:var(--ink);font-family:var(--font-display);font-weight:500}

/* ==========================================================================
   LOGOS PARTENAIRES (images réelles)
   ========================================================================== */
.collab__logos img{height:46px;width:auto;object-fit:contain;opacity:.6;transition:opacity .4s,transform .4s;filter:grayscale(20%)}
.collab__logos img:hover{opacity:1;transform:scale(1.06);filter:none}
.collab__logos .badge-pilote{height:90px}

/* ==========================================================================
   ANIMATIONS (reveal on scroll)
   ========================================================================== */
[data-reveal]{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:.1s}
[data-reveal-delay="2"]{transition-delay:.2s}
[data-reveal-delay="3"]{transition-delay:.3s}
[data-reveal-delay="4"]{transition-delay:.4s}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width:1024px){
  .hero__grid{grid-template-columns:1fr;gap:0}
  .hero__visual{display:none}
  .hero__content{padding-block:9rem 6rem}
  .value-grid{grid-template-columns:1fr;gap:1rem}
  .value-item:not(:last-child)::after{display:none}
  .value-item{border-bottom:1px solid rgba(230,195,113,.2)}
  .footer__grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:repeat(2,1fr);gap:2.5rem}
}
@media (max-width:768px){
  body{font-size:1.1rem}
  .menu,.nav-cta .btn{display:none}
  .burger{display:flex}
  .split{grid-template-columns:1fr}
  .split--reverse .split__media{order:0}
  .split__media .frame{display:none}
  .contact-grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .footer__bottom{flex-direction:column;text-align:center}
  .hero__badge{position:static;margin-top:2rem;max-width:none}
}