/* ================================================================
   WestVibe Home — westvibe-home.css
   New page sections for the redesigned West Vibe home:
     - Philosophy
     - Booking Culture
     - Owner Experiences
     - Service Investment Guide (accordion)
     - Pricing Note
     - Hero microcopy
   All brand tokens inherited from westvibe.css :root.
   ================================================================ */

/* ── Shared home section defaults ─────────────────────────────────────────── */
.wv-philosophy,
.wv-booking-culture,
.wv-owner-experiences,
.wv-service-guide,
.wv-pricing-note {
  padding-block: clamp(64px, 9vw, 112px);
}

/* ── Scroll-reveal base ───────────────────────────────────────────────────── */
[data-wv-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 0.72s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.72s cubic-bezier(0.22, 1, 0.36, 1);
}

[data-wv-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  [data-wv-reveal] {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* ================================================================
   HERO — microcopy extension
   ================================================================ */
.wv-hero__microcopy {
  margin-top: 20px;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: rgba(255, 255, 255, 0.72);
}

/* ================================================================
   PHILOSOPHY
   ================================================================ */
.wv-philosophy {
  background-color: var(--wv-home-ivory, #F7F1E6);
}

.wv-philosophy__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(48px, 6vw, 96px);
  align-items: start;
}

.wv-philosophy__eyebrow {
  margin-bottom: 16px;
}

.wv-philosophy__title {
  margin-bottom: 32px;
}

.wv-philosophy__body p {
  font-size: 1rem;
  line-height: 1.8;
  color: var(--wv-muted, #6f685f);
  margin-bottom: 1.1em;
}

.wv-philosophy__body p:last-child {
  margin-bottom: 0;
}

/* ── Value cards ─────────────────────────────────────────────────────────── */
.wv-philosophy__values {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  align-content: start;
}

.wv-value-card {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 24px;
  background: #ffffff;
  border: 1px solid var(--wv-home-beige, #DFD2BC);
  border-radius: var(--wv-radius-lg, 16px);
  box-shadow: 0 8px 24px rgba(27, 23, 19, 0.05);
  transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.wv-value-card:hover {
  box-shadow: 0 16px 40px rgba(27, 23, 19, 0.09);
  transform: translateY(-3px);
}

.wv-value-card__icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: var(--wv-home-cream, #EFE5D3);
  border-radius: 50%;
  color: var(--wv-home-warm-gold, #B88A3B);
}

.wv-value-card__content {
  min-width: 0;
}

.wv-value-card__title {
  font-family: var(--wv-font-display);
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--wv-text-dark, #111111);
  margin: 0 0 6px;
  line-height: 1.3;
}

.wv-value-card__desc {
  font-size: 0.8125rem;
  color: var(--wv-muted, #6f685f);
  line-height: 1.6;
  margin: 0;
}

/* ================================================================
   BOOKING CULTURE
   ================================================================ */
.wv-booking-culture {
  background-color: var(--wv-home-cream, #EFE5D3);
}

.wv-booking-culture__inner {
  max-width: 860px;
  margin-inline: auto;
}

.wv-booking-culture__header {
  margin-bottom: 40px;
}

.wv-booking-culture__eyebrow {
  margin-bottom: 16px;
}

.wv-booking-culture__title {
  margin-bottom: 0;
}

.wv-booking-culture__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 64px);
  align-items: start;
}

.wv-booking-culture__text p {
  font-size: 1rem;
  line-height: 1.8;
  color: var(--wv-muted, #6f685f);
  margin-bottom: 1em;
}

.wv-booking-culture__text p:last-child {
  margin-bottom: 0;
}

.wv-booking-culture__highlight {
  font-weight: 600;
  color: var(--wv-home-warm-gold, #B88A3B) !important;
  font-style: italic;
}

/* ── Booking pillars ─────────────────────────────────────────────────────── */
.wv-booking-pillars {
  list-style: none;
  padding: 0;
  margin: 0 0 32px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.wv-booking-pillars__item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(184, 138, 59, 0.2);
  border-radius: var(--wv-radius-lg, 16px);
}

.wv-booking-pillars__icon {
  flex-shrink: 0;
  color: var(--wv-home-warm-gold, #B88A3B);
  display: flex;
  align-items: center;
}

.wv-booking-pillars__text {
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--wv-text-dark, #111111);
  line-height: 1.4;
}

.wv-booking-culture__cta {
  grid-column: 1 / -1;
  margin-top: 16px;
}

/* ================================================================
   OWNER-LEVEL EXPERIENCES
   ================================================================ */
.wv-owner-experiences {
  background-color: var(--wv-home-ivory, #F7F1E6);
}

.wv-owner-experiences__header {
  max-width: 740px;
  margin-inline: auto;
  text-align: center;
}

.wv-owner-experiences__booking-note {
  font-style: italic;
  font-size: 0.9375rem;
  color: var(--wv-muted, #6f685f);
  margin-top: 16px;
}

.wv-owner-experiences__cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-top: 56px;
}

.wv-owner-card {
  position: relative;
  background: #ffffff;
  border: 1px solid var(--wv-home-beige, #DFD2BC);
  border-radius: 24px;
  padding: clamp(32px, 5vw, 52px);
  box-shadow: 0 20px 60px rgba(27, 23, 19, 0.07);
  overflow: hidden;
  transition: box-shadow 0.35s ease, transform 0.35s ease;
}

.wv-owner-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--wv-home-warm-gold, #B88A3B), var(--wv-gold, #c8a45d));
  opacity: 0.7;
}

.wv-owner-card:hover {
  box-shadow: 0 32px 80px rgba(27, 23, 19, 0.12);
  transform: translateY(-4px);
}

.wv-owner-card__number {
  font-family: var(--wv-font-display);
  font-size: 4rem;
  font-weight: 700;
  color: var(--wv-home-beige, #DFD2BC);
  line-height: 1;
  margin-bottom: 24px;
  letter-spacing: -0.02em;
}

.wv-owner-card__title {
  font-family: var(--wv-font-display);
  font-size: clamp(1.125rem, 2vw, 1.375rem);
  font-weight: 700;
  color: var(--wv-text-dark, #111111);
  line-height: 1.3;
  margin: 0 0 20px;
}

.wv-owner-card__investment-label {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--wv-home-warm-gold, #B88A3B);
  margin: 0 0 6px;
}

.wv-owner-card__price {
  font-family: var(--wv-font-display);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 700;
  color: var(--wv-text-dark, #111111);
  margin: 0 0 24px;
  letter-spacing: -0.02em;
}

.wv-owner-card__desc {
  font-size: 0.9375rem;
  line-height: 1.7;
  color: var(--wv-muted, #6f685f);
  margin: 0 0 32px;
}

.wv-owner-card__cta {
  width: 100%;
  justify-content: center;
}

/* ================================================================
   SERVICE INVESTMENT GUIDE
   ================================================================ */
.wv-service-guide {
  background-color: #050505;
}

.wv-service-guide__header {
  text-align: center;
  margin-bottom: clamp(32px, 4vw, 56px);
}

.wv-service-guide__tagline {
  font-family: var(--wv-font-display);
  font-size: clamp(1rem, 1.6vw, 1.25rem);
  font-style: italic;
  color: var(--wv-home-warm-gold, );
  margin-top: 10px;
  letter-spacing: 0.02em;
}

.wv-service-guide__intro {
  max-width: 720px;
  margin-inline: auto;
  text-align: center;
  margin-bottom: clamp(40px, 5vw, 72px);
}

.wv-service-guide__intro p {
  font-size: 1rem;
  line-height: 1.8;
  color: var(--wv-muted, #6f685f);
  margin-bottom: 0.85em;
}

.wv-service-guide__intro-note {
  font-size: 0.875rem !important;
  font-style: italic;
  color: var(--wv-home-warm-gold, #B88A3B) !important;
}

/* ── Accordion ────────────────────────────────────────────────────────────── */
.wv-service-accordion {
  border: 1px solid var(--wv-home-beige, #DFD2BC);
  border-radius: 20px;
  overflow: hidden;
}

.wv-service-category {
  border-bottom: 1px solid var(--wv-home-beige, #DFD2BC);
}

.wv-service-category:last-child {
  border-bottom: none;
}

/* ── Accordion trigger ───────────────────────────────────────────────────── */
.wv-service-category__trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: clamp(20px, 3vw, 28px) clamp(24px, 4vw, 40px);
  background: transparent;
  border: none;
  cursor: pointer;
  text-align: left;
  transition: background 0.25s ease;
  font-family: inherit;
}

.wv-service-category__trigger:hover {
  background: var(--wv-home-ivory, #F7F1E6);
}

.wv-service-category__trigger:focus-visible {
  outline: 2px solid var(--wv-home-warm-gold, #B88A3B);
  outline-offset: -2px;
}

.wv-service-category.is-open > .wv-service-category__trigger {
  background: var(--wv-home-ivory, #F7F1E6);
}

.wv-service-category__trigger > .wv-service-category__trigger-content > .wv-service-category__name {
  color: var(--wv-text-dark, #111111) !important;
}

.wv-service-category__trigger-content {
  display: flex;
  align-items: center;
  gap: 20px;
  min-width: 0;
}

.wv-service-category__number {
  font-family: var(--wv-font-display);
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--wv-home-warm-gold, #B88A3B);
  opacity: 0.7;
  min-width: 28px;
  flex-shrink: 0;
}

.wv-service-category__name {
  font-family: var(--wv-font-display);
  font-size: clamp(1rem, 1.8vw, 1.1875rem);
  font-weight: 600;
  color: var(--wv-text-white, #FFF);
  line-height: 1.3;
}

.wv-service-category__chevron {
  flex-shrink: 0;
  color: var(--wv-home-warm-gold, #B88A3B);
  display: flex;
  align-items: center;
  transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}

.wv-service-category.is-open > .wv-service-category__trigger .wv-service-category__chevron {
  transform: rotate(180deg);
}

/* ── Accordion panel ─────────────────────────────────────────────────────── */
.wv-service-category__panel {
  overflow: hidden;
  transition: height 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

/* `hidden` attribute = display:none by default, JS removes it and manages height */
.wv-service-category__panel[hidden] {
  display: none;
}

.wv-service-category__panel-inner {
  padding: clamp(16px, 3vw, 32px) clamp(24px, 4vw, 40px) clamp(24px, 3vw, 40px);
  padding-left: clamp(64px, 8vw, 96px); /* align with category name */
}

.wv-service-category__desc {
  font-size: 0.9375rem;
  line-height: 1.7;
  color: var(--wv-muted, #6f685f);
  margin: 0 0 28px;
  font-style: italic;
  max-width: 600px;
}

/* ── Service list ────────────────────────────────────────────────────────── */
.wv-service-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.wv-service-item {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  padding: 13px 0;
  border-bottom: 1px solid rgba(223, 210, 188, 0.5);
}

.wv-service-item:last-child {
  border-bottom: none;
}

.wv-service-item__name {
  font-size: 0.9375rem;
  color: var(--wv-text-dark, #111111);
  font-weight: 500;
  flex: 1;
  min-width: 0;
}

.wv-service-item__price {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--wv-text-dark, #111111);
  white-space: nowrap;
  flex-shrink: 0;
}

.wv-service-item__price--consult {
  color: var(--wv-home-warm-gold, #B88A3B);
  font-style: italic;
  font-weight: 500;
}

.wv-service-item--consultation .wv-service-item__name {
  color: var(--wv-muted, #6f685f);
}

/* Dotted separator between name and price */
.wv-service-item::after {
  content: '';
  flex: 1;
  max-width: 80px;
  border-bottom: 1px dotted var(--wv-home-beige, #DFD2BC);
  margin-bottom: 3px;
  order: 2;
}

/* Reorder so dot is between name and price */
.wv-service-item__name {
  order: 1;
}

.wv-service-item__price {
  order: 3;
}

/* ================================================================
   PRICING NOTE
   ================================================================ */
.wv-pricing-note {
  background-color: var(--wv-home-ivory, #F7F1E6);
}

.wv-pricing-note__inner {
  max-width: 720px;
  margin-inline: auto;
  text-align: center;
}

.wv-pricing-note__eyebrow {
  margin-bottom: 16px;
}

.wv-pricing-note__title {
  margin-bottom: 32px;
}

.wv-pricing-note__body p {
  font-size: 1rem;
  line-height: 1.8;
  color: var(--wv-muted, #6f685f);
  margin-bottom: 1em;
}

.wv-pricing-note__body p:last-child {
  margin-bottom: 0;
}

.wv-pricing-note__cta {
  margin-top: 40px;
}

/* ── Dark ghost button variant ───────────────────────────────────────────── */
.wv-button--ghost.wv-button--dark,
.wv-button--dark {
  background: transparent;
  color: var(--wv-text-dark, #111111);
  border-color: rgba(27, 23, 19, 0.28);
}

.wv-button--ghost.wv-button--dark:hover,
.wv-button--dark:hover {
  background: rgba(27, 23, 19, 0.06);
  border-color: rgba(27, 23, 19, 0.48);
}

/* ================================================================
   RESPONSIVE
   ================================================================ */

/* ── ≤ 1024px ─────────────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .wv-philosophy__inner {
    grid-template-columns: 1fr;
    gap: 48px;
  }

  .wv-philosophy__values {
    grid-template-columns: 1fr 1fr;
  }

  .wv-booking-culture__body {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .wv-booking-culture__cta {
    grid-column: auto;
  }

  .wv-owner-experiences__cards {
    gap: 24px;
  }
}

/* ── ≤ 768px ─────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .wv-owner-experiences__cards {
    grid-template-columns: 1fr;
  }

  .wv-philosophy__values {
    grid-template-columns: 1fr;
  }

  .wv-service-category__panel-inner {
    padding-left: clamp(24px, 4vw, 40px);
  }

  .wv-owner-card__cta {
    width: 100%;
  }
}

/* ── ≤ 480px ─────────────────────────────────────────────────────────────── */
@media (max-width: 480px) {
  .wv-value-card {
    padding: 20px;
  }

  .wv-owner-card {
    padding: 28px 24px;
  }

  .wv-service-category__number {
    display: none;
  }

  .wv-service-category__trigger-content {
    gap: 0;
  }

  .wv-hero__microcopy {
    font-size: 0.75rem;
  }

  .wv-booking-pillars__item {
    padding: 14px 16px;
  }
}

/* ============================================================================
   CATEGORY DETAIL PAGE  (single-wv_service_category.php)
   ============================================================================ */

/* ── Hero ──────────────────────────────────────────────────────────────────── */
.wv-cat-detail__hero {
  position: relative;
  background: var(--wv-home-espresso);
  color: var(--wv-home-ivory);
  padding: 120px 0 64px;
  overflow: hidden;
}
.wv-cat-detail__hero--has-image {
  min-height: 420px;
  display: flex;
  align-items: flex-end;
}
.wv-cat-detail__hero-image {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.wv-cat-detail__hero-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  display: block;
}
.wv-cat-detail__hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    to bottom,
    rgba(27, 23, 19, 0.45) 0%,
    rgba(27, 23, 19, 0.75) 100%
  );
}
.wv-cat-detail__hero-content {
  position: relative;
  z-index: 2;
}
.wv-cat-detail__hero-content .wv-eyebrow {
  color: var(--wv-home-warm-gold);
  margin-bottom: 10px;
}
.wv-cat-detail__title {
  font-family: var(--wv-font-display, 'Playfair Display', serif);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  color: inherit;
  margin: 0 0 16px;
  line-height: 1.15;
}
.wv-cat-detail__subtitle {
  font-size: 1.05rem;
  color: rgba(247, 241, 230, 0.88);
  max-width: 640px;
  line-height: 1.65;
  margin: 0;
}

/* ── Breadcrumb ────────────────────────────────────────────────────────────── */
.wv-breadcrumb {
  margin-bottom: 24px;
}
.wv-breadcrumb ol {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  align-items: center;
  font-size: 0.8125rem;
  color: rgba(247, 241, 230, 0.6);
}
.wv-breadcrumb a {
  color: rgba(247, 241, 230, 0.75);
  text-decoration: none;
  transition: color 0.2s;
}
.wv-breadcrumb a:hover,
.wv-breadcrumb a:focus {
  color: var(--wv-home-warm-gold);
}
.wv-breadcrumb [aria-current="page"] {
  color: var(--wv-home-ivory);
}

/* ── Description block ─────────────────────────────────────────────────────── */
.wv-cat-detail__description {
  padding-top: 56px;
  padding-bottom: 24px;
}
.wv-cat-detail__description-inner {
  max-width: 720px;
  font-size: 1.0625rem;
  line-height: 1.75;
  color: var(--wv-home-espresso);
}

/* ── Services list ──────────────────────────────────────────────────────────── */
.wv-cat-detail__services {
  padding-top: 40px;
  padding-bottom: 56px;
}
.wv-cat-detail__services-title {
  font-family: var(--wv-font-display, 'Playfair Display', serif);
  font-size: clamp(1.25rem, 2vw, 1.75rem);
  color: var(--wv-home-espresso);
  margin: 0 0 10px;
}
.wv-cat-detail__services-note {
  font-size: 0.875rem;
  color: var(--wv-home-muted);
  margin: 0 0 32px;
  max-width: 640px;
  line-height: 1.6;
}
.wv-cat-service-list {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 1px solid var(--wv-home-beige);
}
.wv-cat-service-row {
  display: flex;
  align-items: baseline;
  gap: 16px;
  padding: 20px 0;
  border-bottom: 1px solid var(--wv-home-beige);
}
.wv-cat-service-row--consultation {
  background: rgba(184, 138, 59, 0.03);
}
.wv-cat-service-row__info {
  flex: 1;
  min-width: 0;
}
.wv-cat-service-row__name {
  font-family: var(--wv-font-display, 'Playfair Display', serif);
  font-size: 1.0625rem;
  font-weight: 600;
  margin: 0 0 4px;
  color: var(--wv-home-espresso);
}
.wv-cat-service-row__name a {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s;
}
.wv-cat-service-row__name a:hover,
.wv-cat-service-row__name a:focus {
  color: var(--wv-home-warm-gold);
}
.wv-cat-service-row__desc {
  font-size: 0.875rem;
  color: var(--wv-home-muted);
  margin: 0 0 6px;
  line-height: 1.55;
}
.wv-cat-service-row__duration {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 0.8125rem;
  color: var(--wv-home-muted);
  margin: 0;
}
.wv-cat-service-row__meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
  flex-shrink: 0;
}
.wv-cat-service-row__price {
  font-size: 1rem;
  font-weight: 600;
  color: var(--wv-home-warm-brown);
  white-space: nowrap;
}
.wv-cat-service-row__price--consult {
  color: var(--wv-home-muted);
  font-style: italic;
}
.wv-cat-service-row__badge {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--wv-home-warm-gold);
  border: 1px solid var(--wv-home-warm-gold);
  padding: 2px 8px;
  border-radius: 2px;
}

/* ── CTA block ─────────────────────────────────────────────────────────────── */
.wv-cat-detail__cta {
  padding: 48px 0 64px;
}
.wv-cat-detail__booking-note {
  max-width: 640px;
  font-size: 0.9375rem;
  color: var(--wv-home-muted);
  line-height: 1.7;
  margin-bottom: 28px;
}
.wv-cat-detail__cta-buttons {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

/* ── Accordion desc-row (service guide on home) ────────────────────────────── */
.wv-service-category__desc-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 20px;
}
.wv-service-category__detail-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--wv-home-warm-gold);
  text-decoration: none;
  white-space: nowrap;
  transition: opacity 0.2s;
  flex-shrink: 0;
}
.wv-service-category__detail-link:hover,
.wv-service-category__detail-link:focus {
  opacity: 0.75;
}

/* ============================================================================
   SERVICE DETAIL PAGE  (single-wv_service.php)
   ============================================================================ */

.wv-svc-detail__hero {
  padding: 120px 0 48px;
}
.wv-svc-detail .wv-breadcrumb ol {
  color: var(--wv-home-muted);
}
.wv-svc-detail .wv-breadcrumb a {
  color: var(--wv-home-muted);
}
.wv-svc-detail .wv-breadcrumb a:hover,
.wv-svc-detail .wv-breadcrumb a:focus {
  color: var(--wv-home-warm-gold);
}
.wv-svc-detail .wv-breadcrumb [aria-current="page"] {
  color: var(--wv-home-espresso);
}

.wv-svc-detail__header-grid {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 48px;
  align-items: start;
  margin-top: 32px;
}
.wv-svc-detail__header-text .wv-eyebrow {
  margin-bottom: 10px;
}
.wv-svc-detail__title {
  font-family: var(--wv-font-display, 'Playfair Display', serif);
  font-size: clamp(1.75rem, 3.5vw, 2.75rem);
  font-weight: 700;
  color: var(--wv-home-espresso);
  margin: 0 0 20px;
  line-height: 1.15;
}
.wv-svc-detail__price {
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--wv-home-warm-brown);
  margin: 0 0 10px;
}
.wv-svc-detail__price--consult {
  color: var(--wv-home-muted);
  font-style: italic;
}
.wv-svc-detail__duration {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.9rem;
  color: var(--wv-home-muted);
  margin: 0 0 16px;
}
.wv-svc-detail__consult-note {
  background: rgba(184, 138, 59, 0.06);
  border-left: 3px solid var(--wv-home-warm-gold);
  padding: 12px 16px;
  font-size: 0.9rem;
  color: var(--wv-home-muted);
  line-height: 1.6;
  margin: 0 0 20px;
}
.wv-svc-detail__cta-row {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 24px;
}
.wv-svc-detail__header-image {
  border-radius: 4px;
  overflow: hidden;
}
.wv-svc-detail__header-image img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 4/3;
  object-fit: cover;
}

/* ── Description / content ─────────────────────────────────────────────────── */
.wv-svc-detail__description {
  padding: 48px 0;
  border-top: 1px solid var(--wv-home-beige);
}
.wv-svc-detail__short-desc {
  font-size: 1.1rem;
  font-style: italic;
  color: var(--wv-home-muted);
  margin: 0 0 24px;
  line-height: 1.7;
  max-width: 720px;
}
.wv-svc-detail__content {
  max-width: 720px;
  font-size: 1rem;
  line-height: 1.75;
  color: var(--wv-home-espresso);
}

/* ── Gallery ────────────────────────────────────────────────────────────────── */
.wv-svc-detail__gallery {
  padding: 0 0 48px;
}
.wv-svc-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 12px;
}
.wv-svc-gallery__item {
  margin: 0;
  overflow: hidden;
  border-radius: 3px;
}
.wv-svc-gallery__item img {
  width: 100%;
  height: 240px;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
.wv-svc-gallery__item:hover img {
  transform: scale(1.03);
}

/* ── Related services ──────────────────────────────────────────────────────── */
.wv-svc-detail__related {
  padding: 48px 0;
  border-top: 1px solid var(--wv-home-beige);
}
.wv-svc-detail__related-title {
  font-family: var(--wv-font-display, 'Playfair Display', serif);
  font-size: clamp(1.15rem, 2vw, 1.5rem);
  color: var(--wv-home-espresso);
  margin: 0 0 28px;
}
.wv-related-services {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 20px;
}
.wv-related-service-card__link {
  display: block;
  color: inherit;
  text-decoration: none;
  border: 1px solid var(--wv-home-beige);
  border-radius: 4px;
  overflow: hidden;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.wv-related-service-card__link:hover,
.wv-related-service-card__link:focus {
  border-color: var(--wv-home-warm-gold);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
}
.wv-related-service-card__image img {
  width: 100%;
  height: 160px;
  object-fit: cover;
  display: block;
}
.wv-related-service-card__body {
  padding: 14px 16px;
}
.wv-related-service-card__name {
  font-family: var(--wv-font-display, 'Playfair Display', serif);
  font-size: 0.9375rem;
  font-weight: 600;
  margin: 0 0 4px;
  color: var(--wv-home-espresso);
}
.wv-related-service-card__price {
  font-size: 0.875rem;
  color: var(--wv-home-warm-brown);
  font-weight: 600;
  margin: 0;
}

/* ── Bottom CTA ────────────────────────────────────────────────────────────── */
.wv-svc-detail__bottom-cta {
  padding: 56px 0 72px;
  border-top: 1px solid var(--wv-home-beige);
}
.wv-svc-detail__bottom-cta-inner {
  text-align: center;
}
.wv-svc-detail__bottom-cta-copy {
  font-family: var(--wv-font-display, 'Playfair Display', serif);
  font-size: clamp(1.25rem, 2.5vw, 1.75rem);
  color: var(--wv-home-espresso);
  margin: 0 0 24px;
}

/* ── Responsive ────────────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .wv-svc-detail__header-grid {
    grid-template-columns: 1fr;
  }
  .wv-svc-detail__header-image {
    order: -1;
    max-height: 360px;
    overflow: hidden;
  }
  .wv-svc-detail__header-image img {
    height: 360px;
  }
}
@media (max-width: 768px) {
  .wv-cat-detail__hero {
    padding: 100px 0 48px;
  }
  .wv-cat-detail__title {
    font-size: 1.75rem;
  }
  .wv-cat-service-row {
    flex-direction: column;
    gap: 8px;
  }
  .wv-cat-service-row__meta {
    align-items: flex-start;
    flex-direction: row;
    gap: 12px;
  }
  .wv-cat-detail__cta-buttons,
  .wv-svc-detail__cta-row {
    flex-direction: column;
    align-items: stretch;
    text-align: center;
  }
  .wv-service-category__desc-row {
    flex-direction: column;
    gap: 10px;
  }
  .wv-svc-gallery {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  }
}
