﻿:root {
  --color-black: #080706;
  --color-charcoal: #171514;
  --color-ink: #2b2723;
  --color-ivory: #fbf7ef;
  --color-warm-white: #fffdf8;
  --color-beige: #e8ddc9;
  --color-gold: #b8924b;
  --color-gold-light: #d8bd7a;
  --color-muted: #746b5f;
  --shadow-soft: 0 24px 70px rgba(8, 7, 6, 0.18);
  --font-display: "Cormorant Garamond", Georgia, serif;
  --font-body: "Inter", Arial, sans-serif;
  --max-width: 1180px;
  --header-height: 88px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--color-ink);
  background: var(--color-warm-white);
  font-family: var(--font-body);
  line-height: 1.7;
}
a { color: inherit; text-decoration: none; }

.site-header {
  position: sticky;
  top: 0;
  left: 0;
  z-index: 50;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  width: 100%;
  padding: 22px clamp(20px, 4vw, 64px);
  color: var(--color-ivory);
  background: var(--color-black);
  transition: background 240ms ease, padding 240ms ease, box-shadow 240ms ease;
}
.site-header.is-scrolled {
  padding-block: 14px;
  color: var(--color-ink);
  background: rgba(255, 253, 248, 0.96);
  box-shadow: 0 10px 30px rgba(8, 7, 6, 0.08);
  backdrop-filter: blur(18px);
}
.brand {
  font-family: var(--font-display);
  font-size: 1.45rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.nav {
  display: flex;
  gap: clamp(18px, 3vw, 38px);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.nav a, .site-footer a { position: relative; }
.nav a::after, .site-footer a::after {
  position: absolute;
  right: 0;
  bottom: -6px;
  left: 0;
  height: 1px;
  content: "";
  background: currentColor;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 220ms ease;
}
.nav a:hover::after, .site-footer a:hover::after {
  transform: scaleX(1);
  transform-origin: left;
}
.header-cta {
  justify-self: end;
  padding: 11px 18px;
  border: 1px solid currentColor;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: background 220ms ease, color 220ms ease, border-color 220ms ease;
}
.header-cta:hover {
  color: var(--color-black);
  background: var(--color-gold-light);
  border-color: var(--color-gold-light);
}
.menu-toggle {
  display: none;
  justify-self: end;
  width: 44px;
  height: 44px;
  border: 1px solid currentColor;
  border-radius: 50%;
  color: inherit;
  background: transparent;
  cursor: pointer;
}
.menu-toggle span {
  display: block;
  width: 18px;
  height: 1px;
  margin: 5px auto;
  background: currentColor;
  transition: transform 220ms ease;
}
.menu-toggle.is-open span:first-child { transform: translateY(3px) rotate(45deg); }
.menu-toggle.is-open span:last-child { transform: translateY(-3px) rotate(-45deg); }
.mobile-nav {
  position: fixed;
  top: calc(var(--header-height) + 12px);
  right: 18px;
  left: 18px;
  z-index: 45;
  display: none;
  padding: 20px;
  border: 1px solid rgba(184, 146, 75, 0.28);
  border-radius: 8px;
  background: rgba(255, 253, 248, 0.98);
  box-shadow: var(--shadow-soft);
}
.mobile-nav.is-open { display: grid; gap: 12px; }
.mobile-nav a {
  padding: 10px 0;
  color: var(--color-ink);
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.section-dark {
  color: var(--color-ivory);
  background:
    linear-gradient(135deg, rgba(8, 7, 6, 0.92), rgba(23, 21, 20, 0.94)),
    radial-gradient(circle at 76% 18%, rgba(184, 146, 75, 0.24), transparent 32%),
    var(--color-black);
}
.hero {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 42%;
  align-items: stretch;
  height: calc(100svh - var(--header-height));
  min-height: 0;
  padding: clamp(34px, 5vh, 72px) clamp(22px, 6vw, 84px);
  overflow: hidden;
}

@supports (height: 100dvh) {
  .hero {
    height: calc(100dvh - var(--header-height));
  }
}
.hero-content { 
  position: relative; 
  z-index: 2; 
  max-width: 760px; 
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.eyebrow {
  margin: 0 0 18px;
  color: var(--color-gold-light);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.eyebrow.dark { color: var(--color-gold); }
h1, h2, h3 { margin: 0; font-family: var(--font-display); font-weight: 700; line-height: 0.98; }
h1 { max-width: 760px; font-size: clamp(3rem, 7vw, 6rem); }
h2 { color: var(--color-black); font-size: clamp(2.55rem, 5vw, 5.2rem); }
h3 { color: var(--color-black); font-size: clamp(1.8rem, 3vw, 2.55rem); }
.hero-copy {
  max-width: 520px;
  margin: 28px 0 0;
  color: rgba(251, 247, 239, 0.82);
  font-size: clamp(1.08rem, 2vw, 1.28rem);
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 38px; }
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 14px 24px;
  border: 1px solid transparent;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  transition: transform 220ms ease, background 220ms ease, color 220ms ease, border-color 220ms ease;
}
.button:hover { transform: translateY(-2px); }
.button-primary { color: var(--color-black); background: var(--color-gold-light); }
.button-primary:hover { background: var(--color-ivory); }
.button-secondary { color: var(--color-ivory); border-color: rgba(251, 247, 239, 0.48); }
.button-secondary:hover { border-color: var(--color-gold-light); }
.hero-stat {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px 16px;
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px solid rgba(216, 189, 122, 0.22);
}
.hero-stat-label {
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(251, 247, 239, 0.5);
}
.hero-stat-value {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-gold-light);
  margin-left: 4px;
}
.hero-stat-divider {
  color: rgba(216, 189, 122, 0.3);
  font-size: 1rem;
}
.hero-image-col {
  position: relative;
  height: 100%;
  overflow: hidden;
}
.hero-image-col .portrait-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

.intro-band { padding: 44px clamp(22px, 6vw, 84px); color: var(--color-black); background: var(--color-gold-light); }
.intro-band p { max-width: 980px; margin: 0 auto; font-family: var(--font-display); font-size: clamp(1.5rem, 3vw, 2.35rem); line-height: 1.18; text-align: center; }
.content-section { max-width: var(--max-width); margin: 0 auto; padding: 110px clamp(22px, 5vw, 54px); }
.split { display: grid; grid-template-columns: minmax(0, 0.9fr) minmax(0, 1fr); gap: clamp(40px, 7vw, 90px); }
.section-copy { color: var(--color-muted); font-size: 1.05rem; }
.section-copy p { margin-top: 0; }
.section-copy p:last-child { margin-bottom: 0; }
.section-copy.narrow { max-width: 760px; }
.section-ivory { max-width: none; background: var(--color-ivory); }
.section-ivory > * { max-width: var(--max-width); margin-right: auto; margin-left: auto; }
.section-heading { max-width: 820px; margin-bottom: 46px; }
.outcome-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; }
.outcome-card {
  padding: clamp(28px, 4vw, 44px);
  border: 1px solid rgba(184, 146, 75, 0.24);
  border-radius: 8px;
  background: var(--color-warm-white);
  box-shadow: 0 18px 50px rgba(8, 7, 6, 0.06);
  transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
}
.outcome-card:hover { border-color: rgba(184, 146, 75, 0.55); box-shadow: var(--shadow-soft); transform: translateY(-5px); }
.card-number { display: inline-block; margin-bottom: 36px; color: var(--color-gold); font-family: var(--font-display); font-size: 2.3rem; }
.outcome-card p, .testimonial-placeholder p { color: var(--color-muted); }
.audience-section { display: grid; grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr); gap: clamp(36px, 6vw, 80px); }
.audience-list { display: grid; gap: 18px; margin: 8px 0 0; padding: 0; list-style: none; }
.audience-list li { position: relative; padding: 0 0 18px 34px; border-bottom: 1px solid rgba(184, 146, 75, 0.22); color: var(--color-ink); font-weight: 600; }
.audience-list li::before { position: absolute; top: 3px; left: 0; color: var(--color-gold); content: "-"; }
.details-section { max-width: none; background: var(--color-charcoal); }
.details-section .section-heading, .details-grid { max-width: var(--max-width); margin-right: auto; margin-left: auto; }
.details-section h2 { color: var(--color-ivory); }
.details-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1px; background: rgba(216, 189, 122, 0.22); }
.details-grid article { min-height: 180px; padding: 28px; background: var(--color-charcoal); }
.details-grid span {
  display: block;
  color: var(--color-gold-light);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.details-grid strong { display: block; margin-top: 28px; color: var(--color-ivory); font-family: var(--font-display); font-size: clamp(2rem, 3vw, 3.2rem); line-height: 1; }
.proof-section, .about-section { padding-top: 80px; padding-bottom: 80px; }
.testimonial-placeholder { padding: 34px; border: 1px dashed rgba(184, 146, 75, 0.45); border-radius: 8px; background: rgba(232, 221, 201, 0.26); }
.booking { padding: 110px clamp(22px, 6vw, 84px); text-align: center; }
.booking-inner { max-width: 760px; margin: 0 auto; }
.booking h2 { color: var(--color-ivory); }
.booking p { max-width: 560px; margin: 24px auto 34px; color: rgba(251, 247, 239, 0.78); }
.site-footer { display: flex; justify-content: space-between; gap: 18px; padding: 28px clamp(22px, 6vw, 84px); color: var(--color-muted); background: var(--color-warm-white); font-size: 0.9rem; }
.site-footer p { margin: 0; }

/* Offerings Section */
.offerings-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }
.offering-card {
  display: flex;
  flex-direction: column;
  padding: clamp(28px, 4vw, 44px);
  border: 1px solid rgba(184, 146, 75, 0.24);
  border-radius: 8px;
  background: var(--color-warm-white);
  box-shadow: 0 18px 50px rgba(8, 7, 6, 0.06);
  transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
}
.offering-card:hover { border-color: rgba(184, 146, 75, 0.55); box-shadow: var(--shadow-soft); transform: translateY(-5px); }
.offering-card--primary { border-color: rgba(184, 146, 75, 0.6); background: rgba(251, 247, 239, 0.42); }
.offering-meta {
  color: var(--color-gold);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-bottom: 14px;
  margin-top: 16px;
}
.offering-list { display: grid; gap: 14px; margin: 18px 0; padding: 0; list-style: none; }
.offering-list li { position: relative; padding: 0 0 14px 28px; border-bottom: 1px solid rgba(184, 146, 75, 0.22); color: var(--color-ink); font-weight: 600; font-size: 0.95rem; }
.offering-list li::before { position: absolute; top: 2px; left: 0; color: var(--color-gold); content: "-"; }
.offering-list li:last-child { border-bottom: none; padding-bottom: 0; }
.offering-outcome {
  color: var(--color-muted);
  font-size: 0.92rem;
  font-style: italic;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid rgba(184, 146, 75, 0.22);
}
.offering-card .button { margin-top: auto; width: 100%; }
.button-secondary-dark {
  color: var(--color-ink);
  border-color: rgba(43, 39, 35, 0.35);
  background: transparent;
}
.button-secondary-dark:hover {
  border-color: var(--color-gold);
  background: transparent;
}

@media (max-width: 980px) {
  .site-header { grid-template-columns: 1fr auto; }
  .nav, .header-cta { display: none; }
  .menu-toggle { display: block; }
  .hero { grid-template-columns: 1fr 38%; }
  .split, .audience-section { grid-template-columns: 1fr; }
  .details-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .offerings-grid { grid-template-columns: 1fr; }
}
@media (max-width: 680px) {
  .site-header { padding: 16px 18px; }
  .site-header.is-scrolled { padding-block: 12px; }
  .brand { font-size: 1.1rem; }
  .hero { 
    grid-template-columns: 1fr;
    padding: clamp(22px, 4vh, 36px) 20px;
  }
  .hero-image-col { 
    height: clamp(220px, 52vw, 340px);
    order: -1;
  }
  .hero-content {
    justify-content: flex-start;
  }
  .hero-stat {
    gap: 8px 12px;
    margin-top: 22px;
    padding-top: 18px;
  }
  .hero-stat-label {
    font-size: 0.68rem;
  }
  .hero-stat-value {
    font-size: 1rem;
  }
  h1 { font-size: clamp(3rem, 7vw, 4.7rem); }
  h2 { font-size: clamp(2.35rem, 12vw, 3.3rem); }
  .hero-actions, .site-footer { flex-direction: column; align-items: stretch; }
  .hero-actions { margin-top: clamp(22px, 4vh, 32px); }
  .hero-copy { margin-top: clamp(16px, 3vh, 24px); }
  .button { width: 100%; }
  .content-section { padding: 72px 20px; }
  .intro-band { padding: 34px 20px; }
  .outcome-grid, .details-grid, .offerings-grid { grid-template-columns: 1fr; }
  .details-grid article { min-height: 150px; }
  .booking { padding: 78px 20px; }
}

.booking-contact {
  margin-top: 28px;
  font-size: 0.88rem;
  color: rgba(251, 247, 239, 0.65);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.booking-contact a {
  color: var(--color-gold-light);
  transition: color 220ms ease;
}

.booking-contact a:hover {
  color: var(--color-ivory);
}

.booking-social {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 28px;
  margin-top: 22px;
  padding-top: 22px;
  border-top: 1px solid rgba(216, 189, 122, 0.18);
}

.booking-social a {
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(251, 247, 239, 0.48);
  transition: color 220ms ease;
}

.booking-social a:hover {
  color: var(--color-gold-light);
}

.social-icon-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(216, 189, 122, 0.25);
  border-radius: 50%;
  color: rgba(251, 247, 239, 0.5);
  transition: color 220ms ease, border-color 220ms ease, background 220ms ease;
}
.booking-social .social-icon-link:hover {
  color: var(--color-ivory);
  border-color: var(--color-gold-light);
  background: rgba(216, 189, 122, 0.1);
}

.site-footer .social-icon-link {
  border-color: rgba(43, 39, 35, 0.2);
  color: var(--color-muted);
}
.site-footer .social-icon-link:hover {
  color: var(--color-gold);
  border-color: var(--color-gold);
  background: rgba(184, 146, 75, 0.08);
}

.footer-social {
  display: flex;
  gap: 10px;
  align-items: center;
}

@media (max-width: 680px) {
  .booking-social {
    gap: 10px 18px;
  }
}

/* Testimonials Section */
.proof-section {
  background: var(--color-warm-white);
}

.testimonial-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
  margin-top: 48px;
}

.testimonial-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 260px;
  padding: clamp(28px, 4vw, 40px);
  border: 1px solid rgba(184, 146, 75, 0.24);
  border-radius: 8px;
  background: var(--color-warm-white);
  box-shadow: 0 18px 50px rgba(8, 7, 6, 0.06);
  transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
}

.testimonial-card:hover {
  border-color: rgba(184, 146, 75, 0.55);
  box-shadow: var(--shadow-soft);
  transform: translateY(-5px);
}

.testimonial-quote {
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 1.8vw, 1.22rem);
  font-style: italic;
  color: var(--color-ink);
  line-height: 1.75;
  margin: 0 0 24px 0;
  border: none;
  padding: 0;
}

.testimonial-quote::before {
  content: "\201C";
  color: var(--color-gold);
  font-size: 3rem;
  line-height: 0;
  vertical-align: -0.4em;
  margin-right: 4px;
}

.testimonial-card footer {
  display: flex;
  align-items: center;
  margin-top: 10px;
  gap: 8px;
}

.testimonial-name {
  font-family: var(--font-body);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-black);
}

.testimonial-name a {
  color: inherit;
  border-bottom: 1px solid rgba(184, 146, 75, 0.3);
  transition: border-color 220ms ease;
}

.testimonial-name a:hover {
  border-bottom-color: var(--color-gold);
}

.testimonial-title {
  display: inline;
  font-size: 0.76rem;
  color: var(--color-muted);
  letter-spacing: 0.06em;
}

.testimonial-card--practitioner {
  border-style: dashed;
  background: rgba(232, 221, 201, 0.2);
  font-style: italic;
}

.testimonial-card--practitioner .testimonial-quote {
  font-style: italic;
}

@media (max-width: 980px) {
  .testimonial-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .testimonial-grid {
    grid-template-columns: 1fr;
  }
}

/* Read More / Read Less Functionality */
.testimonial-text {
  margin: 0;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
  transition: all 350ms ease;
}

.testimonial-text.is-expanded {
  -webkit-line-clamp: unset;
  overflow: visible;
}

.read-more-btn {
  display: none; /* hidden by default — JS shows it only when needed */
  align-self: flex-start;
  margin-top: 12px;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--color-gold);
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: color 220ms ease;
}

.read-more-btn:hover {
  color: var(--color-gold-light);
}

.read-more-btn.is-visible {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.read-more-btn.is-visible::before {
  content: attr(data-label);
}

.read-more-btn.is-visible::after {
  content: "↓";
  font-size: 0.9em;
  transition: transform 220ms ease;
}

.read-more-btn[aria-expanded="true"]::after {
  transform: rotate(180deg);
}

/* Portrait Image */
.portrait-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}
