@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Jost:wght@200;300;400;500;600&display=swap');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;font-weight:300;color:#2E2E2E;background:#fff;-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.7}
img{display:block;width:100%;height:100%;object-fit:cover}
a{text-decoration:none;color:inherit}
button{font-family:'Jost',sans-serif;cursor:pointer;background:none;border:none}

:root{
  /* Brand palette — exact spec */
  --ink:     #2E2E2E;   /* Charcoal Gray — headings, buttons, bold */
  --bg-soft: #F5F5F5;   /* Warm Light Gray — backgrounds */
  --muted:   #635D58;   /* Darkened from #A3A3A3 for readability */
  --taupe:   #D6CDC4;   /* Soft Taupe — service highlights */
  --white:   #FFFFFF;   /* Pure White — main bg */
  --beige:   #EDE7E3;   /* Accent Beige/Nude — wellness accents */
  /* Gold from button screenshot */
  --gold:    #C4A46B;
  --gold-dk: #A8885A;
  --gold-lt: #D6BC8A;
  --gold-pale:#F9F4EB;
  --gold-border:#E8D8B8;
  /* Supporting */
  --border:  #D4CCBF;   /* Slightly darker for visibility */
  --serif:   'Cormorant Garamond',Georgia,serif;
  --sans:    'Jost',sans-serif;
}

/* ── PROMO BAR ── */
.promo-bar{
  background:var(--gold);color:var(--white);
  text-align:center;
  padding:.6rem 1.5rem;
  font-size:.7rem;letter-spacing:.14em;
  text-transform:uppercase;font-weight:500;
  line-height:1.5;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.promo-bar a{
  text-decoration:underline;
  margin-left:.5rem;
  opacity:.9;font-weight:600;
  white-space:nowrap;
}
@media(max-width:520px){
  .promo-bar{
    font-size:.58rem;
    letter-spacing:.08em;
    padding:.55rem 1rem;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  /* Hide arrow text, just show Learn More */
  .promo-link::after{content:''}
}
@media(max-width:400px){
  /* On very small screens hide the link entirely to keep it 1 line */
  .promo-link{display:none}
}


/* Promo bar responsive text */
.promo-short{display:none}
.promo-full{display:inline}
@media(max-width:520px){
  .promo-full{display:none}
  .promo-short{display:inline}
}

/* ── NAV ── */
.site-nav{
  position:sticky;top:0;z-index:999;height:72px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 5vw;background:rgba(255,255,255,.97);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--border);
  transition:box-shadow .3s
}
.site-nav.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.07)}
.nav-logo{display:flex;flex-direction:column;gap:1px}
.nav-logo-main{font-family:var(--serif);font-size:1.22rem;color:var(--ink);letter-spacing:.02em;line-height:1;font-weight:400}
.nav-logo-main span{color:var(--gold)}
.nav-logo-sub{font-size:.54rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted-lt, #A3A3A3);font-weight:400}
.nav-links{display:flex;align-items:center;gap:2.2rem;list-style:none}
.nav-links a{
  font-size:.71rem;font-weight:400;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);transition:color .2s;
  position:relative;padding-bottom:2px
}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--gold);transition:width .25s}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
/* Book Online button — matches screenshot exactly */
.nav-book{
  background:var(--gold);
  color:var(--white);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.65rem 1.6rem;
  font-family:var(--sans);
  font-size:.71rem;
  font-weight:500;
  letter-spacing:.14em;
  text-transform:uppercase;
  line-height:1;
  white-space:nowrap;
  transition:background .2s;
  flex-shrink:0;
}
.nav-book:hover{background:var(--gold-dk)}

.nav-ham{display:none;flex-direction:column;gap:5px;padding:4px}
.nav-ham span{display:block;width:22px;height:1.5px;background:var(--ink);transition:.3s}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--sans);font-size:.72rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  padding:.85rem 2rem;transition:all .25s;cursor:pointer;border:none
}
.btn-gold{background:var(--gold);color:var(--white)}
.btn-gold:hover{background:var(--gold-dk)}
.btn-dark{background:var(--ink);color:var(--white)}
.btn-dark:hover{background:var(--gold);color:var(--white)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--white)}
.btn-outline-gold{background:transparent;color:var(--gold);border:1.5px solid var(--gold)}
.btn-outline-gold:hover{background:var(--gold);color:var(--white)}

/* ── HERO ── */
.hero{position:relative;height:100svh;min-height:640px;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img{object-position:center top}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(170deg,rgba(46,46,46,.02) 0%,rgba(46,46,46,.22) 40%,rgba(46,46,46,.72) 100%)}
.hero-body{position:relative;z-index:2;padding:0 7vw 10vh;max-width:780px}
.hero-tag{
  display:inline-flex;align-items:center;gap:.8rem;
  font-size:.67rem;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(255,255,255,.85);font-weight:400;margin-bottom:1.4rem
}
.hero-tag::before{content:'';width:28px;height:1px;background:var(--gold-lt)}
.hero h1{font-family:var(--serif);font-size:clamp(3.2rem,8vw,6rem);color:#fff;line-height:1.02;font-weight:300;margin-bottom:1.2rem}
.hero h1 em{font-style:italic;color:var(--gold-lt)}
.hero-desc{font-size:.92rem;color:rgba(255,255,255,.68);line-height:1.85;max-width:440px;margin-bottom:2.5rem;font-weight:300}
.hero-btns{display:flex;gap:.85rem;flex-wrap:wrap}

/* ── TICKER ── */
.ticker{background:var(--ink);overflow:hidden;padding:.75rem 0;white-space:nowrap}
.ticker-inner{display:inline-flex;animation:scroll 28s linear infinite}
.ticker-inner span{font-family:var(--serif);font-size:.82rem;font-style:italic;color:var(--gold-lt);padding:0 2.2rem;letter-spacing:.06em}
.ticker-inner span::after{content:'·';margin-left:2.2rem;color:#555;font-style:normal}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── SECTION LAYOUT ── */
.sec{padding:88px 7vw}
.sec.bg-soft{background:var(--bg-soft)}
.sec.bg-beige{background:var(--beige)}
.sec.bg-taupe{background:var(--taupe)}
.sec.bg-dark{background:var(--ink)}
.wrap{max-width:1180px;margin:0 auto}

/* ── EYEBROW + HEADING ── */
.eyebrow{
  display:flex;align-items:center;gap:.65rem;
  font-size:.63rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:.7rem
}
.eyebrow::before{content:'';width:20px;height:1px;background:var(--gold);flex-shrink:0}
.eyebrow.c{justify-content:center}
.eyebrow.c::before{display:none}
.eyebrow.light{color:rgba(255,255,255,.6)}
.eyebrow.light::before{background:rgba(255,255,255,.4)}
h2.title{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);font-weight:300;line-height:1.1;letter-spacing:.01em;color:var(--ink)}
h2.title em{font-style:italic}
h2.title.light{color:#fff}
.body-text{font-size:.9rem;color:var(--muted);line-height:1.88;max-width:520px;font-weight:400}
.body-text.light{color:rgba(255,255,255,.55);max-width:100%}

/* ── SERVICE GRID (homepage tiles) ── */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--border);margin-top:3rem}
.svc-tile{padding:2.5rem 1.75rem;border-right:1px solid var(--border);display:flex;flex-direction:column;position:relative;overflow:hidden;transition:background .3s;cursor:pointer;background:var(--white)}
.svc-tile:last-child{border-right:none}
.svc-tile::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--gold);transition:width .4s ease}
.svc-tile:hover{background:var(--gold-pale)}
.svc-tile:hover::after{width:100%}
.svc-num{font-family:var(--serif);font-size:2.6rem;color:var(--border);line-height:1;margin-bottom:1.25rem;font-weight:300}
.svc-tile h3{font-family:var(--serif);font-size:1.15rem;font-weight:400;line-height:1.3;margin-bottom:.6rem;color:var(--ink)}
.svc-tile p{font-size:.82rem;color:var(--muted);line-height:1.75;flex:1;font-weight:300}
.svc-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.66rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-top:1.4rem;transition:gap .2s}
.svc-tile:hover .svc-link{gap:.7rem}

/* ── SPLIT SECTION ── */
.split{display:grid;grid-template-columns:1fr 1fr;min-height:520px}
.split.flip{direction:rtl}
.split.flip>*{direction:ltr}
.split-img{overflow:hidden}
.split-img img{transition:transform .9s ease;height:100%}
.split-img:hover img{transform:scale(1.04)}
.split-text{display:flex;flex-direction:column;justify-content:center;padding:4.5rem 5.5vw}
.split-text.soft{background:var(--bg-soft)}
.split-text.beige{background:var(--beige)}
.split-text.taupe{background:var(--taupe)}
.split-text.dark{background:var(--ink)}
.split-text p{margin-top:1rem}
.split-text .btn{margin-top:2rem;align-self:flex-start}

/* ── STEPS ── */
.steps{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--border);margin-top:3rem;background:var(--white)}
.step{padding:2.75rem 2.25rem;border-right:1px solid var(--border)}
.step:last-child{border-right:none}
.step-n{font-family:var(--serif);font-size:4rem;color:var(--border);line-height:1;margin-bottom:1.1rem;font-weight:300}
.step h3{font-family:var(--serif);font-size:1.1rem;font-weight:400;margin-bottom:.55rem;color:var(--ink)}
.step p{font-size:.87rem;color:var(--ink);line-height:1.8;font-weight:300;opacity:.75}

/* ── PLAN CARDS ── */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.plan{background:var(--white);border:1px solid var(--border);padding:2.5rem 2rem;display:flex;flex-direction:column;position:relative;transition:transform .3s,box-shadow .3s}
.plan:hover{transform:translateY(-3px);box-shadow:0 16px 50px rgba(0,0,0,.07)}
.plan.star{background:var(--ink);border-color:var(--ink)}
.plan-badge{position:absolute;top:0;right:2rem;font-size:.58rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;padding:.28rem .85rem;border-radius:0 0 4px 4px;background:var(--gold);color:var(--white)}
.plan-name{font-family:var(--serif);font-size:1.35rem;font-weight:400;margin-bottom:.4rem;color:var(--ink)}
.plan.star .plan-name{color:var(--white)}
.plan-price{display:flex;align-items:baseline;gap:.25rem;margin-bottom:1.1rem}
.plan-amt{font-family:var(--serif);font-size:2.8rem;line-height:1;color:var(--gold);font-weight:300}
.plan-per{font-size:.78rem;color:var(--muted);font-weight:300}
.plan.star .plan-per{color:rgba(255,255,255,.45)}
.plan hr{border:none;border-top:1px solid var(--border);margin-bottom:1.1rem}
.plan.star hr{border-color:rgba(255,255,255,.1)}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:.6rem;flex:1}
.plan ul li{font-size:.84rem;display:flex;gap:.55rem;align-items:flex-start;font-weight:400;color:var(--ink)}
.plan ul li::before{content:'—';color:var(--gold);flex-shrink:0}
.plan.star ul li{color:rgba(255,255,255,.7)}
.plan-cta{margin-top:1.75rem}

/* ── REFERRAL CARDS ── */
.referral-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}
.ref-card{background:var(--white);border:1px solid var(--border);padding:2.25rem 2rem;position:relative;overflow:hidden}
.ref-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--gold)}
.ref-num{font-family:var(--serif);font-size:3.5rem;color:var(--border);line-height:1;margin-bottom:.9rem;font-weight:300}
.ref-card h3{font-family:var(--serif);font-size:1.1rem;font-weight:400;margin-bottom:.5rem;color:var(--ink)}
.ref-card p{font-size:.84rem;color:var(--muted);line-height:1.78;font-weight:300}
.ref-reward{display:inline-flex;align-items:center;gap:.5rem;background:var(--gold-pale);border:1px solid var(--gold-border);padding:.38rem .9rem;border-radius:100px;font-size:.73rem;font-weight:600;color:var(--gold-dk);margin-top:.85rem}

/* ── REVIEWS ── */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.review{background:var(--beige);border:1px solid var(--border);padding:2rem 1.75rem}
.review-stars{font-size:.76rem;color:var(--gold);letter-spacing:3px;margin-bottom:1rem}
.review blockquote{font-family:var(--serif);font-size:1.02rem;font-style:italic;color:var(--ink);line-height:1.72;margin-bottom:1rem;font-weight:300}
.review cite{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* ── FAQ ── */
.faqs{max-width:680px;margin-top:2.75rem}
.faq{border-bottom:1px solid var(--border)}
.faq-btn{width:100%;text-align:left;padding:1.15rem 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;font-size:.9rem;font-weight:400;color:var(--ink);background:none;border:none;cursor:pointer;font-family:var(--sans)}
.faq-icon{width:20px;height:20px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.78rem;color:var(--muted);flex-shrink:0;transition:.25s}
.faq.open .faq-icon{background:var(--gold);border-color:var(--gold);color:var(--white);transform:rotate(45deg)}
.faq-ans{font-size:.86rem;color:var(--muted);line-height:1.85;max-height:0;overflow:hidden;transition:max-height .35s ease,padding .3s;font-weight:300}
.faq.open .faq-ans{max-height:300px;padding-bottom:1.2rem}

/* ── CTA BAND ── */
.cta-band{background:var(--gold);padding:5.5rem 7vw;text-align:center}
.cta-band h2{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);color:var(--white);font-weight:300;margin-bottom:.85rem}
.cta-band p{font-size:.9rem;color:rgba(255,255,255,.85);max-width:380px;margin:0 auto 2.25rem;line-height:1.8;font-weight:300}

/* ── SERVICES PAGE — full detail cards ── */
.services-page-hero{background:var(--bg-soft);padding:7rem 7vw 4.5rem;border-bottom:1px solid var(--border)}
.services-page-hero h1{font-family:var(--serif);font-size:clamp(2.8rem,6vw,5rem);color:var(--ink);font-weight:300;line-height:1.05;margin-top:.7rem}
.services-page-hero p{color:var(--muted);font-size:.92rem;max-width:520px;margin-top:.9rem;line-height:1.8;font-weight:300}

/* Service category header */
.svc-cat-header{
  padding:3.5rem 7vw 0;
  max-width:calc(1180px + 14vw);margin:0 auto
}
.svc-cat-title{
  font-family:var(--serif);font-size:clamp(1.5rem,3vw,2.2rem);
  font-weight:300;color:var(--ink);padding-bottom:1rem;
  border-bottom:2px solid var(--taupe);margin-bottom:0
}
.svc-cat-sub{font-size:.8rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-top:.35rem}

/* Service detail cards grid */
.svc-detail-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:1px;background:var(--border);
  margin:0 7vw 0
}
.svc-detail-card{
  background:var(--white);padding:2.25rem 2rem;
  display:flex;flex-direction:column;gap:.6rem;
  transition:background .25s
}
.svc-detail-card:hover{background:var(--gold-pale)}
.svc-card-name{font-family:var(--serif);font-size:1.2rem;font-weight:400;color:var(--ink);line-height:1.25}
.svc-card-sub{font-size:.76rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}
.svc-card-desc{font-size:.84rem;color:var(--muted);line-height:1.8;font-weight:300;flex:1}
.svc-card-bullets{list-style:none;display:flex;flex-direction:column;gap:.35rem;margin-top:.25rem}
.svc-card-bullets li{font-size:.82rem;color:var(--muted);display:flex;gap:.5rem;align-items:flex-start;font-weight:300}
.svc-card-bullets li::before{content:'·';color:var(--gold);font-size:1rem;flex-shrink:0;line-height:1.4}
.svc-card-meta{display:flex;align-items:center;gap:1rem;margin-top:.5rem;padding-top:.75rem;border-top:1px solid var(--border)}
.svc-card-time{font-size:.72rem;color:var(--muted);letter-spacing:.06em}
.svc-card-price{font-family:var(--serif);font-size:1.2rem;color:var(--ink);font-weight:400;margin-left:auto}
.svc-card-book{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.66rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold);margin-top:.25rem;transition:gap .2s
}
.svc-detail-card:hover .svc-card-book{gap:.65rem}

/* Section spacer */
.svc-section-spacer{height:3.5rem}
.svc-section-bottom-border{border-bottom:1px solid var(--border);margin:0 7vw 3.5rem}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:5rem;align-items:start;margin-top:3rem}
.contact-info h3{font-family:var(--serif);font-size:1.2rem;font-weight:400;margin-bottom:1.6rem;color:var(--ink)}
.ci{display:flex;gap:.85rem;align-items:flex-start;margin-bottom:1.3rem}
.ci-icon{width:36px;height:36px;border:1px solid var(--gold-border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:.76rem;flex-shrink:0}
.ci strong{display:block;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:2px}
.ci span,.ci a{font-size:.87rem;color:var(--ink)}
.map{margin-top:1.5rem;border:1px solid var(--border);overflow:hidden}
.map iframe{display:block;width:100%;height:200px;border:none}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}
.field{margin-bottom:1rem}
.field label{display:block;font-size:.62rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem}
.field input,.field textarea,.field select{
  width:100%;padding:.8rem 1rem;background:var(--white);border:1px solid var(--border);
  font-family:var(--sans);font-size:.86rem;font-weight:300;color:var(--ink);
  outline:none;transition:border-color .2s;appearance:none
}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--gold)}
.field textarea{resize:vertical;min-height:108px}
.form-note{font-size:.71rem;color:var(--muted);line-height:1.65;margin-bottom:1.1rem}
.form-note a{color:var(--gold);text-decoration:underline}


/* ── CLEAN TYPOGRAPHIC PAGE HEADER (replaces image headers) ── */
.page-header{
  background:var(--white);
  padding:5.5rem 7vw 4rem;
  border-bottom:2px solid var(--border);
  position:relative;
}
.page-header::after{
  content:'';
  position:absolute;
  bottom:-2px;left:7vw;
  width:60px;height:2px;
  background:var(--gold);
}
.page-header .eyebrow{margin-bottom:1rem}
.page-header h1{
  font-family:var(--serif);
  font-size:clamp(2.8rem,6vw,4.8rem);
  color:var(--ink);font-weight:300;
  line-height:1.05;
}
.page-header h1 em{font-style:italic;color:var(--gold-dk)}
.page-header p{
  color:var(--muted);font-size:.92rem;
  max-width:560px;margin-top:1rem;
  line-height:1.8;font-weight:400;
}
.page-header-meta{
  display:flex;gap:2.5rem;flex-wrap:wrap;
  margin-top:2rem;padding-top:2rem;
  border-top:1px solid var(--border);
}
.page-header-meta span{
  font-size:.72rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted-lt)
}
.page-header-meta span strong{
  display:block;color:var(--ink);
  font-size:.82rem;letter-spacing:0;
  text-transform:none;font-weight:500;margin-bottom:1px;
}

/* ── ABOUT HERO (kept for main homepage-style pages only) ── */
.about-hero{height:55vh;min-height:400px;position:relative;overflow:hidden;display:flex;align-items:flex-end}
.about-hero-bg{position:absolute;inset:0}
.about-hero-bg img{object-position:center 20%}
.about-hero-mask{position:absolute;inset:0;background:linear-gradient(to top,rgba(46,46,46,.7) 0%,rgba(46,46,46,.05) 65%)}
.about-hero-body{position:relative;z-index:2;padding:0 7vw 4.5rem}
.about-hero-body h1{font-family:var(--serif);font-size:clamp(2.8rem,6vw,5rem);color:var(--white);font-weight:300;line-height:1.05;margin-top:.7rem}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:3rem}
.val{border:1px solid var(--border);padding:2.25rem 1.75rem;background:var(--white)}
.val-icon{width:38px;height:38px;border:1px solid var(--gold-border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:.82rem;margin-bottom:1.1rem}
.val h3{font-family:var(--serif);font-size:1.1rem;font-weight:400;margin-bottom:.5rem;color:var(--ink)}
.val p{font-size:.82rem;color:var(--muted);line-height:1.8;font-weight:300}

/* ── BOOK PAGE ── */
.book-header{background:var(--bg-soft);padding:4.5rem 7vw 3.5rem;text-align:center;border-bottom:1px solid var(--border)}
.book-header h1{font-family:var(--serif);font-size:clamp(2.4rem,5vw,4rem);color:var(--ink);font-weight:300;margin-bottom:.7rem}
.book-header p{font-size:.9rem;color:var(--muted);max-width:400px;margin:0 auto}
.book-meta{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.25rem 2rem;
  margin-top:2rem;
  padding-top:2rem;
  border-top:1px solid var(--border);
  max-width:560px;
  margin-left:auto;
  margin-right:auto;
  text-align:left;
}
@media(max-width:520px){
  .book-meta{
    grid-template-columns:1fr;
    gap:1rem;
    text-align:left;
  }
}
.book-meta-item strong{display:block;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:3px;font-weight:500}
.book-meta-item span{font-size:.83rem;color:var(--muted)}
.book-bg{background:var(--beige);padding:2.5rem 5vw 5rem}
.book-note{max-width:680px;margin:0 auto 1.25rem;text-align:center;font-size:.72rem;color:var(--muted);line-height:1.65;padding:.65rem 1.25rem;background:rgba(196,164,107,.07);border:1px solid var(--gold-border)}
.book-note a{color:var(--gold);text-decoration:underline}
.book-box{max-width:1100px;margin:0 auto;background:var(--white);box-shadow:0 2px 30px rgba(0,0,0,.06);overflow:hidden;border:1px solid var(--border)}
.book-cta-card{min-height:460px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1.5rem;padding:4rem 2rem;text-align:center;background:var(--white)}
.book-fallback{text-align:center;padding:2rem;background:var(--white);border-top:1px solid var(--border);font-size:.84rem;color:var(--muted)}
.book-fallback a{color:var(--gold);font-weight:500}

/* ── PLANS PAGE ── */
.pg-hero{background:var(--bg-soft);padding:7rem 7vw 4.5rem;border-bottom:1px solid var(--border)}
.pg-hero h1{font-family:var(--serif);font-size:clamp(2.8rem,6vw,5rem);color:var(--ink);font-weight:300;line-height:1.05;margin-top:.7rem}
.pg-hero p{color:var(--muted);font-size:.92rem;max-width:460px;margin-top:.9rem;line-height:1.8;font-weight:300}

/* Cherry */
.cherry-section{padding-top:0}
.cherry-heading{text-align:center;max-width:460px;margin:0 auto 2rem}

/* Comparison table */
.cmp-wrap{overflow-x:auto;margin-top:3rem}
.cmp-table{width:100%;border-collapse:collapse;font-size:.84rem}
.cmp-table th{padding:.85rem 1.15rem;text-align:center;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--muted);border-bottom:2px solid var(--border)}
.cmp-table th:first-child{text-align:left}
.cmp-table td{padding:.85rem 1.15rem;border-bottom:1px solid var(--border);text-align:center}
.cmp-table td:first-child{text-align:left;font-size:.82rem;color:var(--muted);font-weight:300}
.cmp-table tr:hover td{background:rgba(196,164,107,.04)}
.ck{color:#1a7a40;font-size:1rem;font-weight:600}
.da{color:var(--border)}
.fc{background:rgba(196,164,107,.05)}
.pcell{font-family:var(--serif);font-size:1.4rem;color:var(--gold);font-weight:300}
.pcell small{font-family:var(--sans);font-size:.66rem;color:var(--muted);display:block;font-weight:300}

/* ── LEGAL PAGES ── */
.legal-hero{background:var(--bg-soft);padding:6.5rem 7vw 4rem;border-bottom:1px solid var(--border)}
.legal-hero h1{font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.8rem);color:var(--ink);font-weight:300}
.legal-hero p{font-size:.82rem;color:var(--muted);margin-top:.5rem}
.legal-body{max-width:740px;margin:0 auto;padding:4.5rem 7vw 6.5rem}
.legal-date{display:inline-block;background:var(--gold-pale);border:1px solid var(--gold-border);border-radius:100px;padding:.27rem 1rem;font-size:.7rem;font-weight:600;letter-spacing:.1em;color:var(--gold);margin-bottom:2.25rem}
.legal-body h2{font-family:var(--serif);font-size:1.35rem;font-weight:400;margin:2.25rem 0 .65rem;padding-bottom:.45rem;border-bottom:1px solid var(--border);color:var(--ink)}
.legal-body h3{font-size:.88rem;font-weight:600;margin:1.3rem 0 .35rem;color:var(--ink)}
.legal-body p,.legal-body li{font-size:.86rem;color:var(--muted);line-height:1.9;margin-bottom:.65rem;font-weight:300}
.legal-body ul{padding-left:1.4rem}
.legal-body a{color:var(--gold);text-decoration:underline}
.hipaa-box{background:var(--gold-pale);border-left:3px solid var(--gold);padding:1.4rem 1.6rem;margin-bottom:1.75rem;font-size:.83rem;color:var(--ink);line-height:1.75;border-radius:0 4px 4px 0}

/* ── SUCCESS ── */
.success{min-height:68vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:4rem 7vw}
.success-icon{width:60px;height:60px;border:1px solid var(--gold-border);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.4rem;font-size:1.3rem;color:var(--gold);background:var(--gold-pale)}

/* ── FOOTER ── */
.site-footer{background:var(--ink);padding:5rem 7vw 2.5rem}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:2.25rem}
.footer-logo{font-family:var(--serif);font-size:1.15rem;color:var(--white);margin-bottom:.9rem;font-weight:400}
.footer-logo span{color:var(--gold)}
.footer-tagline{font-size:.8rem;color:rgba(255,255,255,.55);line-height:1.75;max-width:210px;font-weight:300}
.footer-social{display:flex;gap:.5rem;margin-top:1.5rem}
.footer-social a{width:32px;height:32px;border:1px solid rgba(255,255,255,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:rgba(255,255,255,.35);transition:.2s}
.footer-social a:hover{border-color:var(--gold);color:var(--gold)}
.footer-col-title{font-size:.61rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,.85);margin-bottom:1.1rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.footer-col ul a{font-size:.8rem;color:rgba(255,255,255,.55);transition:.2s;font-weight:300}
.footer-col ul a:hover{color:var(--gold)}
.footer-col address{font-style:normal;font-size:.8rem;color:rgba(255,255,255,.55);line-height:1.9;font-weight:300}
.footer-col address a{color:rgba(255,255,255,.55);transition:.2s}
.footer-col address a:hover{color:var(--gold)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;font-size:.72rem;color:rgba(255,255,255,.45)}
.footer-bottom a{color:rgba(255,255,255,.45);transition:.2s}
.footer-bottom a:hover{color:var(--gold)}
.footer-medical{text-align:center;font-size:.66rem;color:rgba(255,255,255,.18);line-height:1.8;margin-top:1.4rem;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.05)}
.footer-medical a{color:rgba(255,255,255,.25);text-decoration:underline}

/* ── PHOTO STRIP ── */
.strip{display:grid;grid-template-columns:repeat(4,1fr);height:320px}
.strip div{overflow:hidden}
.strip div img{transition:transform .8s ease}
.strip div:hover img{transform:scale(1.06)}

/* ── SCROLL REVEAL ── */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease}
.reveal.on{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}


/* ══════════════════════════════════════
   SERVICES PAGE — full detail cards
══════════════════════════════════════ */









/* ── CATEGORY IMAGE — sits in header row alongside title ── */
.cat-sep{padding:3.5rem 7vw 0}
.cat-sep-inner{
  border-top:2px solid var(--taupe);
  padding-top:0;
  display:grid;
  grid-template-columns:1fr 340px;
  align-items:stretch;
  max-width:1180px;margin:0 auto;
  overflow:hidden;
}
.cat-sep-text{
  padding:2rem 2.5rem 2rem 0;
  display:flex;flex-direction:column;justify-content:center;gap:.4rem;
}


@media(max-width:900px){
  .cat-sep-inner{grid-template-columns:1fr;grid-template-rows:auto}
  
  .cat-sep-text{padding:1.75rem 0 1.25rem}
}

/* Category separator — now handled above in cat-img block */
.cat-sep-inner-legacy{
  border-top:2px solid var(--taupe);
  padding-top:2.5rem;
  display:flex;align-items:baseline;gap:1.5rem;flex-wrap:wrap;
  max-width:1180px;margin:0 auto
}
.cat-name{
  font-family:var(--serif);
  font-size:clamp(1.6rem,3vw,2.2rem);
  font-weight:300;color:var(--ink)
}
.cat-brand{
  font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted);font-weight:400
}

/* Cards grid */
.cards-wrap{padding:1.5rem 7vw 0;max-width:calc(1180px + 14vw);margin:0 auto}
.cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--border);
  align-items:stretch;
}



.card{
  background:var(--white);padding:2.25rem 2rem;
  display:flex;flex-direction:column;gap:.55rem;
  transition:background .25s
}
.card:hover{background:var(--gold-pale)}
.card-name{
  font-family:var(--serif);font-size:1.22rem;
  font-weight:400;color:var(--ink);line-height:1.25
}
.card-tagline{
  font-size:.75rem;font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;color:var(--gold)
}
.card-desc{
  font-size:.86rem;color:var(--muted);
  line-height:1.8;font-weight:400;flex:1;margin-top:.1rem
}
.card-bullets{
  list-style:none;display:flex;flex-direction:column;
  gap:.35rem;margin-top:.25rem
}
.card-bullets li{
  font-size:.84rem;color:var(--muted);
  display:flex;gap:.5rem;align-items:flex-start;font-weight:400
}
.card-bullets li::before{
  content:'·';color:var(--gold);
  font-size:1.1rem;flex-shrink:0;line-height:1.35
}
.card-footer{
  display:flex;align-items:center;gap:1rem;
  margin-top:.85rem;padding-top:.85rem;
  border-top:1px solid var(--border)
}
.card-time{
  font-size:.72rem;color:var(--muted);
  letter-spacing:.06em;display:flex;align-items:center;gap:.35rem
}
.card-time::before{content:'◷';font-size:.8rem;color:var(--taupe)}
.card-price{
  font-family:var(--serif);font-size:1.22rem;
  color:var(--ink);font-weight:400;margin-left:auto
}
.card-price small{
  font-family:var(--sans);font-size:.65rem;
  color:var(--muted);font-weight:300
}
.card-book{
  font-size:.66rem;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:var(--gold);
  display:flex;align-items:center;gap:.35rem;transition:gap .2s
}
.card:hover .card-book{gap:.55rem}

/* Bottom consultation note */
.consult-note{
  background:var(--bg-soft);
  padding:3.5rem 7vw;
  text-align:center;
  border-top:1px solid var(--border);
  margin-top:3.5rem
}
.consult-note p{
  font-size:.9rem;color:var(--muted);
  margin-bottom:1.25rem;max-width:480px;
  margin-left:auto;margin-right:auto;line-height:1.8;font-weight:400
}
















/* ── SERVICE CARD GRID VARIANTS ── */
.cards-1{
  grid-template-columns:1fr;
  max-width:520px;   /* single card: readable width, not full viewport */
}
.cards-2{
  grid-template-columns:1fr 1fr;
}
/* responsive */
@media(max-width:900px){
  .cards,.cards-2{grid-template-columns:1fr 1fr}
  .cards-1{grid-template-columns:1fr;max-width:100%}
}
@media(max-width:600px){
  .cards,.cards-1,.cards-2{grid-template-columns:1fr}
}



/* About page mission + oversight grids */
.about-mission-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:5rem;
  align-items:center;
}
@media(max-width:900px){
  .about-mission-grid{
    grid-template-columns:1fr;
    gap:2.5rem;
  }
}

/* ── MOBILE FIXES ── */

/* 1. Promo bar — prevent Learn More wrapping to new line */
.promo-bar{
  font-size:.62rem;
  padding:.55rem 1rem;
  line-height:1.4;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
@media(max-width:480px){
  .promo-bar{
    font-size:.6rem;
    letter-spacing:.08em;
    white-space:normal;
    display:flex;
    align-items:center;
    justify-content:center;
    flex-wrap:nowrap;
    gap:.3rem;
  }
  .promo-bar a{
    margin-left:.25rem;
    white-space:nowrap;
    flex-shrink:0;
  }
}

/* 2. About page mission — stack to single column on mobile */

@media(max-width:768px){
  .sec{padding:60px 5vw}
  .svc-grid{grid-template-columns:1fr}
  .nav-links{display:none;position:fixed;top:72px;left:0;right:0;background:var(--white);flex-direction:column;padding:1.75rem 5vw;gap:1.4rem;border-bottom:1px solid var(--border);z-index:998}
  .nav-links.open{display:flex}
  .nav-ham{display:flex}
  .field-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .book-meta{
    grid-template-columns:1fr;
    gap:1rem;
    max-width:100%;
    text-align:center;
  }
  .book-meta-item strong{text-align:center}
  .services-page-hero{padding:5rem 5vw 3rem}
  .pg-hero{padding:5rem 5vw 3rem}
  /* Contact grid stack */
  .contact-grid{grid-template-columns:1fr;gap:2rem}
  /* Dark section quote box — fix word wrapping */
  .sec.bg-dark p[style]{
    font-size:1.1rem !important;
    line-height:1.65 !important;
    word-break:normal !important;
    hyphens:none !important;
  }
  /* Page header on mobile */
  .page-header{padding:4rem 5vw 2.5rem}
  .page-header h1{font-size:clamp(2rem,10vw,3rem)}
  /* Split sections stack */
  .split{grid-template-columns:1fr}
  .split.flip{direction:ltr}
  .split-img{height:260px}
  .split-text{padding:2.5rem 5vw}
  /* Values grid */
  .values{grid-template-columns:1fr}
  /* Referral grid */
  .referral-grid{grid-template-columns:1fr}
  /* Plans */
  .plans{grid-template-columns:1fr;max-width:100%}
  /* Reviews */
  .reviews{grid-template-columns:1fr}
  /* Steps */
  .steps{grid-template-columns:1fr}
  .step{border-right:none;border-bottom:1px solid var(--border)}
  .step:last-child{border-bottom:none}
  /* Cards wrap padding */
  .cards-wrap{padding-left:0;padding-right:0}
  .cat-sep{padding:3rem 5vw 0}
}



/* Book page mobile */
@media(max-width:600px){
  .book-header{padding:3rem 5vw 2.5rem}
  .book-header h1{font-size:clamp(1.8rem,8vw,3rem);text-align:center}
  .book-header p{text-align:center}
  .book-br{display:block}
  .book-bg{padding:1.5rem 4vw 3rem}
  .book-note{font-size:.68rem}
}
@media(min-width:601px){
  .book-br{display:none}
}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;min-height:auto}
  .split.flip{direction:ltr}
  .split-img{height:320px}
  .split-text{padding:3.5rem 7vw}
  .steps{grid-template-columns:1fr}
  .step{border-right:none;border-bottom:1px solid var(--border)}
  .step:last-child{border-bottom:none}
  .plans{grid-template-columns:1fr;max-width:400px}
  .referral-grid{grid-template-columns:1fr}
  .reviews{grid-template-columns:1fr;max-width:440px}
  .contact-grid{grid-template-columns:1fr;gap:2.5rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .strip{grid-template-columns:1fr 1fr;height:240px}
  .values{grid-template-columns:1fr}
  .svc-detail-grid{grid-template-columns:1fr;margin:0 0}
  .svc-cat-header{padding:3rem 5vw 0}
  .svc-section-bottom-border{margin:0 0 3rem}
}
@media(max-width:680px){
  .cards{grid-template-columns:1fr}
}
@media(max-width:768px){
  .sec{padding:60px 5vw}
  .svc-grid{grid-template-columns:1fr}
  .nav-links{display:none;position:fixed;top:72px;left:0;right:0;background:var(--white);flex-direction:column;padding:1.75rem 5vw;gap:1.4rem;border-bottom:1px solid var(--border);z-index:998}
  .nav-links.open{display:flex}
  .nav-ham{display:flex}
  .field-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .book-meta{
    grid-template-columns:1fr;
    gap:1rem;
    max-width:100%;
    text-align:center;
  }
  .book-meta-item strong{text-align:center}
  .services-page-hero{padding:5rem 5vw 3rem}
  .pg-hero{padding:5rem 5vw 3rem}
}
