/* Prestige Skin — design system (see DESIGN.md) */
:root{
  /* Cinematic noir × members club — rich black, pearl text, antique gold whisper */
  --ivory:#0F0D0B;         /* page bg — deep rich black with a warm whisper, not muddy brown */
  --sand:#181613;          /* slight surface lift (cards, modal) */
  --ink:#F5F2EC;           /* pearl text */
  --muted:rgba(245,242,236,.66);
  --gold:#C9A227;
  --champagne:#E5C76B;
  --espresso:#0F0D0B;      /* same as bg — no contrast band needed */
  --line:rgba(245,242,236,.16);
  --line-dk:rgba(245,242,236,.16);
  --serif:"Fraunces",Georgia,serif; --sans:"Instrument Sans",system-ui,sans-serif;
  --maxw:1200px; --pad:40px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--ivory);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.eyebrow{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.05;letter-spacing:-.01em}
.rule{height:1px;background:var(--gold);opacity:.5;border:0}
.hairline{height:1px;background:var(--line);border:0}

/* buttons */
/* Ghost CTA — pearl text, thin gold underline. One button style site-wide. */
.btn,.btn-cta,.btn-solid,.btn-gold,.btn-light{
  font-family:var(--sans);font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  cursor:pointer;display:inline-block;text-decoration:none;white-space:nowrap;
  position:relative;padding:6px 2px;color:var(--ink);background:transparent;border:0;border-radius:0;
  transition:color .3s ease
}
.btn::after,.btn-cta::after,.btn-solid::after,.btn-gold::after,.btn-light::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--gold);
  transition:height .25s ease, background .25s ease
}
.btn:hover,.btn-cta:hover,.btn-solid:hover,.btn-gold:hover,.btn-light:hover{color:var(--champagne)}
.btn:hover::after,.btn-cta:hover::after,.btn-solid:hover::after,.btn-gold:hover::after,.btn-light:hover::after{height:2px;background:var(--champagne)}
.btn-sm{font-size:11px;letter-spacing:.14em}

/* nav */
nav.site{position:fixed;top:0;left:0;right:0;width:100%;background:transparent;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:50;transition:opacity .55s ease, transform .55s ease, background .4s ease}
/* Hidden while the hero video is in view; JS removes the class once scrolled past */
body.hero-hide-nav nav.site{opacity:0;pointer-events:none;transform:translateY(-12px);backdrop-filter:none;-webkit-backdrop-filter:none}
nav.site{transition:opacity .55s ease, transform .55s ease, background .35s ease}
/* Soft scrim only when scrolled, for nav legibility over photos */
nav.site.scrolled{background:rgba(15,13,11,.78)}

/* Nav CTA is a real button (gold outline pill), not the ghost underline used elsewhere */
nav.site .btn-cta{padding:9px 20px;border:1px solid var(--gold);border-radius:999px;font-size:11px;letter-spacing:.16em;color:var(--ink);transition:background .35s ease, color .35s ease}
nav.site .btn-cta::after{display:none}
nav.site .btn-cta:hover{background:var(--gold);color:var(--ivory)}
nav.site .btn-cta:hover::after{display:none}
/* (curtain reveal removed — replaced by the hero video) */
nav.site .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;gap:24px;max-width:none;padding:0 clamp(24px,3.5vw,60px)}
.word{font-family:var(--sans);font-weight:600;letter-spacing:.30em;text-transform:uppercase;font-size:15px;color:var(--ink);text-decoration:none}
.word b{color:var(--gold);font-weight:600}
/* nav brand logo (white wordmark image) */
.brand{display:flex;align-items:center;text-decoration:none;line-height:0}
.brand-logo{height:18px;width:auto;display:block}
@media(max-width:560px){.brand-logo{height:15px}}
.navlinks{display:flex;gap:22px;list-style:none}
.navlinks a{font-family:var(--serif);font-size:16px;font-weight:400;letter-spacing:.005em;color:var(--muted);text-decoration:none;transition:color .3s;padding:4px 0;border-bottom:1px solid transparent;white-space:nowrap}
.navlinks a:hover{color:var(--ink)}
.navlinks a.active{color:var(--ink);border-bottom-color:var(--gold)}

/* nav menu wrapper: invisible box on desktop (links + CTA flow straight into the bar),
   becomes a full-width dropdown panel under the bar on mobile. Hamburger ≤1024px. */
.nav-menu{display:contents}
.nav-toggle{display:none}
@media(max-width:1024px){
  .nav-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;margin-left:auto;margin-right:-8px;padding:0;background:none;border:0;cursor:pointer}
  /* phone: logo centered in the bar, hamburger pinned right */
  nav.site .brand{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}
  .nav-toggle span{display:block;width:24px;height:1.5px;background:var(--ink);transition:transform .3s ease,opacity .2s ease}
  .nav-menu{display:flex;flex-direction:column;align-items:stretch;position:absolute;top:74px;left:0;right:0;
    background:var(--sand);border-top:1px solid var(--line);padding:6px 0 22px;
    box-shadow:0 24px 48px rgba(0,0,0,.5);
    opacity:0;visibility:hidden;transform:translateY(-10px);pointer-events:none;
    transition:opacity .3s ease,transform .3s ease,visibility .3s}
  nav.site.nav-open .nav-menu{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}
  .nav-menu .navlinks{display:flex;flex-direction:column;gap:0;width:100%}
  .nav-menu .navlinks a{display:block;padding:16px clamp(24px,6vw,40px);font-size:19px;color:var(--ink);white-space:normal;border-bottom:0}
  .nav-menu .navlinks a.active{color:var(--gold);border-bottom:0}
  .nav-menu .btn-cta{display:block;margin:18px clamp(24px,6vw,40px) 4px;text-align:center}
  nav.site.nav-open .nav-toggle span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  nav.site.nav-open .nav-toggle span:nth-child(2){opacity:0}
  nav.site.nav-open .nav-toggle span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
}

/* hero — full-viewport looping video, no overlaid copy */
.hero{position:relative;height:100vh;overflow:hidden;padding:0;background:var(--ivory)}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:0;will-change:transform}
.hero-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(to top, var(--ivory) 0%, rgba(15,13,11,.96) 9%, rgba(15,13,11,.55) 20%, rgba(15,13,11,.1) 36%, rgba(15,13,11,0) 60%, rgba(15,13,11,0) 100%)}
.hero-scroll{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--ink);text-decoration:none;font-family:var(--sans);font-size:10px;letter-spacing:.3em;text-transform:uppercase;opacity:.78;transition:opacity .3s ease}
.hero-scroll svg{transition:transform .3s ease}
.hero-scroll:hover{opacity:1}
.hero-scroll:hover svg{transform:translateY(4px)}
@keyframes scrollHint{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}
.hero-scroll{animation:scrollHint 2.6s ease-in-out infinite}

/* intro — the headline + portrait, right below the hero video */
section.intro{padding:130px 0 110px}
.intro-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:72px;align-items:center}
.intro-copy{max-width:none}
section.intro .eyebrow{display:block;margin-bottom:30px}
section.intro h1{font-family:var(--serif);font-weight:500;line-height:1.05;font-size:clamp(40px,4.6vw,72px);margin:0 0 26px;color:var(--ink);max-width:14ch}
section.intro h1 em{font-style:italic;color:var(--gold)}
section.intro p.lede{font-size:17px;line-height:1.55;color:var(--muted);max-width:34em;margin:0 0 36px}
.intro-actions{display:flex;align-items:center;gap:30px;flex-wrap:wrap}
.intro-actions .meta{font-size:13px;letter-spacing:.04em;color:var(--muted)}
.intro-actions .meta b{color:var(--ink);font-weight:600}
.intro-photo{margin:0;aspect-ratio:4/5;overflow:hidden;border-radius:0;background:var(--sand);border:5px solid var(--gold)}
.intro-photo img{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width:880px){
  section.intro{padding:90px 0 80px}
  .intro-grid{grid-template-columns:1fr;gap:36px}
  .intro-photo{aspect-ratio:5/4;max-width:520px}
}

/* legacy photo helper kept for sections that still need it */
.photo{position:relative;overflow:hidden}
.photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* sections */
section{padding:104px 0}
/* gradient seam: smooth fade between two section background colors.
   OKLAB interpolation keeps light↔dark fades warm instead of muddy-gray. */
.seam{height:110px;pointer-events:none;
  background:linear-gradient(to bottom,var(--a),var(--b));
  background:linear-gradient(to bottom in oklab,var(--a),var(--b))}
.seam-tight{height:50px}
@media(max-width:880px){.seam{height:72px}.seam-tight{height:38px}}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:52px;flex-wrap:wrap}
.section-head .eyebrow{margin-bottom:18px;display:block}
.lead-2{font-family:var(--serif);font-size:clamp(28px,3.2vw,44px);font-weight:400;line-height:1.16;max-width:20ch}

/* expert beat */
.expert{background:var(--sand)}
.expert .grid{display:grid;grid-template-columns:.85fr 1.15fr;column-gap:64px;row-gap:0;align-items:center;grid-template-areas:"portrait head" "portrait body"}
.expert .portrait{grid-area:portrait}.expert .ex-head{grid-area:head}.expert .ex-body{grid-area:body}
.portrait{background:linear-gradient(155deg,#2A2218,#1B1612);aspect-ratio:4/5;border-radius:0;position:relative;overflow:hidden;border:5px solid var(--gold)}
.portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.portrait .frameword{position:absolute;inset:0;display:flex;align-items:flex-end;padding:24px;font-family:var(--serif);font-style:italic;font-size:18px;color:rgba(28,26,23,.4)}
.expert h2{font-size:clamp(30px,3.6vw,46px);margin:16px 0 22px}
.expert p{color:var(--muted);max-width:40em;margin-bottom:18px}
.expert p.article-list{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:18px;line-height:1.55;max-width:38em}
.expert p.src{font-size:12px;letter-spacing:.06em;color:rgba(246,241,233,.45);margin-top:8px;margin-bottom:0}
.expert p.src em{font-style:italic;color:var(--gold)}
.sign{font-family:var(--serif);font-style:italic;font-size:30px;color:var(--ink);margin-top:22px}

/* menu — editorial treatment index (replaces the card grid) */
.menu{padding:96px 0}
.menu-grid{display:grid;grid-template-columns:1.1fr .9fr;column-gap:72px;row-gap:0;align-items:center;grid-template-areas:"head feature" "list feature"}
.menu-head{grid-area:head}.menu-list{grid-area:list}.menu-feature{grid-area:feature}
.menu-head .eyebrow{display:block;margin-bottom:16px}
.menu-title{font-family:var(--serif);font-size:clamp(28px,3.2vw,40px);font-weight:400;line-height:1.1;margin-bottom:24px}
.menu-list{display:block;border-top:1px solid var(--line)}
.menu-row{display:flex;align-items:baseline;gap:22px;padding:20px 4px;border-bottom:1px solid var(--line);text-decoration:none;color:inherit;transition:padding .35s ease,color .35s ease}
.menu-row .mr-num{font-size:12px;letter-spacing:.16em;color:var(--gold);min-width:22px}
.menu-row .mr-name{font-family:var(--serif);font-size:clamp(21px,2.3vw,28px);font-weight:500;flex:1;line-height:1.05}
.menu-row .mr-count{font-size:12px;letter-spacing:.04em;color:var(--muted);font-variant-numeric:tabular-nums}
.menu-row:hover,.menu-row.active{padding-left:14px}
.menu-row:hover .mr-name,.menu-row.active .mr-name{color:var(--gold)}
.menu-feature{margin:0}
.mf-img{aspect-ratio:4/5;background:linear-gradient(155deg,#2A2218,#1B1612);background-size:cover;background-position:center;border-radius:0;display:flex;align-items:flex-end;padding:22px;border:5px solid var(--gold)}
.mf-img .mf-label{font-family:var(--serif);font-style:italic;font-size:18px;color:rgba(245,242,236,.55)}
.mf-img.has-img .mf-label{display:none}
.mf-cap{display:flex;justify-content:space-between;align-items:baseline;gap:20px;margin-top:16px;font-size:13.5px;color:var(--muted)}
.mf-cap .mf-go{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);white-space:nowrap}

/* dossier — Candela proof section (full-width dark spec sheet) */
.dossier{background:var(--espresso);color:var(--ink);padding:108px 0}
.dossier + .dossier{padding-top:0;margin-top:-12px}
.dossier + .dossier .wrap{padding-top:48px}
/* reversed layout: photo on the left, head on the right */
.dossier-reverse .dossier-top{grid-template-columns:.7fr 1.3fr}
.dossier-reverse .dossier-photo{order:-1}
.dossier-reverse .dossier-head{padding-left:24px;padding-right:24px}
.dossier .eyebrow{color:var(--champagne);display:block;margin-bottom:16px}
.dossier-top{display:grid;grid-template-columns:1.3fr .7fr;gap:56px;align-items:center}
.dossier-photo{aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;padding:36px;background:transparent}
.dossier-photo img{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}
.dossier-head{max-width:none}
.dossier h2{font-family:var(--serif);font-size:clamp(28px,3.8vw,46px);font-weight:400;color:var(--ink);line-height:1.05;margin-bottom:18px;text-wrap:pretty}
.dossier h2 em{font-style:italic;color:var(--champagne)}
.dossier-head p{color:rgba(246,241,233,.72);font-size:17px;margin:0;max-width:50ch}
.dossier-specs{display:grid;grid-template-columns:repeat(5,1fr);border-top:1px solid var(--line-dk);border-bottom:1px solid var(--line-dk);margin:52px 0 40px}
.dossier-specs>div{padding:24px 20px;border-right:1px solid var(--line-dk);text-align:center}
.dossier-specs>div:last-child{border-right:0}
.ds-k{display:block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--champagne);margin-bottom:10px}
.ds-v{font-family:var(--serif);font-size:18px;color:var(--ink);line-height:1.2}
.dossier-foot{display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap}
.ds-statement{font-family:var(--serif);font-style:italic;font-size:clamp(18px,2.1vw,26px);color:var(--champagne);max-width:30ch;margin:0;line-height:1.3}

/* avis — scrolling wall of reviews (left-aligned, not centered) */
.avis{background:var(--ivory)}
.avis-head{margin-bottom:40px;display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap}
.avis-head .eyebrow{display:block;margin-bottom:14px}
.avis-head .lead-2{max-width:18ch;margin:0}
.avis-sub{font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.avis-sub b{color:var(--ink);font-weight:600}
.avis-wall{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:24px;max-height:620px;overflow:hidden;text-align:left;
  -webkit-mask-image:linear-gradient(to bottom,transparent,#000 11%,#000 86%,transparent);
  mask-image:linear-gradient(to bottom,transparent,#000 11%,#000 86%,transparent)}
.avis-col{display:flex;flex-direction:column;gap:24px;animation:avisScroll 40s linear infinite;will-change:transform}
.avis-col.alt{animation-duration:52s}
.avis-wall:hover .avis-col{animation-play-state:paused}
@keyframes avisScroll{from{transform:translateY(0)}to{transform:translateY(-50%)}}
.avis-card{background:var(--sand);border:1px solid var(--line);border-radius:4px;padding:26px 26px 22px}
.avis-card .stars{color:var(--gold);letter-spacing:.25em;font-size:13px;margin-bottom:14px}
.avis-card blockquote{font-family:var(--serif);font-style:italic;font-size:17px;line-height:1.5;color:var(--ink);margin:0 0 16px}
.avis-card figcaption{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.avis-card figcaption span{color:var(--gold)}
@media(prefers-reduced-motion:reduce){
  .avis-wall{max-height:none;overflow:visible;-webkit-mask-image:none;mask-image:none}
  .avis-col{animation:none}
  .avis-card.dup{display:none}
}
@media(max-width:880px){
  .avis-wall{grid-template-columns:1fr;max-height:540px}
}

/* rencontre — Karen video interview (espresso) */
.rencontre{background:var(--espresso);color:var(--ink);text-align:center}
.rencontre .eyebrow{color:var(--champagne);display:block;margin-bottom:14px}
.rencontre h2{font-family:var(--serif);font-size:clamp(30px,3.6vw,48px);font-weight:400;color:var(--ink);margin-bottom:18px}
.rencontre .intro{color:rgba(246,241,233,.72);max-width:46em;margin:0 auto 40px;font-size:17px}
.video-frame{position:relative;max-width:920px;margin:0 auto;aspect-ratio:16/9;border-radius:0;overflow:hidden;border:5px solid var(--gold);background:linear-gradient(155deg,#2A2218,#1B1612)}
.video-frame iframe,.video-frame video{position:absolute;inset:0;width:100%;height:100%;border:0;object-fit:cover}
.video-frame .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-decoration:none}
.video-frame .play .disc{width:84px;height:84px;border-radius:50%;border:1px solid var(--champagne);display:flex;align-items:center;justify-content:center;color:var(--champagne);font-size:24px;padding-left:5px;background:rgba(36,31,25,.35);transition:all .35s}
.video-frame .play:hover .disc{background:var(--champagne);color:var(--espresso)}
.video-frame .vcap{position:absolute;left:20px;bottom:18px;font-family:var(--serif);font-style:italic;font-size:14px;color:rgba(229,199,107,.55)}
.rencontre .pull{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.4vw,28px);color:var(--champagne);max-width:24ch;margin:42px auto 0;line-height:1.32}
.rencontre .pull cite{display:block;font-style:normal;font-family:var(--sans);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:rgba(246,241,233,.6);margin-top:16px}

/* proof */
.proof{text-align:center}
.proof .stars{color:var(--gold);letter-spacing:.3em;font-size:20px;margin-bottom:18px}
.proof blockquote{font-family:var(--serif);font-size:clamp(26px,3.4vw,40px);font-weight:400;line-height:1.28;max-width:18ch;margin:0 auto 26px;font-style:italic}
.proof .src{font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.proof .badges{display:flex;gap:48px;justify-content:center;margin-top:54px;flex-wrap:wrap}
.proof .badge .n{font-family:var(--serif);font-size:38px}
.proof .badge .l{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:6px}

/* ===== category page ===== */
.page-head{padding:128px 0 28px}
.page-head .eyebrow{display:block;margin-bottom:18px}
.page-head h1{font-size:clamp(38px,5vw,68px);font-weight:500;margin-bottom:22px}
.page-head .intro{font-size:18px;color:var(--muted);max-width:46em;margin-bottom:30px}
.crumb{font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin-bottom:26px}
.crumb a{text-decoration:none;color:var(--muted)}
.crumb a:hover{color:var(--ink)}

/* femme/homme toggle */
.toggle{display:inline-flex;border:1px solid var(--line);border-radius:999px;padding:4px;background:var(--ivory);margin-bottom:8px}
.toggle button{font-family:var(--sans);font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--muted);background:transparent;border:0;padding:11px 30px;border-radius:999px;cursor:pointer;transition:all .3s}
.toggle button.on{background:var(--ink);color:var(--ivory)}

.variant[hidden]{display:none}
.svc-group{margin-top:56px}
.svc-group .glabel{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);padding-bottom:14px;border-bottom:1px solid var(--gold);display:inline-block;margin-bottom:8px}

/* service row */
.svc{display:grid;grid-template-columns:1fr auto auto;gap:28px;align-items:center;padding:26px 14px;border-bottom:1px solid var(--line);border-radius:2px}
.svc .info h3{font-family:var(--serif);font-size:22px;font-weight:500;margin-bottom:6px}
.svc .info p{font-size:14.5px;color:var(--muted);max-width:60ch;margin:0}
.svc .dur{font-size:13px;letter-spacing:.04em;color:var(--muted);white-space:nowrap;min-width:64px;text-align:right}
.svc .right{display:flex;align-items:center;gap:22px}
.svc .price{font-family:var(--serif);font-size:21px;color:var(--ink);font-variant-numeric:tabular-nums;white-space:nowrap;min-width:96px;text-align:right;transition:color .3s ease}

/* clickable row → opens booking modal (applies to both full + compact) */
a.svc{text-decoration:none;color:inherit;cursor:pointer;transition:background .3s ease, padding .3s ease}
a.svc:hover{background:rgba(201,162,39,.06);padding-left:18px;padding-right:10px}
a.svc:hover .price{color:var(--gold)}

/* persistent "Réserver →" affordance on every clickable row */
.svc-cta{display:inline-flex;align-items:baseline;gap:8px;color:var(--gold);font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase;min-width:108px;justify-content:flex-end;transition:color .3s ease}
.svc-cta .svc-go{display:inline-block;color:var(--gold);font-size:15px;line-height:1;transform:translateX(0);transition:transform .3s ease}
a.svc:hover .svc-cta{color:var(--champagne)}
a.svc:hover .svc-cta .svc-go{transform:translateX(4px)}
@media (max-width:640px){.svc-cta{min-width:0;font-size:10px;gap:6px}}

/* compact rows (laser zones without description) */
.svc.compact{grid-template-columns:1fr auto;padding:16px 14px}
.svc.compact .info h3{font-size:18px}
.svc.compact .right{gap:16px;align-items:baseline}
.svc.compact .price{font-size:18px;min-width:64px}
.svc.compact .dur{min-width:58px}
.zone-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 56px}

/* FAQ */
.faq{padding:120px 0}
.faq .wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:start}
.faq-head{position:sticky;top:110px}
.faq-head .eyebrow{display:block;margin-bottom:16px}
.faq-head h2{font-family:var(--serif);font-size:clamp(28px,3.4vw,44px);font-weight:500;line-height:1.08;margin:0;color:var(--ink)}
.faq-list{border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:22px 0;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-q{font-family:var(--serif);font-size:clamp(18px,1.5vw,21px);font-weight:400;line-height:1.3}
.faq-ic{position:relative;flex:0 0 16px;width:16px;height:16px;margin-top:3px}
.faq-ic::before,.faq-ic::after{content:"";position:absolute;background:var(--gold);transition:transform .3s ease,opacity .3s ease}
.faq-ic::before{top:7px;left:0;width:16px;height:2px}
.faq-ic::after{top:0;left:7px;width:2px;height:16px}
.faq-item[open] .faq-ic::after{transform:scaleY(0);opacity:0}
.faq-item summary:hover .faq-q{color:var(--champagne)}
.faq-a{overflow:hidden;padding:0 0 24px;max-width:60ch}
.faq-a p{color:var(--muted);font-size:16px;line-height:1.65;margin:0}
.faq-item[open] summary .faq-q{color:var(--gold)}
@media(max-width:820px){.faq .wrap{grid-template-columns:1fr;gap:28px}.faq-head{position:static}.faq{padding:72px 0}}

/* booking strip */
.bookstrip{background:var(--sand);padding:72px 0}
.bookstrip .wrap{display:flex;justify-content:space-between;align-items:center;gap:44px;flex-wrap:wrap}
.bookstrip .bk-text{max-width:48ch}
.bookstrip .eyebrow{display:block;margin-bottom:12px}
.bookstrip h2{font-family:var(--serif);font-size:clamp(26px,3vw,38px);font-weight:400;margin-bottom:10px}
.bookstrip p{color:var(--muted);margin:0}

/* Phase 6 — subtle fade-up on sections as they enter the viewport (only when JS present, reduced-motion safe) */
html.js section{opacity:0;transform:translateY(22px);transition:opacity .85s cubic-bezier(.22,.61,.36,1), transform .85s cubic-bezier(.22,.61,.36,1)}
html.js section.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){html.js section{opacity:1;transform:none;transition:none}}

/* ===== /le-cabinet editorial page ===== */
.cab-hero{position:relative;height:100vh;overflow:hidden;padding:0}
.cab-hero-bg{position:absolute;inset:0;z-index:0}
.cab-hero-bg img{width:100%;height:100%;object-fit:cover;display:block}
.cab-hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,var(--ivory) 0%,rgba(15,13,11,.98) 9%,rgba(15,13,11,.82) 18%,rgba(15,13,11,.5) 28%,rgba(15,13,11,.18) 38%,rgba(15,13,11,0) 50%,rgba(15,13,11,0) 100%)}
.cab-hero h1{text-shadow:0 2px 20px rgba(0,0,0,.6)}
.cab-hero .lede{text-shadow:0 1px 14px rgba(0,0,0,.75)}
.cab-hero-copy{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding-top:140px;padding-bottom:90px}
.cab-hero .eyebrow{display:block;margin-bottom:18px}
.cab-hero h1{font-family:var(--serif);font-size:clamp(40px,5.6vw,82px);font-weight:500;line-height:1.04;margin:0 0 22px;max-width:18ch;color:var(--ink)}
.cab-hero .lede{font-size:17px;color:rgba(245,242,236,.94);max-width:48em;margin:0}

.cab-bio{padding:100px 0 90px}
.cab-bio .cab-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:72px;align-items:start}
/* B&W Karen portrait: bright polished-silver / diamond frame (static, no motion).
   Silver, not gold, so it doesn't fight the monochrome shot. */
.cab-portrait{aspect-ratio:4/5;border-radius:0;overflow:hidden;background:var(--sand);margin:0;border:5px solid #eef2f5;border-image:linear-gradient(135deg,#ffffff,#aeb8c2 16%,#ffffff 32%,#cdd6de 50%,#ffffff 68%,#a8b3bd 84%,#ffffff) 1;box-shadow:0 0 26px rgba(223,231,238,.30)}
.cab-portrait img{width:100%;height:100%;object-fit:cover;display:block}
.cab-bio .eyebrow{display:block;margin-bottom:14px}
.cab-bio h2{font-family:var(--serif);font-size:clamp(28px,3.4vw,44px);font-weight:500;line-height:1.1;margin:0 0 24px}
.cab-bio-name{font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(40px,5vw,68px);line-height:1;color:var(--gold);margin:0 0 28px}
.cab-bio p{color:var(--muted);margin-bottom:18px;max-width:42em}
.cab-quote{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.2vw,26px);color:var(--champagne);line-height:1.35;margin:24px 0;padding-left:18px;border-left:1px solid var(--gold);max-width:30ch}
.cab-press{font-size:13.5px;color:var(--muted);margin-top:14px}
.cab-creds{list-style:none;padding:0;margin:0 0 30px;display:flex;flex-direction:column;gap:8px}
.cab-creds li{font-family:var(--sans);font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);position:relative;padding-left:22px;line-height:1.4}
.cab-creds li::before{content:"";position:absolute;left:0;top:.62em;width:12px;height:1px;background:var(--gold)}
.cab-press em{font-style:italic;color:var(--ink)}

.cab-philo{padding:120px 0;text-align:center}
.cab-philo .eyebrow{display:block;margin-bottom:48px}
.cab-philo-quote{margin:0 auto 60px}
.cab-philo-quote p{font-family:"Caveat","Brush Script MT",cursive;font-style:normal;font-weight:500;font-size:clamp(36px,4.8vw,60px);line-height:1.15;color:var(--ink);margin:0 auto 24px;max-width:28ch;text-wrap:balance;letter-spacing:.005em}
.cab-philo-quote cite{display:block;font-style:normal;font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold)}
.cab-philo-prose{max-width:38em;margin:0 auto;text-align:left}
.cab-philo-prose p{color:var(--muted);font-size:17px;line-height:1.7;margin:0 0 20px}
.cab-philo-prose p:last-child{margin:0}
/* legacy classes kept harmless */
.cab-philo-title{display:none}.cab-philo-body{display:none}

.cab-rooms{padding:90px 0}
.cab-rooms-head{max-width:54ch;margin:0 0 48px}
.cab-rooms-head .eyebrow{display:block;margin-bottom:14px}
.cab-rooms-head h2{font-family:var(--serif);font-size:clamp(28px,3.4vw,44px);font-weight:500;line-height:1.1;margin:0 0 18px}
.cab-rooms-head p{color:var(--muted);margin:0}
/* Uniform 6-photo grid — 3 columns × 2 rows, all cells the same format, overall block a square. */
.cab-gallery{display:grid;grid-template-columns:1fr 1.12fr;gap:16px}
.cab-gallery figure{margin:0;overflow:hidden;border-radius:0;background:var(--sand);border:5px solid var(--gold)}
.cab-gallery img{width:100%;height:100%;object-fit:cover;display:block}
.cab-gallery .cab-wide{aspect-ratio:16/9}
.cab-gallery .cab-tall{grid-column:1;grid-row:1/span 2}

.cab-access{padding:80px 0 100px}
.cab-access-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:64px;align-items:start}
.cab-access .eyebrow{display:block;margin-bottom:14px}
.cab-access h2{font-family:var(--serif);font-size:clamp(28px,3.2vw,42px);font-weight:500;line-height:1.1;margin:0}
.cab-access-cols{display:grid;grid-template-columns:1fr 1fr;gap:36px}
.cab-access-cols p{font-size:15px;line-height:1.8;color:var(--muted);margin:0 0 22px}
.cab-access-cols a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--gold);transition:color .3s}
.cab-access-cols a:hover{color:var(--champagne)}
.cab-k{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:6px;font-weight:600}

@media (max-width:880px){
  .cab-hero{height:100vh}
  .cab-hero-copy{height:100%;padding-top:120px;padding-bottom:60px}
  .cab-bio .cab-grid,.cab-access-grid,.cab-access-cols{grid-template-columns:1fr;gap:36px}
  .cab-gallery{grid-template-columns:1fr;gap:12px}
  .cab-gallery .cab-tall{grid-column:auto;grid-row:auto;aspect-ratio:4/5}
  .cab-bio,.cab-philo,.cab-rooms,.cab-access{padding:64px 0}
}

/* booking modal — slide-over panel embedding Planity (or a fallback link) */
.book-overlay{position:fixed;inset:0;z-index:200}
.book-overlay[hidden]{display:none}
.book-backdrop{position:absolute;inset:0;background:rgba(28,26,23,.45);backdrop-filter:blur(3px);animation:bookFade .35s ease}
/* centered pop-up dialog (wider than the old slide-over) */
.book-panel{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(920px,92vw);max-height:90vh;height:auto;background:var(--ivory);border-radius:16px;box-shadow:0 30px 90px rgba(0,0,0,.55);display:flex;flex-direction:column;overflow:hidden;animation:bookPop .35s cubic-bezier(.22,.61,.36,1)}
@keyframes bookPop{from{opacity:0;transform:translate(-50%,-47%) scale(.97)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
@keyframes bookFade{from{opacity:0}to{opacity:1}}
@media(max-width:600px){.book-panel{width:96vw;max-height:94vh}}
.book-head{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:1px solid var(--line)}
.book-head .eyebrow{display:block}
.book-title{font-family:var(--serif);font-size:23px;font-weight:500;margin-top:6px}
.book-close{background:none;border:0;font-size:30px;line-height:1;color:var(--muted);cursor:pointer;padding:0 4px}
.book-close:hover{color:var(--ink)}
.book-body{flex:1;min-height:0;overflow:auto;padding:30px}
.book-fallback{text-align:center;padding:48px 10px}
.book-fallback p{color:var(--muted);margin-bottom:24px}
.book-fallback .btn{margin-bottom:8px}
.book-fallback .book-info{font-size:13px;line-height:1.8;margin:24px 0 0}
.planity-embed{min-height:62vh}
.book-altlink{text-align:center;font-size:13px;color:rgba(245,242,236,.6);margin:14px 0 4px;padding:0 16px}
.book-altlink[hidden]{display:none}
.book-altlink a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.book-overlay.has-embed .book-body{padding:0 26px;background:#0F0D0B}
/* Black canvas + pearl text everywhere. Service / summary / slot boxes are filled with
   the same black — kept OPAQUE (not transparent): the fill masks Planity's stacked
   collapsed/expanded description layers, otherwise the "Plus de détails" text overlaps
   the body copy. Rows are separated by fine pearl hairlines; gold buttons stay the only
   accent fill. */
#planitywl{background-color:#0F0D0B!important}
#planitywl *{background-color:transparent!important;color:#F5F2EC!important}
#planitywl .planity_ui_item-list-element,
#planitywl [class*="service-module_toggle"]{background-color:#0F0D0B!important}
#planitywl .planity_ui_item-list-element{border-bottom:1px solid rgba(246,241,233,.14)!important}
#planitywl .planity_bookappointment-button-choose,
#planitywl .planity-gift-voucher-button-choose{background-color:#C9A227!important;color:#0F0D0B!important;border:0!important}
@media(prefers-reduced-motion:reduce){.book-panel,.book-backdrop{animation:none}}

/* footer — same dark page, pearl text */
footer.site{background:var(--ivory);color:var(--muted);padding:64px 0 40px}
footer.site .brand{line-height:0}
footer.site .brand-logo{height:22px}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1.1fr 1fr 1fr;gap:40px;margin:36px 0}
footer.site h4{font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;font-weight:600}
footer.site p,footer.site a{font-size:14px;color:var(--muted);text-decoration:none;line-height:1.9;display:block}
footer.site a:hover{color:var(--ink)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:12px 20px;flex-wrap:wrap}
.foot-copy{font-size:12px;letter-spacing:.04em;margin:0}
.foot-legal{margin:0;font-size:12px;letter-spacing:.04em;color:var(--muted);white-space:nowrap}
footer.site .foot-legal a{display:inline;font-size:12px;letter-spacing:.04em}
footer.site .foot-legal a:hover{color:var(--gold)}

/* legal pages (mentions légales + confidentialité) */
.legal-head{padding:128px 0 8px}
.legal-head .eyebrow{display:block;margin-bottom:14px}
.legal-head h1{font-family:var(--serif);font-size:clamp(34px,4.4vw,56px);font-weight:500;line-height:1.04;margin:0}
.legal-updated{color:var(--muted);font-size:13px;letter-spacing:.04em;margin:14px 0 0}
.legal{padding:32px 0 96px}
.legal-doc{max-width:72ch}
.legal-sec{padding:26px 0;border-top:1px solid var(--line)}
.legal-sec:first-child{border-top:0;padding-top:8px}
.legal-sec h2{font-family:var(--serif);font-size:clamp(20px,2vw,26px);font-weight:500;color:var(--ink);margin:0 0 14px}
.legal-sec p{color:var(--muted);font-size:15.5px;line-height:1.75;margin:0 0 12px}
.legal-sec p:last-child{margin-bottom:0}
.legal-sec a{color:var(--gold);text-decoration:none;border-bottom:1px solid rgba(201,162,39,.4)}
.legal-sec a:hover{color:var(--champagne)}
.legal-list{list-style:none;margin:0 0 12px;padding:0}
.legal-list li{color:var(--muted);font-size:15.5px;line-height:1.7;padding:3px 0}
.legal-list strong{color:var(--ink);font-weight:500}
.legal-todo{color:var(--gold);border-bottom:1px dotted rgba(201,162,39,.6);font-style:italic;opacity:.9}
@media(max-width:640px){.legal-head{padding-top:104px}}

@media(max-width:880px){
  :root{--pad:22px}
  .navlinks{display:none}
  .expert .grid{grid-template-columns:1fr;grid-template-areas:"head" "portrait" "body";row-gap:24px}
  .hero{min-height:84vh}
  .hero-copy{padding:120px 0 72px;min-height:84vh}
  .menu-grid{grid-template-columns:1fr;grid-template-areas:"head" "feature" "list";row-gap:26px}
  .menu-feature{position:sticky;top:88px;z-index:2;background:var(--ivory);padding-bottom:12px}
  .mf-img{aspect-ratio:16/10}
  .dossier{padding:72px 0}
  .dossier-top,.dossier-reverse .dossier-top{grid-template-columns:1fr;gap:30px}
  .dossier-photo{aspect-ratio:auto;padding:0;width:100%;max-width:260px;margin-inline:auto}
  .dossier-photo img{aspect-ratio:auto;width:100%;height:auto}
  /* phone: VelaShape (reverse) stacks text-above-photo + aligns like Candela */
  .dossier-reverse .dossier-photo{order:0}
  .dossier-reverse .dossier-head{padding-left:0;padding-right:0}
  .dossier-specs{grid-template-columns:repeat(2,1fr)}
  .dossier-specs>div{border-right:0;border-bottom:1px solid var(--line-dk);padding:18px 12px}
  .dossier-specs>div:nth-child(odd){border-right:1px solid var(--line-dk)}
  /* phone: a lone trailing spec (e.g. "Résultat", 5th of 5) spans both columns, centered */
  .dossier-specs>div:last-child:nth-child(odd){grid-column:1/-1;border-right:0}
  .dossier-foot{flex-direction:column;align-items:flex-start;gap:24px}
  .avis-head{flex-direction:column;align-items:flex-start;gap:10px}
  .bookstrip .wrap{flex-direction:column;align-items:flex-start;gap:24px}
  .zone-grid{grid-template-columns:1fr}
  .svc{grid-template-columns:1fr;gap:12px;align-items:start}
  .svc .right{justify-content:space-between;width:100%}
  .svc .dur{text-align:left}
  section{padding:72px 0}
  footer.site .cols{grid-template-columns:1fr}
}
