/* =========================================================
   AU PETIT PARIS — Maison de Mariage, Béziers
   DA sur-mesure : bleu de Paris (enseigne) · ivoire · champagne
   Prata (display) · Outfit (UI) · Pinyon Script (wordmark)
   ========================================================= */

:root{
  --cream:#F6F0E6;
  --cream-2:#EFE6D7;
  --cream-3:#E7DCC9;
  --navy:#1B2A3A;
  --navy-2:#15212E;
  --navy-ink:#0E1822;
  --gold:#A9853F;        /* gold for text/lines sur ivoire (lisible) */
  --gold-soft:#C7A86B;   /* gold doux sur navy */
  --blush:#E7CBC4;
  --rose:#BC8579;
  --ink:#26211B;
  --muted:#6F665B;
  --line:rgba(27,42,58,.13);
  --line-gold:rgba(169,133,63,.34);
  --shadow:0 24px 60px -28px rgba(20,30,42,.45);
  --shadow-sm:0 12px 30px -18px rgba(20,30,42,.4);
  --wrap:1180px;
  --r:14px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --t:.55s var(--ease);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:"Outfit",system-ui,-apple-system,"Segoe UI",sans-serif;
  font-size:clamp(16px,1.1vw,17px);line-height:1.7;font-weight:300;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3{font-family:"Prata",Georgia,serif;font-weight:400;line-height:1.12;
  letter-spacing:.005em;color:var(--navy);margin:0}
::selection{background:var(--navy);color:var(--cream)}
.skip{position:fixed;left:-999px;top:0;z-index:200;background:var(--navy);color:#fff;padding:.7rem 1rem}
.skip:focus{left:8px;top:8px}

.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(20px,5vw,40px)}
section[id]{scroll-margin-top:74px}
.section{padding-block:clamp(64px,9vw,120px)}
.muted{color:var(--muted)}

/* ---------- Eyebrow + section heads ---------- */
.eyebrow{font-family:"Outfit";font-weight:600;font-size:.72rem;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold);margin:0 0 1rem}
.eyebrow--light{color:var(--gold-soft)}
.eyebrow::before{content:"";display:inline-block;width:26px;height:1px;background:var(--gold);
  vertical-align:middle;margin-right:.7em;opacity:.7}
.sec-head{max-width:660px;margin:0 auto clamp(40px,6vw,68px);text-align:center}
.sec-head h2{font-size:clamp(2rem,5.4vw,3.1rem)}
.sec-head__lede{margin:1.1rem auto 0;color:var(--muted);max-width:54ch}
h2{font-size:clamp(1.9rem,5vw,2.8rem)}
h3{font-size:1.34rem}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:"Outfit";font-weight:500;font-size:.82rem;letter-spacing:.13em;text-transform:uppercase;
  padding:1.05em 1.7em;border-radius:999px;border:1px solid transparent;transition:.4s var(--ease);
  white-space:nowrap;line-height:1}
.btn .ico{font-size:1em;transform:translateY(.5px)}
.btn--gold{background:var(--gold);color:#fff;box-shadow:0 14px 30px -16px rgba(169,133,63,.8)}
.btn--gold:hover{background:#946f31;transform:translateY(-2px)}
.btn--ink{background:transparent;color:var(--navy);border-color:rgba(27,42,58,.32)}
.btn--ink:hover{background:var(--navy);color:var(--cream);border-color:var(--navy);transform:translateY(-2px)}
.btn--glass{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.5);backdrop-filter:blur(6px)}
.btn--glass:hover{background:rgba(255,255,255,.22);transform:translateY(-2px)}
.btn--ghost-d{background:transparent;color:var(--cream);border-color:rgba(246,240,230,.4)}
.btn--full{width:100%}
.link-gold{font-family:"Outfit";font-weight:600;font-size:.8rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--gold);transition:.3s}
.link-gold:hover{color:#946f31;letter-spacing:.16em}

/* =========================================================
   HEADER
   ========================================================= */
.hdr{position:fixed;inset:0 0 auto;z-index:90;transition:.45s var(--ease)}
.hdr__in{max-width:1320px;margin-inline:auto;padding:clamp(14px,2.4vw,22px) clamp(18px,5vw,40px);
  display:flex;align-items:center;gap:1.4rem}
.brand{display:flex;flex-direction:column;line-height:1;margin-right:auto}
.brand__script{font-family:"Pinyon Script",cursive;font-size:1.95rem;color:var(--cream);
  letter-spacing:.01em;transition:color .45s var(--ease);line-height:.9;padding-top:.1em}
.brand__sub{font-family:"Outfit";font-weight:500;font-size:.56rem;letter-spacing:.34em;
  text-transform:uppercase;color:var(--blush);margin-top:.5em;transition:color .45s var(--ease)}
.nav{display:none;gap:1.7rem}
.nav a{font-family:"Outfit";font-weight:400;font-size:.82rem;letter-spacing:.06em;color:var(--cream);
  position:relative;padding:.2em 0;transition:color .3s;opacity:.92}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--gold-soft);transition:width .35s var(--ease)}
.nav a:hover{opacity:1}
.nav a:hover::after{width:100%}
.hdr__cta{display:none;padding:.85em 1.4em;font-size:.74rem}

/* header scrolled / solid */
.hdr.is-solid{background:rgba(246,240,230,.92);backdrop-filter:blur(12px);
  box-shadow:0 1px 0 var(--line),0 18px 40px -34px rgba(20,30,42,.5)}
.hdr.is-solid .brand__script{color:var(--navy)}
.hdr.is-solid .brand__sub{color:var(--gold)}
.hdr.is-solid .nav a{color:var(--navy)}
.hdr.is-solid .burger span{background:var(--navy)}

/* burger */
.burger{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;
  background:none;border:0;padding:0}
.burger span{display:block;width:24px;height:1.5px;background:var(--cream);margin-inline:auto;transition:.35s var(--ease)}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* drawer */
.drawer{position:fixed;inset:0;z-index:80;background:rgba(21,33,46,.97);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:.45s var(--ease)}
.drawer.open{opacity:1;visibility:visible}
.drawer__nav{display:flex;flex-direction:column;align-items:center;gap:1.4rem;text-align:center;padding:2rem}
.drawer__nav a:not(.btn){font-family:"Prata",serif;font-size:1.7rem;color:var(--cream);
  transform:translateY(14px);opacity:0;transition:.5s var(--ease)}
.drawer.open .drawer__nav a:not(.btn){transform:none;opacity:1}
.drawer__nav a:nth-child(2){transition-delay:.06s}.drawer__nav a:nth-child(3){transition-delay:.12s}
.drawer__nav a:nth-child(4){transition-delay:.18s}.drawer__nav a:nth-child(5){transition-delay:.24s}
.drawer__rule{width:60px;height:1px;background:var(--line-gold);margin:.4rem 0}
.drawer .btn{min-width:230px;transform:translateY(14px);opacity:0;transition:.5s var(--ease) .3s}
.drawer.open .btn{transform:none;opacity:1}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;isolation:isolate}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{width:100%;height:115%;object-fit:cover;object-position:50% 32%;will-change:transform}
.hero__scrim{position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(to top,rgba(14,24,34,.86) 0%,rgba(14,24,34,.34) 38%,rgba(14,24,34,.12) 62%,rgba(14,24,34,.42) 100%),
    radial-gradient(120% 80% at 50% 120%,rgba(14,24,34,.5),transparent 60%)}
.hero__in{position:relative;width:100%;max-width:var(--wrap);margin-inline:auto;
  padding:0 clamp(20px,5vw,40px) clamp(72px,12vw,120px);color:var(--cream)}
.hero__title{margin:.2em 0 0}
.hero__script{display:block;font-family:"Pinyon Script",cursive;font-weight:400;
  font-size:clamp(2.1rem,7.5vw,4rem);color:var(--blush);line-height:1;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero__big{display:block;font-family:"Prata",serif;color:#fff;
  font-size:clamp(2.1rem,9.6vw,6rem);line-height:1;margin-top:.1em;text-shadow:0 4px 40px rgba(0,0,0,.35)}
.hero__lede{max-width:46ch;margin:1.4rem 0 0;color:rgba(246,240,230,.92);font-weight:300;
  font-size:clamp(1rem,1.5vw,1.12rem)}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2rem}
.hero__scroll{position:absolute;left:50%;bottom:22px;translate:-50% 0;width:26px;height:42px;
  border:1px solid rgba(246,240,230,.5);border-radius:14px;z-index:1}
.hero__scroll span{position:absolute;left:50%;top:8px;translate:-50% 0;width:3px;height:8px;border-radius:2px;
  background:var(--blush);animation:scroll 1.8s var(--ease) infinite}
@keyframes scroll{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,14px)}}

/* =========================================================
   BANDEAU CONFIANCE
   ========================================================= */
.strip{background:var(--navy);color:var(--cream)}
.strip__in{list-style:none;margin:0;padding:clamp(34px,5vw,52px) clamp(20px,5vw,40px);
  max-width:var(--wrap);margin-inline:auto;display:grid;grid-template-columns:repeat(2,1fr);
  gap:clamp(26px,5vw,40px) 1rem;text-align:center}
.strip__in li{display:flex;flex-direction:column;gap:.35rem;position:relative}
.strip__in b{font-family:"Prata",serif;font-size:clamp(2rem,6vw,2.8rem);color:#fff;line-height:1}
.strip__in b i{font-style:normal;color:var(--gold-soft);font-size:.55em}
.strip__in span{font-size:.78rem;letter-spacing:.05em;color:rgba(246,240,230,.72);text-transform:uppercase}

/* =========================================================
   LA MAISON
   ========================================================= */
.maison{background:var(--cream)}
.maison__grid{display:grid;gap:clamp(34px,6vw,72px);align-items:center}
.maison__media{position:relative}
.maison__media img{width:100%;border-radius:var(--r);box-shadow:var(--shadow);
  aspect-ratio:4/5;object-fit:cover}
.maison__badge{position:absolute;right:-6px;bottom:-18px;width:118px;height:118px;border-radius:50%;
  background:var(--navy);color:var(--cream);display:grid;place-items:center;text-align:center;
  box-shadow:var(--shadow);border:1px solid var(--gold-soft)}
.maison__badge-num{font-family:"Prata",serif;font-size:1.18rem;line-height:1.15}
.maison__badge::after{content:"";position:absolute;inset:7px;border:1px solid rgba(199,168,107,.4);border-radius:50%}
.maison__txt h2{font-size:clamp(2rem,5.2vw,2.9rem);margin-bottom:.2em}
.maison__txt p{margin:0 0 1.05rem;color:#403a32}
.maison__txt p strong{font-weight:600;color:var(--navy)}
.maison__txt em{font-style:italic;color:var(--rose)}
.maison__sign{margin:1.6rem 0 1.8rem;padding-top:1.4rem;border-top:1px solid var(--line)}
.sign__script{display:block;font-family:"Pinyon Script",cursive;font-size:2.2rem;color:var(--navy);line-height:.9}
.sign__role{font-family:"Outfit";font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold)}

/* =========================================================
   PRESTATIONS
   ========================================================= */
.presta{background:linear-gradient(180deg,var(--cream),var(--cream-2))}
.presta__grid{display:grid;gap:18px;grid-template-columns:1fr}
.pcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2rem 1.6rem;
  position:relative;overflow:hidden;transition:.45s var(--ease);min-height:200px;
  display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line-gold)}
.pcard__ico{font-size:1.7rem;color:var(--gold);line-height:1;margin-bottom:.9rem}
.pcard h3{margin-bottom:.5rem}
.pcard p{margin:0;color:var(--muted);font-size:.97rem}
.pcard em{font-style:italic;color:var(--rose);font-weight:400}
.pcard .link-gold{margin-top:auto;padding-top:1rem;align-self:flex-start}
.pcard--cta{background:var(--navy);border-color:var(--navy)}
.pcard--cta h3{color:#fff}.pcard--cta p{color:rgba(246,240,230,.74)}
.pcard--cta .pcard__ico{color:var(--gold-soft)}
/* photo cards */
.pcard--photo{min-height:330px;justify-content:flex-end;border:0;color:#fff}
.pcard--photo::before{content:"";position:absolute;inset:0;background:var(--bg) center/cover;
  transition:transform .8s var(--ease);z-index:0}
.pcard--photo::after{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(to top,rgba(14,24,34,.9),rgba(14,24,34,.28) 55%,rgba(14,24,34,.08))}
.pcard--photo:hover::before{transform:scale(1.06)}
.pcard--photo .pcard__body{position:relative;z-index:1}
.pcard--photo h3{color:#fff}
.pcard--photo p{color:rgba(255,255,255,.88)}
.pcard--photo em{color:var(--blush)}

/* =========================================================
   GALERIE
   ========================================================= */
.gal{background:var(--cream-2)}
.gal__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;
  max-width:1320px;margin:0 auto;padding-inline:clamp(12px,4vw,24px)}
.gal__item{position:relative;margin:0;overflow:hidden;border-radius:10px;cursor:pointer;
  aspect-ratio:3/4;background:var(--cream-3)}
.gal__item img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.gal__item:hover img{transform:scale(1.07)}
.gal__item::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(14,24,34,.6),transparent 45%);
  opacity:0;transition:.4s}
.gal__item:hover::after{opacity:1}
.gal__item figcaption{position:absolute;left:14px;bottom:12px;z-index:2;color:#fff;
  font-family:"Prata",serif;font-size:.96rem;opacity:0;transform:translateY(8px);transition:.45s var(--ease);
  text-shadow:0 2px 14px rgba(0,0,0,.5)}
.gal__item:hover figcaption{opacity:1;transform:none}
.gal__more{text-align:center;margin-top:30px}

/* =========================================================
   CITATION
   ========================================================= */
.quote{position:relative;color:var(--cream);text-align:center;isolation:isolate;
  padding-block:clamp(72px,12vw,130px)}
.quote__media{position:absolute;inset:0;z-index:-2}
.quote__media img{width:100%;height:100%;object-fit:cover;object-position:50% 30%;filter:saturate(.9)}
.quote::before{content:"";position:absolute;inset:0;z-index:-1;background:rgba(14,24,34,.74)}
.quote__in{max-width:760px;margin-inline:auto;padding-inline:clamp(24px,6vw,40px)}
.quote__mark{font-family:"Prata",serif;font-size:4rem;color:var(--gold-soft);line-height:.4;display:block;height:.5em}
.quote__in p{font-family:"Prata",serif;font-size:clamp(1.3rem,3.4vw,2rem);line-height:1.45;color:#fff;margin:.4em 0 1rem}
.quote__in cite{font-style:normal;font-family:"Outfit";font-size:.78rem;letter-spacing:.24em;
  text-transform:uppercase;color:var(--blush)}

/* =========================================================
   AVIS
   ========================================================= */
.avis{background:var(--cream)}
.avis__grid{display:grid;gap:18px;grid-template-columns:1fr}
.rev{margin:0;background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:1.7rem 1.6rem;box-shadow:var(--shadow-sm);position:relative}
.rev__stars{color:var(--gold);letter-spacing:.18em;font-size:.95rem;margin-bottom:.7rem}
.rev blockquote{margin:0 0 1.1rem;font-size:.98rem;line-height:1.65;color:#3c362e}
.rev figcaption{display:flex;flex-direction:column;border-top:1px solid var(--line);padding-top:.9rem}
.rev figcaption b{font-family:"Prata",serif;font-weight:400;font-size:1.05rem;color:var(--navy)}
.rev figcaption span{font-size:.76rem;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}
.avis__src{text-align:center;margin-top:2rem;font-size:.84rem;color:var(--muted)}
.avis__src a{color:var(--gold);font-weight:500}

/* =========================================================
   INFOS
   ========================================================= */
.infos{background:linear-gradient(180deg,var(--cream-2),var(--cream))}
.infos__grid{display:grid;gap:clamp(30px,5vw,56px);align-items:center}
.infos__txt h2{font-size:clamp(1.9rem,5vw,2.7rem);margin-bottom:.3em}
.infos__list{list-style:none;margin:1.6rem 0;padding:0;display:flex;flex-direction:column;gap:1.15rem}
.infos__list li{display:flex;gap:1rem;align-items:flex-start}
.il__ico{flex:0 0 auto;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  background:#fff;border:1px solid var(--line-gold);color:var(--gold);font-size:1.15rem}
.infos__list b{display:block;font-family:"Outfit";font-weight:600;font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--navy);margin-bottom:.2rem}
.infos__list a:hover{color:var(--gold)}
.infos__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:.5rem}
.infos__map{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);
  min-height:300px;background:var(--cream-3)}
.infos__map iframe{width:100%;height:100%;min-height:340px;border:0;display:block;filter:grayscale(.2) contrast(1.02)}

/* =========================================================
   RENDEZ-VOUS
   ========================================================= */
.rdv{background:var(--navy);color:var(--cream);position:relative;overflow:hidden}
.rdv::before{content:"";position:absolute;right:-10%;top:-30%;width:60%;height:120%;
  background:radial-gradient(closest-side,rgba(199,168,107,.12),transparent);pointer-events:none}
.rdv__grid{display:grid;gap:clamp(34px,5vw,60px);align-items:start;position:relative}
.rdv__intro h2{color:#fff;font-size:clamp(2rem,5.4vw,3rem)}
.rdv__intro .eyebrow{color:var(--gold-soft)}
.rdv__intro p{color:rgba(246,240,230,.82)}
.rdv__direct{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.6rem}
.rdv__chip{display:inline-flex;align-items:center;gap:.5em;padding:.7em 1.1em;border-radius:999px;
  border:1px solid rgba(246,240,230,.28);font-size:.86rem;letter-spacing:.03em;transition:.35s var(--ease)}
.rdv__chip span{color:var(--gold-soft)}
.rdv__chip:hover{background:rgba(246,240,230,.08);border-color:var(--gold-soft);transform:translateY(-2px)}
.rdv__form{background:var(--cream);border-radius:var(--r);padding:clamp(22px,4vw,34px);
  box-shadow:var(--shadow);color:var(--ink)}
.field{margin-bottom:1.05rem}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.05rem}
.field label{display:block;font-family:"Outfit";font-weight:500;font-size:.72rem;letter-spacing:.13em;
  text-transform:uppercase;color:var(--navy);margin-bottom:.45rem}
.field input,.field select,.field textarea{width:100%;font-family:"Outfit";font-size:.98rem;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:10px;padding:.85em .95em;transition:.3s;font-weight:300}
.field textarea{resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(169,133,63,.14)}
.field input::placeholder,.field textarea::placeholder{color:#a99f90}
.rdv__note{font-size:.78rem;color:var(--muted);text-align:center;margin:.9rem 0 0}
.rdv__ok{margin:1rem 0 0;padding:.9rem 1rem;border-radius:10px;background:rgba(169,133,63,.12);
  border:1px solid var(--line-gold);color:#7a5f24;text-align:center;font-size:.92rem}

/* =========================================================
   FOOTER
   ========================================================= */
.foot{background:var(--navy-2);color:rgba(246,240,230,.78)}
.foot__in{display:grid;gap:2.4rem;padding-block:clamp(48px,7vw,72px)}
.brand__script--lg{font-size:2.6rem;color:var(--cream)}
.brand__sub--light{color:var(--gold-soft)}
.foot__tag{font-family:"Prata",serif;font-style:italic;color:var(--blush);margin:.9rem 0 0;font-size:1.05rem}
.foot__nav{display:flex;flex-wrap:wrap;gap:.4rem 1.4rem}
.foot__nav a{font-size:.86rem;letter-spacing:.05em;transition:.3s}
.foot__nav a:hover{color:var(--gold-soft)}
.foot__contact p{margin:.2rem 0;font-size:.92rem}
.foot__contact a:hover{color:var(--gold-soft)}
.foot__bar{border-top:1px solid rgba(246,240,230,.12);padding-block:1.3rem;
  display:flex;flex-direction:column;gap:.4rem;align-items:center;text-align:center;
  font-size:.76rem;color:rgba(246,240,230,.55)}
.foot__credit strong{color:var(--gold-soft);font-weight:600}

/* =========================================================
   DOCK MOBILE
   ========================================================= */
.dock{position:fixed;left:0;right:0;bottom:0;z-index:70;display:flex;
  background:rgba(21,33,46,.96);backdrop-filter:blur(10px);border-top:1px solid rgba(199,168,107,.25);
  padding-bottom:env(safe-area-inset-bottom)}
.dock a{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:.6rem .3rem;
  color:var(--cream);font-size:.66rem;letter-spacing:.04em}
.dock a span{font-size:1.05rem;color:var(--gold-soft)}
.dock__mid{background:var(--gold);margin:0;}
.dock__mid span{color:#fff}
.dock__mid{color:#fff}

/* =========================================================
   LIGHTBOX
   ========================================================= */
.lb{position:fixed;inset:0;z-index:120;background:rgba(11,18,26,.94);display:none;
  align-items:center;justify-content:center;padding:4vw}
.lb.open{display:flex}
.lb__img{max-width:92vw;max-height:88vh;border-radius:6px;box-shadow:0 30px 80px -20px rgba(0,0,0,.7);
  animation:lbin .4s var(--ease)}
@keyframes lbin{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:none}}
.lb__close,.lb__nav{position:absolute;background:rgba(246,240,230,.1);border:1px solid rgba(246,240,230,.3);
  color:var(--cream);border-radius:50%;width:50px;height:50px;font-size:1.6rem;line-height:1;
  display:grid;place-items:center;transition:.3s}
.lb__close:hover,.lb__nav:hover{background:rgba(246,240,230,.22)}
.lb__close{top:18px;right:18px}
.lb__nav{top:50%;translate:0 -50%}
.lb__prev{left:14px}.lb__next{right:14px}

/* =========================================================
   REVEAL (gated par html.js — fix specificité lea_charee)
   ========================================================= */
html.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
html.js .reveal.in{opacity:1;transform:none}
/* hero : contenu au-dessus de la ligne de flottaison → animation au chargement (pas tributaire du scroll) */
html.js .hero__in .reveal{animation:heroIn 1s var(--ease) both}
html.js .hero__in .reveal:nth-child(1){animation-delay:.2s}
html.js .hero__in .reveal:nth-child(2){animation-delay:.36s}
html.js .hero__in .reveal:nth-child(3){animation-delay:.56s}
html.js .hero__in .reveal:nth-child(4){animation-delay:.74s}
@keyframes heroIn{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){
  html.js .reveal{opacity:1!important;transform:none!important}
  html.js .hero__in .reveal{animation:none!important;opacity:1!important;transform:none!important}
  .hero__scroll span{animation:none}
}
/* mode capture (?shot) : tout visible, sans animation — pour screenshots headless */
html.shot .reveal,html.shot .hero__in .reveal{opacity:1!important;transform:none!important;animation:none!important}
html.shot .hero{min-height:0;height:700px}
html.shot .hero__scroll{display:none}

/* =========================================================
   RESPONSIVE — tablette
   ========================================================= */
@media (min-width:600px){
  .presta__grid{grid-template-columns:repeat(2,1fr)}
  .avis__grid{grid-template-columns:repeat(2,1fr)}
  .field--row{gap:1rem}
  .foot__bar{flex-direction:row;justify-content:space-between}
}

/* =========================================================
   RESPONSIVE — desktop (restraint : pas surdimensionné)
   ========================================================= */
@media (min-width:1000px){
  body{font-size:16.5px}
  .nav{display:flex}
  .hdr__cta{display:inline-flex}
  .burger{display:none}
  .dock{display:none}
  .hero{min-height:94vh}
  .hero__media img{object-position:50% 28%}
  .hero__in{padding-bottom:clamp(78px,8vw,104px)}
  .strip__in{grid-template-columns:repeat(4,1fr)}
  .strip__in li:not(:last-child)::after{content:"";position:absolute;right:-.5rem;top:50%;translate:0 -50%;
    width:1px;height:46px;background:rgba(246,240,230,.16)}
  .maison__grid{grid-template-columns:0.92fr 1.08fr}
  .maison__grid{gap:72px}
  .presta__grid{grid-template-columns:repeat(3,1fr)}
  .avis__grid{grid-template-columns:repeat(3,1fr)}
  .gal__grid{grid-template-columns:repeat(4,1fr);grid-auto-flow:dense;gap:14px}
  .gal__item--tall{grid-row:span 2;aspect-ratio:3/4}
  .gal__item{aspect-ratio:1}
  .gal__item--wide{grid-column:span 2;aspect-ratio:auto}
  .infos__grid{grid-template-columns:1fr 1.05fr}
  .rdv__grid{grid-template-columns:1fr 1.05fr}
  .foot__in{grid-template-columns:1.4fr 1fr 1fr;align-items:start}
  .pcard--photo{min-height:300px}
}
@media (min-width:1280px){
  .hero__big{font-size:clamp(5rem,7vw,6rem)}
  .gal__item--tall{aspect-ratio:3/4}
}

/* pad bas mobile pour le dock */
@media (max-width:999px){
  body{padding-bottom:62px}
  .drawer{padding-bottom:62px}
}
@media (max-width:560px){
  .eyebrow{letter-spacing:.22em;font-size:.66rem}
  .eyebrow::before{width:18px;margin-right:.55em}
  .hero__in{padding-bottom:clamp(86px,16vw,120px)}
  .hero__lede{font-size:1rem}
  .btn{padding:.95em 1.35em;font-size:.78rem}
  .sec-head__lede,.maison__txt p,.rdv__intro p{font-size:.98rem}
}
