.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.05;
  letter-spacing: -0.025em;
  color: var(--sage-very-deep);
  margin-bottom: var(--space-5);
}
.hero__title em { font-style: italic; font-weight: 400; color: var(--sage-deep); }
.hero__subtitle {
  font-family: var(--font-sans);
  font-size: var(--fs-body-lg);
  color: var(--earth-soft);
  max-width: 46ch;
  margin-bottom: var(--space-6);
  line-height: 1.7;
}
.hero__cta { display: flex; flex-wrap: wrap; gap: var(--space-4); align-items: center; }
.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 60%, rgba(74, 62, 48, 0.15) 100%);
  pointer-events: none;
}
@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 { background: var(--color-bg-sage); 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(--sage-very-deep);
}
.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 { 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 { 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(--sage-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(--sage-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; } }

.treatments-preview { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); margin-top: var(--space-7); }
.treatment-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);
}
.treatment-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lift); }
.treatment-card__meta { display: flex; gap: var(--space-2); margin-bottom: var(--space-4); flex-wrap: wrap; }
.treatment-card h3 { font-size: var(--fs-headline-sm); margin-bottom: var(--space-3); }
.treatment-card__price {
  font-family: var(--font-label);
  font-size: var(--fs-headline-md);
  color: var(--sage-very-deep);
  margin-top: var(--space-4);
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
}
.treatment-card__price small { font-size: var(--fs-label-md); color: var(--earth-muted); }
@media (max-width: 1100px) { .treatments-preview { grid-template-columns: repeat(2, 1fr); } } @media (max-width: 600px) { .treatments-preview { grid-template-columns: 1fr; } }

.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(--sage-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(--sage-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);
}
@media (max-width: 860px) { .testimonials { grid-template-columns: 1fr; gap: var(--space-6); } }

.gallery {
  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr;
  grid-template-rows: auto auto;
  gap: var(--space-4);
  margin-top: var(--space-7);
}
.gallery__item {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-md);
  aspect-ratio: 4/5;
  box-shadow: var(--shadow-soft);
}
.gallery__item:nth-child(1) { 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); }
@media (max-width: 860px) {
  .gallery { grid-template-columns: 1fr 1fr; }
  .gallery__item:nth-child(1) { grid-row: span 2; aspect-ratio: 2/3; }
}

.cta-band { background: var(--color-bg-sage); padding-block: var(--space-9); text-align: center; }
.cta-band h2 { font-size: var(--fs-display-md); margin-bottom: var(--space-5); color: var(--sage-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; }

.page-hero { padding-top: var(--space-9); padding-bottom: var(--space-7); background: var(--cream-layer); }
.page-hero__inner { max-width: var(--container-narrow); margin-inline: auto; padding-inline: var(--gutter); }
.page-hero h1 { font-size: var(--fs-display-lg); margin-bottom: var(--space-4); }
.page-hero p { font-size: var(--fs-body-lg); color: var(--earth-soft); max-width: 56ch; }

.about-lead { display: grid; grid-template-columns: 1fr 1.2fr; gap: var(--space-8); align-items: start; }
.about-lead__image { position: relative; aspect-ratio: 4/5; overflow: hidden; border-radius: var(--radius-md); box-shadow: var(--shadow-ambient); }
.about-lead__image img { width: 100%; height: 100%; object-fit: cover; }
.about-lead__text h2 { margin-bottom: var(--space-5); }
.about-lead__text p { margin-bottom: var(--space-4); font-size: var(--fs-body-lg); }
@media (max-width: 860px) { .about-lead { grid-template-columns: 1fr; gap: var(--space-6); } }

.pull-quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--fs-display-md);
  line-height: 1.3;
  color: var(--sage-very-deep);
  text-align: center;
  max-width: 22ch;
  margin: var(--space-9) auto;
  padding: var(--space-6);
}

.about-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-7); margin-top: var(--space-7); }
.about-grid article h3 { font-size: var(--fs-headline-sm); font-style: italic; margin-bottom: var(--space-4); color: var(--sage-very-deep); }
.about-grid article p { color: var(--earth-soft); font-size: var(--fs-body-md); }
@media (max-width: 860px) { .about-grid { grid-template-columns: 1fr; gap: var(--space-6); } }

.treatment-row { display: grid; grid-template-columns: 1fr 1.4fr; gap: var(--space-7); align-items: center; padding-block: var(--space-8); }
.treatment-row:nth-child(even) { grid-template-columns: 1.4fr 1fr; }
.treatment-row:nth-child(even) .treatment-row__image,
.treatment-row:nth-child(even) .treatment-row__visual { order: 2; }
.treatment-row__image { aspect-ratio: 4/3; overflow: hidden; border-radius: var(--radius-md); box-shadow: var(--shadow-ambient); }
.treatment-row__image img { width: 100%; height: 100%; object-fit: cover; }
.treatment-row__meta { display: flex; gap: var(--space-3); margin-bottom: var(--space-4); flex-wrap: wrap; }
.treatment-row h2 { font-size: var(--fs-headline-lg); margin-bottom: var(--space-4); }
.treatment-row p { margin-bottom: var(--space-4); }
.treatment-row__price {
  font-family: var(--font-label);
  font-size: var(--fs-display-md);
  color: var(--sage-very-deep);
  margin-block: var(--space-5);
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
}
.treatment-row__price del { font-size: var(--fs-title-md); color: var(--earth-muted); }
@media (max-width: 860px) {
  .treatment-row, .treatment-row:nth-child(even) { grid-template-columns: 1fr; gap: var(--space-5); padding-block: var(--space-6); }
  .treatment-row:nth-child(even) .treatment-row__image,
  .treatment-row:nth-child(even) .treatment-row__visual { order: -1; }
}

.faq-list { max-width: var(--container-narrow); margin-inline: auto; }
.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(95, 107, 79, 0.1); }
.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(--sage-very-deep);
  cursor: pointer;
}
.faq-item__q::after { content: "+"; font-family: var(--font-label); font-size: 1.5rem; color: var(--sage-deep); }
.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: 500px; padding-top: var(--space-4); padding-bottom: var(--space-3); }

.contact-grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: var(--space-8); }
.contact-info h2 { margin-bottom: var(--space-5); }
.contact-info__block { margin-bottom: var(--space-6); }
.contact-info__block h3 {
  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(--sage-deep); }
.contact-map { aspect-ratio: 4/5; border-radius: var(--radius-md); overflow: hidden; background: var(--cream-layer); box-shadow: var(--shadow-ambient); }
.contact-map iframe { width: 100%; height: 100%; border: 0; filter: sepia(15%) saturate(85%) hue-rotate(60deg); }
@media (max-width: 860px) { .contact-grid { grid-template-columns: 1fr; gap: var(--space-6); } .contact-map { aspect-ratio: 1/1; } }


/* ---------- Editorial treatment visuals (no photo) ---------- */
.treatment-row__visual {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-ambient);
  display: flex;
  align-items: center;
  justify-content: center;
}
.treatment-row__visual svg.deco {
  position: absolute;
  width: 55%;
  height: auto;
  stroke: var(--sage-deep);
  stroke-width: 1;
  fill: none;
  opacity: 0.85;
  z-index: 2;
}
.treatment-row__visual .numeral {
  position: absolute;
  font-family: var(--font-serif);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(8rem, 18vw, 16rem);
  line-height: 1;
  color: var(--sage-very-deep);
  opacity: 0.12;
  z-index: 1;
  letter-spacing: -0.04em;
  user-select: none;
  pointer-events: none;
}
.treatment-row__visual.v1 { background: linear-gradient(135deg, var(--cream-layer) 0%, var(--sage-pale) 100%); }
.treatment-row__visual.v1 .numeral { top: 8%; left: 6%; }
.treatment-row__visual.v2 { background: linear-gradient(160deg, var(--cream-beige) 0%, var(--cream-layer) 100%); }
.treatment-row__visual.v2 .numeral { bottom: 5%; right: 8%; }
.treatment-row__visual.v3 { background: linear-gradient(200deg, var(--sage-pale) 0%, var(--cream-surface) 100%); }
.treatment-row__visual.v3 .numeral { top: 10%; right: 10%; }
.treatment-row__visual.v4 { background: linear-gradient(180deg, var(--cream-elevated) 0%, var(--cream-layer) 50%, var(--sage-pale) 100%); }
.treatment-row__visual.v4 .numeral { bottom: 8%; left: 8%; }
.treatment-row__visual.v5 { background: linear-gradient(135deg, var(--sage-pale) 0%, var(--cream-beige) 100%); }
.treatment-row__visual.v5 .numeral { top: 12%; left: 10%; }

/* ========================================================================
   RESERVATION PAGE — clean centered layout
   ======================================================================== */

.reservation-wrap {
  max-width: 720px;
  margin: 0 auto;
  padding-block: var(--space-9);
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: calc(var(--space-10) + var(--space-5));
}

.reservation-intro {
  text-align: center;
  font-size: var(--fs-body-lg);
  color: var(--earth-soft);
  line-height: 2.0;
  margin: var(--space-7) auto;
  max-width: 56ch;
  padding-inline: var(--space-5);
}
.reservation-intro strong { color: var(--sage-very-deep); }

.booking-cta {
  background: linear-gradient(135deg, var(--cream-elevated) 0%, var(--cream-layer) 55%, var(--sage-pale) 100%);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-ambient);
  padding: calc(var(--space-10) + var(--space-5)) var(--space-8);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.booking-cta::before {
  content: "";
  position: absolute;
  top: -40%;
  right: -30%;
  width: 380px;
  height: 380px;
  background: radial-gradient(circle, rgba(138, 149, 120, 0.18) 0%, transparent 70%);
  pointer-events: none;
}
.booking-cta > * { position: relative; z-index: 1; }
.booking-cta .eyebrow {
  display: block;
  margin: 0 0 var(--space-6);
}
.booking-cta h2 {
  font-size: var(--fs-display-md);
  color: var(--sage-very-deep);
  margin: 0 auto var(--space-6);
  max-width: none;
  line-height: 1.2;
}
.booking-cta > p {
  max-width: 42ch;
  margin: 0 auto var(--space-8);
  color: var(--earth-soft);
  font-size: var(--fs-body-lg);
  text-align: center;
  line-height: 1.8;
}
.booking-cta .btn {
  min-width: 260px;
  margin: 0 auto;
}
.booking-cta__hint {
  display: block;
  max-width: none;
  margin: var(--space-6) auto 0;
  font-size: var(--fs-label-md);
  color: var(--earth-muted);
}

.reservation-fallback {
  text-align: center;
  padding: calc(var(--space-10) + var(--space-3)) var(--space-8);
  background: var(--cream-layer);
  border-radius: var(--radius-md);
}
.reservation-fallback .eyebrow {
  display: block;
  margin: 0 0 var(--space-5);
}
.reservation-fallback > p {
  max-width: 48ch;
  margin: 0 auto var(--space-7);
  color: var(--earth-soft);
  text-align: center;
  line-height: 1.8;
}
.reservation-fallback__buttons {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  flex-wrap: wrap;
}

/* Center the page-hero content on reservation page */
.page-hero--center .page-hero__inner { text-align: center; }
.page-hero--center .page-hero__inner p { margin-left: auto; margin-right: auto; }

@media (max-width: 640px) {
  .booking-cta { padding: var(--space-7) var(--space-5); }
  .booking-cta .btn { min-width: 0; width: 100%; }
  .reservation-fallback__buttons { flex-direction: column; width: 100%; }
  .reservation-fallback__buttons .btn { width: 100%; }
}
