
:root{
  --porcelain:#F7F2ED; --linen:#F1E6DC; --white:#FFFDFB;
  --ink:#2A2522; --charcoal:#3A332E; --mocha:#6E625A;
  --blush:#F4D2BE; --blush-deep:#ECB695; --blush-soft:#FBEDE3;
  --terracotta:#B27355; --bronze:#A57A52; --line:#E6D8CB;
  --shadow:0 18px 50px rgba(95,70,50,.10);
  --maxw:1200px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Jost',system-ui,sans-serif;color:var(--ink);background:var(--porcelain);
  font-weight:300;line-height:1.7;font-size:17px;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.display{font-family:'Playfair Display',Georgia,serif;font-weight:400;line-height:1.12;color:var(--ink)}
em,.it{font-style:italic}
a{color:var(--terracotta);text-decoration:none;transition:color .2s,opacity .2s}
a:hover{color:var(--bronze)}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--terracotta);font-weight:400}
.lede{font-size:1.18rem;color:var(--mocha);font-weight:300}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5em;font-size:.82rem;letter-spacing:.16em;
  text-transform:uppercase;padding:16px 30px;border-radius:40px;font-weight:400;transition:.25s;cursor:pointer;border:1px solid transparent}
.btn-primary{background:var(--blush);color:var(--ink)}
.btn-primary:hover{background:var(--blush-deep);color:var(--ink);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.6)}
.btn-ghost:hover{background:rgba(255,255,255,.12);color:var(--white)}
.btn-dark{background:var(--ink);color:var(--blush-soft)}
.btn-dark:hover{background:var(--charcoal);color:var(--white)}

/* ---------- NAV ---------- */
header.site{position:sticky;top:0;z-index:60;background:rgba(247,242,237,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:18px;padding:18px 28px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:12px;font-family:'Playfair Display',serif;font-size:1.18rem;letter-spacing:.02em;color:var(--ink)}
.brand .mono{width:42px;height:42px;border-radius:50%;background:var(--blush);display:flex;align-items:center;justify-content:center;
  font-weight:600;letter-spacing:-.04em;color:var(--ink);font-size:1rem;flex:0 0 auto}
.nav-center{display:flex;align-items:center;gap:30px;justify-self:center}
.nav-center>div{position:relative}
.nav-center a.top,.nav-center .top{font-family:'Jost',sans-serif;font-weight:400;font-size:.82rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--charcoal);cursor:pointer;padding:8px 0;display:inline-block}
.nav-center a.top:hover,.nav-center .top:hover{color:var(--terracotta)}
.nav-right{justify-self:end}
.mega{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);
  background:var(--white);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);
  padding:22px;min-width:540px;opacity:0;visibility:hidden;transition:.22s;z-index:70}
.nav-center>div:hover .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 30px}
.mega-grid.three{grid-template-columns:1fr 1fr;gap:6px 30px}
.mega h5{font-family:'Jost',sans-serif;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--terracotta);margin:6px 0 8px;font-weight:500;grid-column:1/-1}
.mega a{display:block;padding:8px 10px;border-radius:8px;color:var(--charcoal);font-size:.92rem;font-weight:300}
.mega a:hover{background:var(--blush-soft);color:var(--ink)}
.hamb{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.hamb span{width:24px;height:2px;background:var(--ink);display:block;transition:.2s}
.mobile{display:none;border-top:1px solid var(--line);background:var(--white)}
.mobile.open{display:block}
.mobile a{display:block;padding:14px 28px;border-bottom:1px solid var(--line);color:var(--charcoal);
  font-size:.85rem;letter-spacing:.1em;text-transform:uppercase}
.mobile a.sub{padding-left:46px;text-transform:none;letter-spacing:0;font-size:.95rem;color:var(--mocha)}

/* ---------- HERO (photo) ---------- */
.hero{position:relative;min-height:78vh;display:flex;align-items:center;color:var(--white);overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;
  background-image:
    radial-gradient(75% 60% at 50% 46%, rgba(42,37,32,.50), rgba(42,37,32,0) 72%),
    linear-gradient(180deg, rgba(42,37,32,.55), rgba(42,37,32,.40) 40%, rgba(42,37,32,.68)),
    url('/assets/home-hero.jpg'),
    linear-gradient(135deg,#E7B79A,#C98A66 45%,#7C5135);
  background-size:cover;background-position:center}
.hero .wrap{position:relative;z-index:2;padding-top:60px;padding-bottom:60px}
.hero h1{color:var(--white);font-size:clamp(2.6rem,6vw,4.6rem);text-shadow:0 2px 24px rgba(0,0,0,.32);max-width:14ch}
.hero h1 em{color:var(--blush-soft)}
.hero .lede{color:rgba(255,255,255,.92);max-width:48ch;margin:22px 0 30px;text-shadow:0 1px 12px rgba(0,0,0,.3)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* gradient hero (concerns, hubs, sub-pages w/o photo) */
.ghero{position:relative;padding:120px 0 90px;color:var(--ink);overflow:hidden;
  background:linear-gradient(135deg,var(--blush-soft) 0%,var(--blush) 55%,var(--blush-deep) 100%)}
.ghero:before{content:"";position:absolute;inset:0;opacity:.5;
  background:radial-gradient(60% 80% at 85% 10%,rgba(255,255,255,.6),transparent 60%)}
.ghero .wrap{position:relative;z-index:2}
.ghero h1{font-size:clamp(2.3rem,5vw,3.8rem);max-width:16ch;margin:14px 0}
.ghero .lede{max-width:54ch}
.crumb{font-size:.78rem;letter-spacing:.06em;color:var(--mocha);margin-bottom:6px}
.crumb a{color:var(--mocha)} .crumb a:hover{color:var(--terracotta)}

/* ---------- SECTIONS ---------- */
section{padding:84px 0}
section.tight{padding:60px 0}
.sec-linen{background:var(--linen)}
.sec-blush{background:var(--blush-soft)}
.center{text-align:center}
.center .lede{margin-left:auto;margin-right:auto}
h2.big{font-size:clamp(2rem,4vw,3rem);margin:10px 0 18px}
.kicker{margin-bottom:40px}

/* answer-first block */
.answer{background:var(--white);border:1px solid var(--line);border-left:3px solid var(--blush-deep);
  border-radius:12px;padding:26px 30px;font-size:1.12rem;color:var(--charcoal);max-width:70ch;font-weight:300;box-shadow:var(--shadow)}

/* byline */
.byline{display:flex;align-items:center;gap:10px;font-size:.82rem;color:var(--mocha);margin:22px 0 0;font-weight:300}
.byline .dot{width:5px;height:5px;border-radius:50%;background:var(--blush-deep)}

/* trust strip */
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.trust .t b{font-family:'Playfair Display',serif;font-size:1.8rem;display:block;color:var(--ink);font-weight:400}
.trust .t span{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--mocha)}

/* numbered treatment rows */
.rows{display:flex;flex-direction:column;gap:2px;margin-top:30px}
.row{display:grid;grid-template-columns:64px 200px 1fr auto;gap:26px;align-items:center;
  padding:26px 6px;border-top:1px solid var(--line);transition:.2s}
.row:last-child{border-bottom:1px solid var(--line)}
.row:hover{background:var(--blush-soft)}
.row .num{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--blush-deep)}
.row .thumb{width:200px;height:150px;border-radius:10px;object-fit:cover;background:
  linear-gradient(135deg,var(--blush-soft),var(--blush-deep))}
.row h3{font-size:1.35rem}
.row p{color:var(--mocha);font-size:.95rem;margin-top:4px;max-width:52ch}
.row .tag{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--terracotta);
  border:1px solid var(--line);border-radius:30px;padding:6px 12px;white-space:nowrap}
.row a.rowlink{display:contents}

/* card grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:34px}
.grid.two{grid-template-columns:repeat(2,1fr)}
.card{background:var(--white);border:1px solid var(--line);border-radius:16px;overflow:hidden;
  transition:.25s;box-shadow:var(--shadow);display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px)}
.card .ct{padding:26px}
.card .cap{height:140px;background:linear-gradient(135deg,var(--blush-soft),var(--blush-deep))}
.card h3{font-size:1.3rem;margin-bottom:8px}
.card p{color:var(--mocha);font-size:.95rem}
.card .more{margin-top:14px;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--terracotta)}

/* prose */
.prose{max-width:74ch}
.prose h2{font-size:1.7rem;margin:42px 0 14px}
.prose h3{font-size:1.25rem;margin:30px 0 10px}
.prose p{margin:0 0 16px;color:var(--charcoal)}
.prose ul{margin:0 0 16px 1.1em;color:var(--charcoal)}
.prose li{margin:6px 0}
.twocol{display:grid;grid-template-columns:1.4fr 1fr;gap:50px;align-items:start}

/* FAQ (visible) */
.faq{border-top:1px solid var(--line);margin-top:40px}
.faq .q{border-bottom:1px solid var(--line);padding:24px 0}
.faq .q h4{font-family:'Jost',sans-serif;font-weight:500;font-size:1.05rem;color:var(--ink);margin-bottom:8px}
.faq .q p{color:var(--mocha);font-size:.97rem}

/* CTA band */
.cta{background:linear-gradient(135deg,var(--ink),#4a3f37);color:var(--white);text-align:center}
.cta h2{color:var(--white);font-size:clamp(1.9rem,4vw,2.8rem)}
.cta p{color:rgba(255,255,255,.85);max-width:52ch;margin:14px auto 26px}

/* pairs / related */
.pairs{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:24px}
.pair{background:var(--white);border:1px solid var(--line);border-radius:12px;padding:20px}
.pair h4{font-family:'Jost',sans-serif;font-weight:500;font-size:1rem;margin-bottom:6px}
.pair p{font-size:.86rem;color:var(--mocha)}
.related{margin-top:20px;font-size:.92rem;color:var(--mocha)}
.related a{font-weight:400}

/* visit / contact */
.visit{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.visit .map{border-radius:16px;overflow:hidden;border:1px solid var(--line);min-height:340px}
.visit .map iframe{width:100%;height:100%;min-height:340px;border:0;display:block}
.vrow{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.vrow b{font-family:'Jost',sans-serif;font-weight:500;min-width:90px;color:var(--ink)}
.vrow a,.vrow span{color:var(--mocha)}

/* quote */
.quote{text-align:center;max-width:62ch;margin:0 auto}
.quote p{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(1.4rem,3vw,2rem);
  color:var(--ink);line-height:1.4}
.quote cite{display:block;margin-top:20px;font-family:'Jost',sans-serif;font-style:normal;
  font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--terracotta)}

/* footer */
footer.site{background:var(--ink);color:rgba(255,255,255,.78);padding:64px 0 30px;font-size:.92rem;font-weight:300}
footer.site .fgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px}
footer.site h6{font-family:'Jost',sans-serif;font-weight:500;font-size:.72rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--blush);margin-bottom:14px}
footer.site a{color:rgba(255,255,255,.78);display:block;padding:5px 0}
footer.site a:hover{color:var(--white)}
footer.site .fbrand{font-family:'Playfair Display',serif;font-size:1.4rem;color:var(--white);margin-bottom:12px}
.fbar{border-top:1px solid rgba(255,255,255,.14);margin-top:44px;padding-top:22px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.78rem;color:rgba(255,255,255,.55)}
.fbar a{display:inline}
.compliance-note{font-size:.78rem;color:rgba(255,255,255,.5);max-width:60ch;margin-top:8px}

/* misc */
.disclaim{font-size:.82rem;color:var(--mocha);margin-top:18px}
.areas{font-size:.92rem;color:var(--mocha);margin-top:10px}

@media(max-width:900px){
  .nav{grid-template-columns:auto auto;}
  .nav-center{display:none}
  .nav-right .btn{padding:12px 20px}
  .hamb{display:flex}
  .twocol,.visit{grid-template-columns:1fr;gap:30px}
  .trust{grid-template-columns:repeat(2,1fr);gap:30px}
  .grid,.grid.two{grid-template-columns:1fr}
  .pairs{grid-template-columns:1fr}
  .row{grid-template-columns:40px 1fr;gap:14px;row-gap:4px}
  .row .thumb{display:none}.row .tag{display:none}
  .row .num{font-size:1.2rem}
  .hero{min-height:70vh}
  section{padding:60px 0}
}

/* ---- home hero split + quote card ---- */
.hero-split{display:grid;grid-template-columns:1.25fr .9fr;gap:46px;align-items:center}
.hero-card{background:rgba(255,253,251,.13);backdrop-filter:blur(7px);
  border:1px solid rgba(255,255,255,.32);border-radius:18px;padding:32px 34px;color:#fff;box-shadow:0 18px 50px rgba(0,0,0,.18)}
.hero-card p{font-family:'Playfair Display',serif;font-style:italic;font-size:1.28rem;line-height:1.5;color:#fff}
.hero-card .who{margin-top:18px;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--blush-soft);font-style:normal;font-family:'Jost',sans-serif}
@media(max-width:900px){.hero-split{grid-template-columns:1fr;gap:28px}.hero-card{display:none}}
/* ---- approach steps ---- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:36px}
.step .n{font-family:'Playfair Display',serif;font-size:2rem;color:var(--blush-deep)}
.step h3{font-size:1.22rem;margin:8px 0 6px}
.step p{color:var(--mocha);font-size:.96rem}
@media(max-width:900px){.steps{grid-template-columns:1fr;gap:22px}}
/* ---- about credentials ---- */
.cred{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:20px 0}
.cred .c{background:var(--white);border:1px solid var(--line);border-radius:12px;padding:16px 18px}
.cred .c b{font-family:'Jost',sans-serif;font-weight:500;display:block;color:var(--ink);font-size:.96rem;margin-bottom:2px}
.cred .c span{font-size:.88rem;color:var(--mocha)}
@media(max-width:700px){.cred{grid-template-columns:1fr}}
.ahpra-badge{display:inline-flex;gap:10px;align-items:center;background:var(--blush-soft);
  border:1px solid var(--line);border-radius:30px;padding:11px 20px;font-size:.92rem;color:var(--charcoal);margin:6px 0 4px}
.callout{background:var(--blush-soft);border:1px solid var(--line);border-left:3px solid var(--blush-deep);
  border-radius:12px;padding:22px 26px;margin:26px 0;font-size:.97rem;color:var(--charcoal)}
.subhead{margin:8px 0 0}

/* ---------- PHOTO HERO (treatment sub-pages) — scrim+gradient over photo, warm gradient fallback ---------- */
.phero{position:relative;padding:120px 0 90px;color:var(--white);overflow:hidden;
  background-image:
    radial-gradient(75% 60% at 50% 46%, rgba(42,37,32,.50), rgba(42,37,32,0) 72%),
    linear-gradient(180deg, rgba(42,37,32,.55), rgba(42,37,32,.40) 40%, rgba(42,37,32,.68)),
    var(--hero-img,none),
    linear-gradient(135deg,#E7B79A,#C98A66 45%,#7C5135);
  background-size:cover;background-position:center center}
.phero .wrap{position:relative;z-index:2}
.phero h1{color:var(--white);font-size:clamp(2.3rem,5vw,3.8rem);max-width:16ch;margin:14px 0;
  text-shadow:0 2px 20px rgba(0,0,0,.34)}
.phero .eyebrow{color:var(--blush-soft)}
.phero .crumb{color:rgba(255,255,255,.82)}
.phero .crumb a{color:rgba(255,255,255,.82)} .phero .crumb a:hover{color:#fff}

/* ---------- portrait + "Meet Jane" two-column ---------- */
.meet{display:grid;grid-template-columns:320px 1fr;gap:44px;align-items:center;margin-top:36px}
.meet .portrait{width:100%;height:auto;border-radius:18px;box-shadow:var(--shadow);border:1px solid var(--line)}
.meet .prose{max-width:none;margin:0}
@media(max-width:760px){.meet{grid-template-columns:1fr;gap:26px}.meet .portrait{max-width:360px}}

/* ---------- cookie consent banner (blush/charcoal) ---------- */
.consent{position:fixed;left:18px;right:18px;bottom:18px;z-index:200;max-width:560px;margin:0 auto;
  background:var(--white);border:1px solid var(--line);border-radius:16px;
  box-shadow:0 18px 50px rgba(95,70,50,.22);padding:20px 22px;display:flex;flex-direction:column;gap:14px}
.consent[hidden]{display:none}
.consent p{font-size:.9rem;color:var(--charcoal);font-weight:300;margin:0;line-height:1.6}
.consent a{color:var(--terracotta);text-decoration:underline}
.consent-act{display:flex;gap:10px;justify-content:flex-end}
.consent .btn{padding:11px 22px;font-size:.72rem}
.consent .consent-decline{background:transparent;color:var(--charcoal);border:1px solid var(--line)}
.consent .consent-decline:hover{background:var(--blush-soft);color:var(--ink)}
.consent .consent-accept{background:var(--blush);color:var(--ink)}
.consent .consent-accept:hover{background:var(--blush-deep)}
@media(max-width:520px){.consent-act{flex-direction:column-reverse}.consent .btn{width:100%;justify-content:center}}
