/*
Theme Name: Mountain Sun Medspa
Theme URI: https://example.com/
Author: Armin Dela Cruz
Author URI: https://example.com/
Description: Custom homepage-focused WordPress theme for Mountain Sun Medspa.
Version: 1.0.1
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mountainsunmedspa
*/

@font-face {
  font-family: "La Luxes Serif Pro";
  src: url("assets/fonts/la-luxes-serif-pro-regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "La Luxes Serif Pro";
  src: url("assets/fonts/la-luxes-serif-pro-medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "La Luxes Serif Pro";
  src: url("assets/fonts/la-luxes-serif-pro-bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "La Luxes Serif Pro";
  src: url("assets/fonts/la-luxes-serif-pro-extrabold.ttf") format("truetype");
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "La Luxes Serif Pro";
  src: url("assets/fonts/la-luxes-serif-pro-italic-regular.ttf") format("truetype");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "La Luxes Serif Pro";
  src: url("assets/fonts/la-luxes-serif-pro-italic-bold.ttf") format("truetype");
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}

/* Brand colors — Mountain Sun official palette (2026) */
:root {
  /* Global legibility: rem baseline (~8% over browser default). Must stay first so rem in tokens resolves against this. */
  font-size: 108%;
  --brand-mint: #c0dbd4;
  --brand-cream: #f2eee6;
  --brand-coral: #e99a81;
  --brand-rose: #b67c74;
  --brand-terracotta: #94635c;
  --brand-chocolate: #704639;
  --bg: #faf9f7;
  --cream: #fff;
  --text: #704639;
  --muted: #7a5e56;
  --line: #e0d8cf;
  --sage: #5a8a7e;
  --rose: var(--brand-rose);
  --rose-soft: var(--brand-coral);
  --gold: #c9a227;
  --chocolate: var(--brand-chocolate);
  --footer-bg: #5c3d35;
  --footer-heading: #f2eee6;
  --footer-body: #dfc9c2;
  --footer-muted: #b9a199;
  --footer-rule: rgba(242, 238, 230, 0.22);
  --footer-link-hover: #fff;
  --footer-accent: var(--brand-coral);
  --eyebrow-teal: #3d6d62;
  /* Type scale — headline · subtitle · eyebrow · body · button (tuned down one step vs prior max). */
  --ms-type-headline: calc(clamp(1.62rem, 3.6vw, 2.05rem) + 1pt);
  --ms-type-subtitle: calc(clamp(1.28rem, 2.2vw, 1.62rem) + 1pt);
  --ms-type-eyebrow: 0.68rem;
  --ms-type-body: calc(0.88rem + 2pt);
  /* Default reading leading (homepage .hero-body); set on body + reused in rules */
  --ms-leading-body: 1.72;
  --ms-type-button: calc(0.65rem + 1pt);
  /* Extended scale — former one-off clamps/rems defined once; selectors use var(--ms-type-*). */
  --ms-type-display: calc(clamp(2.15rem, 5.8vw, 3.45rem) + 1pt);
  --ms-type-promo: clamp(0.52rem, 1.65vw, 0.68rem);
  --ms-type-kicker: calc(clamp(1.05rem, 2.2vw, 1.35rem) + 1pt);
  --ms-type-nav-meta: clamp(0.7rem, 1.35vw, 0.8rem);
  --ms-type-logo: calc(0.98rem + 1pt);
  --ms-type-page-heading: calc(clamp(1.65rem, 3.2vw, 2.35rem) + 1pt);
  --ms-type-emphasis: calc(clamp(1.55rem, 3.6vw, 2.25rem) + 1pt);
  --ms-type-article-hero: calc(clamp(1.75rem, 4.5vw, 2.55rem) + 1pt);
  --ms-type-card-hero: clamp(1.85rem, 4.5vw, 2.45rem);
  --ms-type-intro: clamp(1.1rem, 2.2vw, 1.25rem);
  --ms-type-aside: clamp(1.35rem, 2.5vw, 1.55rem);
  --ms-type-accordion-title: calc(clamp(1.2rem, 3.5vw, 1.45rem) + 1pt);
  --ms-type-pill: calc(clamp(1.15rem, 2.8vw, 1.35rem) + 1pt);
  --ms-type-row-accent: calc(clamp(1.35rem, 3.5vw, 1.6rem) + 1pt);
  --ms-type-footer-block: clamp(1.25rem, 3vw, 1.45rem);
  --ms-type-caption: calc(0.72rem + 1pt);
  --ms-type-dense: calc(0.8rem + 2pt);
  --ms-type-card-name: calc(1.02rem + 1pt);
  --ms-type-tier-price: calc(1.2rem + 1pt);
  --ms-type-lede: calc(1.05rem + 1pt);
  /* Small caps labels — hero tags, IV/page eyebrows, section strips (one rhythm site-wide) */
  --ms-eyebrow-font-size: var(--ms-type-eyebrow);
  --ms-eyebrow-font-weight: 700;
  --ms-eyebrow-letter-spacing: 0.2em;
  --ms-eyebrow-color: var(--brand-terracotta);
  /* Warm off-white bands between white sections (not flat gray) */
  --section-band: #f5f2ed;
  --quote-coral: var(--brand-coral);
  --mint-sky: var(--brand-mint);
  /* Shared band behind service icons — warm beige (matches .friday-band palette, not mint) */
  --service-icon-surface: #f3efe6;
  /* Service glyphs: line-art + condensed row; scales up on small screens */
  --home-service-icon: clamp(68px, 12vw, 86px);
  /* Navy/black SVG glyphs → warm chocolate (softer than raw black on mint) */
  --service-icon-img-filter: brightness(0) saturate(100%) invert(30%) sepia(12%) saturate(900%) hue-rotate(326deg) brightness(96%) contrast(90%);
  --terracotta-brand: var(--brand-terracotta);
  --type-section-h2: var(--ms-type-subtitle);
  --type-body: var(--ms-type-body);
  /* Aliased to body — one reading size; keeps existing class hooks without extra scale steps. */
  --type-body-lg: var(--ms-type-body);
  --type-small: var(--ms-type-body);
  --type-card-title: var(--ms-type-body);
  --btn-radius: 6px;
  --btn-font: "Raleway", sans-serif;
  --btn-label-spacing: 0.1em;
  --btn-fill-bg: var(--brand-terracotta);
  --btn-fill-bg-hover: var(--brand-chocolate);
  --btn-fill-fg: #fff;
  --btn-outline-bg: #fff;
  --btn-outline-bg-hover: rgba(148, 99, 92, 0.08);
  --btn-outline-fg: var(--brand-terracotta);
  --btn-outline-border: var(--brand-terracotta);
  /* Motion — prefer transform/opacity (compositor-friendly) */
  --ms-motion-ease: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ms-motion-duration: 0.2s;
  --ms-motion-duration-md: 0.32s;
  --ms-hover-lift: translate3d(0, -2px, 0);
  --ms-shadow-soft: 0 8px 22px rgba(112, 70, 57, 0.09);
  --ms-shadow-hover: 0 14px 34px rgba(112, 70, 57, 0.12);
}

/*
 * Single rem baseline site-wide (108% on :root). Mobile uses the same scale so
 * --ms-type-* tokens match desktop sizing fixes; do not reset font-size to 100% here.
 */

*,
*::before,
*::after { box-sizing: border-box; }

body {
  margin: 0;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--text);
  background: var(--bg);
}

h1, h2, h3 {
  margin: 0 0 12px;
  font-family: "La Luxes Serif Pro", serif;
  font-weight: 700;
  line-height: 1.15;
  color: var(--brand-chocolate);
}

p { margin: 0; color: var(--muted); line-height: var(--ms-leading-body); }
a { color: inherit; }

.container {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 22px;
}

/* Full-width promo strip (above header) */
.top-promo-banner {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 11px max(14px, env(safe-area-inset-left)) 11px max(14px, env(safe-area-inset-right));
  text-align: center;
  text-decoration: none;
  color: #fff;
  font-family: var(--btn-font);
  font-size: var(--ms-type-promo);
  font-weight: 600;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  line-height: 1.35;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  scrollbar-width: none;
  border-bottom: 1px solid rgba(0, 0, 0, 0.12);
  background: var(--brand-chocolate);
  transition:
    background-color var(--ms-motion-duration-md) var(--ms-motion-ease),
    color var(--ms-motion-duration) var(--ms-motion-ease),
    filter var(--ms-motion-duration) var(--ms-motion-ease);
}

.top-promo-banner::-webkit-scrollbar {
  display: none;
}

.top-promo-banner__text {
  position: relative;
  z-index: 1;
  flex: 0 0 auto;
  max-width: none;
  white-space: nowrap;
}

.top-promo-banner:hover {
  color: #fff;
  background: #623c34;
  filter: brightness(1.05);
}

.top-promo-banner:focus-visible {
  outline: 2px solid #fff;
  outline-offset: -4px;
}

.site-header {
  background: #fff;
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
  z-index: 10;
}

.header-inner {
  position: relative;
  z-index: 20;
  min-height: 76px;
  padding: 10px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.logo {
  font-family: "La Luxes Serif Pro", serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: var(--ms-type-logo);
  font-weight: 700;
  text-decoration: none;
}

.logo span { color: var(--rose); }

.header-logo-link {
  display: flex;
  align-items: center;
  line-height: 0;
  text-decoration: none;
  transition:
    opacity var(--ms-motion-duration) var(--ms-motion-ease),
    transform var(--ms-motion-duration) var(--ms-motion-ease);
}

.header-logo-link:hover {
  opacity: 0.9;
  transform: translate3d(0, -1px, 0);
}

.header-logo-img {
  height: 48px;
  width: auto;
  max-width: min(300px, 48vw);
  object-fit: contain;
  object-position: left center;
  display: block;
}

.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  color: var(--brand-chocolate);
  border-radius: 8px;
  margin-left: auto;
}

.nav-toggle:focus-visible {
  outline: 2px solid var(--brand-mint);
  outline-offset: 2px;
}

.nav-toggle__bar {
  display: block;
  width: 22px;
  height: 2px;
  margin: 0 auto;
  background: currentColor;
  border-radius: 1px;
  transition: transform 0.25s ease, opacity 0.25s ease;
}

body.nav-drawer-open .nav-toggle__bar:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

body.nav-drawer-open .nav-toggle__bar:nth-child(2) {
  opacity: 0;
}

body.nav-drawer-open .nav-toggle__bar:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

.nav-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 80;
  background: rgba(112, 70, 57, 0.35);
  backdrop-filter: blur(2px);
}

body.nav-drawer-open .nav-backdrop {
  display: block;
}

body.nav-drawer-open {
  overflow: hidden;
}

.nav {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px 26px;
  font-size: var(--ms-type-body);
}

.nav a {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  color: #463a35;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-size: var(--ms-type-button);
  line-height: 1.25;
  transition: color var(--ms-motion-duration) var(--ms-motion-ease), opacity var(--ms-motion-duration) var(--ms-motion-ease);
}

.nav a:hover { color: var(--terracotta-brand); }

.nav-item {
  position: relative;
}

.nav-item--dropdown {
  display: inline-flex;
  align-items: center;
}

.nav-dropdown-trigger {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  line-height: 1.25;
}

.nav button.nav-dropdown-trigger {
  font: inherit;
  font-family: inherit;
  font-weight: 600;
  font-size: var(--ms-type-button);
  line-height: 1.25;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: #463a35;
  background: none;
  border: 0;
  padding: 0;
  margin: 0;
  cursor: pointer;
  text-align: inherit;
  -webkit-appearance: none;
  appearance: none;
  transition: color var(--ms-motion-duration) var(--ms-motion-ease);
}

.nav button.nav-dropdown-trigger:hover {
  color: var(--terracotta-brand);
}

.nav-dropdown-trigger::after {
  content: "";
  border: solid currentColor;
  border-width: 0 1.5px 1.5px 0;
  display: inline-block;
  padding: 2.5px;
  transform: rotate(45deg);
  margin: 0 0 1px 2px;
  opacity: 0.65;
  flex-shrink: 0;
  align-self: center;
}

/* Desktop: invisible hover bridge (replaces old padding-bottom hack so labels align with plain links). */
@media (min-width: 701px) {
  .nav-item--dropdown::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    height: 12px;
    z-index: 39;
  }
}

.nav-dropdown-panel {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 196px;
  padding: 6px 0;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 12px 32px rgba(58, 30, 30, 0.1);
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px);
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
  z-index: 40;
}

.nav-item--dropdown:hover .nav-dropdown-panel,
.nav-item--dropdown:focus-within .nav-dropdown-panel {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.nav-dropdown-panel a {
  display: block;
  padding: 8px 16px;
  font-weight: 600;
  color: #463a35;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: var(--ms-type-eyebrow);
  transition: background-color var(--ms-motion-duration) var(--ms-motion-ease), color var(--ms-motion-duration) var(--ms-motion-ease);
}

.nav-dropdown-panel a:hover {
  background: #faf7f2;
  color: var(--terracotta-brand);
}

.nav .btn.nav-book {
  margin-left: 10px;
  padding: 8px 16px;
  font-size: var(--ms-type-button);
  font-weight: 700;
  background: var(--brand-terracotta);
  border-color: var(--brand-terracotta);
  color: #fff;
}

.nav .btn.nav-book:hover {
  background: var(--brand-chocolate);
  border-color: var(--brand-chocolate);
  color: #fff;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--btn-radius);
  text-decoration: none;
  font-family: var(--btn-font);
  font-weight: 600;
  border: 1px solid transparent;
  padding: 12px 20px;
  font-size: var(--ms-type-button);
  line-height: 1.2;
  letter-spacing: var(--btn-label-spacing);
  text-transform: uppercase;
  transition:
    background var(--ms-motion-duration) var(--ms-motion-ease),
    color var(--ms-motion-duration) var(--ms-motion-ease),
    border-color var(--ms-motion-duration) var(--ms-motion-ease),
    transform var(--ms-motion-duration) var(--ms-motion-ease),
    box-shadow var(--ms-motion-duration) var(--ms-motion-ease);
}

.btn:hover {
  transform: var(--ms-hover-lift);
  box-shadow: var(--ms-shadow-soft);
}

.btn:active {
  transform: translate3d(0, 0, 0);
  box-shadow: none;
  transition-duration: calc(var(--ms-motion-duration) * 0.85);
}

.btn-primary {
  background: var(--btn-fill-bg);
  color: var(--btn-fill-fg);
  border-color: var(--btn-fill-bg);
}

.btn-primary:hover {
  background: var(--btn-fill-bg-hover);
  border-color: var(--btn-fill-bg-hover);
  color: var(--btn-fill-fg);
}

.btn-soft {
  background: var(--btn-outline-bg);
  color: var(--btn-outline-fg);
  border-color: var(--btn-outline-border);
}

.btn-soft:hover {
  background: var(--btn-outline-bg-hover);
  color: var(--btn-outline-fg);
  border-color: var(--btn-outline-border);
}

.section { padding: 64px 0; }

.section .container > h2 {
  font-size: var(--ms-type-subtitle);
  font-weight: 700;
  margin-bottom: 18px;
}

.kicker {
  display: block;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: var(--ms-eyebrow-font-weight);
  letter-spacing: var(--ms-eyebrow-letter-spacing);
  text-transform: uppercase;
  color: var(--ms-eyebrow-color);
  margin-bottom: 12px;
}

.section-eyebrow {
  display: block;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: var(--ms-eyebrow-font-weight);
  letter-spacing: var(--ms-eyebrow-letter-spacing);
  text-transform: uppercase;
  color: var(--ms-eyebrow-color);
  margin-bottom: 10px;
}

.promo-teaser .section-eyebrow {
  text-align: center;
}

.hero {
  background: linear-gradient(165deg, #fff 0%, var(--brand-cream) 42%, #e8e2d8 100%);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  min-height: min(82vh, 780px);
  padding: clamp(44px, 9vh, 96px) 0 clamp(52px, 7vh, 80px);
}

/* Soft wash so type stays crisp while striations read across the full hero */
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    108deg,
    rgba(255, 252, 248, 0.97) 0%,
    rgba(255, 252, 248, 0.82) min(32%, 22rem),
    rgba(252, 248, 242, 0.45) 52%,
    rgba(245, 240, 232, 0.18) 72%,
    rgba(240, 234, 226, 0.06) 100%
  );
}

/*
 * Full-bleed muscle striation: visible site-wide in hero, softer behind copy (mask),
 * gentle drift animation (honors prefers-reduced-motion below).
 */
.hero__striations {
  --hero-striation-mask: linear-gradient(
    118deg,
    rgba(0, 0, 0, 0.18) 0%,
    rgba(0, 0, 0, 0.38) 32%,
    rgba(0, 0, 0, 0.58) 55%,
    rgba(0, 0, 0, 0.78) 100%
  );
  position: absolute;
  inset: -30% -42% -26% -42%;
  z-index: 0;
  pointer-events: none;
  -webkit-mask-image: var(--hero-striation-mask);
  mask-image: var(--hero-striation-mask);
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}

.hero__striations::before {
  content: "";
  position: absolute;
  inset: -12%;
  background-image: url("assets/images/ms-striations.svg");
  background-repeat: no-repeat;
  background-position: 52% 42%;
  background-size: min(185vw, 3600px) auto;
  opacity: 0.44;
  mix-blend-mode: multiply;
  filter: saturate(0.82) contrast(1.02);
  will-change: transform;
  animation: heroStriaePan 48s ease-in-out infinite alternate;
}

/* Smooth horizontal drift (reverses gently — reads as endless left↔right motion without a hard loop jump). */
@keyframes heroStriaePan {
  0% {
    transform: translate3d(-6.5%, -0.5%, 0);
  }
  100% {
    transform: translate3d(6.5%, 0.5%, 0);
  }
}

@media (max-width: 900px) {
  .hero {
    min-height: auto;
    padding: 40px 0 52px;
    align-items: flex-start;
  }

  .hero::after {
    background: linear-gradient(
      175deg,
      rgba(255, 252, 248, 0.98) 0%,
      rgba(255, 252, 248, 0.82) 28%,
      rgba(252, 247, 240, 0.42) 55%,
      rgba(245, 239, 230, 0.2) 100%
    );
  }

  .hero__striations {
    --hero-striation-mask: linear-gradient(
      168deg,
      rgba(0, 0, 0, 0.2) 0%,
      rgba(0, 0, 0, 0.48) 42%,
      rgba(0, 0, 0, 0.68) 100%
    );
    inset: -42% -52% -38% -52%;
  }

  /* Tall hero + wide SVG: width-based sizing leaves short image height and visible edges; scale by height so the layer stays covered */
  .hero__striations::before {
    background-position: 48% 34%;
    background-size: auto 122%;
    opacity: 0.38;
    inset: -22%;
    animation-duration: 54s;
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero__striations::before {
    animation: none;
    opacity: 0.34;
    transform: none;
    background-position: 52% 42%;
  }

  .hero-copy .hero-welcome,
  .hero-copy .hero-title-line,
  .hero-copy .hero-body,
  .hero-copy .hero-actions {
    animation: none;
    opacity: 1;
    transform: none;
  }
}

.hero-inner {
  position: relative;
  z-index: 2;
  width: 100%;
}

.hero-copy {
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 8px 0 4px;
  position: relative;
  z-index: 2;
  max-width: 38rem;
}

.hero-welcome {
  font-family: "La Luxes Serif Pro", serif;
  font-weight: 700;
  line-height: 1.08;
  color: #2a211e;
  margin: 0 0 20px;
  text-transform: uppercase;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}

.hero-welcome__line {
  display: block;
  letter-spacing: 0.14em;
}

.hero-welcome__line--preface {
  font-size: var(--ms-type-kicker);
  font-weight: 700;
  font-family: "La Luxes Serif Pro", serif;
  letter-spacing: 0.16em;
  color: #3a302c;
}

.hero-welcome__line--brand {
  font-size: var(--ms-type-display);
  letter-spacing: 0.11em;
  color: #231a18;
  white-space: nowrap;
}

.hero-title-line {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-nav-meta);
  font-weight: 600;
  line-height: 1.45;
  color: #6b534c;
  margin: 0 0 20px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.hero-copy .hero-body {
  max-width: 36rem;
  margin-top: 0;
  color: #5a4a44;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
}

.hero-actions {
  margin-top: 32px;
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  align-items: center;
}

@media (prefers-reduced-motion: no-preference) {
  .hero-copy .hero-welcome,
  .hero-copy .hero-title-line,
  .hero-copy .hero-body,
  .hero-copy .hero-actions {
    opacity: 0;
    animation: msHeroFadeRise 0.72s var(--ms-motion-ease) forwards;
  }

  .hero-copy .hero-welcome {
    animation-delay: 0.04s;
  }

  .hero-copy .hero-title-line {
    animation-delay: 0.11s;
  }

  .hero-copy .hero-body {
    animation-delay: 0.18s;
  }

  .hero-copy .hero-actions {
    animation-delay: 0.26s;
  }
}

@keyframes msHeroFadeRise {
  from {
    opacity: 0;
    transform: translate3d(0, 18px, 0);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

.btn-hero-primary {
  padding: 14px 26px;
  font-size: var(--ms-type-button);
  font-weight: 600;
}

.btn-hero-secondary {
  padding: 14px 26px;
  font-size: var(--ms-type-button);
  font-weight: 600;
}

.services {
  background: #fff;
}

.service-block {
  border: 1px solid var(--line);
  background: #fff;
  overflow: hidden;
  border-radius: 20px;
  box-shadow: 0 10px 36px rgba(74, 44, 38, 0.06);
}

.service-feature-card {
  display: grid;
  grid-template-columns: 1.12fr 1fr;
  gap: 0;
  margin-bottom: 0;
  background: #fff;
  border: none;
  border-radius: 0;
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  box-shadow: none;
  transition:
    transform var(--ms-motion-duration-md) var(--ms-motion-ease),
    box-shadow var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.service-feature-card:hover {
  transform: translate3d(0, -2px, 0);
  box-shadow: var(--ms-shadow-soft);
}

.service-feature-card__media {
  position: relative;
  min-height: 280px;
  align-self: stretch;
  background: var(--brand-mint);
  overflow: hidden;
}

.service-feature-card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    118deg,
    rgba(255, 252, 248, 0.28) 0%,
    rgba(247, 243, 237, 0.2) 34%,
    rgba(192, 219, 212, 0.16) 58%,
    rgba(112, 70, 57, 0.2) 100%
  );
}

.service-feature-card__media img {
  position: relative;
  z-index: 0;
  width: 100%;
  height: 100%;
  min-height: 280px;
  object-fit: cover;
  object-position: center center;
  display: block;
  transition: transform var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.service-feature-card:hover .service-feature-card__media img {
  transform: scale(1.03);
}

.service-feature-nad-img {
  image-rendering: auto;
  shape-rendering: geometricPrecision;
  object-position: 40% 52%;
}

.service-feature-card__body {
  background: #fff;
  color: var(--brand-chocolate);
  padding: 28px 26px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 280px;
  gap: clamp(12px, 2.2vw, 22px);
}

.service-feature-card__body .card-eyebrow {
  color: var(--ms-eyebrow-color);
}

.service-feature-card__body h3 {
  color: var(--brand-chocolate);
  margin-bottom: 0;
}

.service-feature-card__body p {
  color: var(--muted);
  margin: 0 0 clamp(12px, 2.2vw, 20px);
  flex: 0 1 auto;
}

.card-eyebrow {
  display: block;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: var(--ms-eyebrow-font-weight);
  letter-spacing: var(--ms-eyebrow-letter-spacing);
  text-transform: uppercase;
  color: var(--ms-eyebrow-color);
  margin-bottom: 8px;
}

.card .card-eyebrow {
  padding: 14px 16px 0;
}

.card .card-content {
  padding: 6px 16px 18px;
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 168px;
}

.service-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  margin: 0;
  border: none;
  background: #fff;
}

.card {
  background: #fff;
  border: none;
  border-radius: 0;
  overflow: hidden;
}

.service-grid .card {
  border: none;
  border-radius: 0;
  margin: 0;
  border-right: 1px solid var(--line);
  box-shadow: none;
  display: flex;
  flex-direction: column;
  transition:
    transform var(--ms-motion-duration-md) var(--ms-motion-ease),
    box-shadow var(--ms-motion-duration-md) var(--ms-motion-ease),
    border-color var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.service-grid .card:hover {
  transform: translate3d(0, -3px, 0);
  box-shadow: var(--ms-shadow-hover);
  z-index: 1;
  position: relative;
}

.service-grid .card__media {
  position: relative;
  aspect-ratio: 4 / 3;
  min-height: 148px;
  max-height: 220px;
  overflow: hidden;
  background: var(--brand-mint);
  border-bottom: 1px solid var(--line);
}

.service-grid .card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

.service-grid .card__media img.service-grid-card-img--iv {
  object-position: 55% 42%;
}

.service-grid .card__media img.service-grid-card-img--wellness {
  object-position: 48% 42%;
}

.service-grid .card__media img.service-grid-card-img--mobile {
  object-position: 50% 42%;
}

.section.services .service-grid .card__media {
  /* ~15% taller row than prior 2.15/1 band */
  aspect-ratio: 2.15 / 1.15;
  min-height: 124px;
  max-height: 182px;
}

.section.services .service-grid .card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    175deg,
    rgba(255, 252, 248, 0.45) 0%,
    rgba(192, 219, 212, 0.28) 42%,
    rgba(112, 70, 57, 0.2) 100%
  );
}

.section.services .service-grid .card__media img:not(.service-grid-card-icon) {
  filter: saturate(0.8) brightness(1.04);
}

/* Hidden sprite + line-art service visuals (homepage grid + mobile tiles) */
.service-line-icons-sprite {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
  pointer-events: none;
}

.section.services .service-grid .card__media--brand-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px 12px;
  background: var(--service-icon-surface);
}

.section.services .service-grid .card__media--brand-icon::after {
  display: none;
}

.section.services .service-grid .card__media--brand-icon .service-grid-card-icon {
  width: min(var(--home-service-icon), 5.25rem);
  height: min(var(--home-service-icon), 5.25rem);
  object-fit: contain;
  display: block;
  filter: var(--service-icon-img-filter);
  opacity: 0.92;
}

.service-grid .card:nth-child(3n) {
  border-right: none;
}

.card-more {
  margin-top: auto;
  align-self: flex-start;
  padding-top: clamp(16px, 3vw, 28px);
  font-size: var(--ms-type-body);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--brand-terracotta);
  text-decoration: none;
  border-bottom: 1px solid rgba(148, 99, 92, 0.35);
  padding-bottom: 2px;
  transition:
    color var(--ms-motion-duration) var(--ms-motion-ease),
    border-color var(--ms-motion-duration) var(--ms-motion-ease),
    transform var(--ms-motion-duration) var(--ms-motion-ease);
}

.card-more:hover {
  color: var(--brand-chocolate);
  border-bottom-color: currentColor;
  transform: translate3d(2px, 0, 0);
}

.service-feature-card__body .card-more {
  margin-top: auto;
  padding-top: clamp(14px, 2.8vw, 26px);
  color: var(--brand-terracotta);
  border-bottom-color: rgba(148, 99, 92, 0.4);
}

.service-feature-card__body .card-more:hover {
  color: var(--brand-chocolate);
  border-bottom-color: currentColor;
}

@media (max-width: 980px) and (min-width: 701px) {
  .service-grid .card:nth-child(3n) {
    border-right: 1px solid var(--line);
  }

  .service-grid .card:nth-child(2n) {
    border-right: none;
  }

  .service-grid .card:nth-child(3) {
    border-top: 1px solid var(--line);
    border-right: none;
  }

  .section.services .service-grid .card__media--brand-icon {
    aspect-ratio: unset;
    min-height: 7.7625rem;
    max-height: none;
  }
}

@media (max-width: 700px) {
  .section.services .service-grid .card__media--brand-icon {
    aspect-ratio: unset;
    min-height: 8.625rem;
    max-height: none;
    padding: 18px 16px;
  }

  .section.services .service-grid .card__media--brand-icon .service-grid-card-icon {
    width: min(112px, 36vw);
    height: min(112px, 36vw);
    max-height: none;
  }

  .service-grid .card {
    border-right: none;
    border-bottom: 1px solid var(--line);
  }

  .service-grid .card:nth-child(3n) {
    border-right: none;
  }

  .service-grid .card:last-child {
    border-bottom: none;
  }

  .section.services .service-grid .card .card-content {
    min-height: 0;
    padding: 4px 16px 14px;
  }

  .section.services .service-grid .card-content p {
    margin-bottom: clamp(14px, 3vw, 22px);
  }

  .section.services .service-grid .card-more {
    margin-top: 0;
    padding-top: clamp(10px, 2.5vw, 18px);
  }
}

.card h3 {
  font-size: var(--ms-type-body);
  margin-bottom: clamp(6px, 1.2vw, 10px);
}

.card .card-content p {
  margin: 0;
}

.card-content p,
.service-feature-card__body p {
  font-size: var(--ms-type-body);
}

.service-condensed-wrap {
  margin-top: 0;
  border: none;
  border-top: 1px solid var(--line);
  background: #fff;
  border-radius: 0 0 19px 19px;
  overflow: hidden;
}

.service-condensed-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.service-condensed {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 20px;
  text-decoration: none;
  color: inherit;
  border-right: 1px solid var(--line);
  transition: background 0.2s ease;
}

.service-condensed__icon {
  flex-shrink: 0;
  width: var(--home-service-icon);
  height: var(--home-service-icon);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: inset 0 0 0 1px rgba(112, 70, 57, 0.08);
}

.service-condensed--massage .service-condensed__icon,
.service-condensed--skincare .service-condensed__icon {
  background: var(--service-icon-surface);
}

.service-condensed__icon img {
  width: calc(var(--home-service-icon) * 0.5);
  height: calc(var(--home-service-icon) * 0.5);
  object-fit: contain;
  display: block;
  filter: var(--service-icon-img-filter);
  opacity: 0.9;
}

/* Homepage services — condensed row icons ~10% larger on desktop only */
@media (min-width: 981px) {
  .section.services .service-condensed__icon {
    width: calc(var(--home-service-icon) * 1.1);
    height: calc(var(--home-service-icon) * 1.1);
  }

  .section.services .service-condensed__icon img {
    width: calc(var(--home-service-icon) * 0.55);
    height: calc(var(--home-service-icon) * 0.55);
  }
}

.service-condensed:last-child {
  border-right: none;
}

.service-condensed:hover {
  background: rgba(245, 242, 237, 0.75);
}

.service-condensed__text {
  flex: 1;
  min-width: 0;
}

.service-condensed__title {
  display: block;
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-lede);
  font-weight: 700;
  color: var(--brand-chocolate);
  margin-bottom: 3px;
}

.service-condensed__sub {
  display: block;
  font-size: var(--ms-type-body);
  color: var(--muted);
}

.service-condensed__arrow {
  flex-shrink: 0;
  color: var(--brand-terracotta);
  font-size: var(--ms-type-intro);
  font-weight: 300;
}

.reviews {
  background: #fff;
}

.review-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.review {
  border: 1px solid var(--line);
  background: #fff;
  padding: 26px 24px 24px;
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  transition:
    background var(--ms-motion-duration-md) var(--ms-motion-ease),
    border-color var(--ms-motion-duration-md) var(--ms-motion-ease),
    transform var(--ms-motion-duration-md) var(--ms-motion-ease),
    box-shadow var(--ms-motion-duration-md) var(--ms-motion-ease);
  animation: reviewFadeIn 0.82s var(--ms-motion-ease) backwards;
}

.review:nth-child(1) { animation-delay: 0.06s; }
.review:nth-child(2) { animation-delay: 0.14s; }
.review:nth-child(3) { animation-delay: 0.22s; }

.review:hover {
  transform: translateY(-4px);
  background: #faf6f3;
  border-color: #e8d4cc;
  box-shadow: 0 12px 32px rgba(74, 44, 38, 0.08);
}

@keyframes reviewFadeIn {
  from {
    opacity: 0;
    transform: translate3d(0, 22px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .review {
    animation: none;
    transition: none;
  }

  .review:hover {
    transform: none;
  }

  .faq-acc__panel,
  .faq-acc__content,
  .faq-acc__chev {
    transition: none;
  }

  .ms-reveal-init,
  .ms-reveal-init.ms-reveal-visible {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .btn:hover {
    transform: none;
    box-shadow: none;
  }

  .header-logo-link:hover {
    transform: none;
  }

  .card-more:hover {
    transform: none;
  }

  .service-grid .card,
  .service-feature-card,
  .ms-post-card {
    transition: none;
  }

  .service-grid .card:hover,
  .service-feature-card:hover,
  .ms-post-card:hover {
    transform: none;
    box-shadow: none;
  }

  .service-feature-card:hover .service-feature-card__media img,
  .ms-post-card:hover .ms-post-card__image {
    transform: none;
  }

  .footer-svc-link:hover,
  .social-row a:hover {
    transform: none;
  }

  .iv-page .iv-page__bottom,
  .iv-hero-meta__cell,
  .iv-hero-split__pill,
  .iv-page--mobile .mobile-svc-tile,
  .iv-page--mobile .mobile-intake-card,
  .mem-nad-card,
  .mem-iv-card,
  .mem-special-strip,
  .mem-bottom-cta,
  .iv-page--contact .contact-form-col,
  .iv-page--contact .contact-info-col,
  .iv-page--contact .contact-map-block,
  .team-lead-card,
  .team-pract-card,
  .team-gallery__item,
  .team-cta {
    transition: none;
  }

  .iv-page .iv-page__bottom:hover,
  .iv-page--mobile .mobile-svc-tile:hover,
  .iv-page--mobile .mobile-intake-card:hover,
  .mem-nad-card:hover,
  .mem-iv-card:hover,
  .mem-special-strip:hover,
  .mem-bottom-cta:hover,
  .iv-page--contact .contact-form-col:hover,
  .iv-page--contact .contact-info-col:hover,
  .iv-page--contact .contact-map-block:hover,
  .team-lead-card:hover,
  .team-pract-card:hover,
  .team-gallery__item:hover,
  .team-cta:hover {
    transform: none;
  }

  .mem-iv-card:hover .mem-iv-card__img img,
  .team-pract-card:hover .team-pract-card__photo img,
  .team-lead-card:hover .team-lead-card__img img {
    transform: none;
  }
}

.review--featured {
  /* Same base as .review; hover still applies */
  background: #fff;
  border-color: var(--line);
}

.review__quote {
  flex: 1;
  font-size: var(--ms-type-body);
  color: #3a2a26;
  line-height: var(--ms-leading-body);
  margin: 0 0 20px;
}

.review__footer {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: auto;
}

.review__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.review__avatar--initials {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--brand-mint);
  color: var(--brand-chocolate);
  font-size: var(--ms-type-caption);
  font-weight: 700;
  letter-spacing: 0.02em;
}

.reviews-cta {
  display: flex;
  justify-content: center;
  margin-top: 28px;
}

.review__who-name {
  display: block;
  font-size: var(--ms-type-body);
  font-weight: 700;
  color: #4a3530;
}

.review__who-meta {
  display: block;
  font-size: var(--ms-type-body);
  color: #5c4a45;
  margin-top: 2px;
}

.stars { color: var(--brand-terracotta); letter-spacing: 1px; margin-bottom: 12px; }

.faq {
  background: #fff;
}

.faq-cta {
  display: flex;
  justify-content: center;
  margin-top: 28px;
}

.faq-accordion {
  width: 100%;
  margin-top: 8px;
  border: 1px solid #ddd2c5;
  border-radius: 10px;
  background: #fff;
  overflow: hidden;
}

.faq-acc-item {
  border-bottom: 1px solid #e8dfd6;
}

.faq-acc-item:last-child {
  border-bottom: none;
}

.faq-acc-item summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-body);
  font-weight: 700;
  color: #281f1d;
  transition: background 0.25s ease;
}

.faq-acc-item summary::-webkit-details-marker {
  display: none;
}

.faq-acc-item summary:hover {
  background: #faf7f2;
}

.faq-acc__chev {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  margin-left: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ms-eyebrow-color);
  font-size: var(--ms-type-eyebrow);
  transition: transform 0.35s ease;
}

.faq-acc-item[open] .faq-acc__chev {
  transform: rotate(180deg);
}

.faq-acc__panel {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.45s ease;
}

.faq-acc-item[open] .faq-acc__panel {
  grid-template-rows: 1fr;
}

.faq-acc__panel-inner {
  min-height: 0;
  overflow: hidden;
}

.faq-acc__content {
  padding: 0 20px 20px 20px;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity 0.35s ease 0.05s, transform 0.35s ease 0.05s;
}

.faq-acc-item[open] .faq-acc__content {
  opacity: 1;
  transform: translateY(0);
}

.faq-acc__content p + p {
  margin-top: 12px;
}

.faq-acc__content a {
  color: #6b3f38;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.faq-acc__content a:hover {
  color: var(--rose);
}

.provider {
  background: #fff;
}

.provider .container > .section-eyebrow {
  margin-bottom: 12px;
}

.provider .container > h2 {
  margin-bottom: 28px;
}

.provider-card-stack {
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
  margin-top: 0;
  background: #fff;
  box-shadow: 0 8px 28px rgba(74, 44, 38, 0.05);
}

.provider-feature {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
  gap: 0;
  align-items: stretch;
  margin-bottom: 0;
  background: #fff;
  border: none;
  border-radius: 0;
  overflow: hidden;
}

.provider-feature__photo {
  position: relative;
  min-height: 0;
  align-self: stretch;
  background: var(--brand-cream);
  overflow: hidden;
}

.provider-feature__photo img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 26%;
  display: block;
}

.provider-feature__text {
  padding: 44px 36px 48px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.provider-feature__text h2 {
  font-size: var(--ms-type-page-heading);
  margin: 0 0 22px;
  line-height: 1.12;
}

.provider-quote--accent {
  margin: 0 0 22px;
  padding: 0 0 0 16px;
  border-left: 2px solid var(--line);
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-body);
  font-style: italic;
  font-weight: 700;
  line-height: var(--ms-leading-body);
  color: #4a3530;
}

.provider-role {
  font-size: var(--ms-type-body);
  font-weight: 600;
  color: var(--muted);
  margin-bottom: 14px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.provider-teaser {
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  margin: 0 0 22px;
}

.provider-feature__text .provider-bio-link {
  margin-bottom: 20px;
  align-self: flex-start;
}

.provider-bubbles {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.provider-bubble {
  display: inline-block;
  padding: 6px 12px;
  border-radius: 999px;
  background: #f0eeeb;
  color: #4a3530;
  font-size: var(--ms-type-caption);
  font-weight: 600;
  letter-spacing: 0.04em;
}

.provider-bio-link {
  font-size: var(--ms-type-body);
  font-weight: 600;
  color: var(--terracotta-brand);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: rgba(166, 93, 79, 0.35);
  transition: color 0.2s ease, text-decoration-color 0.2s ease;
}

.provider-bio-link:hover {
  color: #8e4e42;
  text-decoration-color: currentColor;
}

.provider-team-footer {
  padding: 28px 24px;
  text-align: center;
  border-top: 1px solid var(--line);
  background: #fff;
}

.provider-team-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 220px;
  padding: 14px 26px;
  border-radius: var(--btn-radius);
  background: var(--btn-outline-bg);
  color: var(--btn-outline-fg);
  border: 1px solid var(--btn-outline-border);
  font-family: var(--btn-font);
  font-size: var(--ms-type-button);
  line-height: 1.2;
  font-weight: 600;
  letter-spacing: var(--btn-label-spacing);
  text-transform: uppercase;
  text-decoration: none;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.provider-team-cta:hover {
  background: var(--btn-outline-bg-hover);
  color: var(--btn-outline-fg);
  border-color: var(--btn-outline-border);
}

.provider-secondary {
  margin-top: 0;
  padding: 14px 24px 12px;
  background: #faf9f7;
  border: none;
  border-top: 1px solid var(--line);
  border-radius: 0;
}

.provider-row {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  padding: 16px 0;
  border-bottom: 1px solid var(--line);
}

.provider-row:last-child {
  border-bottom: none;
}

.provider-row__avatar {
  width: 100%;
  height: 100%;
  min-height: 100%;
  object-fit: cover;
  object-position: center 18%;
  flex-shrink: 0;
  display: block;
  border-radius: 0;
}

.provider-row__avatar-wrap {
  width: 92px;
  height: 112px;
  border-radius: 10px;
  overflow: hidden;
  flex-shrink: 0;
  border: 1px solid var(--line);
  background: var(--brand-cream);
}

.provider-row__avatar-wrap .provider-row__avatar {
  width: 100%;
  height: 100%;
  min-height: 112px;
  display: block;
  border-radius: 0;
}

.provider-row__body {
  flex: 1;
  min-width: 0;
}

.provider-row__body h3 {
  font-size: var(--ms-type-subtitle);
  margin: 0 0 12px;
}

.provider-row__body .provider-teaser {
  margin-bottom: 14px;
}

@media (min-width: 981px) {
  .provider-feature__photo {
    min-height: clamp(460px, 62vh, 720px);
  }

  .provider-feature__photo img {
    object-position: center top;
  }

  /* Jeremiah + Jinhee: two columns so teasers don’t stretch edge-to-edge */
  .provider-secondary {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    column-gap: 0;
    align-items: start;
    padding: 18px 28px 16px;
  }

  .provider-secondary .provider-row {
    border-bottom: none;
    padding: 14px 0;
  }

  .provider-secondary .provider-row:first-child {
    border-right: 1px solid var(--line);
    padding-right: 28px;
  }

  .provider-secondary .provider-row:last-child {
    padding-left: 28px;
  }
}

.promo-block {
  background: #fff;
  padding: 52px 0 56px;
}

.promo-teaser {
  max-width: none;
  width: 100%;
  margin: 0 auto;
  text-align: center;
}

.promo-teaser h2 {
  font-size: var(--ms-type-subtitle);
  letter-spacing: 0.02em;
  text-transform: none;
  font-weight: 700;
  margin: 0 0 12px;
  color: #281f1d;
}

.promo-teaser-lede {
  color: var(--muted);
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  margin: 0 auto;
  max-width: 36em;
}

.tier-preview {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  align-items: stretch;
  margin: 26px auto 0;
  max-width: none;
  width: 100%;
}

.tier-preview-item {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  text-align: left;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 20px 16px 18px;
  box-shadow: 0 8px 26px rgba(74, 44, 38, 0.07);
}

.tier-preview-item.tier-preview-item--membership {
  display: grid;
  grid-template-columns: minmax(104px, 40%) 1fr;
  gap: 0;
  padding: 0;
  overflow: hidden;
  align-items: stretch;
}

.tier-preview-item__media {
  position: relative;
  min-height: 8.75rem;
  background: var(--section-band);
}

.tier-preview-item__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

.tier-preview-item__body {
  padding: 16px 16px 16px 18px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  text-align: left;
  min-height: 0;
}

.tier-preview-item--membership .tier-preview-item__tail {
  margin-top: auto;
  padding-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.tier-preview-item--membership .tier-preview-hint {
  margin-top: 0;
  padding-top: 0;
}

.tier-preview-item--membership .tier-preview-copy {
  margin: 0;
}

.tier-preview-name {
  display: block;
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-caption);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #3a2a26;
  line-height: 1.35;
}

.tier-preview-price {
  display: block;
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-tier-price);
  font-weight: 700;
  color: #4a302a;
  margin-top: 8px;
}

/* Renders a simpler single-stroke $ than La Luxes’ default glyph */
.tier-preview-dollar {
  font-family: var(--btn-font);
  font-weight: 600;
  margin-right: 0.04em;
}

.tier-preview-period {
  font-size: 0.65em;
  font-weight: 500;
}

.tier-preview-hint {
  display: block;
  font-size: var(--ms-type-body);
  color: #7a6560;
  margin-top: 8px;
  line-height: 1.4;
}

.tier-preview-copy {
  margin: 10px 0 0;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
}

.promo-teaser-cta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-top: 24px;
}

.btn-mem {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 188px;
  padding: 14px 22px;
  border-radius: var(--btn-radius);
  background: var(--btn-fill-bg);
  color: var(--btn-fill-fg);
  font-family: var(--btn-font);
  font-size: var(--ms-type-button);
  line-height: 1.2;
  font-weight: 600;
  letter-spacing: var(--btn-label-spacing);
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid var(--btn-fill-bg);
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.btn-mem:hover {
  background: var(--btn-fill-bg-hover);
  border-color: var(--btn-fill-bg-hover);
  color: var(--btn-fill-fg);
}

.btn-mem--ghost {
  background: var(--btn-outline-bg);
  color: var(--btn-outline-fg);
  border-color: var(--btn-outline-border);
}

.btn-mem--ghost:hover {
  background: var(--btn-outline-bg-hover);
  color: var(--btn-outline-fg);
  border-color: var(--btn-outline-border);
}

.promo-teaser-note {
  margin-top: 24px;
  font-size: var(--ms-type-body);
  color: #5c4a45;
  line-height: var(--ms-leading-body);
  max-width: 32em;
  margin-left: auto;
  margin-right: auto;
}

.promo-teaser-note.promo-teaser-note--link {
  display: block;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  padding: 18px 20px;
  border: 1px solid #dcc8bf;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.35);
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.promo-teaser-note.promo-teaser-note--link:hover {
  background: rgba(255, 255, 255, 0.65);
  border-color: var(--brand-terracotta);
  color: var(--brand-chocolate);
}

.friday-band {
  position: relative;
  overflow: hidden;
  background: linear-gradient(165deg, #fff 0%, #f7f3ed 42%, #ebe4d9 100%);
  padding: 112px 0 120px;
}

.friday-band__striations {
  --friday-striation-mask: radial-gradient(
    ellipse 88% 78% at 50% 50%,
    rgba(0, 0, 0, 0.55) 0%,
    rgba(0, 0, 0, 0.2) 55%,
    transparent 78%
  );
  position: absolute;
  inset: -20% -15%;
  z-index: 0;
  pointer-events: none;
  -webkit-mask-image: var(--friday-striation-mask);
  mask-image: var(--friday-striation-mask);
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}

.friday-band__striations::before {
  content: "";
  position: absolute;
  inset: -6%;
  background-image: repeating-linear-gradient(
      108deg,
      transparent 0 14px,
      rgba(112, 70, 57, 0.035) 14px 15px
    ),
    repeating-linear-gradient(
      72deg,
      transparent 0 22px,
      rgba(112, 70, 57, 0.022) 22px 23px
    );
  background-repeat: repeat;
  background-position: 50% 50%;
  background-size: min(115vw, 1900px) min(115vw, 1900px);
  opacity: 0.22;
  mix-blend-mode: multiply;
  filter: saturate(0.88);
  will-change: transform;
  animation: fridayStriaeDrift 90s ease-in-out infinite alternate;
}

@keyframes fridayStriaeDrift {
  0% {
    transform: translate3d(-0.45%, -0.4%, 0);
  }
  100% {
    transform: translate3d(0.45%, 0.4%, 0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .friday-band__striations::before {
    animation: none;
    opacity: 0.2;
    transform: none;
    background-position: 50% 50%;
  }
}

@media (max-width: 720px) {
  .friday-band__striations {
    --friday-striation-mask: radial-gradient(
      ellipse 92% 88% at 50% 50%,
      rgba(0, 0, 0, 0.5) 0%,
      rgba(0, 0, 0, 0.18) 58%,
      transparent 82%
    );
    inset: -28% -20% -32% -20%;
  }

  .friday-band__striations::before {
    inset: -10%;
    background-size: min(200vw, 2400px) auto;
    background-position: 50% 50%;
    opacity: 0.2;
  }
}

.friday-band__inner {
  position: relative;
  z-index: 1;
  max-width: 44rem;
  margin: 0 auto;
  text-align: center;
}

.friday-band__eyebrow {
  display: block;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: var(--ms-eyebrow-font-weight);
  letter-spacing: var(--ms-eyebrow-letter-spacing);
  text-transform: uppercase;
  color: var(--ms-eyebrow-color);
  margin: 0 0 14px;
  line-height: 1.35;
}

.friday-band__title {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-emphasis);
  font-weight: 700;
  font-style: normal;
  letter-spacing: 0.02em;
  line-height: 1.22;
  text-transform: none;
  margin: 0 0 16px;
  color: #1a1412;
}

.friday-band__title-accent {
  font-style: italic;
  font-weight: 600;
  color: var(--brand-coral);
}

.friday-band__lede {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: #3a2f2c;
  margin: 0 0 26px;
  font-weight: 500;
}

.friday-band__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 14px 22px;
  margin: 0;
}

.friday-band__locations {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.15em 0.5em;
  max-width: 36rem;
  margin-left: auto;
  margin-right: auto;
}

.friday-band__pill {
  display: inline;
  padding: 0;
  border-radius: 0;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-caption);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--brand-terracotta);
  background: none;
  border: none;
  box-shadow: none;
}

.friday-band__pill:not(:first-child)::before {
  content: "·";
  display: inline-block;
  margin-right: 0.5em;
  color: rgba(112, 70, 57, 0.32);
  font-weight: 400;
  letter-spacing: 0;
}

.friday-band__actions .friday-band__btn-secondary {
  min-width: 11rem;
}


.site-footer {
  background: var(--footer-bg);
  color: var(--footer-body);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.8fr 1.1fr 1.1fr 1.1fr;
  gap: 34px;
  padding: 52px 0 28px;
  font-size: var(--ms-type-body);
}

.footer-grid p,
.footer-grid a {
  color: var(--footer-body);
  text-decoration: none;
}

.footer-grid a {
  transition:
    color var(--ms-motion-duration) var(--ms-motion-ease),
    opacity var(--ms-motion-duration) var(--ms-motion-ease);
}

.footer-grid a:hover {
  color: var(--footer-link-hover);
}

.footer-title {
  font-family: "Raleway", sans-serif;
  margin-bottom: 16px;
  color: var(--footer-heading);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: var(--ms-type-body);
  font-weight: 700;
}

.footer-brand {
  max-width: 320px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  justify-self: start;
}

/*
 * Logo–copy “gap”: ms-footer-logo.svg uses a square 750×750 viewBox with ~15–20% empty
 * canvas below the artwork. Margins on .footer-copy barely change that — crop the img
 * (object-fit: cover + aspect ~1/0.82) so the layout box matches the visible mark; px translate + object-position (~34%) tune the crest.
 */
.footer-brand .footer-copy {
  max-width: 14.5rem;
}

.footer-logo {
  width: 187px;
  /* Slightly taller box than 0.78 — less of the mark clipped by cover */
  aspect-ratio: 1 / 0.82;
  object-fit: cover;
  /* Bias toward upper third of artwork (percent translate on img was ~4–6px — too small to see) */
  object-position: 50% 34%;
  display: block;
  margin: 0 0 0 -0.65rem;
  line-height: 0;
  transform: translateY(calc(-1 * clamp(6px, 2.35vw, 14px)));
}

.footer-copy {
  margin: 0 0 10px;
  line-height: var(--ms-leading-body);
  color: var(--footer-body);
}

.footer-grid .footer-address {
  margin-bottom: 18px;
  line-height: var(--ms-leading-body);
  color: var(--footer-body);
}

.footer-address__street {
  color: var(--footer-accent);
}

.footer-copyright {
  color: var(--footer-accent);
}

.footer-label {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-caption);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--footer-accent);
  margin: 0 0 8px;
}

/* Paragraph color from .footer-grid p must not wash out accent labels */
.footer-grid p.footer-label,
.footer-stack--visit .footer-label {
  color: var(--footer-accent);
}

.footer-label--spaced {
  margin-top: 18px;
}

.footer-metro-dots {
  line-height: var(--ms-leading-body);
  color: var(--footer-body);
}

.footer-stack--quick a {
  color: var(--footer-body);
}

.footer-stack--quick a:hover {
  color: var(--footer-link-hover);
}

.social-row {
  display: flex;
  gap: 12px;
  margin-top: 0;
}

.social-row a {
  width: 28px;
  height: 28px;
  border: 1px solid var(--footer-rule);
  color: var(--footer-heading);
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--ms-type-body);
  transition:
    border-color var(--ms-motion-duration) var(--ms-motion-ease),
    color var(--ms-motion-duration) var(--ms-motion-ease),
    transform var(--ms-motion-duration) var(--ms-motion-ease),
    background-color var(--ms-motion-duration) var(--ms-motion-ease);
}

.social-row a:hover {
  transform: translate3d(0, -2px, 0);
  border-color: rgba(242, 238, 230, 0.55);
}

.social-row a svg {
  width: 14px;
  height: 14px;
  display: block;
  flex-shrink: 0;
}

.footer-stack p {
  margin-bottom: 7px;
  line-height: 1.25;
}

.footer-svc-link {
  display: block;
  margin-bottom: 10px;
  text-decoration: none;
  transition: transform var(--ms-motion-duration) var(--ms-motion-ease);
}

.footer-svc-link:hover {
  transform: translate3d(3px, 0, 0);
}

.footer-svc-title {
  display: block;
  color: var(--footer-accent);
  font-weight: 600;
  font-size: var(--ms-type-body);
  line-height: 1.3;
  transition: color var(--ms-motion-duration) var(--ms-motion-ease);
}

.footer-svc-desc {
  display: block;
  color: var(--footer-body);
  font-size: var(--ms-type-body);
  font-weight: 400;
  margin-top: 3px;
  line-height: 1.4;
}

.footer-svc-link:hover .footer-svc-title {
  color: var(--footer-link-hover);
}

.footer-bottom {
  border-top: 1px solid var(--footer-rule);
  margin-top: 8px;
}

.footer-bottom-inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  column-gap: 20px;
  row-gap: 6px;
  padding: 10px 0 14px;
  color: var(--footer-muted);
  font-size: var(--ms-type-body);
}

.footer-legal {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px 20px;
}

.footer-legal a {
  color: var(--footer-muted);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}

.footer-legal a:hover {
  color: var(--footer-link-hover);
}

@media (max-width: 980px) {
  .service-feature-card,
  .provider-feature { grid-template-columns: 1fr; }

  .provider-feature__photo {
    min-height: min(68vw, 460px);
    max-height: none;
  }

  .provider-feature__photo img {
    object-position: center 30%;
  }

  .service-feature-card__media {
    min-height: 220px;
    max-height: 300px;
    height: auto;
  }

  .service-feature-card__media img {
    min-height: 220px;
    object-fit: cover;
    object-position: center 40%;
  }

  .service-feature-card__body {
    min-height: 0;
  }

  .hero-copy {
    max-width: none;
    padding: 4px 0 0;
  }
  .service-grid,
  .review-grid { grid-template-columns: 1fr 1fr; }
  .service-condensed-row {
    grid-template-columns: 1fr;
  }
  .service-condensed {
    border-right: none;
    border-bottom: 1px solid var(--line);
  }
  .service-condensed:last-child {
    border-bottom: none;
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 24px 22px;
    padding-top: 44px;
    align-items: start;
  }

  .footer-brand {
    grid-column: 1 / -1;
    max-width: 40rem;
    justify-self: start;
  }

  .footer-grid > .footer-stack:nth-child(2) {
    grid-column: 1;
  }

  .footer-grid > .footer-stack:nth-child(3) {
    grid-column: 2;
  }

  .footer-grid > .footer-stack:nth-child(4) {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 16px;
    column-gap: 20px;
  }

  .footer-stack--quick .footer-title {
    grid-column: 1 / -1;
    margin-bottom: 10px;
  }

  .footer-stack--quick p {
    margin-bottom: 5px;
  }

  .tier-preview {
    grid-template-columns: 1fr;
    max-width: none;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }

  .tier-preview-item.tier-preview-item--membership {
    grid-template-columns: minmax(96px, 36%) 1fr;
  }

  .tier-preview-item__media {
    min-height: 7.5rem;
  }
}

@media (max-width: 700px) {
  .nav-toggle {
    display: flex;
    position: relative;
    z-index: 100;
  }

  .nav {
    position: fixed;
    top: 0;
    right: 0;
    width: min(300px, 88vw);
    height: 100vh;
    height: 100dvh;
    margin: 0;
    padding: 84px 22px 28px;
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0;
    background: #fff;
    box-shadow: -16px 0 48px rgba(112, 70, 57, 0.12);
    transform: translateX(100%);
    transition: transform 0.3s ease;
    z-index: 90;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    /* Off-canvas drawer must not intercept taps meant for the header / hamburger. */
    pointer-events: none;
  }

  .nav.is-open {
    transform: translateX(0);
    pointer-events: auto;
  }

  .nav > a {
    display: flex;
    align-items: center;
    width: 100%;
    box-sizing: border-box;
  }

  .nav-item--dropdown {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    box-sizing: border-box;
    padding-bottom: 0;
    margin-bottom: 0;
  }

  .nav > a,
  .nav > .nav-item {
    padding: 14px 0;
    border-bottom: 1px solid var(--line);
  }

  .nav .btn.nav-book {
    margin-left: 0;
    margin-top: 8px;
    justify-content: center;
    width: 100%;
  }

  .nav-dropdown-panel {
    position: static;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    box-shadow: none;
    border: none;
    padding: 4px 0 8px 4px;
  }

  .nav-item--dropdown:hover .nav-dropdown-panel,
  .nav-item--dropdown:focus-within .nav-dropdown-panel {
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
  }

  .nav-dropdown-panel a {
    padding: 10px 12px;
    font-size: var(--ms-type-eyebrow);
  }

  .service-grid,
  .review-grid { grid-template-columns: 1fr; }
  /* Homepage hero — ~20% more vertical padding than the ≤900px stack (40px / 52px) */
  .hero {
    padding: calc(40px * 1.2) 0 calc(52px * 1.2);
  }

  .hero-copy { padding: 0 0 8px; }

  /* “Mountain Sun” must not clip on narrow viewports */
  .hero-welcome__line--brand {
    white-space: normal;
    max-width: 100%;
    overflow-wrap: break-word;
    hyphens: manual;
  }

  .container {
    padding-left: max(22px, env(safe-area-inset-left));
    padding-right: max(22px, env(safe-area-inset-right));
  }
  .site-footer .container {
    padding-left: max(24px, env(safe-area-inset-left));
    padding-right: max(24px, env(safe-area-inset-right));
  }
  .footer-grid {
    font-size: var(--ms-type-body);
    /* Pull main grid up within the footer band (~3% of a typical phone viewport height) */
    padding: calc(40px - clamp(0.65rem, 2.75vmin, 1.35rem)) 0 28px;
  }

  .site-footer .footer-bottom {
    margin-top: max(0, calc(8px - clamp(0.15rem, 1vmin, 0.45rem)));
  }

  .footer-brand {
    max-width: 100%;
    justify-self: start;
  }

  .footer-logo {
    width: min(221px, 88vw);
    max-width: 88vw;
    margin-left: -0.65rem;
    aspect-ratio: 1 / 0.82;
    object-fit: cover;
    object-position: 50% 34%;
    transform: translateY(calc(-1 * clamp(6px, 2.35vw, 14px)));
  }

  .footer-copyright {
    font-size: var(--ms-type-body);
  }

  .footer-bottom-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    padding-top: 12px;
    padding-bottom: 16px;
  }

  .footer-legal {
    gap: 14px 18px;
  }

  .provider-feature__photo {
    min-height: min(92vw, 520px);
  }

  .provider-feature__photo img {
    object-position: center 34%;
  }

  /* Homepage meet-your-providers: match meet-the-team portrait frame on small screens */
  .provider-row {
    align-items: flex-start;
  }

  .provider-row__avatar-wrap {
    width: 118px;
    min-width: 118px;
    max-width: 140px;
    height: 232px;
  }

  .provider-row__avatar-wrap .provider-row__avatar {
    min-height: 232px;
  }
}

/* Blog + Book Now: flex column + main grows — avoids --bg showing as a band under the footer. */
body.page-blog,
body.page-book-now,
body.page-template-page-book-now-php,
body.archive,
body.blog,
body.single-post {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  min-height: 100dvh;
  margin: 0;
  background: #fff;
}

body.page-blog > main.blog-page,
body.page-book-now > main.iv-page--booking,
body.page-template-page-book-now-php > main.iv-page--booking,
body.archive #primary,
body.blog #primary,
body.single-post #primary {
  flex: 1 0 auto;
  width: 100%;
}

body.page-blog > script,
body.page-book-now > script,
body.page-template-page-book-now-php > script,
body.archive > script,
body.blog > script,
body.single-post > script {
  display: none !important;
}

.blog-page {
  background: #fff;
  padding: 40px 0 56px;
}

.blog-page__inner {
  max-width: 40rem;
}

.blog-page__lede {
  margin: 18px 0 0;
  max-width: 36rem;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
}

.blog-page__lede a {
  color: var(--brand-terracotta);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.blog-page__lede a:hover {
  color: var(--brand-chocolate);
}

/* Screen reader only (WordPress pattern) */
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  word-wrap: normal !important;
}

/* --------------------------------------------------------------------------
   Post archive + single (blog index, categories, posts)
   -------------------------------------------------------------------------- */

.ms-post-archive,
.ms-post-single {
  background: #fff;
  color: var(--text);
  padding: 40px 0 64px;
}

.ms-post-archive__inner,
.ms-post-single__inner {
  max-width: 1120px;
  margin: 0 auto;
}

.ms-post-archive__header {
  max-width: 40rem;
  margin-bottom: clamp(2rem, 4vw, 2.75rem);
}

.ms-post-archive__header .iv-page__eyebrow {
  margin-bottom: 1rem;
}

.ms-post-archive__header .iv-page__title {
  font-size: var(--ms-type-card-hero);
  font-weight: 500;
  line-height: 1.12;
  color: var(--brand-chocolate);
  margin: 0 0 12px;
}

.ms-post-archive__desc {
  margin-top: 12px;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
}

.ms-post-archive__desc p {
  margin: 0 0 10px;
}

.ms-post-archive__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 280px), 1fr));
  gap: clamp(1.25rem, 3vw, 1.75rem);
}

.ms-post-card {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: clamp(1.25rem, 3vw, 1.5rem);
  box-shadow: 0 6px 22px rgba(74, 44, 38, 0.04);
  transition:
    box-shadow var(--ms-motion-duration-md) var(--ms-motion-ease),
    border-color var(--ms-motion-duration-md) var(--ms-motion-ease),
    transform var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.ms-post-card:hover {
  border-color: rgba(148, 99, 92, 0.35);
  box-shadow: 0 12px 32px rgba(74, 44, 38, 0.09);
  transform: translate3d(0, -2px, 0);
}

.ms-post-card__media {
  display: block;
  margin: 0 0 1rem;
  line-height: 0;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--section-band);
}

.ms-post-card__media:focus-visible {
  outline: 2px solid var(--brand-terracotta);
  outline-offset: 2px;
}

.ms-post-card__image {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  object-position: center center;
  vertical-align: middle;
  transition: transform var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.ms-post-card:hover .ms-post-card__image {
  transform: scale(1.02);
}

.ms-post-card__media--placeholder {
  aspect-ratio: 16 / 10;
  min-height: 140px;
  border-radius: 10px;
  background: linear-gradient(
    165deg,
    #faf9f7 0%,
    rgba(192, 219, 212, 0.22) 100%
  );
}

.ms-post-card__title {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-intro);
  font-weight: 500;
  line-height: 1.25;
  margin: 0 0 8px;
}

.ms-post-card__title a {
  color: var(--brand-chocolate);
  text-decoration: none;
  transition: color var(--ms-motion-duration) var(--ms-motion-ease);
}

.ms-post-card__title a:hover {
  color: var(--brand-terracotta);
}

.ms-post-card__date {
  display: block;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-caption);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 12px;
}

.ms-post-card__excerpt {
  flex: 1 1 auto;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
}

.ms-post-card__excerpt p {
  margin: 0;
}

.ms-post-card__more {
  margin-top: 1rem;
  align-self: flex-start;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-caption);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brand-terracotta);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color var(--ms-motion-duration) var(--ms-motion-ease);
}

.ms-post-card__more:hover {
  color: var(--brand-chocolate);
}

.ms-post-archive__empty {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  color: var(--muted);
  margin: 0;
}

/* Scroll-triggered fade-in (theme.js adds .ms-reveal-init then .ms-reveal-visible) */
.ms-reveal-init {
  opacity: 0;
  transform: translate3d(0, 16px, 0);
}

.ms-reveal-init.ms-reveal-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition:
    opacity 0.52s var(--ms-motion-ease),
    transform 0.52s var(--ms-motion-ease);
}

.ms-post-archive__pagination-wrap {
  margin-top: clamp(2rem, 4vw, 3rem);
}

.ms-post-archive__pagination-wrap .navigation.pagination {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px 14px;
  font-family: "Raleway", sans-serif;
}

.ms-post-archive__pagination-wrap .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
  min-height: 2.25rem;
  padding: 0 10px;
  font-size: var(--ms-type-body);
  font-weight: 600;
  color: var(--brand-chocolate);
  text-decoration: none;
  border: 1px solid var(--line);
  border-radius: var(--btn-radius);
  background: #fff;
}

.ms-post-archive__pagination-wrap .page-numbers:hover,
.ms-post-archive__pagination-wrap .page-numbers.current {
  border-color: var(--brand-terracotta);
  color: var(--brand-terracotta);
}

.ms-post-archive__pagination-wrap .page-numbers.current {
  background: rgba(192, 219, 212, 0.25);
}

.ms-post-single__inner {
  max-width: 42rem;
}

.ms-post-single__header {
  margin-bottom: clamp(1.25rem, 3vw, 1.75rem);
}

.ms-post-single__header .iv-page__eyebrow {
  margin-bottom: 1rem;
}

.ms-post-single__header .iv-page__title {
  font-size: var(--ms-type-card-hero);
  font-weight: 500;
  line-height: 1.12;
  color: var(--brand-chocolate);
  margin: 0 0 12px;
}

.ms-post-single__date {
  display: block;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-caption);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}

.ms-post-single__media {
  margin: 0 0 clamp(1.5rem, 3vw, 2rem);
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--line);
  line-height: 0;
}

.ms-post-single__image {
  display: block;
  width: 100%;
  height: auto;
}

.ms-post-content {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
}

.ms-post-content > p:first-child {
  margin-top: 0;
}

.ms-post-content p {
  margin: 0 0 1rem;
}

.ms-post-content a {
  color: var(--brand-terracotta);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.ms-post-content a:hover {
  color: var(--brand-chocolate);
}

.ms-post-content h2,
.ms-post-content h3,
.ms-post-content h4 {
  font-family: "La Luxes Serif Pro", serif;
  color: var(--brand-chocolate);
  margin: 1.75rem 0 0.65rem;
  line-height: 1.2;
}

.ms-post-content h2 {
  font-size: var(--ms-type-aside);
  font-weight: 500;
}

.ms-post-content h3 {
  font-size: var(--ms-type-subtitle);
  font-weight: 500;
}

.ms-post-content ul,
.ms-post-content ol {
  margin: 0 0 1rem 1.1rem;
  padding: 0;
}

.ms-post-content li {
  margin-bottom: 6px;
}

.ms-post-content blockquote {
  margin: 1.25rem 0;
  padding: 1rem 1.15rem 1rem 1.1rem;
  border-left: 3px solid var(--brand-terracotta);
  background: #faf9f7;
  font-style: italic;
  color: var(--brand-chocolate);
}

.ms-post-content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--btn-radius);
}

.ms-post-pages {
  margin-top: 2rem;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  color: var(--muted);
}

.ms-post-pages__label {
  font-weight: 600;
  margin-right: 8px;
}

.ms-post-single__nav {
  max-width: 42rem;
  margin-left: auto;
  margin-right: auto;
}

.ms-post-single__nav .post-navigation {
  margin: clamp(2.5rem, 5vw, 3.5rem) 0 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  font-family: "Raleway", sans-serif;
}

.ms-post-single__nav .post-navigation .nav-previous a,
.ms-post-single__nav .post-navigation .nav-next a {
  display: block;
  padding: 1rem 1.1rem;
  border: 1px solid var(--line);
  border-radius: 12px;
  text-decoration: none;
  color: var(--brand-chocolate);
  transition: border-color 0.2s ease, background 0.2s ease;
}

.ms-post-single__nav .post-navigation .nav-next {
  text-align: right;
}

.ms-post-single__nav .post-navigation a:hover {
  border-color: var(--brand-terracotta);
  background: #faf9f7;
}

.ms-post-nav__label {
  display: block;
  font-size: var(--ms-type-eyebrow);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 6px;
}

.ms-post-nav__title {
  display: block;
  font-size: var(--ms-type-body);
  font-weight: 600;
  color: var(--brand-terracotta);
}

@media (max-width: 719px) {
  .ms-post-single__nav .post-navigation {
    grid-template-columns: 1fr;
  }

  .ms-post-single__nav .post-navigation .nav-next {
    text-align: left;
  }
}

/* --------------------------------------------------------------------------
   Book Now — Vagaro embed in a branded shell
   -------------------------------------------------------------------------- */

.iv-page--booking {
  padding: 32px 0 64px;
}

.iv-page--booking .iv-page__inner {
  max-width: 920px;
}

.booking-page__intro {
  text-align: center;
  max-width: 36rem;
  margin: 0 auto 2rem;
}

.booking-page__intro .iv-page__eyebrow {
  margin-bottom: 1rem;
}

.booking-page__lede {
  margin: 14px 0 0;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
}

.booking-widget-shell {
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: visible;
  background: #fff;
  box-shadow: 0 8px 28px rgba(74, 44, 38, 0.04);
  padding: clamp(1.35rem, 3.5vw, 2.25rem) clamp(1rem, 3vw, 1.75rem) clamp(1.75rem, 4vw, 2.5rem);
}

.booking-widget__scroll-anchor {
  display: block;
  height: 1px;
  width: 1px;
  margin: 0;
  overflow: hidden;
  clip-path: inset(50%);
  scroll-margin-top: 6rem;
}

.booking-widget__frame-title.embedded-widget-title,
.booking-widget-shell #frameTitle {
  font-family: "La Luxes Serif Pro", serif !important;
  font-size: var(--ms-type-subtitle) !important;
  font-weight: 500 !important;
  line-height: 1.25 !important;
  color: var(--brand-chocolate) !important;
  padding: 0 0 1rem !important;
  margin: 0 !important;
  text-align: center !important;
  box-sizing: border-box !important;
}

.booking-widget__vagaro.vagaro {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 auto !important;
  padding: 0 !important;
  border: 0 !important;
  text-align: center !important;
  box-sizing: border-box !important;
  min-height: 480px;
}

.booking-widget__vagaro.vagaro iframe {
  width: 100% !important;
  max-width: 100% !important;
  min-height: 520px !important;
  border: 0 !important;
  display: block;
  margin: 0 auto;
}

@media (max-width: 719px) {
  .iv-page--booking .booking-prep__heading {
    font-size: var(--ms-type-eyebrow);
  }

  .iv-page--booking .booking-prep__label {
    font-size: var(--ms-type-eyebrow);
  }

  .iv-page--booking .booking-prep__text {
    font-size: var(--ms-type-body);
    line-height: var(--ms-leading-body);
  }

  .iv-page--booking .booking-page__lede {
    font-size: var(--ms-type-body);
  }

  .iv-page--booking .booking-widget__frame-title.embedded-widget-title,
  .iv-page--booking .booking-widget-shell #frameTitle {
    font-size: var(--ms-type-subtitle) !important;
  }

  .iv-page--booking .booking-widget__vagaro.vagaro iframe {
    min-height: 600px !important;
  }

  .iv-page--booking .booking-page__bottom-text,
  .iv-page--booking .booking-page__footnote {
    font-size: var(--ms-type-body);
  }
}

/* Vagaro injects marketing links in the host div (outside the iframe) */
.booking-widget__vagaro.vagaro > a[href*="vagaro.com/pro"],
.booking-widget__vagaro.vagaro a[href*="vagaro.com/pro"] {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.booking-prep {
  margin: 0 0 2rem;
}

.booking-prep__heading {
  margin: 0 0 1rem;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  text-align: center;
}

.booking-prep__grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
}

@media (min-width: 720px) {
  .booking-prep__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
  }
}

.booking-prep__card {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #faf9f7;
  padding: 1.1rem 1.15rem 1.15rem;
  text-align: left;
}

.booking-prep__label {
  display: block;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand-terracotta);
  margin-bottom: 0.45rem;
}

.booking-prep__text {
  margin: 0;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--text);
}

.booking-prep__text a {
  color: var(--brand-terracotta);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.booking-prep__text a:hover {
  color: var(--brand-chocolate);
}

.booking-page__bottom {
  margin: 2.5rem 0 0;
  padding: clamp(1.35rem, 3vw, 1.75rem) clamp(1rem, 3vw, 1.5rem);
  border-radius: 12px;
  border: 1px solid var(--line);
  background: #faf9f7;
}

.booking-page__bottom-inner {
  max-width: 36rem;
  margin: 0 auto;
  text-align: center;
}

.booking-page__bottom-title {
  margin: 0 0 0.5rem;
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-subtitle);
  font-weight: 500;
  color: var(--brand-chocolate);
}

.booking-page__bottom-text {
  margin: 0;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
}

.booking-page__footnote {
  margin: 2rem auto 0;
  max-width: 32rem;
  text-align: center;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
}

.booking-page__footnote a {
  color: var(--brand-terracotta);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.booking-page__footnote a:hover {
  color: var(--brand-chocolate);
}

/* --------------------------------------------------------------------------
   IV Therapy page — Option 1 split hero + neutral / white surface
   -------------------------------------------------------------------------- */

.iv-page {
  background: #fff;
  color: var(--text);
  padding: 32px 0 64px;
}

.iv-page__inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 22px;
}

.iv-hero-shell {
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 8px 28px rgba(74, 44, 38, 0.04);
  margin-bottom: 8px;
  /* Shared split-hero minimum — all service pages; row grows if copy is taller (no scrollbars) */
  --iv-hero-split-min-h: clamp(420px, 44vw, 480px);
}

/* Membership callout carries vertical rhythm; avoid a double gap before it */
.iv-hero-shell:has(+ .iv-membership-nudge) {
  margin-bottom: 0;
}

.iv-hero-split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: stretch;
  min-height: var(--iv-hero-split-min-h);
}

.iv-hero-split__text {
  min-height: var(--iv-hero-split-min-h);
  padding: clamp(28px, 5vw, 48px) clamp(22px, 4vw, 40px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: #fff;
}

/* Page + blog: same rhythm as .section-eyebrow / .card-eyebrow (must not depend on .iv-page parent). */
.iv-page__eyebrow {
  display: block;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: var(--ms-eyebrow-font-weight);
  letter-spacing: var(--ms-eyebrow-letter-spacing);
  text-transform: uppercase;
  color: var(--ms-eyebrow-color);
  margin-bottom: 14px;
}

.iv-page--contact .contact-col__eyebrow {
  display: block;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ms-eyebrow-color);
  margin: 0 0 10px;
}

/* --------------------------------------------------------------------------
   Contact page — narrow editorial layout (matches reference structure)
   -------------------------------------------------------------------------- */

.iv-page--contact {
  padding: 0 0 56px;
}

.iv-page--contact .iv-page__inner {
  max-width: 780px;
}

.iv-page--contact .contact-hero-shell {
  border-radius: 12px;
  overflow: hidden;
  border: none;
  box-shadow: none;
  background: #fff;
}

.iv-page--contact .contact-hero-grid {
  display: block;
  padding: clamp(2rem, 5vw, 3.25rem) clamp(1.25rem, 3vw, 2rem);
  border-bottom: none;
  background: #fff;
}

.iv-page--contact .contact-hero__intro .iv-page__eyebrow {
  margin-bottom: 1rem;
}

.iv-page--contact .contact-hero__intro .iv-page__title {
  font-size: var(--ms-type-headline);
  font-weight: 700;
  line-height: 1.08;
  margin: 0;
}

@media (min-width: 721px) {
  /* Match Book Now: .iv-page--booking top padding is 32px before the headline. */
  .iv-page--contact {
    padding-top: 32px;
  }

  .iv-page--contact .contact-hero-grid {
    padding-top: 0;
    padding-bottom: clamp(1.5rem, 3vw, 2.25rem);
    padding-left: clamp(1.25rem, 3vw, 2rem);
    padding-right: clamp(1.25rem, 3vw, 2rem);
  }
}

.iv-page--contact .contact-body-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin-top: 1.5rem;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: 0 8px 28px rgba(74, 44, 38, 0.04);
  background: #fff;
}

.iv-page--contact .contact-form-col {
  padding: clamp(2rem, 4vw, 3rem) clamp(1.25rem, 3vw, 2rem);
  border-right: 1px solid var(--line);
  background: #fff;
}

.iv-page--contact .contact-col__title {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-subtitle);
  font-weight: 500;
  line-height: 1.2;
  color: var(--brand-chocolate);
  margin: 0 0 0.5rem;
}

.iv-page--contact .contact-col__desc {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  margin: 0 0 1.75rem;
}

.iv-page--contact .contact-col__desc a {
  color: var(--brand-terracotta);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.iv-page--contact .contact-col__desc a:hover {
  color: var(--brand-chocolate);
}

/* WPForms — contact + mobile services (wrapper: .theme-wpforms) */
.iv-page .theme-wpforms {
  margin-top: 0.25rem;
}

.iv-page .theme-wpforms .wpforms-container,
.iv-page .theme-wpforms .wpforms-container-full {
  margin: 0;
  padding: 0;
  font-family: "Raleway", sans-serif;
}

.iv-page .theme-wpforms .wpforms-form {
  margin: 0;
}

.iv-page .theme-wpforms .wpforms-field-layout {
  width: 100%;
  max-width: 100%;
}

.iv-page .theme-wpforms .wpforms-field,
.iv-page .theme-wpforms .wpforms-field-container {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  clear: both;
  box-sizing: border-box;
}

.iv-page .theme-wpforms .wpforms-field {
  padding: 0 0 1.1rem;
}

/* Layout rows: full form width; 2+ fields in a row split evenly (same total width as single fields) */
.iv-page .theme-wpforms .wpforms-field-row {
  display: grid !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box;
  grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
  gap: 14px;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.iv-page .theme-wpforms .wpforms-field-row::before,
.iv-page .theme-wpforms .wpforms-field-row::after {
  content: none !important;
  display: none !important;
}

.iv-page .theme-wpforms .wpforms-field-row > * {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0;
  float: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  box-sizing: border-box;
}

@media (max-width: 719px) {
  .iv-page .theme-wpforms .wpforms-field-row {
    grid-template-columns: 1fr;
  }

  /* Full name: stay two columns on mobile (no wrap) */
  .iv-page .theme-wpforms .wpforms-field-name .wpforms-field-row {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    column-gap: 8px;
  }

  .iv-page .theme-wpforms .wpforms-field-label,
  .iv-page .theme-wpforms .wpforms-field-label-inline {
    font-size: var(--ms-type-eyebrow);
  }

  .iv-page .theme-wpforms .wpforms-field-sublabel,
  .iv-page .theme-wpforms .wpforms-field-description,
  .iv-page .theme-wpforms .wpforms-field-limit-text {
    font-size: var(--ms-type-body);
  }

  .iv-page .theme-wpforms input[type="text"],
  .iv-page .theme-wpforms input[type="email"],
  .iv-page .theme-wpforms input[type="tel"],
  .iv-page .theme-wpforms input[type="url"],
  .iv-page .theme-wpforms input[type="number"],
  .iv-page .theme-wpforms input[type="date"],
  .iv-page .theme-wpforms select,
  .iv-page .theme-wpforms textarea {
    font-size: var(--ms-type-body);
    padding: 12px 14px;
  }

  .iv-page .theme-wpforms label.wpforms-error {
    font-size: var(--ms-type-body);
  }

  /*
   * WPForms “modern” dropdown = Choices.js — placeholder lives in .choices__inner, not <select>.
   * Extra min-height + padding + line-height so “Select a choice” is not clipped on phones.
   */
  .iv-page .theme-wpforms .choices__inner {
    min-height: 3.35rem !important;
    padding: 12px 2.75rem 12px 14px !important;
    font-size: var(--ms-type-body) !important;
    line-height: 1.5 !important;
    display: flex !important;
    align-items: center !important;
    overflow: visible !important;
  }

  .iv-page .theme-wpforms .choices__list--single {
    padding: 0 !important;
  }

  .iv-page .theme-wpforms .choices__list--single .choices__item {
    line-height: 1.5 !important;
    padding: 0 !important;
    white-space: normal !important;
    word-wrap: break-word;
    overflow-wrap: anywhere;
  }

  .iv-page .theme-wpforms .wpforms-field-select select,
  .iv-page .theme-wpforms select.wpforms-field-medium {
    min-height: 3.35rem !important;
    line-height: 1.5 !important;
  }
}

/* Full name: row + halves fill the name field width */
.iv-page .theme-wpforms .wpforms-field.wpforms-field-name,
.iv-page .theme-wpforms .wpforms-field-container.wpforms-field-name {
  width: 100% !important;
  max-width: 100% !important;
}

.iv-page .theme-wpforms .wpforms-field-name .wpforms-field-row-block,
.iv-page .theme-wpforms .wpforms-field-name .wpforms-one-half,
.iv-page .theme-wpforms .wpforms-field-name .wpforms-three-sixths {
  float: none !important;
  width: 100% !important;
  max-width: 100%;
  min-width: 0;
  margin-left: 0 !important;
  margin-right: 0 !important;
  clear: none !important;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 4px;
}

.iv-page .theme-wpforms .wpforms-field-name .wpforms-first,
.iv-page .theme-wpforms .wpforms-field-name .wpforms-last {
  padding-left: 0;
  padding-right: 0;
}

.iv-page .theme-wpforms .wpforms-field-label,
.iv-page .theme-wpforms .wpforms-field-label-inline {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0 0 6px;
  line-height: 1.35;
}

.iv-page .theme-wpforms .wpforms-required-label {
  color: var(--brand-terracotta);
  font-weight: 700;
}

.iv-page .theme-wpforms .wpforms-field-sublabel,
.iv-page .theme-wpforms .wpforms-field-description,
.iv-page .theme-wpforms .wpforms-field-limit-text {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  color: var(--muted);
  margin-top: 4px;
}

.iv-page .theme-wpforms input[type="text"],
.iv-page .theme-wpforms input[type="email"],
.iv-page .theme-wpforms input[type="tel"],
.iv-page .theme-wpforms input[type="url"],
.iv-page .theme-wpforms input[type="number"],
.iv-page .theme-wpforms input[type="date"],
.iv-page .theme-wpforms select,
.iv-page .theme-wpforms textarea {
  width: 100% !important;
  max-width: 100% !important;
  display: block;
  border: 1px solid var(--line);
  border-radius: var(--btn-radius);
  padding: 10px 12px;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--brand-chocolate);
  background: #fff;
  box-shadow: none;
  transition: border-color 0.2s ease, outline 0.2s ease;
  box-sizing: border-box;
}

/* Classic + modern WPForms selects — match text input width */
.iv-page .theme-wpforms .wpforms-field-select select,
.iv-page .theme-wpforms select.wpforms-field-medium {
  width: 100% !important;
  max-width: 100% !important;
}

.iv-page .theme-wpforms .choices {
  width: 100% !important;
  max-width: 100% !important;
  margin-bottom: 0;
}

.iv-page .theme-wpforms .choices__inner {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box;
}

.iv-page .theme-wpforms .wpforms-field-select-style-modern .choices {
  width: 100% !important;
  max-width: 100% !important;
}

.iv-page .theme-wpforms textarea {
  min-height: 8rem;
  resize: vertical;
}

.iv-page .theme-wpforms input:focus,
.iv-page .theme-wpforms select:focus,
.iv-page .theme-wpforms textarea:focus {
  outline: 2px solid var(--brand-mint);
  outline-offset: 1px;
  border-color: var(--brand-terracotta);
}

.iv-page .theme-wpforms input.wpforms-error,
.iv-page .theme-wpforms select.wpforms-error,
.iv-page .theme-wpforms textarea.wpforms-error {
  border-color: var(--brand-rose);
}

.iv-page .theme-wpforms .wpforms-field-checkbox ul li,
.iv-page .theme-wpforms .wpforms-field-radio ul li {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  color: var(--brand-chocolate);
}

.iv-page .theme-wpforms .wpforms-field-checkbox input,
.iv-page .theme-wpforms .wpforms-field-radio input {
  accent-color: var(--brand-terracotta);
}

.iv-page .theme-wpforms .wpforms-submit-container {
  padding: 0.35rem 0 0;
}

/* Submit — override WPForms default blue (theme + !important wins over plugin CSS). */
.iv-page .theme-wpforms .wpforms-submit-container button.wpforms-submit,
.iv-page .theme-wpforms .wpforms-submit-container input[type="submit"].wpforms-submit,
.iv-page .theme-wpforms .wpforms-submit-container button[type="submit"],
.iv-page .theme-wpforms .wpforms-submit-wrap button.wpforms-submit,
.iv-page .theme-wpforms .wpforms-submit-wrap input[type="submit"].wpforms-submit {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: var(--btn-radius) !important;
  font-family: var(--btn-font) !important;
  font-weight: 600 !important;
  font-size: var(--ms-type-button) !important;
  letter-spacing: var(--btn-label-spacing) !important;
  text-transform: uppercase !important;
  padding: 12px 22px !important;
  line-height: 1.2 !important;
  border: 1px solid var(--btn-fill-bg) !important;
  background: var(--btn-fill-bg) !important;
  background-image: none !important;
  color: var(--btn-fill-fg) !important;
  box-shadow: none !important;
  text-shadow: none !important;
  cursor: pointer !important;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease !important;
  -webkit-appearance: none;
  appearance: none;
}

.iv-page .theme-wpforms .wpforms-submit-container button.wpforms-submit:hover,
.iv-page .theme-wpforms .wpforms-submit-container input[type="submit"].wpforms-submit:hover,
.iv-page .theme-wpforms .wpforms-submit-container button[type="submit"]:hover,
.iv-page .theme-wpforms .wpforms-submit-wrap button.wpforms-submit:hover,
.iv-page .theme-wpforms .wpforms-submit-wrap input[type="submit"].wpforms-submit:hover {
  background: var(--btn-fill-bg-hover) !important;
  border-color: var(--btn-fill-bg-hover) !important;
  color: var(--btn-fill-fg) !important;
  background-image: none !important;
}

.iv-page .theme-wpforms .wpforms-confirmation-container-full,
.iv-page .theme-wpforms .wpforms-confirmation-container {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  border: 1px solid var(--line);
  border-radius: var(--btn-radius);
  background: #faf9f7;
  padding: 1rem 1.15rem;
}

.iv-page .theme-wpforms label.wpforms-error {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  color: var(--brand-terracotta);
  margin-top: 4px;
}

.iv-page--contact .contact-info-col {
  padding: clamp(2rem, 4vw, 3rem) clamp(1.25rem, 3vw, 2rem);
  display: flex;
  flex-direction: column;
  gap: 0;
  background: #faf9f7;
}

.iv-page--contact .contact-info-block + .contact-info-block {
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 1px solid var(--line);
}

.iv-page--contact .contact-info-block__label {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--brand-chocolate);
  opacity: 0.78;
  margin: 0 0 6px;
}

.iv-page--contact .contact-info-block__value {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--brand-chocolate);
  margin: 0;
}

.iv-page--contact .contact-info-block__value a {
  color: var(--brand-terracotta);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.iv-page--contact .contact-info-block__value a:hover {
  color: var(--brand-chocolate);
}

.iv-page--contact .contact-info-block__sub {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--brand-chocolate);
  opacity: 0.82;
  margin: 8px 0 0;
}

.iv-page--contact .contact-hours-table {
  width: 100%;
  border-collapse: collapse;
  font-family: "Raleway", sans-serif;
}

.iv-page--contact .contact-hours-table td {
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  padding: 4px 0;
  color: var(--brand-chocolate);
}

.iv-page--contact .contact-hours-table td:last-child {
  text-align: right;
  color: var(--brand-chocolate);
  opacity: 0.82;
}

/* Tuesday – Saturday: time always on the line below the label */
.iv-page--contact .contact-hours-table tr.contact-hours-table__row--tue-sat td {
  display: block;
  width: 100%;
  text-align: left !important;
}

.iv-page--contact .contact-hours-table tr.contact-hours-table__row--tue-sat td:first-child {
  padding-bottom: 2px;
}

.iv-page--contact .contact-hours-table tr.contact-hours-table__row--tue-sat td:last-child {
  padding-top: 0;
}

.iv-page--contact .contact-map-block {
  margin-top: 1.5rem;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: 0 8px 28px rgba(74, 44, 38, 0.04);
}

.iv-page--contact .contact-map-header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 12px 20px;
  padding: 1.5rem clamp(1.25rem, 3vw, 2rem) 1rem;
  background: #fff;
  border-bottom: 1px solid var(--line);
}

.iv-page--contact .contact-map-header__title {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  font-weight: 600;
  line-height: var(--ms-leading-body);
  color: var(--brand-chocolate);
  margin: 0 0 4px;
}

.iv-page--contact .contact-map-header__address {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--brand-chocolate);
  opacity: 0.82;
  margin: 0;
}

.iv-page--contact .contact-map-directions {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  font-weight: 600;
  line-height: var(--ms-leading-body);
  color: var(--brand-terracotta);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.iv-page--contact .contact-map-directions:hover {
  color: var(--brand-chocolate);
}

.iv-page--contact .contact-map-frame {
  position: relative;
  width: 100%;
  height: 220px;
  border-top: 1px solid var(--line);
  background: #faf9f7;
  overflow: hidden;
}

.iv-page--contact .contact-map-frame iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
}

.iv-page--contact .contact-booking-cta {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem 2rem;
  margin-top: 1.25rem;
  padding: 2rem clamp(1.25rem, 3vw, 2rem);
  border-radius: 12px;
  background: #faf9f7;
  border: 1px solid var(--line);
  box-shadow: 0 6px 24px rgba(74, 44, 38, 0.04);
}

.iv-page--contact .contact-booking-cta__text {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-accordion-title);
  font-weight: 700;
  line-height: 1.3;
  color: var(--brand-chocolate);
  margin: 0;
}

.iv-page--contact .contact-booking-cta__text em {
  font-style: italic;
  font-weight: 700;
  color: var(--brand-rose);
}

@media (max-width: 719px) {
  .iv-page--contact .contact-body-grid {
    grid-template-columns: 1fr;
  }

  .iv-page--contact .contact-form-col {
    border-right: none;
    border-bottom: 1px solid var(--line);
  }

  .iv-page--contact .contact-col__desc {
    font-size: var(--ms-type-body);
    line-height: var(--ms-leading-body);
  }

  .iv-page--contact .contact-booking-cta {
    flex-direction: column;
    align-items: stretch;
    text-align: center;
  }

  .iv-page--contact .contact-booking-cta .btn {
    width: 100%;
    justify-content: center;
  }
}

.iv-page .iv-page__title {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-headline);
  font-weight: 700;
  line-height: 1.12;
  color: var(--brand-chocolate);
  margin: 0 0 14px;
}

.iv-page .iv-page__title em {
  font-style: italic;
  font-weight: 700;
  color: var(--brand-rose);
}

.iv-hero-split__lede {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  max-width: 22rem;
  margin: 0 0 clamp(28px, 4.5vw, 42px);
}

.iv-hero-split__book {
  align-self: flex-start;
}

.iv-hero-split__cta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px 14px;
  margin-top: clamp(6px, 1.2vw, 12px);
}

.iv-hero-split__cta-row .iv-hero-split__book {
  margin-top: 0;
}

@media (max-width: 720px) {
  .iv-hero-split__cta-row {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    max-width: 22rem;
  }

  .iv-hero-split__cta-row .iv-hero-split__book {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    justify-content: center;
  }
}

.iv-membership-nudge {
  width: 100%;
  max-width: none;
  box-sizing: border-box;
  margin: clamp(22px, 3.25vw, 32px) 0;
  padding: clamp(18px, 3vw, 24px) clamp(18px, 3vw, 22px);
  border-radius: 12px;
  border: 1px solid var(--line);
  background: #faf9f7;
  box-shadow: 0 4px 18px rgba(74, 44, 38, 0.05);
}

.iv-membership-nudge + .iv-page__list {
  padding-top: 0;
}

.iv-membership-nudge__text {
  margin: 0;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
}

.iv-membership-nudge__text a {
  color: var(--brand-terracotta);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.iv-membership-nudge__text a:hover {
  color: var(--brand-chocolate);
}

.iv-hero-split__visual {
  position: relative;
  min-height: var(--iv-hero-split-min-h);
  background: var(--brand-chocolate);
  overflow: hidden;
  align-self: stretch;
}

.iv-hero-split__photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 55% 42%;
  display: block;
}

.iv-hero-split__scrim {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    195deg,
    rgba(44, 32, 28, 0.12) 0%,
    rgba(44, 32, 28, 0.05) 38%,
    rgba(28, 22, 20, 0.55) 100%
  );
  pointer-events: none;
}

.iv-hero-split__pills {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  list-style: none;
  margin: 0;
  padding: clamp(18px, 4vw, 32px);
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}

.iv-hero-split__pill {
  display: inline-block;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 250, 247, 0.95);
  border: 1px solid rgba(255, 255, 255, 0.28);
  padding: 7px 14px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.18);
  backdrop-filter: blur(6px);
  cursor: default;
  transition:
    transform var(--ms-motion-duration-md) var(--ms-motion-ease),
    box-shadow var(--ms-motion-duration-md) var(--ms-motion-ease),
    border-color var(--ms-motion-duration-md) var(--ms-motion-ease),
    background-color var(--ms-motion-duration-md) var(--ms-motion-ease),
    color var(--ms-motion-duration-md) var(--ms-motion-ease);
}

@media (hover: hover) and (pointer: fine) and (prefers-reduced-motion: no-preference) {
  .iv-hero-split__pill:hover {
    transform: translate3d(0, -3px, 0);
    border-color: rgba(255, 255, 255, 0.48);
    background: rgba(0, 0, 0, 0.32);
    color: #fff;
    box-shadow:
      0 10px 26px rgba(0, 0, 0, 0.28),
      0 0 0 1px rgba(255, 255, 255, 0.12);
  }
}

.iv-hero-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-top: 1px solid var(--line);
  background: #faf9f7;
  min-height: 5.85rem;
  box-sizing: border-box;
  align-items: stretch;
}

.iv-hero-meta__cell {
  padding: 18px clamp(20px, 4vw, 32px);
  display: flex;
  flex-direction: column;
  gap: 5px;
  justify-content: center;
  border-right: 1px solid var(--line);
}

.iv-hero-meta__cell:last-child {
  border-right: none;
}

.iv-hero-meta__label {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: 600;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: #8f6f63;
}

.iv-hero-meta__value {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--brand-chocolate);
}

.iv-page__list {
  padding-top: 28px;
}

.iv-page__cat {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: var(--ms-eyebrow-font-weight);
  letter-spacing: var(--ms-eyebrow-letter-spacing);
  text-transform: uppercase;
  color: var(--ms-eyebrow-color);
  margin: 0;
  padding: 28px 0 12px;
  border-bottom: 1px solid var(--line);
}

.iv-page__cat[id] {
  scroll-margin-top: 5.5rem;
}

.iv-page__list-lede {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  max-width: 36rem;
  margin: 6px 0 18px;
  padding: 0;
}

.iv-acc__book-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px 14px;
  margin-top: 6px;
}

.iv-acc__book-row .iv-acc__cta {
  margin-top: 0;
}

@media (max-width: 720px) {
  .iv-page .iv-acc__book-row {
    flex-direction: column;
    align-items: stretch;
  }

  .iv-page .iv-acc__book-row .iv-acc__cta {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    justify-content: center;
  }
}

.iv-acc {
  border-bottom: 1px solid var(--line);
}

.iv-acc__summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 24px 0;
  cursor: pointer;
  list-style: none;
}

.iv-acc__summary::-webkit-details-marker {
  display: none;
}

.iv-acc__summary-text {
  display: flex;
  flex-direction: column;
  gap: 5px;
  flex: 1;
  min-width: 0;
  text-align: left;
}

.iv-acc__name {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-pill);
  font-weight: 700;
  color: var(--brand-chocolate);
  transition: color 0.2s ease;
}

.iv-acc__summary:hover .iv-acc__name {
  color: var(--brand-terracotta);
}

.iv-acc__summary:focus {
  outline: none;
}

.iv-acc__summary:focus-visible {
  outline: 2px solid var(--brand-terracotta);
  outline-offset: 3px;
  border-radius: 4px;
}

.iv-acc__summary:focus-visible .iv-acc__name {
  color: var(--brand-terracotta);
}

.iv-acc__tagline {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  color: var(--muted);
  line-height: var(--ms-leading-body);
}

.iv-acc__icon {
  position: relative;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  transition: transform 0.25s ease;
}

.iv-acc__icon::before,
.iv-acc__icon::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  background: var(--brand-rose);
  border-radius: 1px;
  transform: translate(-50%, -50%);
}

.iv-acc__icon::before {
  width: 12px;
  height: 2px;
}

.iv-acc__icon::after {
  width: 2px;
  height: 12px;
}

.iv-acc[open] .iv-acc__icon {
  transform: rotate(45deg);
}

.iv-acc__body {
  padding: 0 0 28px;
}

.iv-acc__benefits {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-bottom: 14px;
}

.iv-acc__pill {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: 600;
  color: var(--muted);
  background: #f7f6f4;
  padding: 5px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
}

.iv-acc__desc {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  max-width: 36rem;
  margin: 0 0 16px;
}

.iv-acc__note {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  font-style: italic;
  color: var(--muted);
  line-height: var(--ms-leading-body);
  max-width: 36rem;
  margin: 0 0 18px;
}

.iv-acc__recommended {
  margin: 0 0 16px;
  padding: 12px 14px;
  max-width: 36rem;
  background: #f7f6f4;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.iv-acc__recommended-label {
  display: block;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: var(--ms-eyebrow-font-weight);
  letter-spacing: var(--ms-eyebrow-letter-spacing);
  text-transform: uppercase;
  color: var(--ms-eyebrow-color);
  margin-bottom: 7px;
}

.iv-acc__recommended-text {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
}

.iv-acc__cta {
  margin-top: 4px;
}

/*
 * Service pages (not FAQ): on small screens, accordion body + tagline + pills share one reading size
 * with leading aligned to homepage hero description (--ms-leading-body).
 */
@media (max-width: 720px) {
  .iv-page:not(.faq-page) .iv-page__list-lede {
    font-size: var(--ms-type-body);
    line-height: var(--ms-leading-body);
  }

  .iv-page:not(.faq-page) .iv-acc__tagline,
  .iv-page:not(.faq-page) .iv-acc__desc,
  .iv-page:not(.faq-page) .iv-acc__note,
  .iv-page:not(.faq-page) .iv-acc__recommended-text {
    font-size: var(--ms-type-body);
    line-height: var(--ms-leading-body);
  }

  .iv-page:not(.faq-page) .iv-acc__pill {
    font-family: "Raleway", sans-serif;
    font-size: var(--ms-type-body);
    font-weight: 500;
    line-height: 1.35;
    padding: 6px 14px;
  }

  .iv-page:not(.faq-page) .iv-acc__recommended-label {
    font-size: var(--ms-type-body);
    letter-spacing: 0.06em;
    opacity: 0.82;
  }

  .iv-page:not(.faq-page) .iv-acc__body {
    padding: 0 0 22px;
  }
}

.iv-page__bottom {
  margin-top: 44px;
  padding: 32px 28px;
  border-radius: 12px;
  background: #faf9f7;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  border: 1px solid var(--line);
  box-shadow: 0 6px 24px rgba(74, 44, 38, 0.04);
}

/* Optional line breaks in section titles — hidden on small screens to avoid awkward rags */
.ms-bottom-title__break {
  display: none;
}

@media (min-width: 981px) {
  .ms-bottom-title__break {
    display: inline;
  }
}

.iv-page__bottom-title {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-subtitle);
  font-weight: 700;
  line-height: 1.2;
  color: var(--brand-chocolate);
  margin: 0 0 10px;
}

.iv-page__bottom-text {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  max-width: 28rem;
  margin: 0;
}

.iv-page__bottom-text a {
  color: var(--brand-terracotta);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

.iv-page__bottom-text a:hover {
  color: var(--brand-chocolate);
}

/* NAD+ Therapy — hero photo crop */
.iv-page--nad .iv-hero-split__photo {
  object-position: 40% 52%;
}

/* Skincare & facials — hero photo crop + add-on cards */
.iv-page--skincare .iv-hero-split__photo {
  object-position: 50% 42%;
}

.iv-page__title--skincare-hero {
  text-wrap: balance;
}

/* Massage therapy — hero photo crop */
.iv-page--massage .iv-hero-split__photo {
  object-position: 50% 38%;
}

.iv-page__title--massage-hero {
  text-wrap: balance;
}

/* Wellness shots — hero photo crop */
.iv-page--wellness-shots .iv-hero-split__photo {
  object-position: 48% 42%;
}

/* Mobile services — hero photo crop (legacy split hero if used elsewhere) */
.iv-page--mobile .iv-hero-split__photo {
  object-position: 48% 40%;
}

/* --------------------------------------------------------------------------
   Mobile services page — layout aligned to mobile reference, Mountain Sun tokens
   -------------------------------------------------------------------------- */

.iv-page--mobile .mobile-hero-centered {
  text-align: center;
  padding: clamp(36px, 7vw, 64px) 0 clamp(28px, 4vw, 40px);
}

.iv-page--mobile .mobile-hero-centered .iv-page__eyebrow {
  margin-bottom: 16px;
}

.iv-page--mobile .mobile-hero-centered .iv-page__title {
  margin-left: auto;
  margin-right: auto;
  max-width: 18em;
  font-size: var(--ms-type-headline);
  line-height: 1.12;
  font-weight: 700;
}

.iv-page--mobile .mobile-hero-rule {
  width: 40px;
  height: 2px;
  margin: 0 auto 20px;
  background: var(--brand-coral);
  border-radius: 1px;
}

.iv-page--mobile .mobile-hero-lede {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  max-width: 22rem;
  margin: 0 auto 26px;
}

.iv-page--mobile .mobile-meta-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  border: none;
  border-radius: 14px;
  overflow: hidden;
  background: var(--brand-chocolate);
  margin-bottom: 8px;
  box-shadow: 0 10px 36px rgba(45, 28, 22, 0.14);
}

.iv-page--mobile .mobile-meta-strip__cell {
  padding: 18px 20px;
  border-right: 1px solid rgba(255, 255, 255, 0.07);
}

.iv-page--mobile .mobile-meta-strip__cell:last-child {
  border-right: none;
}

.iv-page--mobile .mobile-meta-strip__label {
  display: block;
  font-size: var(--ms-type-eyebrow);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(242, 238, 230, 0.55);
  margin-bottom: 6px;
}

.iv-page--mobile .mobile-meta-strip__value {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-body);
  line-height: 1.35;
  color: #faf7f4;
}

.iv-page--mobile .mobile-sec-block {
  margin-top: 40px;
}

.iv-page--mobile .mobile-sec-block:first-of-type {
  margin-top: 36px;
}

.iv-page--mobile .mobile-sec-block .section-eyebrow {
  margin-bottom: 10px;
}

.iv-page--mobile .mobile-sec-head {
  margin-bottom: 20px;
}

.iv-page--mobile .mobile-sec-head h2 {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-subtitle);
  font-weight: 500;
  color: var(--brand-chocolate);
  line-height: 1.15;
  margin: 0 0 10px;
}

.iv-page--mobile .mobile-sec-head p {
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  margin: 0;
  max-width: 32rem;
}

.iv-page--mobile .mobile-intake-card {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  background: rgba(236, 245, 242, 0.45);
  border: none;
  border-left: 3px solid var(--brand-coral);
  border-radius: 0 10px 10px 0;
  padding: 16px 20px 16px 18px;
  margin-bottom: 20px;
  box-shadow: none;
}

.iv-page--mobile .mobile-intake-card__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--brand-coral);
  flex-shrink: 0;
  margin-top: 5px;
}

.iv-page--mobile .mobile-intake-card p {
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  margin: 0;
}

.iv-page--mobile .mobile-intake-card strong {
  color: var(--brand-chocolate);
  font-weight: 600;
}

.iv-page--mobile .mobile-svc-cards-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.iv-page--mobile .mobile-svc-tile {
  background: var(--section-band);
  border: none;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: none;
}

.iv-page--mobile .mobile-svc-tile__media {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 2;
  min-height: 0;
  overflow: hidden;
  background: var(--brand-mint);
  border-bottom: none;
}

.iv-page--mobile .mobile-svc-tile__media::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    175deg,
    rgba(255, 252, 248, 0.45) 0%,
    rgba(192, 219, 212, 0.28) 42%,
    rgba(112, 70, 57, 0.2) 100%
  );
}

.iv-page--mobile .mobile-svc-tile__media--brand-icon::after {
  display: none;
}

.iv-page--mobile .mobile-svc-tile__media:not(.mobile-svc-tile__media--brand-icon) img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

/* Icon tiles — same language as homepage service grid (.card__media--brand-icon) */
.iv-page--mobile .mobile-svc-tile__media--brand-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px 10px;
  background: rgba(243, 239, 230, 0.65);
  aspect-ratio: 2.1 / 1;
  min-height: 5.25rem;
  max-height: 6.5rem;
}

.iv-page--mobile .mobile-svc-tile__media--brand-icon .mobile-svc-card-icon {
  position: static;
  width: min(var(--home-service-icon), 4.5rem);
  height: min(var(--home-service-icon), 4.5rem);
  max-height: 5rem;
  object-fit: contain;
  display: block;
  filter: var(--service-icon-img-filter);
  opacity: 0.92;
}

.iv-page--mobile .mobile-svc-tile__media--line-art {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px 16px;
  background: var(--service-icon-surface);
}

.iv-page--mobile .mobile-svc-tile__media--line-art::after {
  display: none;
}

.iv-page--mobile .mobile-svc-tile__media--line-art .mobile-svc-tile__icon-svg {
  width: min(240px, 88%);
  height: auto;
  max-height: none;
}

.iv-page--mobile .mobile-svc-tile__body {
  padding: 18px 18px 20px;
  border-top: 1px solid rgba(224, 216, 207, 0.55);
}

.iv-page--mobile .mobile-svc-tile__num {
  font-size: var(--ms-type-eyebrow);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand-terracotta);
  margin-bottom: 6px;
}

.iv-page--mobile .mobile-svc-tile__name {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-body);
  font-weight: 600;
  color: var(--brand-chocolate);
  margin: 0 0 8px;
  line-height: 1.25;
}

.iv-page--mobile .mobile-svc-tile__desc {
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  margin: 0;
}

.iv-page--mobile .mobile-occasion-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1.25rem, 3vw, 2rem);
}

.iv-page--mobile .mobile-occasion-card {
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 8px 6px 0;
  border-top: 1px solid rgba(224, 216, 207, 0.65);
}

.iv-page--mobile .mobile-occasion-card__icon {
  font-size: var(--ms-type-intro);
  margin-bottom: 12px;
  color: var(--brand-coral);
  line-height: 1;
}

.iv-page--mobile .mobile-occasion-card h3 {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-body);
  font-weight: 600;
  color: var(--brand-chocolate);
  margin: 0 0 8px;
}

.iv-page--mobile .mobile-occasion-card p {
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  margin: 0;
}

.iv-page--mobile .mobile-how-wrap {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  border: none;
  border-radius: 0;
  overflow: visible;
  background: transparent;
}

.iv-page--mobile .mobile-how-step {
  background: var(--section-band);
  padding: 20px 16px;
  border: none;
  border-radius: 12px;
  border-right: none;
}

.iv-page--mobile .mobile-how-step:last-child {
  border-right: none;
}

.iv-page--mobile .mobile-how-step__num {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-body);
  line-height: 1;
  color: rgba(184, 108, 78, 0.45);
  margin-bottom: 10px;
}

.iv-page--mobile .mobile-how-step__title {
  font-size: var(--ms-type-body);
  font-weight: 600;
  color: var(--brand-chocolate);
  margin: 0 0 6px;
}

.iv-page--mobile .mobile-how-step p {
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  margin: 0;
}

.iv-page--mobile .mobile-area-band {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 22px 28px;
  padding: 28px 26px;
  border-radius: 14px;
  background: var(--brand-chocolate);
  border: none;
  box-shadow: 0 10px 36px rgba(45, 28, 22, 0.12);
}

.iv-page--mobile .mobile-area-band__text h2 {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-body);
  font-weight: 600;
  color: #faf7f4;
  margin: 0 0 8px;
  line-height: 1.2;
}

.iv-page--mobile .mobile-area-band__text p {
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: rgba(242, 238, 230, 0.72);
  margin: 0;
  max-width: 26rem;
}

.iv-page--mobile .mobile-area-band__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.iv-page--mobile .mobile-area-pill {
  font-size: var(--ms-type-eyebrow);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(250, 247, 244, 0.92);
  border: none;
  background: rgba(255, 255, 255, 0.1);
  padding: 7px 14px;
  border-radius: 999px;
}

.iv-page--mobile .mobile-faq-wrap {
  border: none;
  border-radius: 0;
  overflow: visible;
  background: transparent;
}

.iv-page--mobile .mobile-faq-details {
  border-bottom: 1px solid rgba(224, 216, 207, 0.85);
}

.iv-page--mobile .mobile-faq-details:first-child {
  border-top: 1px solid rgba(224, 216, 207, 0.85);
}

.iv-page--mobile .mobile-faq-details:last-child {
  border-bottom: 1px solid rgba(224, 216, 207, 0.85);
}

.iv-page--mobile .mobile-faq-details summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 20px;
  font-size: var(--ms-type-body);
  font-weight: 600;
  color: var(--brand-chocolate);
}

.iv-page--mobile .mobile-faq-details summary::-webkit-details-marker {
  display: none;
}

.iv-page--mobile .mobile-faq-details summary::after {
  content: "+";
  font-size: 1.15em;
  font-weight: 500;
  color: var(--muted);
  flex-shrink: 0;
  line-height: 1;
}

.iv-page--mobile .mobile-faq-details[open] summary::after {
  content: "−";
}

.iv-page--mobile .mobile-faq-details .mobile-faq-a {
  padding: 0 20px 16px;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
}

/* Mobile services — inquiry: card stack (warm shell + inner form panel) */
#mobile-inquiry.mobile-inquiry {
  position: relative;
  margin-top: 44px;
  padding: 36px clamp(18px, 4vw, 28px) 28px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: linear-gradient(
    158deg,
    #fffefc 0%,
    #faf6ef 38%,
    #f4ece2 100%
  );
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.75),
    0 16px 48px rgba(74, 44, 38, 0.08);
  overflow: hidden;
}

#mobile-inquiry.mobile-inquiry::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 5px;
  background: linear-gradient(
    90deg,
    rgba(192, 219, 212, 0.95) 0%,
    rgba(166, 93, 79, 0.55) 52%,
    rgba(166, 93, 79, 0.85) 100%
  );
  opacity: 0.95;
}

#mobile-inquiry.mobile-inquiry h2 {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-subtitle);
  font-weight: 500;
  color: var(--brand-chocolate);
  margin: 0 0 10px;
  line-height: 1.18;
  letter-spacing: 0.01em;
  max-width: 20ch;
  text-wrap: balance;
}

#mobile-inquiry.mobile-inquiry .mobile-inquiry__sub {
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  margin: 0 0 14px;
  max-width: 36rem;
}

#mobile-inquiry.mobile-inquiry .mobile-inquiry__travel-note {
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  margin: 0 0 22px;
  max-width: 36rem;
  padding: 10px 12px 10px 14px;
  border-left: 3px solid var(--brand-terracotta);
  background: rgba(255, 255, 255, 0.55);
  border-radius: 0 8px 8px 0;
}

#mobile-inquiry.mobile-inquiry .mobile-wpforms.theme-wpforms {
  position: relative;
  z-index: 0;
  margin-top: 2px;
  padding: clamp(20px, 4vw, 28px) clamp(16px, 3.5vw, 24px);
  border-radius: 12px;
  background: #fff;
  border: 1px solid rgba(224, 216, 207, 0.95);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.9) inset,
    0 6px 26px rgba(74, 44, 38, 0.06);
}

/* Slightly richer fields only on mobile-services (all viewports) */
body.page-mobile-services main .wpforms-container .wpforms-field-label,
body.page-mobile-services main .wpforms-container .wpforms-field-label-inline,
body.page-template-page-mobile-services-php main .wpforms-container .wpforms-field-label,
body.page-template-page-mobile-services-php main .wpforms-container .wpforms-field-label-inline {
  color: #6a534c;
  letter-spacing: 0.11em;
}

body.page-mobile-services main .wpforms-container input[type="text"],
body.page-mobile-services main .wpforms-container input[type="email"],
body.page-mobile-services main .wpforms-container input[type="tel"],
body.page-mobile-services main .wpforms-container input[type="url"],
body.page-mobile-services main .wpforms-container input[type="number"],
body.page-mobile-services main .wpforms-container input[type="date"],
body.page-mobile-services main .wpforms-container select,
body.page-mobile-services main .wpforms-container textarea,
body.page-template-page-mobile-services-php main .wpforms-container input[type="text"],
body.page-template-page-mobile-services-php main .wpforms-container input[type="email"],
body.page-template-page-mobile-services-php main .wpforms-container input[type="tel"],
body.page-template-page-mobile-services-php main .wpforms-container input[type="url"],
body.page-template-page-mobile-services-php main .wpforms-container input[type="number"],
body.page-template-page-mobile-services-php main .wpforms-container input[type="date"],
body.page-template-page-mobile-services-php main .wpforms-container select,
body.page-template-page-mobile-services-php main .wpforms-container textarea {
  background: #fff;
  border-color: #e3d9d0;
  box-shadow: none;
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    background-color 0.2s ease;
}

body.page-mobile-services main .wpforms-container input:focus,
body.page-mobile-services main .wpforms-container select:focus,
body.page-mobile-services main .wpforms-container textarea:focus,
body.page-template-page-mobile-services-php main .wpforms-container input:focus,
body.page-template-page-mobile-services-php main .wpforms-container select:focus,
body.page-template-page-mobile-services-php main .wpforms-container textarea:focus {
  background: #fff;
  border-color: var(--brand-terracotta);
  box-shadow: none;
  outline: 2px solid var(--brand-mint);
  outline-offset: 2px;
}

body.page-mobile-services main .wpforms-container .wpforms-submit-container button.wpforms-submit,
body.page-mobile-services main .wpforms-container .wpforms-submit-container input[type="submit"].wpforms-submit,
body.page-mobile-services main .wpforms-container .wpforms-submit-container button[type="submit"],
body.page-mobile-services main .wpforms-container .wpforms-submit-wrap button.wpforms-submit,
body.page-mobile-services main .wpforms-container .wpforms-submit-wrap input[type="submit"].wpforms-submit,
body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-container button.wpforms-submit,
body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-container input[type="submit"].wpforms-submit,
body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-container button[type="submit"],
body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-wrap button.wpforms-submit,
body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-wrap input[type="submit"].wpforms-submit {
  box-shadow: 0 4px 14px rgba(166, 93, 79, 0.22);
}

body.page-mobile-services main .wpforms-container .wpforms-submit-container button.wpforms-submit:hover,
body.page-mobile-services main .wpforms-container .wpforms-submit-container input[type="submit"].wpforms-submit:hover,
body.page-mobile-services main .wpforms-container .wpforms-submit-container button[type="submit"]:hover,
body.page-mobile-services main .wpforms-container .wpforms-submit-wrap button.wpforms-submit:hover,
body.page-mobile-services main .wpforms-container .wpforms-submit-wrap input[type="submit"].wpforms-submit:hover,
body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-container button.wpforms-submit:hover,
body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-container input[type="submit"].wpforms-submit:hover,
body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-container button[type="submit"]:hover,
body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-wrap button.wpforms-submit:hover,
body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-wrap input[type="submit"].wpforms-submit:hover {
  box-shadow: 0 6px 20px rgba(112, 70, 57, 0.18);
}

/*
 * Mobile services page — every WPForms embed (inquiry + blocks/shortcodes without .theme-wpforms).
 * body.page-mobile-services: slug must be mobile-services. Template class covers slug mismatches.
 * max-width 991px: applies on phones and tablets (earlier 719px missed many viewports).
 */
@media (max-width: 991px) {
  body.page-mobile-services #mobile-inquiry.mobile-inquiry,
  body.page-template-page-mobile-services-php #mobile-inquiry.mobile-inquiry {
    margin-top: 32px;
    padding: 28px clamp(16px, 4vw, 22px) 22px;
  }

  body.page-mobile-services #mobile-inquiry.mobile-inquiry h2,
  body.page-template-page-mobile-services-php #mobile-inquiry.mobile-inquiry h2 {
    margin-bottom: 6px;
    font-size: var(--ms-type-subtitle);
  }

  body.page-mobile-services #mobile-inquiry.mobile-inquiry .mobile-inquiry__sub,
  body.page-template-page-mobile-services-php #mobile-inquiry.mobile-inquiry .mobile-inquiry__sub {
    font-size: var(--ms-type-body);
    line-height: var(--ms-leading-body);
    margin-bottom: 12px;
  }

  body.page-mobile-services main .wpforms-container,
  body.page-template-page-mobile-services-php main .wpforms-container {
    margin-top: 0;
  }

  body.page-mobile-services main .wpforms-container .wpforms-field,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-field {
    padding-bottom: 0.7rem !important;
  }

  body.page-mobile-services main .wpforms-container .wpforms-field-row,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-field-row {
    gap: 10px !important;
  }

  body.page-mobile-services main .wpforms-container .wpforms-field-name .wpforms-field-row,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-field-name .wpforms-field-row {
    gap: 6px !important;
    column-gap: 6px !important;
  }

  body.page-mobile-services main .wpforms-container .wpforms-field-label,
  body.page-mobile-services main .wpforms-container .wpforms-field-label-inline,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-field-label,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-field-label-inline {
    margin-bottom: 4px !important;
    font-size: var(--ms-type-eyebrow) !important;
  }

  body.page-mobile-services main .wpforms-container input[type="text"],
  body.page-mobile-services main .wpforms-container input[type="email"],
  body.page-mobile-services main .wpforms-container input[type="tel"],
  body.page-mobile-services main .wpforms-container input[type="url"],
  body.page-mobile-services main .wpforms-container input[type="number"],
  body.page-mobile-services main .wpforms-container input[type="date"],
  body.page-mobile-services main .wpforms-container select,
  body.page-mobile-services main .wpforms-container textarea,
  body.page-template-page-mobile-services-php main .wpforms-container input[type="text"],
  body.page-template-page-mobile-services-php main .wpforms-container input[type="email"],
  body.page-template-page-mobile-services-php main .wpforms-container input[type="tel"],
  body.page-template-page-mobile-services-php main .wpforms-container input[type="url"],
  body.page-template-page-mobile-services-php main .wpforms-container input[type="number"],
  body.page-template-page-mobile-services-php main .wpforms-container input[type="date"],
  body.page-template-page-mobile-services-php main .wpforms-container select,
  body.page-template-page-mobile-services-php main .wpforms-container textarea {
    padding: 8px 10px !important;
    font-size: var(--ms-type-body) !important;
  }

  body.page-mobile-services main .wpforms-container textarea,
  body.page-template-page-mobile-services-php main .wpforms-container textarea {
    min-height: 6.25rem !important;
  }

  body.page-mobile-services main .wpforms-container .wpforms-submit-container,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-container {
    padding-top: 0.1rem !important;
  }

  body.page-mobile-services main .wpforms-container .wpforms-submit-container button.wpforms-submit,
  body.page-mobile-services main .wpforms-container .wpforms-submit-container input[type="submit"].wpforms-submit,
  body.page-mobile-services main .wpforms-container .wpforms-submit-container button[type="submit"],
  body.page-mobile-services main .wpforms-container .wpforms-submit-wrap button.wpforms-submit,
  body.page-mobile-services main .wpforms-container .wpforms-submit-wrap input[type="submit"].wpforms-submit,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-container button.wpforms-submit,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-container input[type="submit"].wpforms-submit,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-container button[type="submit"],
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-wrap button.wpforms-submit,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-submit-wrap input[type="submit"].wpforms-submit {
    padding: 10px 18px !important;
  }

  body.page-mobile-services main .wpforms-container .wpforms-confirmation-container-full,
  body.page-mobile-services main .wpforms-container .wpforms-confirmation-container,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-confirmation-container-full,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-confirmation-container {
    padding: 0.85rem 1rem !important;
    font-size: var(--ms-type-body) !important;
  }
}

@media (max-width: 719px) {
  body.page-mobile-services #mobile-inquiry.mobile-inquiry .mobile-inquiry__sub,
  body.page-template-page-mobile-services-php #mobile-inquiry.mobile-inquiry .mobile-inquiry__sub {
    font-size: var(--ms-type-body);
    line-height: var(--ms-leading-body);
  }

  body.page-mobile-services main .wpforms-container .wpforms-field-label,
  body.page-mobile-services main .wpforms-container .wpforms-field-label-inline,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-field-label,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-field-label-inline {
    font-size: var(--ms-type-eyebrow) !important;
  }

  body.page-mobile-services main .wpforms-container input[type="text"],
  body.page-mobile-services main .wpforms-container input[type="email"],
  body.page-mobile-services main .wpforms-container input[type="tel"],
  body.page-mobile-services main .wpforms-container input[type="url"],
  body.page-mobile-services main .wpforms-container input[type="number"],
  body.page-mobile-services main .wpforms-container input[type="date"],
  body.page-mobile-services main .wpforms-container select,
  body.page-mobile-services main .wpforms-container textarea,
  body.page-template-page-mobile-services-php main .wpforms-container input[type="text"],
  body.page-template-page-mobile-services-php main .wpforms-container input[type="email"],
  body.page-template-page-mobile-services-php main .wpforms-container input[type="tel"],
  body.page-template-page-mobile-services-php main .wpforms-container input[type="url"],
  body.page-template-page-mobile-services-php main .wpforms-container input[type="number"],
  body.page-template-page-mobile-services-php main .wpforms-container input[type="date"],
  body.page-template-page-mobile-services-php main .wpforms-container select,
  body.page-template-page-mobile-services-php main .wpforms-container textarea {
    font-size: var(--ms-type-body) !important;
    padding: 12px 14px !important;
  }

  body.page-mobile-services main .wpforms-container .wpforms-confirmation-container-full,
  body.page-mobile-services main .wpforms-container .wpforms-confirmation-container,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-confirmation-container-full,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-confirmation-container {
    font-size: var(--ms-type-body) !important;
  }

  body.page-mobile-services main .wpforms-container .choices__inner,
  body.page-template-page-mobile-services-php main .wpforms-container .choices__inner {
    min-height: 3.35rem !important;
    padding: 12px 2.75rem 12px 14px !important;
    font-size: var(--ms-type-body) !important;
    line-height: 1.5 !important;
    display: flex !important;
    align-items: center !important;
    overflow: visible !important;
  }

  body.page-mobile-services main .wpforms-container .choices__list--single .choices__item,
  body.page-template-page-mobile-services-php main .wpforms-container .choices__list--single .choices__item {
    line-height: 1.5 !important;
    padding: 0 !important;
    white-space: normal !important;
    word-wrap: break-word;
    overflow-wrap: anywhere;
  }

  body.page-mobile-services main .wpforms-container .wpforms-field-select select,
  body.page-template-page-mobile-services-php main .wpforms-container .wpforms-field-select select {
    min-height: 3.35rem !important;
    line-height: 1.5 !important;
  }
}

.iv-page--mobile .iv-page__bottom {
  margin-top: 40px;
}

@media (max-width: 820px) {
  .iv-page--mobile .mobile-meta-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .iv-page--mobile .mobile-meta-strip__cell:nth-child(2n) {
    border-right: none;
  }

  .iv-page--mobile .mobile-meta-strip__cell:nth-child(-n + 2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  }
}

@media (max-width: 720px) {
  .iv-page--mobile .mobile-svc-tile__media--line-art {
    min-height: 9.5rem;
    padding: 22px 18px;
  }

  .iv-page--mobile .mobile-svc-tile__media--line-art .mobile-svc-tile__icon-svg {
    width: min(280px, 72vw);
  }

  .iv-page--mobile .mobile-svc-cards-grid {
    gap: 10px;
  }

  .iv-page--mobile .mobile-occasion-grid {
    grid-template-columns: 1fr;
  }

  .iv-page--mobile .mobile-how-wrap {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .iv-page--mobile .mobile-how-step {
    border-right: none;
    border-bottom: none;
  }

  .iv-page--mobile .mobile-how-step:last-child {
    border-bottom: none;
  }

  .iv-page--mobile .mobile-area-band__pills {
    justify-content: flex-start;
  }

}

@media (max-width: 480px) {
  .iv-page--mobile .mobile-meta-strip {
    grid-template-columns: 1fr;
  }

  .iv-page--mobile .mobile-meta-strip__cell {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  }

  .iv-page--mobile .mobile-meta-strip__cell:last-child {
    border-bottom: none;
  }
}

.iv-page__cat#wellness-shots {
  scroll-margin-top: 6.5rem;
}

.iv-skincare-addons {
  list-style: none;
  margin: 6px 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  width: 100%;
}

@media (min-width: 540px) {
  .iv-skincare-addons {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 820px) {
  .iv-skincare-addons {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.iv-skincare-addons__card {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 16px 18px;
  background: #faf9f7;
  box-shadow: 0 4px 16px rgba(74, 44, 38, 0.04);
  box-sizing: border-box;
  min-width: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-start;
}

.iv-skincare-addons__name {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-body);
  font-weight: 500;
  line-height: 1.35;
  color: var(--brand-chocolate);
}

.iv-skincare-addons__desc {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  margin: 0;
}

.iv-page__bottom-btn {
  flex-shrink: 0;
}

@media (max-width: 720px) {
  .iv-hero-shell {
    --iv-hero-split-min-h: clamp(248px, 58vw, 300px);
  }

  .iv-hero-split {
    grid-template-columns: 1fr;
    min-height: 0;
    height: auto;
    max-height: none;
  }

  .iv-hero-split__text {
    min-height: 0;
    height: auto;
  }

  .iv-hero-split__visual {
    min-height: var(--iv-hero-split-min-h);
    height: auto;
    max-height: none;
    order: -1;
  }

  .iv-hero-meta {
    grid-template-columns: 1fr;
  }

  .iv-hero-meta__cell {
    border-right: none;
    border-bottom: 1px solid var(--line);
  }

  .iv-hero-meta__cell:last-child {
    border-bottom: none;
  }

  /* Hero strip under service heroes: same reading size as accordion body (label = tone via opacity). */
  .iv-page:not(.faq-page) .iv-hero-meta__label,
  .iv-page:not(.faq-page) .iv-hero-meta__value {
    font-family: "Raleway", sans-serif;
    font-size: var(--ms-type-body);
    line-height: var(--ms-leading-body);
    color: var(--brand-chocolate);
  }

  .iv-page:not(.faq-page) .iv-hero-meta__label {
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    opacity: 0.78;
  }

  .iv-page:not(.faq-page) .iv-hero-meta__value {
    font-weight: 500;
    opacity: 1;
  }

  .iv-page__bottom {
    flex-direction: column;
    align-items: stretch;
    text-align: center;
  }

  .iv-page__bottom-btn {
    width: 100%;
    justify-content: center;
  }
}

/* --------------------------------------------------------------------------
   FAQ page — denser type & spacing than IV formula accordions (long Q&A list)
   -------------------------------------------------------------------------- */

.team-page.faq-page .team-body .iv-page.faq-page {
  padding-top: 0;
  padding-bottom: 48px;
}

.team-page.faq-page .team-hero__title {
  font-size: var(--ms-type-headline);
}

.team-page.faq-page .team-hero__intro {
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
}

.team-page.faq-page .team-hero__panel {
  padding: clamp(17px, 3vw, 28px) clamp(15px, 3vw, 30px) clamp(19px, 3vw, 30px);
}

.iv-page.faq-page .iv-page__cat {
  padding: 20px 0 12px;
}

/* Extra air between FAQ category blocks (after each accordion group) */
.iv-page.faq-page .iv-acc + .iv-page__cat {
  margin-top: 44px;
  padding-top: 8px;
}

.iv-page.faq-page .iv-acc__summary {
  padding: 16px 0;
  gap: 14px;
}

.iv-page.faq-page .iv-acc__name {
  font-size: var(--ms-type-body);
  line-height: 1.24;
}

.iv-page.faq-page .iv-acc__desc {
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
}

.iv-page.faq-page .iv-acc__body {
  padding: 0 0 20px;
}

.iv-page.faq-page .iv-acc__body ul {
  list-style: none;
  margin: 0 0 14px;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.iv-page.faq-page .iv-acc__body ul li {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  font-weight: 500;
  color: var(--muted);
  background: #f2eee6;
  padding: 6px 14px;
  border-radius: 999px;
  border: 1px solid var(--line);
}

.iv-page.faq-page .iv-acc__body ul.faq-page__bullet-list {
  display: block;
  list-style: disc;
  list-style-position: outside;
  padding-left: 1.2rem;
  margin: 0 0 14px;
}

.iv-page.faq-page .iv-acc__body ul.faq-page__bullet-list li {
  display: list-item;
  background: none;
  border: none;
  border-radius: 0;
  padding: 0 0 0.35rem;
  font-weight: 400;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
}

.iv-page.faq-page .iv-acc__body ul.faq-page__bullet-list li:last-child {
  padding-bottom: 0;
}

.iv-page.faq-page .faq-page__jump {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  list-style: none;
  margin: 16px 0 0;
  padding: 0;
}

.iv-page.faq-page .faq-page__jump li {
  margin: 0;
}

.iv-page.faq-page .faq-page__jump a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  background: #f2eee6;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid var(--line);
  text-decoration: none;
  transition:
    color 0.18s ease,
    border-color 0.18s ease,
    background 0.18s ease;
}

.iv-page.faq-page .faq-page__jump a:hover {
  color: var(--brand-chocolate);
  border-color: rgba(148, 99, 92, 0.35);
  background: #ebe4d8;
}

.iv-page.faq-page .iv-page__bottom {
  margin-top: 32px;
  padding: 24px 20px;
}

.iv-page.faq-page .iv-page__bottom-title {
  font-size: var(--ms-type-body);
  font-weight: 700;
}

.iv-page.faq-page .iv-page__bottom-text {
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
}

.iv-page.faq-page .iv-acc__icon {
  width: 16px;
  height: 16px;
}

.iv-page.faq-page .iv-acc__icon::before {
  width: 10px;
}

.iv-page.faq-page .iv-acc__icon::after {
  height: 10px;
}

/* --------------------------------------------------------------------------
   Meet the Team — mountain hero + editorial, lead portrait grid, visual practitioner rows
   -------------------------------------------------------------------------- */

.container.team-shell {
  max-width: 900px;
}

.team-page {
  background: #fff;
  color: var(--text);
  padding: 0;
}

.team-body {
  padding: 40px 0 56px;
  background: #fff;
}

.team-container {
  box-sizing: border-box;
}

.team-block {
  scroll-margin-top: 5.5rem;
  padding-bottom: 2.5rem;
  margin-bottom: 2rem;
}

.team-block + .team-block {
  margin-top: 0;
}

.team-block--welcome {
  padding-top: 0.5rem;
}

.team-block--lead {
  padding-bottom: 2rem;
}

.team-block--practitioners {
  padding-bottom: 2rem;
}

.team-block--gallery {
  padding-bottom: 1rem;
  margin-bottom: 0;
}

/* The space — aligned grid */
.team-block--space {
  padding: 2rem 0 2.5rem;
  margin-bottom: 0;
}

.team-space__head {
  text-align: center;
  max-width: 28rem;
  margin: 0 auto 1.35rem;
}

.team-space__head .team-heading,
.team-space__head .team-heading__sub--space {
  text-align: center;
}

.team-space__eyebrow {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: var(--ms-eyebrow-font-weight);
  letter-spacing: var(--ms-eyebrow-letter-spacing);
  text-transform: uppercase;
  color: var(--ms-eyebrow-color);
  margin: 0 0 0.5rem;
}

.team-heading--space {
  margin-bottom: 0.35rem;
}

.team-gallery--space {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.35rem;
  margin: 0.25rem 0 0;
  padding: 0;
}

@media (min-width: 720px) {
  .team-gallery--space {
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem 1.25rem;
    align-items: start;
  }
}

.team-gallery__frame--space {
  position: relative;
  height: auto;
  min-height: 200px;
  aspect-ratio: 5 / 3;
  border-radius: 12px;
  overflow: hidden;
  background: var(--brand-cream);
  border: 1px solid var(--line);
  box-shadow: 0 10px 28px rgba(74, 44, 38, 0.07);
}

.team-gallery__frame--space img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 48%;
  display: block;
  filter: contrast(1.05) saturate(0.88) brightness(1.04);
}

.team-gallery__badge {
  position: absolute;
  left: 12px;
  bottom: 12px;
  z-index: 2;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-button);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #faf9f7;
  padding: 8px 12px;
  border-radius: 8px;
  background: rgba(32, 24, 22, 0.72);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.team-gallery__item--space figcaption {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  font-weight: 600;
  color: var(--brand-chocolate);
  margin: 0.65rem 0 0;
  line-height: var(--ms-leading-body);
  letter-spacing: 0.02em;
}

/* Hero — full-bleed mountain + frosted copy panel overlay */
.team-hero--editorial {
  background: #1a1513;
  padding: 0;
  margin: 0;
  --team-hero-visual-height: clamp(260px, 48vh, 520px);
}

@media (min-width: 960px) {
  .team-hero--editorial {
    --team-hero-visual-height: clamp(360px, 58vh, 680px);
  }
}

.team-hero__wrap {
  position: relative;
  width: 100%;
}

.team-hero--editorial .team-hero__visual {
  position: relative;
  width: 100%;
  height: var(--team-hero-visual-height);
  background: var(--brand-chocolate);
}

.team-hero--editorial .team-hero__mountain {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 42%;
  display: block;
  filter: saturate(0.88) sepia(0.07);
}

.team-hero--editorial .team-hero__scrim {
  position: absolute;
  inset: 0;
  /* Warm chocolate + mint + terracotta wash — Meet the Team + FAQ hero (same treatment) */
  background: linear-gradient(
    155deg,
    rgba(112, 70, 57, 0.45) 0%,
    rgba(192, 219, 212, 0.2) 34%,
    rgba(182, 124, 116, 0.18) 55%,
    rgba(74, 48, 42, 0.62) 100%
  );
  pointer-events: none;
}

.team-hero__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: clamp(16px, 4vw, 32px) clamp(14px, 4vw, 24px) clamp(22px, 5vw, 40px);
  box-sizing: border-box;
  pointer-events: none;
}

@media (min-width: 720px) {
  .team-hero__overlay {
    align-items: center;
    justify-content: center;
    padding: clamp(24px, 6vh, 56px) clamp(20px, 4vw, 32px);
  }

  .team-hero__shell {
    transform: translateY(-6%);
  }
}

@media (max-width: 719px) {
  .team-hero__overlay {
    align-items: center;
    justify-content: center;
    padding: clamp(18px, 5vw, 28px) clamp(14px, 4vw, 20px);
  }
}

.team-hero__shell {
  box-sizing: border-box;
  width: 100%;
  pointer-events: none;
}

.team-hero__panel {
  pointer-events: auto;
  text-align: center;
  width: 100%;
  max-width: 34rem;
  margin: 0 auto;
  padding: clamp(20px, 4vw, 36px) clamp(18px, 4vw, 36px) clamp(22px, 4vw, 38px);
  background: rgba(250, 249, 247, 0.94);
  border: 1px solid rgba(255, 255, 255, 0.65);
  border-radius: 14px;
  box-shadow:
    0 4px 24px rgba(18, 14, 12, 0.18),
    0 1px 0 rgba(255, 255, 255, 0.5) inset;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.team-hero__tag {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: var(--ms-eyebrow-font-weight);
  letter-spacing: var(--ms-eyebrow-letter-spacing);
  text-transform: uppercase;
  color: var(--ms-eyebrow-color);
  margin: 0 0 14px;
}

.team-hero__title {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-article-hero);
  font-weight: 700;
  line-height: 1.12;
  color: var(--brand-chocolate);
  margin: 0 0 18px;
  text-wrap: balance;
}

.team-hero__title em {
  font-style: italic;
  color: var(--brand-rose);
}

.team-hero__byline {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  font-weight: 500;
  color: var(--muted);
  letter-spacing: 0.04em;
  margin: 0 0 18px;
}

.team-hero__rule {
  width: 40px;
  height: 1px;
  margin: 0 auto 18px;
  background: var(--brand-terracotta);
}

.team-hero__title + .team-hero__rule {
  margin-top: 14px;
}

.team-hero__intro {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  max-width: 32rem;
  margin: 0 auto;
}

/* Leadership — option 2 portrait card grid */
.team-lead-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 0.75rem;
}

@media (min-width: 720px) {
  .team-lead-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    align-items: stretch;
  }
}

.team-lead-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 26px rgba(74, 44, 38, 0.05);
  display: flex;
  flex-direction: row;
  align-items: stretch;
}

/* Desktop: classic stacked card (photo on top); mobile keeps horizontal strip */
@media (min-width: 720px) {
  .team-lead-card {
    flex-direction: column;
  }
}

.team-lead-card__img {
  position: relative;
  flex: 0 0 42%;
  max-width: 210px;
  min-width: 132px;
  min-height: 232px;
  background: var(--brand-cream);
  overflow: hidden;
  align-self: stretch;
}

/* Mobile: photo column flush top/left/bottom when bio closed; fixed 232px strip when open */
@media (max-width: 719px) {
  .team-lead-card {
    align-items: flex-start;
  }

  /* Same portrait frame closed or open (matches former “bio expanded” layout) */
  .team-lead-card__img {
    align-self: flex-start;
    flex-shrink: 0;
    flex: 0 0 calc(42% - 20px);
    max-width: calc(210px - 20px);
    min-width: 118px;
    width: auto;
    height: 232px;
    min-height: 232px;
    max-height: 232px;
    margin: 10px;
    border-radius: 10px;
    background: #fff;
  }

  .team-lead-card__img img {
    object-fit: cover;
    object-position: center top;
  }
}

@media (min-width: 720px) {
  .team-lead-card__img {
    flex: none;
    width: 100%;
    max-width: none;
    min-width: 0;
    min-height: 0;
    height: auto;
    max-height: min(48vw, 320px);
    aspect-ratio: 3 / 4;
    align-self: stretch;
  }
}

.team-lead-card__img img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
  object-position: center 30%;
  display: block;
}

.team-lead-card__body {
  padding: 16px 18px 18px;
  display: flex;
  flex-direction: column;
  flex: 1;
  min-width: 0;
  text-align: left;
}

.team-lead-card__name {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-card-name);
  font-weight: 700;
  color: var(--brand-chocolate);
  margin: 0 0 4px;
  line-height: 1.25;
}

.team-lead-card__role {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-button);
  font-weight: 700;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: var(--brand-terracotta);
  margin: 0 0 10px;
}

.team-lead-card__excerpt {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-dense);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  margin: 0 0 4px;
}

.team-lead-card .team-pract-card__tags {
  margin: 4px 0 10px;
}

.team-lead-card__more.team-bio-details {
  margin-top: auto;
  padding-top: 10px;
}

/* Unified “Read full bio” disclosure (leadership + practitioners) */
.team-bio-details {
  border: 0;
}

.team-bio-details__summary {
  list-style: none;
  cursor: pointer;
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-caption);
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--brand-terracotta);
  padding: 4px 0;
  user-select: none;
}

.team-bio-details__summary::-webkit-details-marker {
  display: none;
}

.team-bio-details__summary:hover,
.team-bio-details__summary:hover .team-bio-details__arrow {
  color: var(--brand-chocolate);
}

.team-bio-details__summary:focus-visible {
  outline: 2px solid var(--sage);
  outline-offset: 3px;
  border-radius: 4px;
}

.team-bio-details__body {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
}

.team-bio-details[open] > .team-bio-details__body {
  animation: team-bio-details-open 0.22s ease;
}

@keyframes team-bio-details-open {
  from {
    opacity: 0.65;
  }
  to {
    opacity: 1;
  }
}

/* Massage & esthetics — practitioner cards */
.team-pract-stack {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 0.75rem;
}

.team-pract-card {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 16px;
  padding: 18px 18px 20px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: 0 6px 22px rgba(74, 44, 38, 0.05);
  box-sizing: border-box;
}

.team-pract-card__photo {
  position: relative;
  width: 156px;
  max-width: 100%;
  height: 188px;
  margin: 0 auto;
  border-radius: 12px;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--brand-cream);
}

.team-pract-card__photo img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center bottom;
  display: block;
}

.team-pract-card__main {
  flex: 1;
  min-width: 0;
}

/* ≤719px: portrait frame matches expanded-bio layout whether details are open or not */
@media (max-width: 719px) {
  .team-pract-card {
    flex-direction: row;
    align-items: flex-start;
    gap: 0;
    padding: 0;
    overflow: hidden;
  }

  .team-pract-card__photo {
    align-self: flex-start;
    flex: 0 0 calc(42% - 20px);
    max-width: calc(210px - 20px);
    min-width: 118px;
    width: auto;
    height: 232px;
    min-height: 232px;
    max-height: 232px;
    margin: 10px;
    border-radius: 10px;
    background: #fff;
  }

  .team-pract-card__photo img {
    object-fit: cover;
    object-position: center top;
  }

  .team-pract-card__main {
    padding: 16px 18px 18px;
    display: flex;
    flex-direction: column;
    min-width: 0;
  }
}

@media (min-width: 720px) {
  .team-pract-card {
    flex-direction: row;
    align-items: flex-start;
    gap: 20px;
    padding: 20px 22px 22px;
    overflow: visible;
  }

  .team-pract-card__photo {
    flex: 0 0 auto;
    width: 140px;
    max-width: 140px;
    min-width: 140px;
    height: 176px;
    min-height: 176px;
    max-height: 176px;
    margin: 0;
    border-radius: 12px;
  }

  .team-pract-card__photo img {
    object-position: center 16%;
  }

  .team-pract-card__main {
    display: flex;
    flex-direction: column;
    padding: 0;
  }
}

.team-pract-card__name {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-lede);
  font-weight: 700;
  color: var(--brand-chocolate);
  margin: 0 0 4px;
  line-height: 1.22;
}

.team-pract-card__role {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-button);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brand-terracotta);
  margin: 0 0 10px;
}

.team-pract-card__skim {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-dense);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  margin: 0 0 10px;
}

.team-pract-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 6px;
}

.team-pract-card__tag {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-button);
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--muted);
  background: #f2eee6;
  padding: 4px 10px;
  border-radius: 999px;
}

.team-pract-card__more.team-bio-details {
  margin-top: 4px;
}

.team-heading {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-row-accent);
  font-weight: 700;
  color: var(--brand-chocolate);
  margin: 0 0 6px;
  line-height: 1.2;
}

.team-heading__sub {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  font-weight: 600;
  color: var(--brand-terracotta);
  letter-spacing: 0.06em;
  margin: 0 0 1.1rem;
}

.team-heading__sub.team-heading__sub--space {
  text-align: center;
  max-width: 24rem;
  margin: 0 auto 1.1rem;
}

.team-heading__sub--inline {
  margin-top: -4px;
  margin-bottom: 1.35rem;
  color: var(--muted);
  font-weight: 500;
  letter-spacing: 0.02em;
}

.team-prose {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
}

.team-prose--compact {
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
}

.team-prose p {
  margin: 0 0 0.85rem;
}

.team-prose p:last-child {
  margin-bottom: 0;
}

.team-prose__subhead {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-body);
  font-weight: 500;
  color: var(--brand-chocolate);
  margin: 1.15rem 0 0.65rem;
}

.team-lede {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  margin: 0 0 0.5rem;
}

.team-gallery:not(.team-gallery--space) {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  margin: 0.5rem 0 0;
  padding: 0;
}

@media (min-width: 640px) {
  .team-gallery:not(.team-gallery--space) {
    flex-direction: row;
    gap: 1rem;
    align-items: stretch;
  }

  .team-gallery:not(.team-gallery--space) .team-gallery__item {
    flex: 1;
    min-width: 0;
  }
}

.team-gallery__item {
  margin: 0;
}

.team-gallery__frame:not(.team-gallery__frame--space) {
  border-radius: 14px;
  overflow: hidden;
  background: var(--brand-cream);
  height: clamp(168px, 30vw, 200px);
}

.team-gallery__frame:not(.team-gallery__frame--space) img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 52%;
  display: block;
  filter: saturate(0.9) contrast(1.03);
}

.team-gallery figcaption {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-caption);
  font-weight: 600;
  color: var(--muted);
  margin: 0.5rem 0 0;
  line-height: 1.4;
}

.team-cta {
  text-align: center;
  padding: 2rem 1.5rem 2.25rem;
  margin-top: 1.5rem;
  background: #faf9f7;
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: 0 6px 24px rgba(74, 44, 38, 0.04);
  transition:
    transform var(--ms-motion-duration-md) var(--ms-motion-ease),
    box-shadow var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.team-cta:hover {
  transform: translate3d(0, -2px, 0);
  box-shadow: var(--ms-shadow-soft);
}

.team-cta__title {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-footer-block);
  font-weight: 500;
  color: var(--brand-chocolate);
  margin: 0 0 8px;
}

.team-cta__text {
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
  margin: 0 auto 1.25rem;
  max-width: 34rem;
}

.team-cta__btn {
  display: inline-flex;
}

/* —— Memberships page (static memberships.html) —— */
.mem-page {
  --mem-ink: var(--brand-chocolate);
  --mem-muted: var(--muted);
  --mem-soft: #9e8b7e;
  --mem-line: var(--line);
  --mem-panel: var(--section-band);
  --mem-accent: var(--btn-fill-bg);
  --mem-accent-hover: var(--btn-fill-bg-hover);
  --mem-radius: 12px;
  --mem-radius-sm: var(--btn-radius);
  background: #fff;
  color: var(--text);
  /* Match .iv-page top offset so hero aligns with mobile services */
  padding: 32px 0 0;
}

.mem-page .mem-shell {
  max-width: 900px;
}

.mem-body {
  padding-bottom: 3.5rem;
}

/* Centered hero — typography matches mobile services (.mobile-hero-centered) */
.mem-hero--editorial {
  text-align: center;
  padding: clamp(36px, 7vw, 64px) 0 clamp(28px, 4vw, 40px);
  background: #fff;
}

.mem-hero__tag {
  display: block;
  font-family: "Raleway", sans-serif;
  font-size: var(--ms-type-eyebrow);
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--brand-terracotta);
  margin: 0 auto 16px;
}

.mem-hero__headline {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-headline);
  font-weight: 700;
  line-height: 1.12;
  color: var(--brand-chocolate);
  margin: 0 auto 14px;
  max-width: 18em;
}

.mem-hero__headline em {
  font-style: italic;
  color: var(--brand-rose);
}

.mem-hero__rule {
  width: 40px;
  height: 2px;
  margin: 0 auto 20px;
  background: var(--brand-coral);
  border-radius: 1px;
}

.mem-hero__copy {
  font-family: "Raleway", sans-serif;
  margin: 0 auto 26px;
  max-width: 22rem;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--muted);
}

.mem-hero__pills {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

.mem-hero__pills li {
  font-size: var(--ms-type-eyebrow);
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--brand-chocolate);
  border: 1px solid var(--line);
  padding: 7px 16px;
  border-radius: 20px;
  background: #faf9f7;
}

/* Desktop: hero top matches Book Now (32px from .iv-page / .mem-page before headline). */
@media (min-width: 721px) {
  .iv-page--mobile .mobile-hero-centered {
    padding-top: 0;
    padding-bottom: clamp(28px, 4vw, 40px);
  }

  .mem-hero--editorial {
    padding-top: 0;
    padding-bottom: clamp(28px, 4vw, 40px);
  }
}

.mem-section-label {
  font-size: var(--ms-type-eyebrow);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--brand-chocolate);
  margin: 0 0 1rem;
  font-weight: 600;
}

.mem-section-label--spaced {
  margin-top: 2rem;
}

.mem-dot {
  display: block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--brand-coral);
  flex-shrink: 0;
  margin-top: 0.45rem;
}

.mem-dot--sm {
  width: 4px;
  height: 4px;
  margin-top: 0.42rem;
}

.mem-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--btn-font);
  font-size: var(--ms-type-button);
  font-weight: 600;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: var(--mem-radius-sm);
  border: none;
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, opacity 0.2s ease;
}

.mem-btn--accent {
  background: var(--mem-accent);
  color: #fff;
  padding: 12px 26px;
}

.mem-btn--accent:hover {
  background: var(--mem-accent-hover);
  color: #fff;
}

.mem-btn--dark {
  width: 100%;
  background: var(--btn-fill-bg);
  color: var(--btn-fill-fg);
  padding: 12px;
  border: 1px solid var(--btn-fill-bg);
}

.mem-btn--dark:hover {
  background: var(--btn-fill-bg-hover);
  border-color: var(--btn-fill-bg-hover);
  color: var(--btn-fill-fg);
}

/* NAD+ featured card (light “featured” treatment — matches site cards) */
.mem-nad-card {
  scroll-margin-top: 96px;
  background: #faf6f4;
  border: 1px solid var(--mem-line);
  border-radius: var(--mem-radius);
  overflow: hidden;
  margin-bottom: 0.75rem;
  box-shadow: 0 6px 18px rgba(74, 44, 38, 0.06);
  border-left: 4px solid var(--brand-terracotta);
}

.mem-nad-card__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 280px);
}

.mem-nad-card__main {
  padding: clamp(1.75rem, 4vw, 2.25rem);
}

.mem-nad-card__badge {
  display: inline-block;
  font-size: var(--ms-type-eyebrow);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: rgba(233, 154, 129, 0.28);
  color: var(--brand-terracotta);
  padding: 5px 12px;
  border-radius: var(--mem-radius-sm);
  margin-bottom: 1rem;
  font-weight: 600;
}

.mem-nad-card__name {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-subtitle);
  font-weight: 700;
  color: var(--mem-ink);
  margin: 0 0 0.35rem;
  line-height: 1.2;
}

.mem-nad-card__tagline {
  font-size: var(--ms-type-body);
  color: var(--mem-muted);
  font-style: italic;
  margin: 0 0 1.25rem;
  line-height: var(--ms-leading-body);
}

.mem-nad-card__price {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-headline);
  color: var(--mem-ink);
  margin: 0 0 0.15rem;
}

.mem-nad-card__price-suffix {
  font-size: var(--ms-type-body);
  color: var(--mem-soft);
  font-weight: 500;
}

.mem-nad-card__price-label {
  font-size: var(--ms-type-eyebrow);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mem-soft);
  margin: 0 0 1.5rem;
}

.mem-nad-card__features {
  list-style: none;
  margin: 0 0 1.5rem;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.mem-nad-card__features li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--mem-muted);
}

.mem-nad-card__features strong {
  color: var(--mem-ink);
  font-weight: 600;
}

.mem-nad-card__aside {
  background: #fff;
  padding: clamp(1.5rem, 3vw, 2.25rem) clamp(1.25rem, 2.5vw, 1.75rem);
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  justify-content: center;
  border-left: 1px solid var(--mem-line);
}

.mem-nad-card__img-wrap {
  border-radius: 10px;
  overflow: hidden;
  background: var(--mem-panel);
}

.mem-nad-card__img-wrap img {
  display: block;
  width: 100%;
  height: min(220px, 32vw);
  object-fit: cover;
}

.mem-nad-card__perks {
  margin: 0;
}

.mem-nad-card__perk {
  padding: 10px 0;
  border-bottom: 1px solid var(--mem-line);
}

.mem-nad-card__perk:last-child {
  border-bottom: none;
}

.mem-nad-card__perk dt {
  font-size: var(--ms-type-eyebrow);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mem-muted);
  margin-bottom: 3px;
}

.mem-nad-card__perk dd {
  margin: 0;
  font-size: var(--ms-type-body);
  color: var(--mem-muted);
  line-height: var(--ms-leading-body);
}

/* IV tier grid */
.mem-tier-grid {
  scroll-margin-top: 96px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  align-items: stretch;
}

.mem-iv-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
  background: #fff;
  border: 1px solid var(--mem-line);
  border-radius: var(--mem-radius);
  overflow: hidden;
  box-shadow: 0 6px 18px rgba(74, 44, 38, 0.05);
}

.mem-iv-card__img {
  min-height: clamp(200px, 28vw, 280px);
  height: clamp(200px, 32vw, 300px);
  background: var(--mem-panel);
  overflow: hidden;
}

.mem-iv-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.mem-iv-card__body {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  padding: 1.5rem;
}

.mem-iv-card__name {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-subtitle);
  font-weight: 700;
  color: var(--mem-ink);
  margin: 0 0 0.25rem;
}

.mem-iv-card__tagline {
  font-size: var(--ms-type-body);
  color: var(--mem-soft);
  font-style: italic;
  margin: 0 0 1rem;
  line-height: var(--ms-leading-body);
}

.mem-iv-card__price {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-headline);
  color: var(--mem-ink);
  margin: 0 0 0.1rem;
}

.mem-iv-card__price-suffix {
  font-size: var(--ms-type-body);
  color: var(--mem-soft);
  font-weight: 500;
}

.mem-iv-card__price-label {
  font-size: var(--ms-type-eyebrow);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mem-soft);
  margin: 0 0 1.15rem;
}

.mem-iv-card__features {
  list-style: none;
  margin: 0 0 1.25rem;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 9px;
  flex: 1 1 auto;
  min-height: 0;
}

.mem-iv-card__features li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: #6b5a52;
}

.mem-iv-card__rule {
  border: none;
  border-top: 1px solid #f0e8e2;
  margin: 0 0 1rem;
}

.mem-iv-card__guest-heading {
  margin: 0 0 0.45rem;
  font-size: var(--ms-type-eyebrow);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--mem-soft);
}

.mem-iv-card__guest-list {
  list-style: none;
  margin: 0 0 1.15rem;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.mem-iv-card__guest-list li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: #6b5a52;
}

/* Special strip */
.mem-special-strip {
  scroll-margin-top: 96px;
  margin-top: 2rem;
  background: #fff;
  border: 1px solid var(--mem-line);
  border-radius: var(--mem-radius);
  padding: 1.75rem clamp(1.25rem, 3vw, 2rem);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
  box-shadow: 0 6px 20px rgba(74, 44, 38, 0.05);
}

.mem-special-strip__label {
  font-size: var(--ms-type-eyebrow);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--mem-soft);
  margin: 0 0 0.5rem;
  font-weight: 600;
}

.mem-special-strip__title {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-subtitle);
  font-weight: 700;
  color: var(--mem-ink);
  margin: 0 0 0.35rem;
}

.mem-special-strip__sub {
  margin: 0;
  font-size: var(--ms-type-body);
  color: #6b5a52;
  line-height: var(--ms-leading-body);
}

.mem-special-strip__cta {
  white-space: nowrap;
  flex-shrink: 0;
}

.mem-special-strip--gradient {
  background: linear-gradient(145deg, rgba(245, 242, 237, 0.85) 0%, #fff 55%);
  border-color: rgba(112, 70, 57, 0.14);
}

.mem-special-strip--packages {
  margin-top: 1rem;
}

/* Why section */
.mem-why {
  padding: 3rem 0 0;
}

.mem-why__title {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-subtitle);
  font-weight: 400;
  color: var(--mem-ink);
  margin: 0 0 0.5rem;
}

.mem-why__sub {
  margin: 0 0 1.75rem;
  font-size: var(--ms-type-body);
  color: var(--mem-muted);
  line-height: var(--ms-leading-body);
  max-width: 33rem;
}

.mem-why__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.mem-why-card {
  background: #fff;
  border: 1px solid var(--mem-line);
  border-radius: var(--mem-radius);
  padding: 1.35rem 1.25rem;
  box-shadow: 0 4px 14px rgba(74, 44, 38, 0.04);
}

.mem-why-card__icon {
  display: block;
  font-size: var(--ms-type-subtitle);
  margin-bottom: 0.65rem;
  color: var(--brand-terracotta);
}

.mem-why-card__title {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-subtitle);
  font-weight: 700;
  color: var(--mem-ink);
  margin: 0 0 0.35rem;
}

.mem-why-card__text {
  margin: 0;
  font-size: var(--ms-type-body);
  color: var(--mem-muted);
  line-height: var(--ms-leading-body);
}

/* FAQ */
.mem-faq {
  padding: 3rem 0 0;
}

.mem-faq__title {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-subtitle);
  font-weight: 700;
  color: var(--mem-ink);
  margin: 0 0 1.25rem;
}

.mem-faq__item {
  border-bottom: 1px solid var(--mem-line);
}

.mem-faq__q {
  list-style: none;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: 1.1rem 0;
  font-size: var(--ms-type-body);
  font-weight: 600;
  color: var(--mem-ink);
}

.mem-faq__q::-webkit-details-marker {
  display: none;
}

.mem-faq__chev {
  font-size: 1.15em;
  color: var(--mem-soft);
  transition: transform 0.2s ease;
  flex-shrink: 0;
}

.mem-faq__item[open] .mem-faq__chev {
  transform: rotate(45deg);
}

.mem-faq__a {
  padding: 0 0 1.1rem;
}

.mem-faq__a p {
  margin: 0;
  font-size: var(--ms-type-body);
  line-height: var(--ms-leading-body);
  color: var(--mem-muted);
}

/* Bottom CTA bar */
.mem-bottom-cta {
  margin-top: 3rem;
  background: #fff;
  border: 1px solid var(--mem-line);
  border-radius: var(--mem-radius);
  padding: clamp(1.75rem, 4vw, 2.5rem);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.75rem;
  flex-wrap: wrap;
  box-shadow: 0 6px 20px rgba(74, 44, 38, 0.05);
}

.mem-bottom-cta__title {
  font-family: "La Luxes Serif Pro", serif;
  font-size: var(--ms-type-subtitle);
  font-weight: 700;
  color: var(--mem-ink);
  margin: 0 0 0.5rem;
}

.mem-bottom-cta__text {
  margin: 0;
  font-size: var(--ms-type-body);
  color: var(--mem-muted);
  line-height: var(--ms-leading-body);
  max-width: 22.5rem;
}

.mem-bottom-cta__btn {
  white-space: nowrap;
  flex-shrink: 0;
}

@media (max-width: 720px) {
  .mem-nad-card__inner {
    grid-template-columns: 1fr;
  }

  .mem-nad-card__aside {
    border-left: none;
    border-top: 1px solid var(--mem-line);
  }

  .mem-nad-card__img-wrap img {
    height: 200px;
  }

  .mem-tier-grid {
    grid-template-columns: 1fr;
  }

  .mem-why__grid {
    grid-template-columns: 1fr;
  }

  .mem-special-strip {
    flex-direction: column;
    align-items: stretch;
  }

  .mem-special-strip__cta {
    width: 100%;
  }

  .mem-bottom-cta {
    flex-direction: column;
    align-items: stretch;
  }

  .mem-bottom-cta__btn {
    width: 100%;
  }
}

/* --------------------------------------------------------------------------
   Inner pages — scroll-reveal + hover parity (services, mobile, about, mem, contact)
   -------------------------------------------------------------------------- */

.iv-hero-meta__cell {
  transition: background-color var(--ms-motion-duration) var(--ms-motion-ease);
}

.iv-hero-meta__cell:hover {
  background-color: rgba(192, 219, 212, 0.18);
}

.iv-page .iv-page__bottom {
  transition:
    transform var(--ms-motion-duration-md) var(--ms-motion-ease),
    box-shadow var(--ms-motion-duration-md) var(--ms-motion-ease),
    border-color var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.iv-page .iv-page__bottom:hover {
  transform: translate3d(0, -2px, 0);
  box-shadow: var(--ms-shadow-hover);
}

.iv-page--mobile .mobile-svc-tile {
  transition:
    transform var(--ms-motion-duration-md) var(--ms-motion-ease),
    box-shadow var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.iv-page--mobile .mobile-svc-tile:hover {
  transform: translate3d(0, -3px, 0);
  box-shadow: var(--ms-shadow-hover);
}

.iv-page--mobile .mobile-intake-card {
  transition:
    transform var(--ms-motion-duration-md) var(--ms-motion-ease),
    box-shadow var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.iv-page--mobile .mobile-intake-card:hover {
  transform: translate3d(0, -2px, 0);
  box-shadow: var(--ms-shadow-soft);
}

.mem-nad-card,
.mem-iv-card {
  transition:
    transform var(--ms-motion-duration-md) var(--ms-motion-ease),
    box-shadow var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.mem-nad-card:hover,
.mem-iv-card:hover {
  transform: translate3d(0, -3px, 0);
  box-shadow: var(--ms-shadow-hover);
}

.mem-iv-card__img img {
  transition: transform var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.mem-iv-card:hover .mem-iv-card__img img {
  transform: scale(1.03);
}

.mem-special-strip,
.mem-bottom-cta {
  transition:
    transform var(--ms-motion-duration-md) var(--ms-motion-ease),
    box-shadow var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.mem-special-strip:hover,
.mem-bottom-cta:hover {
  transform: translate3d(0, -2px, 0);
  box-shadow: var(--ms-shadow-hover);
}

.iv-page--contact .contact-form-col,
.iv-page--contact .contact-info-col {
  transition:
    transform var(--ms-motion-duration-md) var(--ms-motion-ease),
    box-shadow var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.iv-page--contact .contact-form-col:hover,
.iv-page--contact .contact-info-col:hover {
  transform: translate3d(0, -2px, 0);
  box-shadow: var(--ms-shadow-soft);
}

.iv-page--contact .contact-map-block {
  transition:
    transform var(--ms-motion-duration-md) var(--ms-motion-ease),
    box-shadow var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.iv-page--contact .contact-map-block:hover {
  transform: translate3d(0, -2px, 0);
  box-shadow: var(--ms-shadow-hover);
}

.team-lead-card,
.team-pract-card {
  transition:
    transform var(--ms-motion-duration-md) var(--ms-motion-ease),
    box-shadow var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.team-lead-card:hover,
.team-pract-card:hover {
  transform: translate3d(0, -2px, 0);
  box-shadow: var(--ms-shadow-hover);
}

.team-pract-card__photo img,
.team-lead-card__img img {
  transition: transform var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.team-pract-card:hover .team-pract-card__photo img,
.team-lead-card:hover .team-lead-card__img img {
  transform: scale(1.02);
}

.team-gallery__item {
  transition:
    transform var(--ms-motion-duration-md) var(--ms-motion-ease),
    box-shadow var(--ms-motion-duration-md) var(--ms-motion-ease);
}

.team-gallery__item:hover {
  transform: translate3d(0, -2px, 0);
}

.wp-block-group h2 {
  margin-top: 2rem;
  margin-bottom: 0.4rem;
}

.wp-block-group p {
  margin-bottom: 0.85rem;
}

.wp-block-group {
  padding-left: 0 !important;
  padding-right: 0 !important;
  max-width: 100% !important;
}

.entry-title {
  padding-left: 0;
  margin-left: 0;
}
