
  :root{
    --rouge:#d00000; --rouge-fonce:#a80000;
    --or:#C59700; --or-fonce:#a37e00;
    --gris:#8c9198; --gris-clair:#adb5bd;
    --encre:#2b2422; --encre-doux:#5c534e;
    --creme:#fdfaf7; --creme2:#f4ece4;
    --sakura:#f4c4d0; --sakura-clair:#fbe9ee; --blanc:#fff;
    --line:#ece2da;
    --maxw:1220px; --r-lg:20px; --r-md:14px; --dur:.3s;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{font-family:'Jost',sans-serif;color:var(--encre);background:var(--creme);line-height:1.75;font-size:16px;-webkit-font-smoothing:antialiased}
  img{max-width:100%;display:block}
  a{color:inherit;text-decoration:none}
  svg{display:block}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
  .script{font-family:'Parisienne',cursive}
  .serif{font-family:'Cormorant Garamond',serif}
  .accent{color:var(--rouge)}

  a:focus-visible,button:focus-visible{outline:3px solid var(--or);outline-offset:3px;border-radius:6px}
  .skip{position:absolute;left:-999px;top:0;background:var(--encre);color:#fff;padding:12px 18px;z-index:300}
  .skip:focus{left:12px;top:12px}

  .label{font-size:11px;letter-spacing:.38em;text-transform:uppercase;color:var(--or-fonce);font-weight:600;display:inline-block}
  .marker{font-family:'Cormorant Garamond',serif;font-size:15px;letter-spacing:.3em;color:var(--gris);display:block;margin-bottom:14px}

  .btn{display:inline-flex;align-items:center;gap:10px;justify-content:center;min-height:48px;font-weight:500;font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;padding:14px 32px;border-radius:100px;border:1.5px solid transparent;cursor:pointer;transition:background var(--dur),color var(--dur),transform var(--dur),box-shadow var(--dur)}
  .btn svg{width:18px;height:18px;flex:none}
  .btn-primary{background:var(--rouge);color:#fff;box-shadow:0 14px 30px -14px rgba(208,0,0,.55)}
  .btn-primary:hover{background:var(--rouge-fonce);transform:translateY(-2px)}
  .btn-outline{border-color:currentColor}
  .btn-outline:hover{background:var(--encre);color:#fff;border-color:var(--encre)}
  .btn-light{border-color:rgba(255,255,255,.55);color:#fff}
  .btn-light:hover{background:#fff;color:var(--encre)}
  .btn-wa{background:#25D366;color:#fff}
  .btn-wa:hover{background:#1da851;transform:translateY(-2px)}

  .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
  .reveal.in{opacity:1;transform:none}

  /* photo helper — graceful fallback */
  .ph{background-position:center;background-size:cover;background-repeat:no-repeat}

  /* ---------- Header ---------- */
  header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background var(--dur),box-shadow var(--dur),border-color var(--dur);border-bottom:1px solid transparent}
  header.solid{background:rgba(253,250,247,.92);backdrop-filter:blur(12px);border-bottom-color:var(--line)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:80px}
  .brand{font-family:'Parisienne',cursive;font-size:30px;line-height:1;display:flex;align-items:center;gap:8px;color:#fff;transition:color var(--dur)}
  header.solid .brand{color:var(--encre)}
  .brand .sk{width:26px;height:26px;color:var(--sakura)}
  .nav-links{display:flex;gap:32px;align-items:center}
  .nav-links a.link{font-size:13.5px;letter-spacing:.06em;color:#fff;position:relative;padding:6px 0;transition:color var(--dur)}
  header.solid .nav-links a.link{color:var(--encre)}
  .nav-links a.link::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--rouge);transition:width var(--dur)}
  .nav-links a.link:hover{color:var(--rouge)}
  .nav-links a.link:hover::after{width:100%}
  .nav .btn{padding:11px 22px;min-height:44px}
  .burger{display:none;width:48px;height:48px;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#fff}
  header.solid .burger{color:var(--encre)}
  .burger svg{width:26px;height:26px}

  /* ---------- Hero ---------- */
  .hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;padding:120px 0 90px;
    background:
      linear-gradient(180deg, rgba(28,20,18,.55), rgba(28,20,18,.32) 42%, rgba(28,20,18,.72)),
      url('/images/hero.jpg') center 28%/cover no-repeat,
      linear-gradient(150deg,#4a352c,#231a17)}
  .hero .inner{position:relative;z-index:2;max-width:840px;padding:0 28px}
  .hero .sub-mark{width:60px;height:60px;color:var(--sakura);margin:0 auto 20px}
  .hero .label{color:#f0d7b6;margin-bottom:22px}
  .hero h1{font-family:'Parisienne',cursive;font-size:clamp(58px,11vw,124px);font-weight:400;line-height:.92;text-shadow:0 4px 40px rgba(0,0,0,.35)}
  .hero h1 .accent{color:#ff5a5a}
  .hero .lead{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(19px,2.6vw,27px);color:#f3ece6;margin:22px auto 0;max-width:600px}
  .hero .cta{margin-top:42px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
  .hero .corner{position:absolute;z-index:2;font-size:10.5px;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.75)}
  .hero .c-tl{top:104px;left:36px} .hero .c-tr{top:104px;right:36px}
  .hero .c-bl{bottom:34px;left:36px} .hero .c-br{bottom:34px;right:36px}
  .scroll-hint{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,.8);animation:bob 2.4s ease-in-out infinite}
  .scroll-hint svg{width:24px;height:24px}
  @keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

  /* ---------- Section base ---------- */
  section{padding:112px 0}
  .sec-head{max-width:680px;margin:0 auto 66px;text-align:center}
  .sec-head h2{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,4.8vw,54px);font-weight:500;line-height:1.04;margin-bottom:16px}
  .sec-head p{color:var(--encre-doux);font-size:17px}
  .divider{height:1px;background:linear-gradient(90deg,transparent,var(--sakura),transparent);max-width:var(--maxw);margin:0 auto}

  /* ---------- Editorial split ---------- */
  .split{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}
  .split.reverse .txt{order:2}
  .split .media{min-height:560px;position:relative;background-color:#e5d6c7}
  .split .media .cap{position:absolute;left:24px;bottom:22px;right:24px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:19px;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.5)}
  .split .txt{display:flex;flex-direction:column;justify-content:center;padding:86px clamp(32px,6vw,86px)}
  .split .txt h2{font-family:'Cormorant Garamond',serif;font-size:clamp(30px,4vw,46px);font-weight:500;line-height:1.08;margin:8px 0 22px}
  .split .txt p{color:var(--encre-doux);margin-bottom:16px;max-width:52ch}
  .split .stats{display:flex;gap:40px;margin-top:26px;flex-wrap:wrap}
  .split .stat .n{font-family:'Cormorant Garamond',serif;font-size:38px;color:var(--rouge);font-weight:600;line-height:1;font-variant-numeric:tabular-nums}
  .split .stat .t{font-size:12px;letter-spacing:.05em;color:var(--gris);text-transform:uppercase;margin-top:4px}
  .split .sign{font-family:'Parisienne',cursive;font-size:34px;color:var(--encre);margin-top:14px}
  .media-kobido{background-image:linear-gradient(0deg,rgba(0,0,0,.15),rgba(0,0,0,0) 45%),url('/images/kobido.jpg');background-color:#d9c8b8}
  .media-prat{background-image:linear-gradient(0deg,rgba(0,0,0,.15),rgba(0,0,0,0) 45%),url('/images/praticienne.jpg');background-color:#3a2c26}

  /* ---------- Soins ---------- */
  #soins{background:linear-gradient(180deg,#fff,var(--creme))}
  .cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:26px}
  .card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform var(--dur),box-shadow var(--dur)}
  .card:hover{transform:translateY(-6px);box-shadow:0 34px 60px -40px rgba(208,0,0,.4)}
  .card .top{padding:32px 30px 22px;position:relative}
  .card .sk-mark{position:absolute;top:26px;right:28px;width:24px;height:24px;color:var(--sakura)}
  .card .cat{text-transform:uppercase;letter-spacing:.26em;font-size:10px;color:var(--or-fonce);font-weight:600}
  .card h3{font-family:'Cormorant Garamond',serif;font-size:27px;font-weight:500;margin:8px 0 8px;padding-right:36px;line-height:1.1}
  .card .desc{font-size:14.5px;color:var(--encre-doux);min-height:46px}
  .card .dur{font-size:13px;color:var(--encre);margin-top:16px;display:flex;align-items:center;gap:8px}
  .card .dur svg{width:16px;height:16px;color:var(--or)}
  .card .foot{padding:20px 30px 28px;margin-top:auto;border-top:1px solid var(--creme2);display:flex;align-items:center;gap:12px}
  .card .old{text-decoration:line-through;color:var(--gris);font-size:16px;font-variant-numeric:tabular-nums}
  .card .now{color:var(--rouge);font-family:'Cormorant Garamond',serif;font-size:38px;font-weight:600;line-height:1;font-variant-numeric:tabular-nums}
  .card .badge{margin-left:auto;background:var(--sakura-clair);color:var(--rouge);font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;padding:6px 12px;border-radius:100px}
  .card.feature{border-color:var(--or)}
  .card.feature .top{background:linear-gradient(180deg,var(--sakura-clair),#fff)}
  .soins-note{text-align:center;margin-top:46px;color:var(--encre-doux);font-size:15px}
  .center{text-align:center}

  /* ---------- Quote band ---------- */
  .band{position:relative;min-height:420px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;
    background:linear-gradient(rgba(28,20,18,.5),rgba(28,20,18,.55)),url('/images/outils.jpg') center 60%/cover no-repeat,linear-gradient(150deg,#4a352c,#231a17)}
  .band .q{position:relative;z-index:2;max-width:760px;padding:0 32px}
  .band .q .script{font-size:clamp(38px,6vw,66px);color:#fff;line-height:1.05}
  .band .q .src{margin-top:16px;font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:#f0d7b6}

  /* ---------- Galerie ---------- */
  .gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
  .gtile{border-radius:var(--r-md);overflow:hidden;background-color:#e5d6c7;position:relative}
  .g1{grid-column:span 2;grid-row:span 2;background-image:url('/images/hero.jpg')}
  .g2{background-image:url('/images/kobido.jpg');background-color:#d9c8b8}
  .g3{background-image:url('/images/outils.jpg');background-color:#d8c4a8}
  .g4{grid-column:span 2;background-image:url('/images/cabine.jpg');background-color:#3a2c26}
  .g5{background-image:url('/images/praticienne.jpg');background-color:#3a2c26}
  .g6{background-image:url('/images/gallery6.jpg');background-color:#d9c8b8}

  /* ---------- Contact ---------- */
  #contact{background:var(--encre);color:#fff}
  #contact .sec-head h2{color:#fff}
  #contact .sec-head p{color:#cbc1ba}
  .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:stretch}
  .contact-info{display:flex;flex-direction:column}
  .contact-info .row{display:flex;gap:16px;padding:22px 0;border-bottom:1px solid rgba(255,255,255,.12)}
  .contact-info .row .ic{width:26px;height:26px;color:var(--sakura);flex:none;margin-top:2px}
  .contact-info .row .ic svg{width:26px;height:26px}
  .contact-info .row .k{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gris-clair)}
  .contact-info .row .v{font-family:'Cormorant Garamond',serif;font-size:22px;margin-top:3px;line-height:1.35}
  .contact-info .row .v a:hover{color:var(--sakura)}
  .map{margin-top:26px;border-radius:var(--r-md);overflow:hidden;border:1px solid rgba(255,255,255,.15);flex:1;min-height:220px}
  .map iframe{width:100%;height:100%;min-height:220px;border:0;display:block;filter:grayscale(.15)}
  .contact-card{background:linear-gradient(160deg,#fff,var(--creme));color:var(--encre);border-radius:var(--r-lg);padding:46px 40px;text-align:center;display:flex;flex-direction:column;justify-content:center}
  .contact-card .script{font-size:42px;color:var(--rouge);line-height:1.05}
  .contact-card p{color:var(--encre-doux);margin:16px 0 28px;font-size:15px}
  .contact-card .btn{width:100%;margin-bottom:14px}
  .contact-card .fine{margin:6px 0 0;font-size:12.5px;color:var(--gris);letter-spacing:.02em}

  /* ---------- Footer ---------- */
  footer{background:#211c1a;color:#fff;text-align:center;padding:64px 0}
  footer .brand{justify-content:center;font-size:40px;color:#fff}
  footer .fnav{display:flex;gap:26px;justify-content:center;margin:24px 0;flex-wrap:wrap;font-size:13px;letter-spacing:.07em}
  footer .fnav a{color:#c9beb7}
  footer .fnav a:hover{color:#fff}
  footer .legal{color:var(--gris-clair);font-size:12.5px;letter-spacing:.04em}

  /* ---------- Floating WhatsApp ---------- */
  .wa-float{position:fixed;bottom:24px;right:24px;z-index:120;background:#25D366;color:#fff;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 34px -8px rgba(37,211,102,.75);transition:transform var(--dur)}
  .wa-float svg{width:32px;height:32px}
  .wa-float:hover{transform:scale(1.08)}

  @media(max-width:900px){
    .split{grid-template-columns:1fr}
    .split.reverse .txt{order:0}
    .split .media{min-height:340px}
    .split .txt{padding:56px 32px}
    .contact-grid{grid-template-columns:1fr;gap:32px}
    .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}
    .g1{grid-column:span 2;grid-row:span 1}
    .g4{grid-column:span 2}
    .nav-links{display:none}
    .burger{display:flex}
    .nav-links.open{display:flex;position:absolute;top:80px;left:0;right:0;flex-direction:column;align-items:flex-start;background:var(--creme);padding:22px 32px;gap:18px;border-bottom:1px solid var(--line);box-shadow:0 20px 30px -20px rgba(0,0,0,.2)}
    .nav-links.open a.link{color:var(--encre)}
    .nav-links.open .btn{width:100%}
    section{padding:84px 0}
    .hero .corner{display:none}
  }
  @media (prefers-reduced-motion: reduce){
    html{scroll-behavior:auto}
    *{animation-duration:.001ms!important;transition-duration:.001ms!important}
    .reveal{opacity:1;transform:none}
    .scroll-hint{animation:none}
  }


/* ============ PAGES INTÉRIEURES ============ */
body.page{padding-top:80px}
.breadcrumb{max-width:var(--maxw);margin:0 auto;padding:22px 32px 0;font-size:12.5px;letter-spacing:.03em;color:var(--gris)}
.breadcrumb a{color:var(--gris);transition:color var(--dur)}
.breadcrumb a:hover{color:var(--rouge)}
.breadcrumb span[aria-current]{color:var(--encre)}
.page-hero{padding:64px 0 34px;text-align:center}
.page-hero .label{margin-bottom:14px}
.page-hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(38px,6vw,66px);font-weight:500;line-height:1.02}
.page-hero .sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(18px,2.4vw,24px);color:var(--encre-doux);margin-top:14px;max-width:640px;margin-left:auto;margin-right:auto}
main.doc{padding:20px 0 100px}
.prose{max-width:760px;margin:0 auto;padding:0 32px}
.prose h2{font-family:'Cormorant Garamond',serif;font-size:clamp(26px,3.4vw,38px);font-weight:500;margin:44px 0 16px;line-height:1.1}
.prose h3{font-family:'Cormorant Garamond',serif;font-size:23px;font-weight:600;margin:30px 0 10px}
.prose p{color:var(--encre-doux);margin-bottom:16px}
.prose ul{margin:0 0 18px 0;padding-left:0;list-style:none}
.prose li{position:relative;padding-left:30px;margin-bottom:12px;color:var(--encre-doux)}
.prose li::before{content:"";position:absolute;left:0;top:9px;width:12px;height:12px;background:var(--sakura);border-radius:50% 50% 50% 0;transform:rotate(45deg)}
.prose a.inline{color:var(--rouge);border-bottom:1px solid var(--sakura)}
.prose a.inline:hover{border-color:var(--rouge)}
.meta-strip{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin:26px 0}
.chip{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:100px;padding:10px 20px;font-size:13px}
.chip svg{width:16px;height:16px;color:var(--or)}
.chip .price{color:var(--rouge);font-weight:600;font-family:'Cormorant Garamond',serif;font-size:19px}
.chip .old{text-decoration:line-through;color:var(--gris);font-size:13px}
.cta-block{max-width:760px;margin:56px auto 0;padding:0 32px;text-align:center}
.cta-block .btn{margin:8px 6px 0}
.soin-media{max-width:960px;margin:30px auto 0;padding:0 32px}
.soin-media .frame{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/9;background-color:#e5d6c7;background-size:cover;background-position:center}
.next-links{max-width:960px;margin:70px auto 0;padding:0 32px;display:grid;grid-template-columns:1fr 1fr;gap:20px}
.next-links a{display:flex;flex-direction:column;gap:6px;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:22px 26px;transition:transform var(--dur),box-shadow var(--dur)}
.next-links a:hover{transform:translateY(-3px);box-shadow:0 24px 44px -34px rgba(208,0,0,.4)}
.next-links .k{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--or-fonce)}
.next-links .t{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--encre)}
/* soins hub grid reuse .cards/.card */
.hub-grid{max-width:var(--maxw);margin:0 auto;padding:20px 32px 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:26px}
.hub-grid a.card{cursor:pointer}
.hub-grid a.card .top{padding:32px 30px 22px;position:relative}
/* tarifs table */
.tarifs{max-width:820px;margin:20px auto 0;padding:0 32px}
.trow{display:flex;align-items:center;gap:18px;padding:24px 0;border-bottom:1px solid var(--line)}
.trow .info{flex:1}
.trow .nm{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:500}
.trow .du{font-size:13px;color:var(--gris);margin-top:2px}
.trow .pr{text-align:right;white-space:nowrap}
.trow .pr .now{color:var(--rouge);font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:600}
.trow .pr .old{text-decoration:line-through;color:var(--gris);font-size:15px;margin-left:8px}
/* FAQ */
.faq{max-width:820px;margin:20px auto 0;padding:0 32px}
.faq details{border-bottom:1px solid var(--line);padding:8px 0}
.faq summary{cursor:pointer;list-style:none;padding:20px 40px 20px 0;position:relative;font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:500;color:var(--encre)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:6px;top:16px;font-size:26px;color:var(--or);font-family:'Jost';transition:transform var(--dur)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--encre-doux);padding:0 0 20px}
/* avis */
.reviews{max-width:var(--maxw);margin:20px auto 0;padding:0 32px;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px}
.review .stars{color:var(--or);letter-spacing:3px;font-size:15px}
.review p{color:var(--encre-doux);font-style:italic;font-family:'Cormorant Garamond',serif;font-size:19px;margin:14px 0}
.review .who{font-size:13px;letter-spacing:.06em;color:var(--encre);font-weight:500}
/* legal */
.legal-doc{max-width:760px;margin:0 auto;padding:0 32px}
.legal-doc h2{font-size:24px;margin-top:36px}
.legal-doc p,.legal-doc li{font-size:14.5px;color:var(--encre-doux)}
@media(max-width:640px){.next-links{grid-template-columns:1fr}}
