/* ==========================================================================
   PAGES — patterns hero, intro, benefits, services, gallery, testimonials...
   ========================================================================== */

/* HERO */
.hero {
  position: relative;
  min-height: 92vh;
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  align-items: center;
  gap: var(--space-8);
  padding-top: var(--space-8);
  padding-bottom: var(--space-10);
  max-width: var(--container-wide);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.hero__text { position: relative; z-index: 2; }
.hero__eyebrow { display: inline-block; margin-bottom: var(--space-5); }
.hero__title {
  font-family: var(--font-serif);
  font-size: var(--fs-display-xl);
  font-weight: 300;
  line-height: 1.02;
  letter-spacing: -0.025em;
  color: var(--terra-very-deep);
  margin-bottom: var(--space-5);
}
.hero__title em { font-style: italic; font-weight: 400; color: var(--terra-deep); }
.hero__subtitle {
  font-family: var(--font-sans);
  font-size: var(--fs-body-lg);
  color: var(--earth-soft);
  max-width: 48ch;
  margin-bottom: var(--space-6);
  line-height: 1.7;
}
.hero__cta { display: flex; flex-wrap: wrap; gap: var(--space-4); align-items: center; }
.hero__trust {
  margin-top: var(--space-6);
  display: flex;
  align-items: center;
  gap: var(--space-4);
  font-size: var(--fs-label-md);
  color: var(--earth-muted);
  letter-spacing: var(--ls-wide);
}
.hero__trust strong { color: var(--terra-very-deep); font-weight: 500; }
.hero__image {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lift);
  transform: translateY(-20px);
}
.hero__image img { width: 100%; height: 100%; object-fit: cover; }
.hero__image::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(58, 34, 24, 0.22) 100%);
  pointer-events: none;
}
/* Petit badge décoratif "Depuis 2016" flottant sur l'image */
.hero__badge {
  position: absolute;
  bottom: var(--space-5);
  left: var(--space-5);
  padding: var(--space-3) var(--space-4);
  background: rgba(250, 244, 234, 0.95);
  backdrop-filter: blur(10px);
  border-radius: var(--radius-md);
  font-family: var(--font-label);
  font-size: var(--fs-label-md);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--terra-very-deep);
  z-index: 3;
  box-shadow: var(--shadow-soft);
}
.hero__badge strong { display: block; font-family: var(--font-serif); font-size: 1.35rem; text-transform: none; letter-spacing: -0.01em; margin-top: 2px; color: var(--terra-deep); font-style: italic; font-weight: 400; }
@media (max-width: 960px) {
  .hero { grid-template-columns: 1fr; min-height: auto; padding-top: var(--space-7); padding-bottom: var(--space-8); }
  .hero__image { transform: none; max-width: 500px; margin-inline: auto; }
}

/* PROMO BAND */
.promo-band { background: var(--color-bg-terra); padding: var(--space-5) 0; text-align: center; }
.promo-band__inner {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-4);
  flex-wrap: wrap;
  justify-content: center;
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--terra-very-deep);
  padding-inline: var(--gutter);
}
.promo-band strong {
  font-family: var(--font-label);
  font-style: normal;
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  font-size: var(--fs-label-md);
  font-weight: 500;
  background: var(--cream-elevated);
  padding: 0.5rem 1rem;
  border-radius: var(--radius-pill);
}

/* INTRO */
.intro { display: grid; grid-template-columns: 1fr 1.1fr; gap: var(--space-8); align-items: center; }
.intro__text { padding-right: var(--space-6); }
.intro__text .eyebrow { margin-bottom: var(--space-4); }
.intro__text h2 { margin-bottom: var(--space-5); }
.intro__text p + p { margin-top: var(--space-4); }
.intro__image {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  border-radius: var(--radius-md);
  transform: translateY(24px);
  box-shadow: var(--shadow-ambient);
}
.intro__image img { width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 860px) {
  .intro { grid-template-columns: 1fr; gap: var(--space-6); }
  .intro__text { padding-right: 0; }
  .intro__image { transform: none; max-width: 500px; margin-inline: auto; }
}

/* BENEFITS (engagements) */
.benefits { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); margin-top: var(--space-7); }
.benefit { padding: var(--space-6) var(--space-5); background: var(--cream-elevated); border-radius: var(--radius-md); text-align: left; }
.benefit svg { width: 36px; height: 36px; stroke: var(--terra-deep); stroke-width: 1.2; fill: none; margin-bottom: var(--space-4); }
.benefit h3 { font-size: var(--fs-title-lg); font-style: italic; margin-bottom: var(--space-3); color: var(--terra-very-deep); }
.benefit p { font-size: var(--fs-body-sm); color: var(--earth-soft); line-height: var(--lh-relaxed); }
@media (max-width: 960px) { .benefits { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .benefits { grid-template-columns: 1fr; } }

/* SERVICES / TARIFS — table premium */
.services-intro { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-8); align-items: end; margin-bottom: var(--space-7); }
.services-intro__note {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--fs-body-lg);
  color: var(--earth-soft);
  line-height: var(--lh-relaxed);
  max-width: 42ch;
}
@media (max-width: 860px) { .services-intro { grid-template-columns: 1fr; gap: var(--space-5); } }

.services-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-5); }
@media (max-width: 860px) { .services-grid { grid-template-columns: 1fr; } }

.service-card {
  background: var(--cream-elevated);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  box-shadow: var(--shadow-ambient);
  transition: transform var(--dur-normal) var(--ease-out), box-shadow var(--dur-normal) var(--ease-out);
  display: flex;
  flex-direction: column;
}
.service-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lift); }
.service-card__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-4);
  margin-bottom: var(--space-3);
  flex-wrap: wrap;
}
.service-card__title {
  font-family: var(--font-serif);
  font-size: var(--fs-headline-sm);
  font-weight: 400;
  color: var(--terra-very-deep);
  letter-spacing: -0.01em;
}
.service-card__duration {
  font-family: var(--font-label);
  font-size: var(--fs-label-md);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--earth-muted);
}
.service-card p { font-size: var(--fs-body-sm); color: var(--earth-soft); margin-bottom: var(--space-5); }
.service-card__prices {
  margin-top: auto;
  padding-top: var(--space-4);
  border-top: 1px solid rgba(164, 85, 58, 0.15);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-3);
}
.service-card__prices--two { grid-template-columns: repeat(2, 1fr); }
.service-card__price {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.service-card__price small {
  font-family: var(--font-label);
  font-size: var(--fs-label-sm);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--earth-muted);
}
.service-card__price strong {
  font-family: var(--font-serif);
  font-size: var(--fs-headline-sm);
  font-weight: 400;
  color: var(--terra-deep);
  letter-spacing: -0.01em;
}
@media (max-width: 520px) { .service-card__prices { grid-template-columns: repeat(2, 1fr); gap: var(--space-4); } }

/* FORFAITS (bandeau premium) */
.packs { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); margin-top: var(--space-7); }
.pack {
  padding: var(--space-6);
  border-radius: var(--radius-md);
  background: var(--cream-elevated);
  box-shadow: var(--shadow-ambient);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  position: relative;
  overflow: hidden;
}
.pack--featured {
  background: linear-gradient(160deg, var(--terra-pale) 0%, var(--cream-elevated) 100%);
  box-shadow: var(--shadow-lift);
}
.pack__eyebrow {
  font-family: var(--font-label);
  font-size: var(--fs-label-md);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--terra-deep);
  font-weight: 500;
}
.pack h3 { font-size: var(--fs-headline-md); font-style: italic; font-weight: 400; }
.pack__price {
  font-family: var(--font-serif);
  font-size: clamp(2.2rem, 3.5vw, 2.8rem);
  font-weight: 300;
  color: var(--terra-very-deep);
  letter-spacing: -0.02em;
  line-height: 1;
}
.pack__price small { font-size: var(--fs-label-md); font-family: var(--font-label); text-transform: uppercase; letter-spacing: var(--ls-wider); color: var(--earth-muted); display: inline-block; margin-left: var(--space-2); }
.pack ul { list-style: none; display: flex; flex-direction: column; gap: var(--space-2); margin-top: var(--space-2); }
.pack ul li { position: relative; padding-left: var(--space-5); font-size: var(--fs-body-sm); color: var(--earth-soft); }
.pack ul li::before {
  content: "";
  position: absolute; left: 0; top: 0.6em;
  width: 10px; height: 1px;
  background: var(--terra-deep);
}
@media (max-width: 960px) { .packs { grid-template-columns: 1fr; } }

/* GALLERY (Avant / Après) */
.gallery-head { display: flex; justify-content: space-between; align-items: end; gap: var(--space-5); flex-wrap: wrap; margin-bottom: var(--space-7); }
.gallery-head h2 { max-width: 16ch; }
.gallery-head p { max-width: 44ch; color: var(--earth-soft); font-size: var(--fs-body-md); }

.gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 1fr;
  gap: var(--space-4);
}
.gallery__item {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-md);
  aspect-ratio: 4/5;
  box-shadow: var(--shadow-soft);
}
.gallery__item--wide { grid-column: span 2; aspect-ratio: 16/11; }
.gallery__item--tall { grid-row: span 2; aspect-ratio: 3/5; }
.gallery__item img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s var(--ease-out); }
.gallery__item:hover img { transform: scale(1.04); }
.gallery__item__caption {
  position: absolute;
  bottom: var(--space-4);
  left: var(--space-4);
  right: var(--space-4);
  color: var(--cream-surface);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--fs-body-md);
  z-index: 2;
  text-shadow: 0 2px 12px rgba(0,0,0,0.35);
}
.gallery__item__caption small {
  display: block;
  font-family: var(--font-label);
  font-style: normal;
  font-size: var(--fs-label-sm);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  opacity: 0.85;
  margin-bottom: 2px;
}
.gallery__item::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.45) 100%);
  pointer-events: none;
}
@media (max-width: 860px) {
  .gallery { grid-template-columns: 1fr 1fr; }
  .gallery__item--wide, .gallery__item--tall { grid-column: auto; grid-row: auto; aspect-ratio: 4/5; }
}
@media (max-width: 520px) { .gallery { grid-template-columns: 1fr; } }

/* TRUST STRIP */
.trust-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  padding-block: var(--space-6);
  border-block: 1px solid rgba(164, 85, 58, 0.16);
}
.trust-strip__item { text-align: center; }
.trust-strip__num {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(2rem, 3.2vw, 2.8rem);
  color: var(--terra-very-deep);
  line-height: 1;
  letter-spacing: -0.02em;
}
.trust-strip__label {
  display: block;
  margin-top: var(--space-2);
  font-family: var(--font-label);
  font-size: var(--fs-label-md);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--earth-muted);
}
@media (max-width: 720px) { .trust-strip { grid-template-columns: repeat(2, 1fr); gap: var(--space-6); } }

/* TESTIMONIALS */
.testimonials { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-8); margin-top: var(--space-7); }
.testimonial { padding: var(--space-6); }
.testimonial blockquote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--fs-headline-sm);
  line-height: 1.5;
  color: var(--terra-very-deep);
  margin-bottom: var(--space-5);
  position: relative;
  padding-left: var(--space-5);
}
.testimonial blockquote::before {
  content: "«";
  position: absolute; left: -0.2em; top: -0.2em;
  font-size: 3em; line-height: 1;
  color: var(--terra-pale);
  font-family: var(--font-serif);
}
.testimonial cite {
  font-family: var(--font-label);
  font-style: normal;
  font-size: var(--fs-label-md);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--earth-muted);
}
.testimonial__stars { display: inline-flex; gap: 2px; margin-bottom: var(--space-3); color: var(--gold-mid); }
@media (max-width: 860px) { .testimonials { grid-template-columns: 1fr; gap: var(--space-6); } }

/* CTA BAND */
.cta-band { background: var(--color-bg-terra); padding-block: var(--space-9); text-align: center; }
.cta-band h2 { font-size: var(--fs-display-md); margin-bottom: var(--space-5); color: var(--terra-very-deep); }
.cta-band p { margin-inline: auto; margin-bottom: var(--space-6); color: var(--earth-soft); font-size: var(--fs-body-lg); max-width: 60ch; }

/* FAQ */
.faq-list { max-width: var(--container-narrow); margin-inline: auto; margin-top: var(--space-7); }
.faq-item { padding: var(--space-5) 0; position: relative; }
.faq-item + .faq-item::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: rgba(164, 85, 58, 0.14); }
.faq-item__q {
  display: flex; justify-content: space-between; align-items: center;
  width: 100%; text-align: left;
  padding: var(--space-3) 0;
  font-family: var(--font-serif);
  font-size: var(--fs-headline-sm);
  color: var(--terra-very-deep);
  cursor: pointer;
  gap: var(--space-4);
}
.faq-item__q::after { content: "+"; font-family: var(--font-label); font-size: 1.5rem; color: var(--terra-deep); flex-shrink: 0; }
.faq-item.is-open .faq-item__q::after { content: "–"; }
.faq-item__a {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--dur-slow) var(--ease-out), padding var(--dur-slow) var(--ease-out);
  color: var(--earth-soft);
  font-size: var(--fs-body-md);
  line-height: var(--lh-relaxed);
}
.faq-item.is-open .faq-item__a { max-height: 600px; padding-top: var(--space-4); padding-bottom: var(--space-3); }

/* CONTACT + BOOKING FORM */
.contact-grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: var(--space-8); align-items: start; margin-top: var(--space-7); }
.contact-info__block { margin-bottom: var(--space-6); }
.contact-info__block h4 {
  font-family: var(--font-label);
  font-size: var(--fs-label-md);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--earth-muted);
  margin-bottom: var(--space-2);
}
.contact-info__block p, .contact-info__block a { font-size: var(--fs-body-lg); color: var(--earth-body); }
.contact-info__block a:hover { color: var(--terra-deep); }

.booking-form {
  background: var(--cream-elevated);
  padding: var(--space-7);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-ambient);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
}
.booking-form__field { display: flex; flex-direction: column; gap: var(--space-2); }
.booking-form__field--full { grid-column: 1 / -1; }
.booking-form__field label {
  font-family: var(--font-label);
  font-size: var(--fs-label-md);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--earth-muted);
  font-weight: 500;
}
.booking-form__field input,
.booking-form__field select,
.booking-form__field textarea {
  font: inherit;
  font-size: var(--fs-body-md);
  color: var(--earth-body);
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(164, 85, 58, 0.25);
  padding: var(--space-3) 0;
  transition: border-color var(--dur-fast) var(--ease-out);
  border-radius: 0;
}
.booking-form__field textarea { resize: vertical; min-height: 90px; }
.booking-form__field input:focus,
.booking-form__field select:focus,
.booking-form__field textarea:focus {
  outline: none;
  border-bottom: 2px solid var(--terra-deep);
}
.booking-form__submit { grid-column: 1 / -1; display: flex; justify-content: flex-end; margin-top: var(--space-3); }
@media (max-width: 860px) {
  .contact-grid { grid-template-columns: 1fr; gap: var(--space-6); }
  .booking-form { grid-template-columns: 1fr; padding: var(--space-5); }
}

/* STICKY CTA MOBILE */
.sticky-cta-mobile {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  display: none;
  z-index: var(--z-modal);
  padding: var(--space-3);
  gap: var(--space-3);
  background: rgba(250, 244, 234, 0.94);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid var(--color-outline);
}
.sticky-cta-mobile .btn { flex: 1; padding: 0.85rem 0.75rem; font-size: var(--fs-label-md); }
@media (max-width: 720px) { .sticky-cta-mobile { display: flex; } body { padding-bottom: 72px; } }
