/* ── BASE COMMUNE PAGES SOINS ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--sage:#C9897A;--sage-pale:#f0cfc4;--sage-light:#E8C4BB;--lin:#E6DDD0;--brun:#4A3028;--brun-doux:#8B6355;--or-doux:#C4A882;--blanc:#FDFAF6;--blanc-chaud:#FAF5F0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--blanc);color:var(--brun);overflow-x:hidden}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 3.5rem;background:rgba(254,252,249,0.93);backdrop-filter:blur(10px);border-bottom:1px solid rgba(201,137,122,0.12)}
.nav-logo{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:400;color:var(--brun);text-decoration:none}
.nav-logo em{font-style:italic;color:#A86E5C}
.nav-links{display:flex;gap:2.5rem;list-style:none;align-items:center}
.nav-links a{font-size:0.8rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--brun-doux);text-decoration:none;opacity:1;transition:opacity 0.2s,color 0.2s}
.nav-links a:hover{opacity:1;color:var(--sage)}
.nav-cta{background:var(--sage)!important;color:white!important;opacity:1!important;padding:0.55rem 1.5rem;border-radius:2rem}

/* ── HERO ── */
.hero{min-height:85vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:linear-gradient(160deg,#f9ede9 0%,#f0cfc4 50%,#e8b8ac 100%);padding:8rem 2rem 4rem;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 30%,rgba(255,255,255,0.3) 0%,transparent 60%)}
.hero-badge{display:inline-flex;align-items:center;gap:0.5rem;background:rgba(255,255,255,0.6);border:1px solid rgba(139,99,85,0.25);border-radius:99px;padding:0.4rem 1rem;font-size:0.75rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--brun-doux);margin-bottom:1.5rem;opacity:0;transform:translateY(20px);animation:fadeUp 0.7s ease 0.2s forwards}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(2.8rem,6vw,5rem);font-weight:400;line-height:1.15;color:var(--brun);margin-bottom:1.2rem;opacity:0;transform:translateY(30px);animation:fadeUp 0.8s ease 0.4s forwards}
.hero h1 em{color:var(--sage);font-style:italic}
.hero-sub{font-size:1.05rem;color:var(--brun-doux);max-width:580px;line-height:1.75;margin-bottom:2.5rem;opacity:0;transform:translateY(20px);animation:fadeUp 0.8s ease 0.6s forwards}
.hero-stats{display:flex;gap:3rem;align-items:center;margin-bottom:3rem;opacity:0;transform:translateY(20px);animation:fadeUp 0.8s ease 0.8s forwards}
.hero-stat{text-align:center}
.hero-stat-num{font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:400;color:var(--brun);display:block}
.hero-stat-label{font-size:0.78rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--brun-doux)}
.hero-divider{width:1px;height:40px;background:rgba(74,48,40,0.2)}
.hero-cta{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;justify-content:center;opacity:0;transform:translateY(20px);animation:fadeUp 0.8s ease 1s forwards}
.btn-primary{background:var(--sage);color:white;padding:0.9rem 2rem;border-radius:99px;text-decoration:none;font-size:0.9rem;transition:background 0.2s,transform 0.2s;display:inline-flex;align-items:center;gap:0.5rem}
.btn-primary:hover{background:var(--brun-doux);transform:translateY(-2px)}
.btn-secondary{color:var(--brun-doux);text-decoration:none;font-size:0.9rem;border-bottom:1px solid var(--sage-light);padding-bottom:2px;transition:color 0.2s,border-color 0.2s}
.btn-secondary:hover{color:var(--brun);border-color:var(--sage)}
.back-link{display:inline-flex;align-items:center;gap:0.5rem;font-size:0.82rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--brun-doux);text-decoration:none;margin-top:2.5rem;opacity:0;animation:fadeUp 0.7s ease 1.2s forwards;transition:color 0.2s}
.back-link:hover{color:var(--brun)}

/* ── SECTIONS COMMUNES ── */
section{padding:6rem 2rem}
.container{max-width:1000px;margin:0 auto}
.section-label{font-size:0.75rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--sage);margin-bottom:0.75rem;display:flex;align-items:center;gap:0.75rem}
.section-label::before{content:'';display:block;width:2rem;height:1px;background:var(--sage)}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3rem);font-weight:400;line-height:1.2;margin-bottom:1.5rem}
.section-title em{color:var(--sage);font-style:italic}

/* ── INTRO ── */
.intro{background:var(--blanc)}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.intro-text p{font-size:1.05rem;line-height:1.8;color:var(--brun-doux);margin-bottom:1.2rem}
.intro-text p strong{color:var(--brun);font-weight:500}
.intro-image{border-radius:20px;overflow:hidden;box-shadow:0 20px 50px rgba(74,48,40,0.12);position:relative;transition:transform 0.4s ease,box-shadow 0.4s ease}
.intro-image:hover{transform:translateY(-6px);box-shadow:0 30px 70px rgba(74,48,40,0.18)}
.intro-image img{width:100%;height:auto;display:block}
.intro-image-badge{position:absolute;bottom:1.5rem;left:1.5rem;background:rgba(253,250,246,0.95);border-radius:12px;padding:0.75rem 1rem;font-size:0.82rem;color:var(--brun-doux)}
.intro-image-badge strong{display:block;font-size:1rem;color:var(--brun)}

/* ── BIENFAITS ── */
.bienfaits{background:var(--blanc-chaud)}
.bienfaits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:3rem}
.bienfait-card{background:var(--blanc);border:1px solid var(--lin);border-radius:16px;padding:2rem;transition:transform 0.3s ease,box-shadow 0.3s ease;opacity:0;transform:translateY(30px)}
.bienfait-card.visible{animation:fadeUp 0.6s ease forwards}
.bienfait-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(74,48,40,0.08)}
.bienfait-icon{width:48px;height:48px;background:var(--sage-pale);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:1rem}
.bienfait-card h3{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:400;margin-bottom:0.5rem}
.bienfait-card p{font-size:0.9rem;line-height:1.7;color:var(--brun-doux)}

/* ── DÉROULÉ ── */
.deroulé{background:var(--blanc)}
.timeline{position:relative;margin-top:3.5rem}
.timeline::before{content:'';position:absolute;left:28px;top:0;bottom:0;width:1px;background:var(--lin)}
.timeline-step{display:flex;gap:2rem;margin-bottom:3rem;position:relative;opacity:0;transform:translateX(-20px)}
.timeline-step.visible{animation:fadeRight 0.6s ease forwards}
.step-num{width:56px;height:56px;flex-shrink:0;background:var(--blanc);border:1.5px solid var(--lin);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--sage);position:relative;z-index:1;transition:background 0.3s,border-color 0.3s}
.timeline-step:hover .step-num{background:var(--sage-pale);border-color:var(--sage)}
.step-content{padding-top:0.75rem}
.step-content h3{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:400;margin-bottom:0.5rem}
.step-content p{font-size:0.93rem;line-height:1.75;color:var(--brun-doux)}
.step-duration{display:inline-block;margin-top:0.5rem;font-size:0.75rem;letter-spacing:0.08em;color:var(--sage);text-transform:uppercase}

/* ── FAQ ── */
.faq{background:var(--blanc-chaud)}
.faq-list{margin-top:3rem}
.faq-item{border-bottom:1px solid var(--lin);opacity:0;transform:translateY(20px)}
.faq-item.visible{animation:fadeUp 0.5s ease forwards}
.faq-question{width:100%;text-align:left;background:none;border:none;padding:1.5rem 0;display:flex;justify-content:space-between;align-items:center;font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:500;color:var(--brun);cursor:pointer;transition:color 0.2s}
.faq-question:hover{color:var(--sage)}
.faq-icon{width:28px;height:28px;flex-shrink:0;background:var(--sage-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--sage);transition:transform 0.3s,background 0.3s}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--sage);color:white}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.4s ease}
.faq-item.open .faq-answer{max-height:300px}
.faq-answer p{padding-bottom:1.5rem;font-size:0.93rem;line-height:1.8;color:var(--brun-doux)}

/* ── TARIF ── */
.tarif{background:linear-gradient(135deg,#f9ede9 0%,var(--sage-pale) 100%)}
.tarif-card{background:var(--blanc);border-radius:24px;padding:3rem;max-width:600px;margin:3rem auto 0;box-shadow:0 20px 60px rgba(74,48,40,0.1);text-align:center;opacity:0;transform:translateY(30px)}
.tarif-card.visible{animation:fadeUp 0.7s ease forwards}
.tarif-badge{display:inline-block;background:var(--sage-pale);color:var(--brun-doux);font-size:0.75rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.4rem 1rem;border-radius:99px;margin-bottom:0.75rem}
.tarif-prix{font-family:'Playfair Display',serif;font-size:3.5rem;color:var(--brun);line-height:1}
.tarif-prix span{font-size:1.2rem;color:var(--brun-doux)}
.tarif-duree{font-size:0.85rem;color:var(--brun-doux);margin-top:0.5rem;margin-bottom:1.5rem}
.tarif-includes{list-style:none;text-align:left;margin-bottom:2rem}
.tarif-includes li{display:flex;align-items:flex-start;gap:0.75rem;font-size:0.9rem;color:var(--brun-doux);padding:0.5rem 0;border-bottom:1px solid var(--lin)}
.tarif-includes li:last-child{border-bottom:none}
.tarif-includes li::before{content:'✓';color:var(--sage);font-weight:600;flex-shrink:0}
.tarif-zone{font-size:0.82rem;color:var(--brun-doux);margin-bottom:2rem;line-height:1.6}
.btn-rdv{display:inline-flex;align-items:center;gap:0.6rem;background:var(--sage);color:white;padding:1rem 2.5rem;border-radius:99px;text-decoration:none;font-size:0.95rem;transition:background 0.2s,transform 0.2s;width:100%;justify-content:center}
.btn-rdv:hover{background:var(--brun-doux);transform:translateY(-2px)}

/* ── BADGE PROMO (rebozo / rituel) ── */
.hero-promo{display:inline-flex;align-items:center;gap:0.6rem;background:rgba(201,137,122,0.15);border:1px solid rgba(201,137,122,0.4);border-radius:99px;padding:0.5rem 1.2rem;font-size:0.82rem;color:var(--brun);margin-bottom:1rem;opacity:0;animation:fadeUp 0.7s ease 0.9s forwards}
.hero-promo strong{color:var(--sage)}
.tarif-promo-badge{display:inline-block;background:rgba(201,137,122,0.15);border:1px solid rgba(201,137,122,0.4);color:var(--sage);font-size:0.8rem;padding:0.3rem 0.9rem;border-radius:99px;margin-bottom:1rem}
.tarif-prix-old{font-size:1rem;color:var(--brun-doux);text-decoration:line-through;margin-bottom:0.25rem}

/* ── AUTRES SOINS ── */
.autres{background:var(--blanc)}
.autres-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:3rem}
.autre-card{background:var(--blanc-chaud);border:1px solid var(--lin);border-radius:16px;padding:1.5rem;text-decoration:none;color:inherit;transition:transform 0.3s,box-shadow 0.3s;opacity:0;transform:translateY(20px)}
.autre-card.visible{animation:fadeUp 0.5s ease forwards}
.autre-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px rgba(74,48,40,0.08)}
.autre-tag{font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--sage);margin-bottom:0.5rem}
.autre-card h3{font-family:'Playfair Display',serif;font-size:1rem;font-weight:400;margin-bottom:0.4rem}
.autre-card p{font-size:0.82rem;color:var(--brun-doux);line-height:1.5}
.autre-prix{margin-top:0.75rem;font-size:0.85rem;font-weight:500;color:var(--brun)}

/* ── FOOTER ── */
footer{background:var(--blanc);border-top:1px solid var(--lin);color:var(--brun-doux);padding:3rem 2rem;text-align:center}
footer a{color:var(--brun-doux);text-decoration:none}
footer .footer-logo{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--brun);margin-bottom:1rem;display:block}
footer .footer-logo em{color:var(--sage);font-style:italic}
footer nav{background:none;border:none;position:static;padding:0;justify-content:center}
footer .nav-links a{color:var(--brun-doux);opacity:1}
footer .nav-links a:hover{opacity:1;color:var(--sage)}
.footer-copy{margin-top:2rem;font-size:0.8rem;color:var(--brun-doux);opacity:0.5}

/* ── ANIMATIONS ── */
@keyframes fadeUp{to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes fadeRight{to{opacity:1;transform:translateX(0)}}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  nav{padding:1rem 1.5rem}
  .nav-links{display:none}
  .nav-hamburger{display:block}
  .intro-grid,.bienfaits-grid,.autres-grid{grid-template-columns:1fr}
  .hero-stats{gap:1.5rem}
  section{padding:4rem 1.25rem}
}

/* ── QUIZ POPUP IS ── */
#is-overlay{display:none;position:fixed;inset:0;background:rgba(74,48,40,0.55);align-items:center;justify-content:center;z-index:9998;padding:1rem}
#is-overlay.is-active{display:flex;animation:isOverlayIn 0.3s ease}
@keyframes isOverlayIn{from{opacity:0}to{opacity:1}}
#is-popup{background:#FDFAF6;border-radius:16px;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;padding:2rem 1.75rem 1.75rem;position:relative;animation:isPopupIn 0.35s ease;border:1px solid #E6DDD0;font-family:'DM Sans',sans-serif;box-sizing:border-box}
@keyframes isPopupIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
#is-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:20px;color:#8B6355;cursor:pointer;line-height:1;padding:0}
#is-close:hover{color:#4A3028}
.is-logo{font-family:'Playfair Display',serif;font-size:12px;color:#8B6355;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:1rem}
.is-progress-bar{height:3px;background:#E6DDD0;border-radius:2px;margin-bottom:1.5rem;overflow:hidden}
.is-progress-fill{height:100%;background:#C9897A;border-radius:2px;transition:width 0.4s ease}
.is-q-label{font-size:11px;text-transform:uppercase;letter-spacing:0.08em;color:#8B6355;margin-bottom:6px}
.is-q-text{font-family:'Playfair Display',serif;font-size:19px;color:#4A3028;line-height:1.4;margin-bottom:1.25rem;font-weight:400}
.is-q-text em{color:#8B6355;font-style:italic}
.is-options{display:flex;flex-direction:column;gap:8px}
.is-opt{background:#fff;border:1px solid #E6DDD0;border-radius:10px;padding:13px 16px;text-align:left;cursor:pointer;font-size:14px;font-family:'DM Sans',sans-serif;color:#4A3028;transition:border-color 0.2s,background 0.2s;line-height:1.4;width:100%}
.is-opt:hover{border-color:#C9897A;background:#f9f0ee}
.is-nav{display:flex;justify-content:space-between;align-items:center;margin-top:1.25rem}
.is-back{background:none;border:none;font-size:13px;color:#8B6355;cursor:pointer;text-decoration:underline;padding:0;font-family:'DM Sans',sans-serif}
.is-back:hover{color:#4A3028}
.is-step-count{font-size:12px;color:#8B6355}
.is-result-badge{display:inline-block;font-size:11px;background:#f9f0ee;color:#8B6355;border-radius:20px;padding:4px 12px;letter-spacing:0.04em;margin-bottom:0.75rem}
.is-result-title{font-family:'Playfair Display',serif;font-size:21px;color:#4A3028;margin-bottom:0.3rem;font-weight:400;line-height:1.3}
.is-result-price{font-size:13px;color:#8B6355;margin-bottom:0.9rem}
.is-result-msg{font-size:14px;color:#4A3028;line-height:1.65;margin-bottom:1.25rem;min-height:52px}
.is-loading{display:flex;align-items:center;gap:8px;font-size:13px;color:#8B6355}
.is-dot{width:7px;height:7px;border-radius:50%;background:#C9897A;animation:isDot 1.2s ease-in-out infinite}
.is-dot:nth-child(2){animation-delay:0.2s}
.is-dot:nth-child(3){animation-delay:0.4s}
@keyframes isDot{0%,80%,100%{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}
.is-btn-rdv{display:block;background:#C9897A;color:#fff;border:none;border-radius:30px;padding:13px 0;text-align:center;font-size:14px;font-family:'DM Sans',sans-serif;cursor:pointer;text-decoration:none;letter-spacing:0.03em;transition:background 0.2s;width:100%;margin-bottom:0.5rem}
.is-btn-rdv:hover{background:#8B6355}
.is-btn-soin{display:block;background:transparent;color:#8B6355;border:1px solid #E6DDD0;border-radius:30px;padding:11px 0;text-align:center;font-size:13px;font-family:'DM Sans',sans-serif;cursor:pointer;text-decoration:none;letter-spacing:0.03em;transition:border-color 0.2s,background 0.2s;width:100%;margin-bottom:1rem}
.is-btn-soin:hover{border-color:#C9897A;background:#f9f0ee}
.is-also{margin-top:0.5rem;padding-top:0.75rem;border-top:1px solid #E6DDD0}
.is-also-label{font-size:11px;text-transform:uppercase;letter-spacing:0.08em;color:#C4A882;margin-bottom:8px}
.is-also-tags{display:flex;flex-wrap:wrap;gap:6px}
.is-also-tag{font-size:12px;border:none;border-radius:20px;padding:4px 12px;color:#8B6355;background:#f0cfc4;font-family:'DM Sans',sans-serif;text-decoration:none;transition:background 0.2s}
.is-also-tag:hover{background:#e4b8ac}
.is-btn-restart{display:block;text-align:center;background:none;border:none;font-size:12px;color:#C4A882;cursor:pointer;margin-top:0.75rem;width:100%;font-family:'DM Sans',sans-serif}
.is-btn-restart:hover{color:#8B6355}
#is-float-btn:hover{background:var(--brun-doux);transform:translateY(-2px)}
@media(max-width:480px){#is-popup{padding:1.5rem 1.25rem}.is-q-text{font-size:17px}#is-float-btn span:last-child{display:none}#is-float-btn{padding:0.85rem;border-radius:50%}}

/* ── HAMBURGER MOBILE ── */
.nav-hamburger{display:none;background:none;border:none;cursor:pointer;padding:0.5rem;color:var(--brun)}
.nav-hamburger svg{width:24px;height:24px}
.nav-overlay{display:none;position:fixed;inset:0;z-index:200;background:rgba(74,48,40,0.4);backdrop-filter:blur(4px)}
.nav-mobile{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:var(--blanc);z-index:201;display:flex;flex-direction:column;padding:2rem 2rem 3rem;gap:0;transition:right 0.35s cubic-bezier(0.4,0,0.2,1);box-shadow:-8px 0 30px rgba(74,48,40,0.1)}
.nav-mobile.open{right:0}.nav-overlay.open{display:block}
.nav-mobile-close{align-self:flex-end;background:none;border:none;cursor:pointer;color:var(--brun-doux);padding:0.5rem;margin-bottom:2rem}
.nav-mobile-close svg{width:22px;height:22px}
.nav-mobile a{font-size:1rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--brun-doux);text-decoration:none;padding:1rem 0;border-bottom:1px solid var(--lin);transition:color 0.2s}
.nav-mobile a:hover{color:var(--sage)}
.nav-mobile .nav-mobile-cta{margin-top:1.5rem;background:var(--sage);color:white;padding:0.9rem 2rem;border-radius:3rem;text-align:center;font-size:0.85rem;letter-spacing:0.1em;border-bottom:none}
