.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__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(--sage-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, 44, 29, 0.18) 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 p { font-size: var(--fs-body-sm); color: var(--earth-soft); }
.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; }

.trust-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  padding-block: var(--space-6);
  border-block: 1px solid rgba(94, 126, 65, 0.14);
}
.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(--sage-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); } }

.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(94, 126, 65, 0.12); }
.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: 600px; padding-top: var(--space-4); padding-bottom: var(--space-3); }

.contact-grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: var(--space-8); align-items: start; margin-top: var(--space-7); }
.contact-info h3 { margin-bottom: var(--space-5); }
.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(--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; } }

.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(251, 246, 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; } }
