/* Design system — Massage Honfleur — Pages Soins */
/* Calqué pixel pour pixel sur index.html :
   section{padding:80px 80px}, Cormorant Garamond + Lato, même palette */
:root{
  --night:#ffffff;
  --ice:#1a1008;
  --sky:#b8873a;
  --silver:#6b5040;
  /* Aliases ancienne convention */
  --gi:#1a1008; --gc:#faf5ea; --gc-d:#f0e8d5;
  --gg:#b8873a; --gg-l:#d4a85c; --gs:#5a4026;
  --shadow-sm:0 1px 3px rgba(26,16,8,.06),0 1px 2px rgba(26,16,8,.04);
  --shadow-md:0 4px 12px rgba(26,16,8,.08),0 2px 6px rgba(26,16,8,.06);
  --shadow-lg:0 20px 40px rgba(26,16,8,.12),0 8px 20px rgba(26,16,8,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Lato',sans-serif;
  background:#ffffff;
  color:#1a1008;
  font-weight:300;
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}

/* ===== NAV — copie exacte homepage ===== */
nav{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(238,228,210,.97);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(184,135,58,.14);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:20px 60px;
  transition:padding .4s cubic-bezier(.25,.1,.25,1),background .35s ease;
}
.logo{
  display:flex;
  align-items:center;
  gap:14px;
  text-decoration:none;
  flex-shrink:0;
}
.logo-icon{
  animation:spin 20s linear infinite;
  flex-shrink:0;
}
@keyframes spin{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}
.logo-text{
  font-family:'Cormorant Garamond',serif;
  font-weight:200;
  font-size:1.3rem;
  letter-spacing:.3em;
  color:#1a1008;
  text-transform:uppercase;
  line-height:1;
  display:block;
}
.logo-sub{
  font-size:.55rem;
  letter-spacing:.5em;
  color:#6b5040;
  margin-top:2px;
  display:block;
}
.nav-breadcrumb{
  display:flex;
  align-items:center;
  gap:.35rem;
  font-family:'Cormorant Garamond',serif;
  font-weight:300;
  font-size:.78rem;
  letter-spacing:.2em;
  color:#6b5040;
  text-transform:uppercase;
}
.nav-breadcrumb a{color:#6b5040;transition:color .3s}
.nav-breadcrumb a:hover{color:#b8873a}
.nav-breadcrumb .sep{opacity:.35}
.nav-breadcrumb .current{color:#1a1008}
.nav-cta{
  background:#1a1008;
  color:#faf5ea;
  border:1px solid #1a1008;
  padding:10px 24px;
  font-family:'Cormorant Garamond',serif;
  font-weight:300;
  font-size:.75rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  cursor:pointer;
  transition:all .3s;
  white-space:nowrap;
  text-decoration:none;
  display:inline-block;
}
.nav-cta:hover{background:#b8873a;border-color:#b8873a;color:#fff}

/* ===== LEGAL BAND — identique .legal-band homepage ===== */
.legal-band{
  background:#f5f0ea;
  border-bottom:1px solid rgba(184,135,58,.08);
  padding:7px 80px;
  text-align:center;
}
.legal-band p{
  font-family:'Lato',sans-serif;
  font-size:.55rem;
  letter-spacing:.18em;
  color:rgba(107,80,64,.70);
  text-transform:uppercase;
  margin:0;
}

/* ===== HERO ===== */
.service-hero{
  position:relative;
  min-height:560px;
  display:flex;
  align-items:flex-end;
  background:#1a1008;
  overflow:hidden;
}
.service-hero__bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:.40;
}
.service-hero__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(16,10,4,.6) 0%,rgba(16,10,4,.2) 40%,rgba(16,10,4,.9) 100%);
}
.service-hero__content{
  position:relative;z-index:2;
  padding:3rem 80px 4.5rem;
}
.service-hero__badges{display:flex;gap:.55rem;margin-bottom:1.4rem;flex-wrap:wrap}
.badge{
  display:inline-block;padding:.3rem .9rem;
  font-family:'Lato',sans-serif;font-size:.6rem;
  font-weight:400;letter-spacing:.22em;text-transform:uppercase;
}
.badge--dur{background:rgba(255,255,255,.08);color:rgba(255,255,255,.75);border:1px solid rgba(255,255,255,.2)}
.badge--price{background:#b8873a;color:#fff}
.badge--season{background:rgba(184,135,58,.12);color:#d4a85c;border:1px solid rgba(184,135,58,.28)}
/* h1 du hero — même style que .hero-title homepage */
.service-hero h1{
  font-family:'Cormorant Garamond',serif;
  font-weight:100;
  font-size:clamp(2.8rem,5.5vw,5rem);
  color:#f8f3eb;
  line-height:1.1;
  letter-spacing:.05em;
  margin-bottom:1rem;
  text-shadow:0 2px 12px rgba(0,0,0,.5);
}
.service-hero__lead{
  font-family:'Lato',sans-serif;
  color:rgba(240,232,216,.75);
  font-size:1rem;font-weight:300;
  letter-spacing:.15em;
  max-width:620px;margin-bottom:2rem;line-height:1.8;
}
.btn{
  display:inline-block;padding:16px 40px;
  font-family:'Cormorant Garamond',serif;
  font-size:.8rem;font-weight:400;
  letter-spacing:.25em;text-transform:uppercase;
  transition:all .3s;cursor:pointer;border:none;text-decoration:none;
}
.btn--gold{background:#b8873a;color:#fff}
.btn--gold:hover{background:#d4a85c}
.btn--ink{background:#1a1008;color:#faf5ea}
.btn--ink:hover{background:#b8873a}

/* ===== SECTIONS DE CONTENU — padding:80px 80px comme l'homepage ===== */
/* Le .container est rendu full-width, chaque .content-block = une section */
.container{
  max-width:none;
  padding:0;
  margin:0;
}
.service-content{overflow:hidden}
.content-block{
  padding:80px 80px; /* identique à section{padding:80px 80px} homepage */
  position:relative;
}
/* Fonds alternés — même logique que #experience/#soins/#avis homepage */
.content-block:nth-child(odd){background:#f8f7f4}
.content-block:nth-child(even){background:#ffffff}
/* Contrainte de lecture sur le texte (pas sur les titres ni les grilles) */
.content-block p{
  font-family:'Lato',sans-serif;
  font-weight:300;font-size:.95rem;
  color:#6b5040;line-height:1.9;
  max-width:720px;margin-bottom:1rem;
}
.content-block p:last-child{margin-bottom:0}

/* ===== TITRES — identiques .section-eyebrow + .section-title homepage ===== */
.section-label{
  font-family:'Cormorant Garamond',serif;
  font-weight:200;font-size:.65rem;
  letter-spacing:.6em;color:#b8873a;
  text-transform:uppercase;margin-bottom:16px;display:block;
}
.section-h2{
  font-family:'Cormorant Garamond',serif;
  font-weight:100;
  font-size:clamp(2rem,4vw,3.5rem); /* = .section-title homepage */
  color:#1a1008;
  line-height:1.15;margin-bottom:20px;
}
.section-line{width:60px;height:1px;background:#b8873a;margin:16px 0 28px}

/* ===== INTRO 2-COL ===== */
.intro-grid{display:grid;gap:3rem;align-items:start;max-width:1100px}
@media(min-width:760px){.intro-grid{grid-template-columns:3fr 2fr}}
.content-photo{overflow:hidden}
.content-photo img{width:100%;height:100%;object-fit:cover}

/* ===== BENEFITS — style .pillar homepage ===== */
.benefits-grid{
  list-style:none;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:0;margin-top:28px;
  max-width:1100px;
  background:rgba(184,135,58,.1);
  border:1px solid rgba(184,135,58,.14);
  box-shadow:0 2px 16px rgba(26,16,8,.06);
}
.benefits-grid li{
  background:#fff;
  border-color:rgba(184,135,58,.14);
  padding:2rem 1.8rem;
  font-family:'Lato',sans-serif;
  font-size:.88rem;font-weight:300;
  line-height:1.8;color:#6b5040;
}
.benefits-grid li::before{
  content:'';display:block;
  width:40px;height:1px;
  background:#b8873a;margin-bottom:1rem;
}
.benefits-grid strong{
  display:block;
  font-family:'Cormorant Garamond',serif;
  font-weight:400;font-size:1.15rem;
  color:#1a1008;margin-bottom:.35rem;
}

/* ===== STORY QUOTE — identique .exp-philosophy-box homepage ===== */
.story-quote{
  background:rgba(184,135,58,.08);
  border-left:3px solid rgba(184,135,58,.4);
  padding:24px 28px;border-radius:0 8px 8px 0;
  max-width:800px;
  font-family:'Cormorant Garamond',serif;
  font-style:italic;font-weight:300;font-size:1.05rem;
  color:#3a2810;line-height:1.85;
}

/* ===== BOOKING CTA — fond #1a1008 pleine largeur ===== */
.booking-cta{
  background:#1a1008;
  color:#faf5ea;
  padding:80px 80px; /* = section homepage */
  text-align:center;
}
.booking-cta__meta{
  display:flex;justify-content:center;
  gap:50px;margin-bottom:1.4rem;flex-wrap:wrap;
}
.booking-cta__meta span{
  font-family:'Lato',sans-serif;
  font-size:.6rem;letter-spacing:.4em;
  text-transform:uppercase;opacity:.4;
}
.booking-cta .section-label{color:#b8873a}
.booking-cta .section-h2{color:#f8f3eb}
.booking-cta .section-line{background:rgba(184,135,58,.3);margin-left:auto;margin-right:auto}
.booking-cta p{
  font-family:'Lato',sans-serif;font-weight:300;
  color:rgba(240,232,216,.6);font-size:.95rem;
  letter-spacing:.15em;line-height:1.8;
  max-width:500px;margin:0 auto 2.5rem;
}

/* ===== FAQ ===== */
.faq-section{
  padding:80px 80px;
  background:#f3f1ec; /* = #avis section homepage */
}
.faq-list{margin-top:28px;display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid rgba(184,135,58,.1)}
.faq-item:first-child{border-top:1px solid rgba(184,135,58,.1)}
.faq-item summary{
  padding:1.3rem 0;
  font-family:'Cormorant Garamond',serif;
  font-weight:300;font-size:1.1rem;
  color:#1a1008;cursor:pointer;
  list-style:none;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  transition:color .2s;max-width:800px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:'+';font-size:1.4rem;font-weight:100;
  color:#b8873a;flex-shrink:0;
  transition:transform .25s;
  font-family:'Cormorant Garamond',serif;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover,.faq-item[open] summary{color:#b8873a}
.faq-item .faq-body{
  padding:.2rem 0 1.3rem;
  font-family:'Lato',sans-serif;font-size:.88rem;
  font-weight:300;color:#6b5040;
  line-height:1.9;max-width:720px;
}

/* ===== RELATED — fond #f4f2ed comme #suite homepage ===== */
.related-services{
  padding:80px 80px;
  background:#f4f2ed;
}
.related-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:1px;margin-top:28px;
  max-width:1100px;
  background:rgba(184,135,58,.1);
}
.related-card{
  background:#fff;overflow:hidden;
  transition:transform .3s;color:inherit;
}
.related-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(26,16,8,.1)}
.related-card__img{aspect-ratio:4/3;overflow:hidden}
.related-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.related-card:hover .related-card__img img{transform:scale(1.04)}
.related-card__body{padding:1.4rem 1.8rem 1.8rem}
.related-card__name{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;font-weight:300;font-size:1.15rem;
  color:#1a1008;margin-bottom:.4rem;
}
.related-card__meta{
  font-family:'Lato',sans-serif;
  font-size:.65rem;letter-spacing:.1em;
  text-transform:uppercase;color:#6b5040;
  display:flex;gap:.8rem;
}

/* ===== FOOTER — copie exacte footer homepage ===== */
footer{
  background:#1a1008;
  color:rgba(240,232,216,.72);
  padding:60px 80px 36px;
  position:relative;overflow:hidden;
}
.footer-top{
  display:grid;gap:2rem 60px;
  grid-template-columns:2fr 1fr 1fr;
  margin-bottom:40px;
}
.footer-logo{
  display:flex;align-items:center;gap:12px;margin-bottom:20px;
}
.footer-brand-name{
  font-family:'Cormorant Garamond',serif;
  font-weight:200;font-size:1.1rem;
  letter-spacing:.3em;color:#f0e8d8;
  text-transform:uppercase;
}
.footer-tagline{
  font-family:'Lato',sans-serif;
  font-size:.8rem;font-weight:300;
  color:#9a7850;line-height:1.8;max-width:260px;margin-bottom:24px;
}
.footer-col h3{
  font-family:'Cormorant Garamond',serif;
  font-weight:300;font-size:.7rem;
  letter-spacing:.3em;color:#b8873a;
  text-transform:uppercase;margin-bottom:20px;
}
.footer-col p,.footer-col address{
  font-family:'Lato',sans-serif;
  font-size:.8rem;font-weight:300;
  font-style:normal;line-height:1.8;color:#9a7850;
}
.footer-col a{color:#9a7850;text-decoration:none;transition:color .2s}
.footer-col a:hover{color:#f0e8d8}
.footer-bottom{
  border-top:1px solid rgba(184,135,58,.06);
  padding-top:30px;
  display:flex;justify-content:space-between;align-items:center;
}
.footer-copy{
  font-family:'Lato',sans-serif;font-size:.7rem;
  letter-spacing:.1em;color:rgba(168,136,96,.4);
}
.footer-copy a{color:inherit;text-decoration:none;transition:color .2s}
.footer-copy a:hover{color:rgba(168,136,96,.7)}
.footer-legal{
  font-family:'Lato',sans-serif;font-size:.7rem;
  letter-spacing:.1em;color:rgba(168,136,96,.4);
}
.footer-legal a{color:inherit;text-decoration:none;transition:color .2s}
.footer-legal a:hover{color:rgba(168,136,96,.7)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .footer-top{grid-template-columns:1fr 1fr;gap:2rem 2rem}
  .footer-top > div:first-child{grid-column:1/-1}
}
@media(max-width:900px){
  nav{padding:18px 24px}
  .legal-band,.faq-section,.related-services,.booking-cta{padding-left:24px;padding-right:24px}
  .content-block{padding:60px 24px}
  .service-hero__content{padding:2.5rem 24px 3.5rem}
  footer{padding:50px 24px 28px}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .service-hero{min-height:440px}
  .service-hero h1{font-size:clamp(2rem,7vw,3rem)}
  .section-h2{font-size:clamp(1.8rem,6vw,2.8rem)}
  .footer-top{grid-template-columns:1fr}
  .benefits-grid{grid-template-columns:1fr}
  .related-grid{grid-template-columns:1fr}
  .logo-sub{display:none}
  .nav-breadcrumb{display:none}
  .content-block{padding:50px 16px}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
