/* ==========================================================================
   Connecting Couples · Cassandra Monroe, LCSW, LCADC
   Design system / shared stylesheet
   Aesthetic: warm, grounded, editorial calm. Sage + clay + ivory.
   Type: Fraunces (display serif) + Hanken Grotesk (humanist sans)
   ========================================================================== */

/* ----- Design tokens ----- */
:root{
  /* surfaces */
  --cream:#F7F3EA;
  --cream-2:#FBF8F1;
  --sand:#EFE7D8;
  --paper:#FFFFFF;

  /* ink */
  --ink:#23322B;
  --ink-2:#3C4A41;
  --ink-3:#5B6760;

  /* sage (primary brand) */
  --sage:#5E7D6B;
  --sage-deep:#42594C;
  --sage-soft:#8FA897;
  --sage-mist:#DDE7E0;

  /* clay (warm accent / CTA) */
  --clay:#B4663F;
  --clay-deep:#9A5230;
  --clay-soft:#E7CBB7;

  /* lines */
  --line:#E4DAC9;
  --line-2:#D6CBB7;

  /* type */
  --serif:"Fraunces", Georgia, "Times New Roman", serif;
  --sans:"Hanken Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  /* fluid type scale */
  --fs-eyebrow:.78rem;
  --fs-body:1.0625rem;
  --fs-lead:clamp(1.15rem,.9rem + .9vw,1.4rem);
  --fs-h4:clamp(1.1rem,1rem + .5vw,1.3rem);
  --fs-h3:clamp(1.35rem,1.1rem + 1vw,1.75rem);
  --fs-h2:clamp(1.9rem,1.4rem + 2.4vw,3.1rem);
  --fs-h1:clamp(2.5rem,1.6rem + 4.2vw,4.75rem);

  /* spacing & shape */
  --container:1180px;
  --container-narrow:760px;
  --gap:clamp(1.5rem,1rem + 2vw,2.75rem);
  --section-y:clamp(4.25rem,3rem + 5vw,7.5rem);
  --radius-s:10px;
  --radius:18px;
  --radius-l:28px;

  /* shadow */
  --shadow-s:0 1px 2px rgba(38,46,40,.06), 0 4px 12px rgba(38,46,40,.05);
  --shadow:0 6px 18px rgba(45,58,49,.07), 0 22px 48px rgba(45,58,49,.08);
  --shadow-l:0 14px 30px rgba(45,58,49,.10), 0 40px 80px rgba(45,58,49,.12);

  /* motion */
  --ease:cubic-bezier(.4,0,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

/* ----- Reset / base ----- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--sans);
  font-size:var(--fs-body);
  line-height:1.7;
  color:var(--ink-2);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  position:relative;
}
img,svg,picture{display:block;max-width:100%}
img{height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{list-style:none;padding:0}
:focus-visible{outline:2.5px solid var(--clay-deep);outline-offset:3px;border-radius:4px}

.skip-link{position:absolute;left:1rem;top:-60px;z-index:200;background:var(--ink);color:#fff;padding:.7rem 1.1rem;border-radius:10px;font-weight:600;transition:top .25s var(--ease)}
.skip-link:focus{top:1rem}

/* subtle film-grain texture across the whole page for warmth */
body::after{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}

/* ----- Typography ----- */
h1,h2,h3,h4{font-family:var(--serif);color:var(--ink);font-weight:500;line-height:1.08;letter-spacing:-.01em;font-optical-sizing:auto}
h1{font-size:var(--fs-h1);line-height:1.02;letter-spacing:-.02em}
h2{font-size:var(--fs-h2)}
h3{font-size:var(--fs-h3);line-height:1.15}
h4{font-size:var(--fs-h4);line-height:1.25}
p{max-width:68ch}
strong{color:var(--ink);font-weight:600}
.serif-i{font-style:italic}

.eyebrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--sans);font-size:var(--fs-eyebrow);font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--sage-deep);
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--clay);display:inline-block}
.eyebrow.center{justify-content:center}
.lead{font-size:var(--fs-lead);line-height:1.55;color:var(--ink-2)}
.muted{color:var(--ink-3)}

/* ----- Layout ----- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(1.25rem,4vw,2.5rem)}
.narrow{max-width:var(--container-narrow)}
.section{position:relative;padding-block:var(--section-y);z-index:2}
.section.tint{background:var(--sand)}
.section.paper{background:var(--paper)}
.section.sage{background:linear-gradient(165deg,var(--sage-deep),#37493e);color:#EAF0EB}
.section.sage h1,.section.sage h2,.section.sage h3,.section.sage h4{color:#fff}
.section.sage .eyebrow{color:var(--clay-soft)}
.section.sage .muted{color:#BFCCC2}
.section-head{max-width:54ch}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{margin-top:.55rem}
.section-head p{margin-top:1.1rem}
.section-head.center p{margin-inline:auto}

.stack-sm>*+*{margin-top:.75rem}
.stack>*+*{margin-top:1.15rem}
.stack-lg>*+*{margin-top:1.9rem}

/* soft decorative gradient blobs */
.blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;z-index:0;pointer-events:none}
.blob.sage{background:radial-gradient(circle at 30% 30%, #9db6a4, transparent 70%)}
.blob.clay{background:radial-gradient(circle at 30% 30%, #e8c4ac, transparent 70%)}

/* ----- Buttons ----- */
.btn{
  --bg:#A4562F;--fg:#fff;--bd:#A4562F;
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  padding:.95em 1.6em;border-radius:999px;
  font-family:var(--sans);font-weight:600;font-size:1rem;letter-spacing:.005em;
  background:var(--bg);color:var(--fg);border:1.5px solid var(--bd);
  transition:transform .25s var(--ease), box-shadow .3s var(--ease), background .25s var(--ease), color .25s var(--ease);
  box-shadow:0 8px 20px rgba(154,82,48,.22);will-change:transform;
}
.btn:hover{background:var(--sage-deep);border-color:var(--sage-deep);transform:translateY(-2px);box-shadow:0 12px 26px rgba(66,89,76,.32)}
.btn:active{transform:translateY(0)}
.btn .arrow{transition:transform .3s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
.btn-ghost{--bg:transparent;--fg:var(--sage-deep);--bd:var(--line-2);box-shadow:none}
.btn-ghost:hover{--bg:var(--sage-deep);--fg:#fff;border-color:var(--sage-deep);box-shadow:0 10px 22px rgba(66,89,76,.18)}
.btn-light{--bg:#fff;--fg:var(--ink);--bd:#fff;box-shadow:0 10px 24px rgba(20,30,24,.25)}
.btn-light:hover{--fg:#fff;border-color:var(--sage-deep)}
.btn-sm{padding:.7em 1.2em;font-size:.92rem}
.btn-block{display:flex;width:100%}
.btn-row{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center}

.textlink{
  display:inline-flex;align-items:center;gap:.4em;color:var(--clay-deep);font-weight:600;
  background-image:linear-gradient(var(--clay),var(--clay));
  background-size:0% 1.5px;background-repeat:no-repeat;background-position:0 100%;
  transition:background-size .3s var(--ease);padding-bottom:2px;
}
.textlink:hover{background-size:100% 1.5px}
.textlink .arrow{transition:transform .3s var(--ease)}
.textlink:hover .arrow{transform:translateX(3px)}

/* ==========================================================================
   Header / navigation
   ========================================================================== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .35s var(--ease), box-shadow .35s var(--ease), padding .35s var(--ease)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-block:1.15rem}
.site-header::before{content:"";position:absolute;inset:0;z-index:-1;background:rgba(247,243,234,.86);backdrop-filter:saturate(140%) blur(12px);-webkit-backdrop-filter:saturate(140%) blur(12px);opacity:0;transition:opacity .35s var(--ease);pointer-events:none}
.site-header.scrolled::before{opacity:1}
.site-header.scrolled{box-shadow:0 1px 0 rgba(0,0,0,.04), 0 10px 30px rgba(40,50,42,.06)}
.site-header.scrolled .container{padding-block:.7rem}

.brand{display:inline-flex;align-items:center;gap:.7rem;flex-shrink:0}
.brand-mark{width:38px;height:38px;flex:none}
.brand-name{display:flex;flex-direction:column;line-height:1;font-family:var(--serif);font-weight:500;font-size:1.22rem;color:var(--ink);letter-spacing:-.01em}
.brand-name small{font-family:var(--sans);font-weight:600;font-size:.6rem;letter-spacing:.22em;color:var(--sage-deep);margin-top:.32rem}

.nav{display:flex;align-items:center;gap:.35rem}
.nav a{font-weight:500;font-size:.98rem;color:var(--ink-2);padding:.5rem .8rem;border-radius:999px;transition:color .2s var(--ease), background .2s var(--ease)}
.nav a:hover{color:var(--ink);background:rgba(94,125,107,.1)}
.nav a[aria-current="page"]{color:var(--sage-deep);background:rgba(94,125,107,.12)}
.nav .btn{margin-left:.6rem}

.nav-toggle{display:none;position:relative;z-index:20;width:46px;height:46px;border-radius:12px;align-items:center;justify-content:center;color:var(--ink);transition:background .2s}
.nav-toggle:hover{background:rgba(94,125,107,.12)}
.nav-toggle svg{width:24px;height:24px}
.nav-toggle .x{display:none}
body.nav-open .nav-toggle .menu{display:none}
body.nav-open .nav-toggle .x{display:block}

@media (max-width:920px){
  .nav-toggle{display:inline-flex}
  .nav{
    position:fixed;inset:0 0 0 auto;width:min(86vw,360px);
    flex-direction:column;align-items:stretch;gap:.25rem;
    background:var(--cream-2);padding:6rem 1.6rem 2rem;
    box-shadow:-20px 0 60px rgba(35,50,43,.18);
    transform:translateX(100%);transition:transform .4s var(--ease-out);
    overflow-y:auto;z-index:10;
  }
  body.nav-open .nav{transform:translateX(0)}
  .nav a{font-size:1.15rem;padding:.85rem 1rem}
  .nav .btn{margin:.75rem 0 0;width:100%}
  .nav-scrim{position:fixed;inset:0;background:rgba(30,40,33,.4);opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s;z-index:90}
  body.nav-open .nav-scrim{opacity:1;visibility:visible}
  body.nav-open{overflow:hidden}
}

/* ==========================================================================
   Hero
   ========================================================================== */
.hero{position:relative;padding-top:clamp(8rem,7rem + 6vw,11rem);padding-bottom:var(--section-y);overflow:hidden}
.hero .blob.sage{width:560px;height:560px;top:-160px;right:-120px}
.hero .blob.clay{width:420px;height:420px;bottom:-180px;left:-140px;opacity:.4}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:clamp(2rem,4vw,4.5rem);position:relative;z-index:2}

.hero-copy h1{margin:1rem 0 0}
.hero-copy .lead{margin-top:1.5rem;max-width:34ch}
.hero-copy .btn-row{margin-top:2rem}
.hero-trust{margin-top:2.4rem;display:flex;flex-wrap:wrap;gap:1.4rem 2rem;align-items:center}
.hero-trust .ht{display:flex;align-items:center;gap:.6rem;font-size:.92rem;color:var(--ink-3);font-weight:500}
.hero-trust .ht svg{width:22px;height:22px;color:var(--sage);flex:none}
.hero-trust .divider{width:1px;height:34px;background:var(--line-2)}

/* arched portrait with layered depth */
.hero-figure{position:relative;justify-self:center;width:min(100%,460px)}
.arch{border-radius:230px 230px var(--radius) var(--radius);overflow:hidden}
.hero-figure .photo{position:relative;z-index:2;box-shadow:var(--shadow-l)}
.hero-figure .photo img{width:100%;height:auto;object-fit:cover;aspect-ratio:4/5}
.hero-figure .frame-offset{position:absolute;z-index:1;inset:22px -22px -22px 22px;border:1.5px solid var(--sage);border-radius:230px 230px var(--radius) var(--radius);}
.hero-figure .dot-cluster{position:absolute;z-index:0;width:120px;height:120px;right:-34px;top:36px;
  background-image:radial-gradient(var(--sage-soft) 1.7px, transparent 1.8px);background-size:16px 16px;opacity:.55}
.hero-badge{position:absolute;z-index:3;bottom:18px;left:-26px;background:var(--paper);border-radius:16px;padding:.8rem 1.05rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:.7rem;max-width:230px}
.hero-badge .ring{width:34px;height:34px;flex:none}
.hero-badge b{display:block;font-family:var(--serif);font-size:.98rem;color:var(--ink);line-height:1.1}
.hero-badge span{font-size:.74rem;color:var(--ink-3);letter-spacing:.02em}

@media (max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
  .hero-figure{order:-1;width:min(82%,360px)}
  .hero-copy .lead{max-width:54ch}
  .arch,.hero-figure .frame-offset{border-radius:180px 180px var(--radius) var(--radius)}
}
@media (max-width:480px){
  .hero-figure{width:min(94%,330px)}
  .hero-badge{left:-8px;padding:.65rem .8rem}
}

/* ==========================================================================
   Welcome / quote band
   ========================================================================== */
.welcome-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.pullquote{font-family:var(--serif);font-size:clamp(1.5rem,1.1rem + 1.8vw,2.35rem);line-height:1.28;color:var(--ink);font-weight:500;letter-spacing:-.01em}
.pullquote .hl{color:var(--clay-deep);font-style:italic}
.signature{margin-top:1.6rem;font-family:var(--serif);font-style:italic;font-size:1.25rem;color:var(--sage-deep)}
@media (max-width:760px){.welcome-grid{grid-template-columns:1fr;gap:1.6rem}}

/* ==========================================================================
   Service cards
   ========================================================================== */
.grid{display:grid;gap:1.4rem}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:900px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.grid-3,.grid-2{grid-template-columns:1fr}}

.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.7rem 1.6rem;position:relative;overflow:hidden;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
}
.card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--clay);transform:scaleY(0);transform-origin:top;transition:transform .4s var(--ease-out)}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line-2)}
.card:hover::before{transform:scaleY(1)}
.card .ico{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;background:var(--sage-mist);color:var(--sage-deep);margin-bottom:1.1rem;transition:background .35s var(--ease), color .35s var(--ease)}
.card:hover .ico{background:var(--sage-deep);color:#fff}
.card .ico svg{width:26px;height:26px}
.card h3{font-size:1.2rem;margin-bottom:.5rem}
.card p{font-size:.99rem;color:var(--ink-3);margin-bottom:0}
.card .more{margin-top:1rem;font-size:.92rem}

/* ==========================================================================
   Credentials / badges
   ========================================================================== */
.cred-wrap{display:grid;grid-template-columns:1fr 1.25fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.badge-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.1rem}
.badge-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;display:grid;place-items:center;min-height:140px;transition:transform .35s var(--ease), box-shadow .35s var(--ease)}
.badge-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.badge-card img{max-height:120px;width:auto;object-fit:contain}
@media (max-width:760px){.cred-wrap{grid-template-columns:1fr}}
@media (max-width:420px){.badge-grid{grid-template-columns:1fr}}

.cred-list{margin-top:1.5rem}
.cred-list li{display:flex;gap:.85rem;align-items:flex-start;padding:.55rem 0}
.cred-list svg{width:22px;height:22px;color:var(--clay);flex:none;margin-top:.2rem}
.cred-list b{color:var(--ink)}

/* ==========================================================================
   Two paths (clients / clinicians)
   ========================================================================== */
.paths{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
@media (max-width:760px){.paths{grid-template-columns:1fr}}
.path{
  position:relative;border-radius:var(--radius-l);padding:clamp(1.8rem,1.4rem + 1.5vw,2.8rem);
  overflow:hidden;border:1px solid transparent;transition:transform .4s var(--ease), box-shadow .4s var(--ease);
  display:flex;flex-direction:column;min-height:300px;
}
.path:hover{transform:translateY(-5px);box-shadow:var(--shadow-l)}
.path.clients{background:linear-gradient(160deg,#5e7d6b,#3f5446);color:#EAF0EB}
.path.clinicians{background:var(--paper);border-color:var(--line);color:var(--ink-2)}
.path .tag{font-size:.74rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;margin-bottom:1rem;display:inline-block}
.path.clients .tag{color:var(--clay-soft)}
.path.clinicians .tag{color:var(--sage-deep)}
.path h3{font-size:clamp(1.5rem,1.2rem + 1vw,2rem);margin-bottom:.7rem}
.path.clients h3{color:#fff}
.path p{margin-bottom:1.5rem}
.path.clients p{color:#CDD8CF}
.path .btn-row{margin-top:auto}
.path .deco-ring{position:absolute;right:-40px;bottom:-40px;width:170px;height:170px;opacity:.18}

/* ==========================================================================
   Insurance + locations
   ========================================================================== */
.info-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem)}
@media (max-width:760px){.info-split{grid-template-columns:1fr}}
.pill-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.2rem}
.pill{background:var(--paper);border:1px solid var(--line-2);border-radius:999px;padding:.55em 1.1em;font-weight:600;font-size:.92rem;color:var(--ink-2);transition:border-color .25s, color .25s, transform .25s}
.pill:hover{border-color:var(--sage);color:var(--sage-deep);transform:translateY(-2px)}
.loc-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem}
.loc-card+.loc-card{margin-top:1rem}
.loc-card h4{display:flex;align-items:center;gap:.6rem;margin-bottom:.4rem}
.loc-card h4 svg{width:22px;height:22px;color:var(--clay)}
.state-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.9rem}
.state{display:inline-flex;align-items:center;gap:.4rem;background:var(--sage-mist);color:var(--sage-deep);border-radius:8px;padding:.35em .75em;font-weight:600;font-size:.88rem}

/* ==========================================================================
   FAQ accordion
   ========================================================================== */
.faq{max-width:820px;margin-inline:auto}
.faq details{border-bottom:1px solid var(--line-2);padding:.35rem 0}
.faq summary{
  list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1.25rem .25rem;font-family:var(--serif);font-size:clamp(1.1rem,1rem + .4vw,1.3rem);color:var(--ink);font-weight:500;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{width:30px;height:30px;flex:none;border-radius:50%;border:1.5px solid var(--line-2);display:grid;place-items:center;transition:transform .35s var(--ease), background .25s, border-color .25s, color .25s;color:var(--sage-deep)}
.faq details[open] summary .pm{transform:rotate(45deg);background:var(--sage-deep);border-color:var(--sage-deep);color:#fff}
.faq summary .pm svg{width:16px;height:16px}
.faq .answer{overflow:hidden;max-height:0;transition:max-height .4s var(--ease)}
.faq details[open] .answer{max-height:600px}
.faq .answer p{padding:0 .25rem 1.4rem;color:var(--ink-3);margin:0}

/* ==========================================================================
   Forms
   ========================================================================== */
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:clamp(1.6rem,1.2rem + 1.5vw,2.6rem);box-shadow:var(--shadow)}
.field{margin-bottom:1.15rem}
.field label{display:block;font-weight:600;font-size:.92rem;color:var(--ink);margin-bottom:.45rem}
.field label .req{color:var(--clay-deep)}
.field input,.field select,.field textarea{
  width:100%;font:inherit;font-size:1rem;color:var(--ink);background:var(--cream-2);
  border:1.5px solid var(--line-2);border-radius:12px;padding:.85em 1em;transition:border-color .25s, box-shadow .25s, background .25s;
}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--sage);background:#fff;box-shadow:0 0 0 4px rgba(94,125,107,.13)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.15rem}
@media (max-width:560px){.field-row{grid-template-columns:1fr}}
.form-note{font-size:.86rem;color:var(--ink-3);margin-top:.4rem}
.form-status{margin-top:1rem;padding:.9rem 1.1rem;border-radius:12px;font-weight:600;font-size:.95rem;display:none}
.form-status.ok{display:block;background:var(--sage-mist);color:var(--sage-deep)}
.form-status.err{display:block;background:#f7e2d8;color:var(--clay-deep)}

.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
@media (max-width:860px){.contact-grid{grid-template-columns:1fr}}
.contact-detail{display:flex;gap:1rem;align-items:flex-start;padding:1.1rem 0;border-bottom:1px solid var(--line)}
.contact-detail:last-child{border-bottom:0}
.contact-detail .ci{width:46px;height:46px;border-radius:12px;background:var(--sage-mist);color:var(--sage-deep);display:grid;place-items:center;flex:none}
.contact-detail .ci svg{width:23px;height:23px}
.contact-detail h4{font-size:1.05rem;margin-bottom:.15rem}
.contact-detail a{color:var(--clay-deep);font-weight:600}
.contact-detail p{font-size:.97rem;color:var(--ink-3);margin:0}

/* ==========================================================================
   Product (clinician PDF) panel
   ========================================================================== */
.product{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,4rem);align-items:center}
@media (max-width:820px){.product{grid-template-columns:1fr}}
.product-visual{position:relative;display:grid;place-items:center;min-height:340px}
.doc-mock{width:min(78%,300px);aspect-ratio:8.5/11;background:var(--paper);border-radius:14px;box-shadow:var(--shadow-l);border:1px solid var(--line);padding:1.6rem 1.5rem;position:relative;transform:rotate(-3deg);transition:transform .5s var(--ease)}
.product-visual:hover .doc-mock{transform:rotate(-1.5deg) translateY(-4px)}
.doc-mock::before{content:"";position:absolute;inset:14px 14px auto 14px;height:4px;background:var(--clay);border-radius:4px;width:46px}
.doc-mock .dl{height:9px;border-radius:5px;background:var(--sand);margin-top:.75rem}
.doc-mock .dl.t{height:14px;background:var(--sage-mist);width:80%;margin-top:1.6rem}
.doc-mock .dl.s{width:60%}
.doc-mock .dgrid{margin-top:1.4rem;display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.doc-mock .dgrid span{height:26px;border-radius:5px;background:var(--cream)}
.doc-mock .stamp{position:absolute;right:-18px;bottom:24px;background:var(--clay);color:#fff;font-family:var(--serif);font-style:italic;font-size:.95rem;padding:.5rem .9rem;border-radius:10px;box-shadow:var(--shadow);transform:rotate(4deg)}
.feature-list{list-style:none;padding:0;margin:.6rem 0 0}
.feature-list li{display:flex;gap:.8rem;align-items:flex-start;padding:.5rem 0}
.feature-list svg{width:22px;height:22px;color:var(--sage);flex:none;margin-top:.25rem}
.price-tag{display:flex;flex-wrap:wrap;align-items:baseline;gap:.4rem .6rem;margin:.4rem 0 1.4rem}
.price-tag .amt{font-family:var(--serif);font-size:2.4rem;color:var(--ink);font-weight:600}
.price-tag .per{color:var(--ink-3);font-size:.95rem}

/* ==========================================================================
   CTA band
   ========================================================================== */
.cta-band{position:relative;overflow:hidden;text-align:center}
.cta-band .blob.clay{width:380px;height:380px;top:-140px;left:-80px;opacity:.35}
.cta-band .blob.sage{width:420px;height:420px;bottom:-180px;right:-100px;opacity:.4}
.cta-inner{position:relative;z-index:2;max-width:640px;margin-inline:auto}
.cta-inner h2{margin-bottom:1rem}
.cta-inner .btn-row{justify-content:center;margin-top:1.8rem}

/* ==========================================================================
   Page hero (interior pages)
   ========================================================================== */
.page-hero{position:relative;padding-top:clamp(8rem,7rem + 5vw,10.5rem);padding-bottom:clamp(2.5rem,2rem + 2vw,4rem);overflow:hidden}
.page-hero .blob.sage{width:480px;height:480px;top:-180px;right:-120px;opacity:.4}
.page-hero .inner{position:relative;z-index:2;max-width:720px}
.breadcrumb{font-size:.85rem;color:var(--ink-3);margin-bottom:1.1rem;display:flex;gap:.5rem;flex-wrap:wrap}
.breadcrumb a:hover{color:var(--sage-deep)}
.breadcrumb span{color:var(--line-2)}
.page-hero h1{margin-bottom:1.1rem}
.page-hero .lead{max-width:60ch}

/* prose blocks for content pages */
.prose{max-width:70ch}
.prose .lead-prose{font-family:var(--serif);font-size:clamp(1.3rem,1.15rem + .7vw,1.65rem);line-height:1.45;color:var(--ink);font-weight:500;margin-bottom:1.5rem}
.prose .lead-prose em{font-style:italic;color:var(--clay-deep)}
.prose h2{margin-top:2.6rem;margin-bottom:.9rem}
.prose h3{margin-top:1.9rem;margin-bottom:.6rem}
.prose p{margin-bottom:1.1rem}
.prose ul.ticks{margin:1rem 0 1.4rem}
.prose ul.ticks li{display:flex;gap:.7rem;align-items:flex-start;padding:.4rem 0;color:var(--ink-2)}
.prose ul.ticks svg{width:21px;height:21px;color:var(--sage);flex:none;margin-top:.25rem}

/* reusable tick list (any context) */
ul.ticks{list-style:none;margin:1rem 0 1.4rem;padding:0}
ul.ticks li{display:flex;gap:.7rem;align-items:flex-start;padding:.4rem 0;color:var(--ink-2);line-height:1.55}
ul.ticks svg{width:21px;height:21px;color:var(--sage);flex:none;margin-top:.28rem}

/* service detail rows */
.svc-detail{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(1.5rem,3vw,3rem);align-items:start;padding-block:clamp(2rem,2vw,3rem)}
.svc-detail:nth-child(even){direction:rtl}
.svc-detail:nth-child(even)>*{direction:ltr}
@media (max-width:780px){.svc-detail,.svc-detail:nth-child(even){grid-template-columns:1fr;direction:ltr}}
.svc-detail .ico-lg{width:64px;height:64px;border-radius:16px;background:var(--sage-mist);color:var(--sage-deep);display:grid;place-items:center;margin-bottom:1.1rem}
.svc-detail .ico-lg svg{width:32px;height:32px}
.svc-anchor{scroll-margin-top:100px}

/* quick-nav chips */
.chip-row{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}
.chip{display:inline-flex;align-items:center;padding:.5rem 1rem;border-radius:999px;background:var(--paper);border:1px solid var(--line);color:var(--ink-2);font-size:.92rem;font-weight:600;transition:all .25s var(--ease)}
.chip:hover{background:var(--sage-mist);border-color:var(--sage-soft);color:var(--sage-deep);transform:translateY(-2px)}

/* about page layout */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,4vw,4rem);align-items:start}
@media (max-width:820px){.about-grid{grid-template-columns:1fr}}
.about-figure{position:relative;width:min(100%,420px);justify-self:center;position:sticky;top:100px}
@media (max-width:820px){.about-figure{position:relative;top:0}}
.about-figure .photo{border-radius:200px 200px var(--radius) var(--radius);overflow:hidden;box-shadow:var(--shadow-l)}
.about-figure .photo img{width:100%;aspect-ratio:4/5;object-fit:cover}
.about-figure .frame-offset{position:absolute;inset:-18px 18px 18px -18px;border:1.5px solid var(--clay-soft);border-radius:200px 200px var(--radius) var(--radius);z-index:-1}

.quick-facts{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;margin-top:1.4rem}
.quick-facts h4{font-size:1rem;letter-spacing:.04em;margin-bottom:.8rem}
.quick-facts dl{display:grid;gap:.7rem}
.quick-facts .qf{display:flex;gap:.7rem;align-items:flex-start}
.quick-facts .qf svg{width:20px;height:20px;color:var(--sage);flex:none;margin-top:.2rem}
.quick-facts dt{font-weight:700;color:var(--ink);font-size:.9rem}
.quick-facts dd{font-size:.92rem;color:var(--ink-3)}

/* ==========================================================================
   Footer
   ========================================================================== */
.crisis-bar{background:var(--sage-deep);color:#E6EDE7;text-align:center;font-size:.92rem;padding:.85rem 1.25rem;position:relative;z-index:2}
.crisis-bar strong{color:#fff}
.crisis-bar a{color:#fff;font-weight:700;text-decoration:underline;text-underline-offset:3px}

.site-footer{background:#26332C;color:#C5D0C7;position:relative;z-index:2;padding-block:clamp(3rem,2.4rem + 2vw,4.5rem) 2rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:2.5rem}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}
.site-footer .brand-name{color:#fff}
.site-footer .brand-name small{color:var(--sage-soft)}
.footer-about{margin-top:1.1rem;font-size:.95rem;max-width:34ch;color:#AEBBB1}
.footer-contact{margin-top:1.2rem;display:grid;gap:.5rem;font-size:.95rem}
.footer-contact a{color:#fff;font-weight:600}
.footer-col h4{color:#fff;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;font-family:var(--sans);font-weight:700;margin-bottom:1.1rem}
.footer-col ul{display:grid;gap:.65rem}
.footer-col a{font-size:.95rem;color:#BAC6BC;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-states{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.4rem}
.footer-states .state{background:rgba(255,255,255,.08);color:#D7E0D9}
.footer-bottom{margin-top:3rem;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.12);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;font-size:.85rem;color:#94A299}
.footer-bottom .disclaimer{max-width:62ch;line-height:1.6}

/* ==========================================================================
   Reveal animations
   ========================================================================== */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease-out), transform .8s var(--ease-out);transition-delay:var(--delay,0ms)}
[data-reveal].in-view{opacity:1;transform:none}
[data-reveal="fade"]{transform:none}
[data-reveal="left"]{transform:translateX(-30px)}
[data-reveal="right"]{transform:translateX(30px)}
[data-reveal="scale"]{transform:scale(.96)}

/* hero load-in (runs immediately, no JS gate) */
@keyframes rise{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.hero [data-anim]{opacity:0;animation:rise .9s var(--ease-out) forwards}
.hero [data-anim="1"]{animation-delay:.05s}
.hero [data-anim="2"]{animation-delay:.18s}
.hero [data-anim="3"]{animation-delay:.31s}
.hero [data-anim="4"]{animation-delay:.44s}
.hero [data-anim="5"]{animation-delay:.57s}
.hero-figure{opacity:0;animation:fadein 1.2s var(--ease-out) .25s forwards}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.hero-badge{animation:floaty 6s ease-in-out 1.4s infinite}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  [data-reveal]{opacity:1 !important;transform:none !important}
  .hero [data-anim],.hero-figure{opacity:1 !important;animation:none !important}
}

/* small helpers */
.mt-0{margin-top:0}
.center{text-align:center}
.maxc{max-width:60ch}
.maxc.center{margin-inline:auto}
hr.rule{border:0;border-top:1px solid var(--line-2);margin:0}

/* real office photos */
.space-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem;max-width:760px;margin:2.4rem auto 0}
.space-photo{margin:0;border-radius:var(--radius-l);overflow:hidden;background:var(--sand);box-shadow:0 18px 42px rgba(40,50,42,.12);aspect-ratio:1/1}
.space-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease-out)}
.space-photo:hover img{transform:scale(1.04)}
.office-figure{margin:0;border-radius:var(--radius-l);overflow:hidden;background:var(--sand);box-shadow:0 18px 42px rgba(40,50,42,.12)}
.office-figure img{width:100%;height:auto;display:block}
@media (max-width:680px){.space-grid{grid-template-columns:1fr;max-width:420px}}

/* insurance logo tiles (uniform size, logos scaled to fit) */
.insurer-row{display:flex;flex-wrap:wrap;gap:.7rem;align-items:stretch;margin-top:1rem}
.insurer{flex:0 0 auto;width:138px;height:62px;display:flex;align-items:center;justify-content:center;padding:.7rem .95rem;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 4px 14px rgba(40,50,42,.05);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.insurer:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(40,50,42,.10)}
.insurer img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block;filter:grayscale(1);transition:filter .35s var(--ease)}
.insurer:hover img{filter:none}
@media (max-width:480px){.insurer{width:calc(50% - .35rem);height:58px}}

/* embedded map (contact) */
.map-embed{width:100%;height:340px;border:0;border-radius:var(--radius-l);box-shadow:0 14px 34px rgba(40,50,42,.10);margin-top:2.2rem;display:block}
@media (max-width:680px){.map-embed{height:280px}}

/* reviews / testimonials */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2.6rem}
.review{display:flex;flex-direction:column;gap:.9rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem 1.5rem;box-shadow:0 10px 30px rgba(40,50,42,.05)}
.review .stars{display:flex;gap:.12rem;color:var(--clay)}
.review .stars svg{width:18px;height:18px;fill:currentColor}
.review blockquote{margin:0;font-size:1rem;line-height:1.65;color:var(--ink-2)}
.review figcaption{display:flex;align-items:center;gap:.75rem;margin-top:auto;padding-top:.5rem}
.review .avatar{flex:0 0 auto;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--sage-mist);color:var(--sage-deep);font-weight:600;font-size:.88rem;font-family:var(--sans);letter-spacing:.02em}
.review .r-name{display:block;font-weight:600;color:var(--ink);font-size:.95rem}
.review .r-src{display:block;font-size:.82rem;color:var(--ink-3)}
.reviews-more{text-align:center;margin-top:1.8rem}
@media (max-width:860px){.reviews{grid-template-columns:1fr;max-width:540px;margin-inline:auto}}
.review{position:relative}
.review::before{content:"\201C";position:absolute;top:.4rem;right:1.2rem;font-family:var(--serif);font-size:3.2rem;line-height:1;color:var(--line-2);pointer-events:none}

/* button + textlink icon sizing fix (keep labels on one line, arrows fixed size) */
.btn{white-space:nowrap;line-height:1}
.btn svg,.btn .arrow{width:1.15em;height:1.15em;flex:0 0 auto}
.textlink svg,.textlink .arrow{width:1.05em;height:1.05em;flex:0 0 auto}

/* linked footer state pills */
a.state{text-decoration:none}
a.state:hover{background:var(--sage-deep);color:#fff}

/* blog */
.post-meta{display:flex;flex-wrap:wrap;gap:.55rem;align-items:center;color:var(--ink-3);font-size:.92rem;font-weight:500}
.post-meta .dot{opacity:.45}
.post-card{display:flex;flex-direction:column;height:100%}
.post-card h3{margin:.55rem 0 .5rem;font-size:1.3rem}
.post-card p{color:var(--ink-2)}
.post-card .textlink{margin-top:auto;padding-top:.9rem}
.post-body{max-width:760px;margin:0 auto}
.post-body .lede{font-size:1.18rem;line-height:1.6;color:var(--ink-2);font-family:var(--sans)}

/* footer social icons */
.footer-social{display:flex;gap:.6rem;margin-top:1.15rem}
.footer-social a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);color:#D7E0D9;transition:background .2s,color .2s,transform .2s}
.footer-social a:hover{background:var(--clay);color:#fff;transform:translateY(-2px)}
.footer-social svg{width:18px;height:18px}

/* service chips: icon + label */
.chip{display:inline-flex;align-items:center;gap:.45em}
.chip svg{width:1.1em;height:1.1em;flex:0 0 auto}

/* Cloudflare Turnstile widget spacing */
.cf-turnstile{margin:1.1rem 0}

/* checkout trust strip */
.buy-trust{display:flex;flex-wrap:wrap;gap:1.1rem;margin-top:1rem;color:var(--ink-3);font-size:.9rem;font-weight:500}
.buy-trust .bt{display:inline-flex;align-items:center;gap:.4em}
.buy-trust svg{width:1.05em;height:1.05em;color:var(--sage);flex:0 0 auto}
.powered-stripe{margin-top:.55rem;color:var(--ink-3);font-size:.82rem}
.stripe-wordmark{color:#635BFF;font-weight:700;letter-spacing:-.02em}

/* social proof badge */
.proof-badge{display:inline-flex;align-items:center;gap:.5em;margin-top:1rem;background:var(--sage-mist);color:var(--sage-deep);border-radius:999px;padding:.45em .95em;font-weight:600;font-size:.9rem;line-height:1.15}
.proof-badge svg{width:1.05em;height:1.05em;flex:0 0 auto}

/* keep this line on one row on desktop (wraps normally on smaller screens) */
@media (min-width:992px){.nowrap-desktop{white-space:nowrap}}
.pay-cards{display:flex;align-items:center;gap:.5rem;margin-top:.7rem}
.pay-cards svg{width:46px;height:29px;display:block;border-radius:5px;box-shadow:0 1px 2px rgba(35,50,43,.10)}
.phase-flow{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin:2rem 0}
.phase-flow .phase{position:relative;background:var(--cream);border:1px solid var(--sand);border-radius:16px;padding:1.5rem 1.3rem}
.phase-flow .phase .phase-num{display:inline-flex;align-items:center;justify-content:center;width:2.1rem;height:2.1rem;border-radius:50%;background:var(--sage);color:#fff;font-family:var(--serif);font-weight:600;font-size:1.05rem;margin-bottom:.7rem}
.phase-flow .phase h4{font-family:var(--serif);font-size:1.2rem;color:var(--sage-deep);margin:0 0 .4rem}
.phase-flow .phase p{margin:0;color:var(--ink-2);font-size:.95rem;line-height:1.55}
@media (min-width:761px){.phase-flow .phase:not(:last-child)::after{content:"";position:absolute;top:50%;right:-1.1rem;width:1.05rem;height:2px;background:var(--clay);opacity:.55}}
@media (max-width:760px){.phase-flow{grid-template-columns:1fr;gap:1rem}}
.nav a.btn,
.nav a.btn:hover{color:var(--fg)}
.nav a.btn:hover{background:var(--sage-deep);border-color:var(--sage-deep)}
.page-hero .btn-row{margin-top:1.8rem}
@media (min-width:1180px){
  .chip-row{gap:.4rem;flex-wrap:nowrap}
  .chip-row .chip{padding:.5rem .7rem;font-size:.8rem}
  .chip-row .chip svg{width:1em}
}
.price-tag .amt-was{font-family:var(--serif);font-size:1.5rem;color:var(--ink-3);font-weight:500;text-decoration:line-through;text-decoration-thickness:2px;opacity:.75}
.price-tag .price-flag{align-self:center;background:var(--clay);color:#fff;font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.26rem .55rem;border-radius:999px}
.btn.is-disabled,.btn.is-disabled:hover{background:#C8C3B8;color:#7C776E;border-color:#C8C3B8;box-shadow:none;transform:none;cursor:default;pointer-events:none}
.soon-badge{display:inline-flex;align-items:center;gap:.45rem;margin:0 0 .7rem;background:var(--sage-mist);color:var(--sage-deep);font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.34rem .75rem;border-radius:999px}
.soon-badge::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--clay);flex:0 0 auto}
.footer-states a.state:hover{background:rgba(255,255,255,.16);color:#fff}
.qf-stat{padding:.15rem 0 .85rem;margin-bottom:.7rem;border-bottom:1px solid var(--line)}
.qf-stat .num{display:block;font-family:var(--serif);font-size:2.2rem;line-height:1.05;color:var(--clay);font-weight:600}
.qf-stat .lbl{display:block;margin-top:.15rem;font-size:.86rem;color:var(--ink-3);font-weight:500;line-height:1.3}
.cred-stat{display:flex;align-items:baseline;gap:.65rem;margin-top:1.6rem;padding-top:1.3rem;border-top:1px solid var(--line)}
.cred-stat .num{font-family:var(--serif);font-size:2rem;line-height:1;color:var(--clay);font-weight:600}
.cred-stat .lbl{font-size:.92rem;color:var(--ink-2);font-weight:500}
.footer-addr{font-size:.95rem}
@media (min-width:1180px){.footer-addr{font-size:.85rem;white-space:nowrap;letter-spacing:-.01em}}
.page-hero.hero-compact,.page-hero:has(.post-meta){padding-bottom:clamp(1.25rem,.9rem + 1vw,2rem)}
.section.section-compact-top,article.section{padding-block-start:clamp(1.5rem,1rem + 1.5vw,2.75rem)}
.nav:focus,.nav:focus-visible{outline:none}


/* ===== Author credential card (articles) ===== */
.author-card{display:flex;gap:1.1rem;align-items:flex-start;background:var(--sand);border:1px solid rgba(94,125,107,.18);border-radius:var(--radius);padding:1.15rem 1.3rem;margin:0 0 2rem}
.author-card__avatar{width:66px;height:66px;border-radius:50%;object-fit:cover;object-position:50% 24%;flex:none}
.author-card__meta{min-width:0}
.author-card__name{font-family:var(--serif);font-weight:600;font-size:1.1rem;color:var(--ink);margin:0}
.author-card__role{font-size:.84rem;color:var(--clay-deep);font-weight:600;margin:.18rem 0 .45rem}
.author-card__bio{font-size:.95rem;color:var(--ink-2);margin:0;line-height:1.55}
.author-card__bio a{color:var(--sage-deep);font-weight:600}
@media (max-width:520px){.author-card{flex-direction:column;gap:.75rem}}

/* ===== Related reading (articles) ===== */
.related-reading__title{font-family:var(--serif);text-align:center;margin:0 0 1.7rem}
.related-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;max-width:780px;margin:0 auto}
.related-card{display:flex;flex-direction:column;gap:.38rem;background:#fff;border:1px solid rgba(94,125,107,.16);border-radius:var(--radius);padding:1.25rem 1.35rem;text-decoration:none;transition:transform .25s var(--ease-out),box-shadow .25s var(--ease-out),border-color .25s var(--ease-out)}
.related-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:rgba(180,102,63,.4)}
.related-card__kicker{font-size:.72rem;letter-spacing:.09em;text-transform:uppercase;color:var(--clay-deep);font-weight:700}
.related-card__title{font-family:var(--serif);font-size:1.12rem;color:var(--ink);line-height:1.28}
.related-card__more{font-size:.85rem;color:var(--sage-deep);font-weight:600;margin-top:.15rem}
@media (max-width:560px){.related-grid{grid-template-columns:1fr}}
