/* ============================================================
   Still Waters Counseling & Therapy — styles
   Palette: dusty slate-blue · pale mist white · warm cream
   ============================================================ */

:root{
  --mist:        #eef4f7;   /* pale mist white bg */
  --mist-2:      #e3edf1;
  --cream:       #f6f1e9;   /* warm cream */
  --cream-2:     #efe6d6;
  --slate:       #5f7d92;   /* dusty slate blue (brand) */
  --slate-deep:  #3f5a6d;   /* deeper slate for text/headings */
  --slate-ink:   #2c414f;   /* near-ink slate */
  --slate-soft:  #8fa8b8;
  --line:        #d4e0e6;
  --white:       #ffffff;
  --shadow:      0 24px 60px -28px rgba(48, 78, 96, .32);
  --shadow-sm:   0 10px 30px -18px rgba(48, 78, 96, .45);

  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Jost", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --script:"Great Vibes", "Cormorant Garamond", cursive;

  --wrap: 1160px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:hidden; scroll-padding-top:90px; }
body{ overflow-x:hidden; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0;
  font-family:var(--sans);
  font-weight:400;
  color:var(--slate-ink);
  background:var(--mist);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }
h1,h2,h3,h4{ margin:0; font-weight:500; line-height:1.12; color:var(--slate-deep); }
p{ margin:0 0 1rem; }
ul,ol{ margin:0; padding:0; list-style:none; }

.skip-link{
  position:absolute; left:-999px; top:0; z-index:200;
  background:var(--slate-deep); color:#fff; padding:.7rem 1.1rem;
  border-radius:0 0 10px 0; font-size:.9rem;
}
.skip-link:focus{ left:0; }

:focus-visible{ outline:2.5px solid var(--slate); outline-offset:3px; border-radius:4px; }

/* ---------- shared type ---------- */
h1{ font-family:var(--serif); font-weight:500; font-size:clamp(2.7rem,6vw,4.6rem); letter-spacing:-.5px; }
h1 em{ font-style:italic; color:var(--slate); }
h2{ font-family:var(--serif); font-size:clamp(1.9rem,3.6vw,2.9rem); letter-spacing:-.3px; }
h3{ font-family:var(--serif); font-size:1.5rem; }
.section-kicker{
  font-family:var(--sans); font-size:.76rem; font-weight:600;
  letter-spacing:.28em; text-transform:uppercase; color:var(--slate);
  margin:0 0 .9rem;
}
.section-sub{ color:#5a6d78; font-size:1.08rem; max-width:52ch; }

/* ---------- buttons ---------- */
.btn{
  --pad:.85rem 1.5rem;
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  font-family:var(--sans); font-weight:500; font-size:.98rem;
  padding:var(--pad); border-radius:999px; border:1px solid transparent;
  text-decoration:none; cursor:pointer; letter-spacing:.01em;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease),
             background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease);
}
.btn:hover{ transform:translateY(-2px); }
.btn-primary{
  background:linear-gradient(135deg, var(--slate) 0%, var(--slate-deep) 100%);
  color:#fff; box-shadow:0 14px 30px -12px rgba(63,90,109,.6);
}
.btn-primary:hover{ box-shadow:0 20px 40px -12px rgba(63,90,109,.7); }
.btn-ghost{
  background:rgba(255,255,255,.5); color:var(--slate-deep);
  border-color:var(--line); backdrop-filter:blur(4px);
}
.btn-ghost:hover{ background:#fff; border-color:var(--slate-soft); }
.btn-call{ background:var(--white); color:var(--slate-deep); border-color:var(--line); }
.btn-call:hover{ border-color:var(--slate-soft); }
.btn-block{ width:100%; }
.i-phone{ width:1.05em; height:1.05em; fill:currentColor; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  /* z-index sits ABOVE the mobile menu (120) and scrim (110) so the header —
     and the nav toggle inside it — stays on top when the drawer is open; the
     toggle can then morph hamburger->X in place instead of being covered.
     The drawer's 6rem top padding is sized to clear this header bar. */
  position:fixed; inset:0 0 auto 0; z-index:140;
  background:rgba(238,244,247,.72);
  backdrop-filter:saturate(1.4) blur(14px);
  border-bottom:1px solid transparent;
  transition:background .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease);
}
.site-header.scrolled{
  background:rgba(244,248,250,.92);
  border-bottom-color:var(--line);
  box-shadow:0 6px 24px -18px rgba(48,78,96,.5);
}
.header-inner{
  max-width:var(--wrap); margin:0 auto; padding:1.1rem clamp(1rem,4vw,2rem);
  display:flex; align-items:center; gap:1.4rem;
  transition:padding .4s var(--ease);
}
.site-header.scrolled .header-inner{ padding-top:.7rem; padding-bottom:.7rem; }

.brand{ text-decoration:none; display:flex; flex-direction:column; line-height:1; margin-right:auto; }
.brand-script{
  font-family:var(--script); color:var(--slate-deep);
  font-size:clamp(2.15rem,3.6vw,2.85rem); line-height:.9;
  transition:font-size .4s var(--ease);
}
.site-header.scrolled .brand-script{ font-size:clamp(1.85rem,3vw,2.35rem); }
.brand-sub{
  font-family:var(--sans); font-weight:600; color:var(--slate);
  font-size:.66rem; letter-spacing:.34em; text-transform:uppercase;
  margin-top:.28rem;
}
.brand-sub .llc{ letter-spacing:.18em; opacity:.75; }

.primary-nav ul{ display:flex; gap:1.9rem; }
.primary-nav a{
  position:relative; text-decoration:none; color:var(--slate-deep);
  font-size:.95rem; font-weight:400; padding:.3rem 0;
  transition:color .3s var(--ease);
}
.primary-nav a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:100%;
  background:var(--slate); transform:scaleX(0); transform-origin:right;
  transition:transform .4s var(--ease);
}
.primary-nav a:hover{ color:var(--slate); }
.primary-nav a:hover::after{ transform:scaleX(1); transform-origin:left; }
.primary-nav a.active{ color:var(--slate); }
.primary-nav a.active::after{ transform:scaleX(1); transform-origin:left; }

.header-call{ padding:.6rem 1.15rem; font-size:.92rem; }

/* nav toggle */
.nav-toggle{
  display:none; width:44px; height:44px; border:none; background:transparent;
  cursor:pointer; padding:10px; position:relative; z-index:130;
}
.nav-toggle span{
  display:block; height:2px; width:100%; background:var(--slate-deep); border-radius:2px;
  margin:5px 0; transition:transform .4s var(--ease), opacity .3s var(--ease);
}
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile menu — fixed full-viewport clip WRAPPER so the off-canvas panel can
   never extend the scrollable area (fixed elements aren't clipped by root
   overflow-x:hidden, which is what leaks horizontal scroll on iOS/Android) */
.mobile-menu{
  position:fixed; inset:0; z-index:120; overflow:hidden;
  visibility:hidden; pointer-events:none;
  transition:visibility 0s linear .5s;   /* stay visible through the slide-out, then hide */
}
.mobile-menu.open{ visibility:visible; transition-delay:0s; }
/* the sliding panel lives INSIDE the clip wrapper. wrapper stays
   pointer-events:none so taps on the empty area fall through to the scrim
   (tap-outside-to-close); only the panel itself captures pointer events */
.mobile-menu-panel{
  position:absolute; top:0; right:0; bottom:0; width:min(86vw,360px);
  background:linear-gradient(160deg, var(--mist) 0%, #dbe8ee 100%);
  box-shadow:-30px 0 60px -30px rgba(48,78,96,.5);
  transform:translateX(100%); transition:transform .5s var(--ease);
  padding:6rem 2rem 2rem; overflow-y:auto; pointer-events:auto;
}
.mobile-menu.open .mobile-menu-panel{ transform:translateX(0); }
.mobile-menu ul{ display:flex; flex-direction:column; gap:.3rem; margin-bottom:1.6rem; }
.mobile-menu a{
  text-decoration:none; color:var(--slate-deep); font-family:var(--serif);
  font-size:1.5rem; padding:.55rem 0; display:block;
  border-bottom:1px solid var(--line); opacity:0; transform:translateX(14px);
}
.mobile-menu.open a{ animation:menuIn .5s var(--ease) forwards; }
.mobile-menu.open li:nth-child(1) a{ animation-delay:.06s; }
.mobile-menu.open li:nth-child(2) a{ animation-delay:.10s; }
.mobile-menu.open li:nth-child(3) a{ animation-delay:.14s; }
.mobile-menu.open li:nth-child(4) a{ animation-delay:.18s; }
.mobile-menu.open li:nth-child(5) a{ animation-delay:.22s; }
.mobile-menu.open li:nth-child(6) a{ animation-delay:.26s; }
.mobile-menu.open li:nth-child(7) a{ animation-delay:.30s; }
.mobile-menu.open li:nth-child(8) a{ animation-delay:.34s; }
@keyframes menuIn{ to{ opacity:1; transform:translateX(0); } }
/* the call button in the drawer is a filled pill CTA, not a plain menu link —
   undo the .mobile-menu a link styles (left-align, 0 side padding, border-bottom,
   serif, opacity:0) it would otherwise inherit and win on specificity */
.mobile-menu .btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  width:100%; margin-top:.5rem; padding:.95rem 1.5rem;
  border:1px solid transparent; border-radius:999px;
  background:linear-gradient(135deg, var(--slate) 0%, var(--slate-deep) 100%);
  color:#fff; font-family:var(--sans); font-size:1rem; font-weight:500;
  letter-spacing:.02em; box-shadow:0 14px 30px -12px rgba(63,90,109,.6);
  opacity:1; transform:none; animation:none;
}
.mobile-menu .btn .i-phone{ width:1.05em; height:1.05em; flex:none; opacity:.9; }
.menu-scrim{
  position:fixed; inset:0; z-index:110; background:rgba(44,65,79,.35);
  backdrop-filter:blur(2px); opacity:0; transition:opacity .4s var(--ease);
}
.menu-scrim.show{ opacity:1; }

/* the off-canvas drawer is only used <=960px (hamburger); drop it from layout on desktop so it can't create horizontal overflow */
@media (min-width:961px){ .mobile-menu, .menu-scrim{ display:none; } }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; padding:clamp(6rem,8vw,7rem) clamp(1rem,4vw,2rem) clamp(2.5rem,5vw,3.5rem);
  background:
    radial-gradient(120% 90% at 80% -10%, #ffffff 0%, transparent 55%),
    radial-gradient(120% 100% at 10% 110%, var(--cream) 0%, transparent 45%),
    linear-gradient(160deg, #f3f8fa 0%, #dde9ef 55%, #e6f0f4 100%);
  overflow:hidden;
}
.hero-grid{
  max-width:var(--wrap); margin:0 auto; position:relative; z-index:2;
  display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(2rem,5vw,4.5rem);
  align-items:center;
}
.eyebrow{
  display:inline-flex; align-items:center; gap:.6rem;
  background:rgba(255,255,255,.7); border:1px solid var(--line);
  padding:.5rem 1rem; border-radius:999px; font-size:.82rem; font-weight:500;
  color:var(--slate-deep); box-shadow:var(--shadow-sm); margin-bottom:1.4rem;
}
.eyebrow .dot{
  width:8px; height:8px; border-radius:50%; background:var(--slate);
  box-shadow:0 0 0 0 rgba(95,125,146,.5); animation:pulse 2.6s infinite;
}
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(95,125,146,.45); }
  70%{ box-shadow:0 0 0 9px rgba(95,125,146,0); }
  100%{ box-shadow:0 0 0 0 rgba(95,125,146,0); }
}
.hero h1{ margin-bottom:1.3rem; }
.hero-lede{ font-size:1.18rem; color:#4d6270; max-width:44ch; margin-bottom:1.9rem; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:.9rem; margin-bottom:2rem; }
.hero-meta{
  display:flex; flex-wrap:wrap; gap:.6rem 1.4rem; font-size:.86rem; color:var(--slate);
  padding-top:1.3rem; border-top:1px solid var(--line);
}
.hero-meta li{ position:relative; padding-left:1.1rem; }
.hero-meta li::before{
  content:""; position:absolute; left:0; top:.62em; width:6px; height:6px;
  border-radius:50%; background:var(--slate-soft);
}

/* hero provider byline */
.hero-byline{
  font-family:var(--serif); font-size:clamp(1.15rem,2.3vw,1.5rem);
  color:var(--slate-deep); margin:-.4rem 0 1.4rem; line-height:1.3;
}
.hero-byline strong{ font-weight:600; color:var(--slate); }
.hero-byline span{
  display:block; font-family:var(--sans); font-size:.8rem; font-weight:500;
  letter-spacing:.12em; text-transform:uppercase; color:var(--slate-soft); margin-top:.3rem;
}

/* hero media */
.hero-media{ position:relative; }
.hero-photo{
  aspect-ratio:3/4; border-radius:180px 180px 24px 24px;
  background-size:cover; background-position:center;
  box-shadow:var(--shadow); position:relative; z-index:2;
  border:6px solid rgba(255,255,255,.7);
}
.hero-photo-glow{
  position:absolute; inset:-8% -12% -12% -8%; z-index:1;
  background:radial-gradient(60% 60% at 60% 30%, rgba(255,255,255,.9), transparent 70%);
  filter:blur(6px);
}

/* hero ripple motif */
.hero-ripples{ position:absolute; top:14%; right:8%; width:340px; height:340px; z-index:1; pointer-events:none; opacity:.5; }
.hero-ripples .ripple{
  position:absolute; inset:0; margin:auto; border:1.5px solid var(--slate-soft);
  border-radius:50%; opacity:0;
  animation:ripple 6s var(--ease) infinite;
}
.hero-ripples .r2{ animation-delay:2s; }
.hero-ripples .r3{ animation-delay:4s; }
.hero-ripples .drop{
  position:absolute; top:50%; left:50%; width:10px; height:10px; margin:-5px 0 0 -5px;
  border-radius:50%; background:radial-gradient(circle at 35% 30%, #fff, var(--slate-soft));
  box-shadow:0 4px 10px rgba(95,125,146,.4);
  animation:drop 6s var(--ease) infinite;
}
@keyframes ripple{
  0%{ transform:scale(.15); opacity:.7; }
  80%{ opacity:.05; }
  100%{ transform:scale(1); opacity:0; }
}
@keyframes drop{
  0%,100%{ transform:translateY(0) scale(1); }
  50%{ transform:translateY(-6px) scale(.9); }
}

/* ============================================================
   VALUES ROW
   ============================================================ */
.values{ background:var(--white); border-top:1px solid var(--line); }
.values ul{
  max-width:var(--wrap); margin:0 auto;
  display:grid; grid-template-columns:repeat(4,1fr);
  padding:clamp(1.4rem,2.6vw,1.9rem) clamp(1rem,4vw,2rem);
}
.values li{
  display:flex; flex-direction:column; align-items:center; gap:.55rem;
  color:var(--slate-deep); position:relative; padding:.3rem 1rem;
}
.values li:not(:last-child)::after{
  content:""; position:absolute; right:0; top:50%; transform:translateY(-50%);
  height:46px; width:1px; background:var(--line);
}
.values svg{ width:38px; height:38px; color:var(--slate); }
.v-name{
  font-family:var(--serif); font-size:1.45rem; font-style:italic; color:var(--slate-deep);
}

/* ============================================================
   INTRO
   ============================================================ */
.intro{ padding:clamp(4rem,8vw,7rem) clamp(1rem,4vw,2rem); }
.intro-inner{ max-width:820px; margin:0 auto; text-align:center; }
.intro-lead{
  font-family:var(--serif); font-size:clamp(1.5rem,3.2vw,2.15rem);
  line-height:1.32; color:var(--slate-deep); font-weight:400; margin-bottom:1.4rem;
}
.intro-note{ font-size:1.1rem; color:#576b76; max-width:56ch; margin:0 auto; }
.intro-note strong{ color:var(--slate-deep); }

/* ============================================================
   ABOUT
   ============================================================ */
.about{
  padding:clamp(4rem,8vw,7rem) clamp(1rem,4vw,2rem);
  background:linear-gradient(180deg, var(--mist) 0%, #e5eff3 100%);
}
.about-grid{
  max-width:var(--wrap); margin:0 auto;
  display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(2rem,6vw,5rem);
  align-items:center;
}
.about-media{ position:relative; }
/* provider photo card (portrait + name badge; graceful monogram until the
   real photo is dropped at assets/laura-gonzales.jpg) */
.provider-card{
  position:relative; margin:0; aspect-ratio:4/5; max-width:400px;
  border-radius:26px; overflow:hidden;
  border:8px solid #fff; box-shadow:var(--shadow);
  background:linear-gradient(160deg,#dceaf0 0%,#c3d8e2 100%);
  rotate:-2deg; transition:rotate .5s var(--ease);
}
.provider-card:hover{ rotate:0deg; }
.provider-monogram{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-family:var(--script); font-size:7rem; color:#fff; opacity:.6;
  text-shadow:0 8px 24px rgba(63,90,109,.25);
}
.provider-card img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1;
}
.provider-badge{
  position:absolute; left:0; right:0; bottom:0; z-index:2;
  display:flex; flex-direction:column; gap:.06rem; padding:1.7rem 1.3rem .95rem;
  background:linear-gradient(to top, rgba(44,65,79,.94), rgba(44,65,79,.5) 55%, transparent);
  color:#fff;
}
.pb-name{ font-family:var(--serif); font-size:1.5rem; font-weight:600; line-height:1.1; }
.pb-cred{ font-family:var(--sans); font-size:.72rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; opacity:.92; margin-top:.15rem; }
.pb-role{ font-family:var(--sans); font-size:.85rem; opacity:.85; }
.about-verse-chip{
  position:absolute; top:-16px; left:-14px; z-index:3;
  background:var(--slate-deep); color:#eaf2f6; padding:.8rem 1.25rem;
  border-radius:14px; box-shadow:var(--shadow-sm); rotate:-3deg;
}
.about-verse-chip span{ font-family:var(--serif); font-style:italic; font-size:1.2rem; }
.about-copy h2{ margin:.4rem 0 1.3rem; }
.about-copy p{ color:#4d6270; font-size:1.06rem; }
.pull{
  margin:1.8rem 0; padding:1.2rem 0 1.2rem 1.6rem;
  border-left:3px solid var(--slate); font-family:var(--serif);
  font-size:1.4rem; font-style:italic; color:var(--slate-deep); line-height:1.4;
}
.pull strong{ color:var(--slate); font-style:normal; }
.signoff{ font-family:var(--serif); font-style:italic; font-size:1.2rem; color:var(--slate); margin:1.4rem 0 0; line-height:1.4; }
.signoff span{ font-style:normal; font-weight:600; letter-spacing:.04em; }

/* ============================================================
   SPECIALTIES
   ============================================================ */
.specialties{ padding:clamp(4rem,8vw,7rem) clamp(1rem,4vw,2rem); }
.section-head{ max-width:var(--wrap); margin:0 auto 2.8rem; }
.section-head h2{ margin-bottom:.7rem; }

.top-specialties{
  max-width:var(--wrap); margin:0 auto 3rem;
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem;
}
.spec-feature{
  position:relative; padding:2.4rem 1.8rem 2rem; border-radius:20px;
  background:linear-gradient(165deg,#fff, #f2f8fa);
  border:1px solid var(--line); box-shadow:var(--shadow-sm);
  overflow:hidden; transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.spec-feature::before{
  content:""; position:absolute; top:-40px; right:-40px; width:130px; height:130px;
  border-radius:50%; border:1px solid var(--line); opacity:.7;
}
.spec-feature::after{
  content:""; position:absolute; top:-20px; right:-20px; width:90px; height:90px;
  border-radius:50%; border:1px solid var(--line); opacity:.5;
}
.spec-feature:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.spec-num{
  font-family:var(--serif); font-size:1rem; color:var(--slate-soft);
  letter-spacing:.1em; display:block; margin-bottom:.8rem;
}
.spec-feature h3{ font-size:1.65rem; margin-bottom:.7rem; color:var(--slate-deep); }
.spec-feature p{ color:#576b76; margin:0; font-size:1rem; }

/* expertise — columned, not a wall */
.expertise{
  max-width:var(--wrap); margin:0 auto; padding:2.4rem clamp(1.4rem,4vw,3rem);
  background:var(--white); border-radius:22px; border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}
.expertise-title{ font-family:var(--serif); font-size:1.35rem; color:var(--slate); margin-bottom:1.4rem; font-style:italic; }
.expertise-cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:.4rem 2.4rem; }
.expertise-cols ul{ display:flex; flex-direction:column; gap:.15rem; }
.expertise-cols li{
  padding:.5rem 0 .5rem 1.5rem; position:relative; color:#4d6270;
  font-size:.98rem; border-bottom:1px solid #eef3f5;
}
.expertise-cols li::before{
  content:""; position:absolute; left:0; top:.95em; width:7px; height:7px;
  border-radius:50%; border:1.5px solid var(--slate-soft);
}

/* ============================================================
   THERAPIES (dark band)
   ============================================================ */
.therapies{
  background:
    radial-gradient(90% 120% at 20% 0%, #4a6577 0%, transparent 60%),
    linear-gradient(160deg, var(--slate-deep) 0%, var(--slate-ink) 100%);
  color:#dce8ee; padding:clamp(4rem,8vw,7rem) clamp(1rem,4vw,2rem);
  position:relative; overflow:hidden;
}
.therapies::before{
  content:""; position:absolute; inset:0 0 auto 0; height:40%;
  background:url("assets/water-band.jpg") center/cover no-repeat;
  opacity:.12; pointer-events:none;
  -webkit-mask-image:linear-gradient(to bottom, #000, transparent);
  mask-image:linear-gradient(to bottom, #000, transparent);
}
.therapies-inner{ max-width:var(--wrap); margin:0 auto; position:relative; }
.on-dark h2, .on-dark .section-kicker{ color:#fff; }
.on-dark .section-kicker{ color:#a9c4d2; }
.on-dark .section-sub{ color:#b9cdd7; }
.therapy-tags{
  display:flex; flex-wrap:wrap; gap:.7rem; margin-top:2rem;
}
.therapy-tags li{
  padding:.6rem 1.15rem; border-radius:999px; font-size:.92rem;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.18);
  color:#e3eef3; transition:background .3s var(--ease), transform .3s var(--ease), border-color .3s;
}
.therapy-tags li:hover{ background:rgba(255,255,255,.14); border-color:rgba(255,255,255,.4); transform:translateY(-2px); }

/* ============================================================
   WHO I HELP
   ============================================================ */
.who{ padding:clamp(4rem,8vw,7rem) clamp(1rem,4vw,2rem); }
.who-grid{ max-width:var(--wrap); margin:0 auto; display:grid; gap:2.4rem; }
.who-head{ max-width:60ch; }
.who-head h2{ margin:.5rem 0 .8rem; }
.who-panels{ display:grid; grid-template-columns:1fr 1fr; gap:1.4rem; }
.who-panel{
  padding:2.2rem 2rem; border-radius:20px; background:linear-gradient(160deg,#fff,#eef5f8);
  border:1px solid var(--line); box-shadow:var(--shadow-sm);
  transition:transform .4s var(--ease);
}
.who-panel:hover{ transform:translateY(-5px); }
.who-panel svg{ width:44px; height:44px; color:var(--slate); margin-bottom:1rem; }
.who-panel h3{ margin-bottom:.5rem; }
.who-panel p{ color:#576b76; margin:0; }

.who-ages{ display:flex; align-items:center; flex-wrap:wrap; gap:1.4rem 2rem; padding-top:.5rem; }
.ages-label{ font-family:var(--sans); font-size:.76rem; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:var(--slate); }
.ages-track{ display:flex; flex-wrap:wrap; gap:1rem; }
.ages-track li{
  display:flex; flex-direction:column; gap:.15rem;
  padding:.7rem 1.3rem; border-radius:14px; background:var(--white);
  border:1px solid var(--line); color:#576b76; font-size:.9rem;
}
.ages-track span{ font-family:var(--serif); font-size:1.4rem; color:var(--slate-deep); }

/* ============================================================
   CREDENTIALS
   ============================================================ */
.credentials{
  padding:clamp(4rem,8vw,7rem) clamp(1rem,4vw,2rem);
  background:linear-gradient(180deg,#e5eff3 0%, var(--mist) 100%);
}
.cred-grid{
  max-width:var(--wrap); margin:0 auto;
  display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(2rem,5vw,4rem); align-items:start;
}
.cred-block{
  background:linear-gradient(160deg, var(--slate) 0%, var(--slate-deep) 100%);
  color:#eaf3f7; padding:2.4rem 2rem; border-radius:22px; box-shadow:var(--shadow);
  position:sticky; top:100px;
}
.cred-block h3{ color:#fff; font-style:italic; margin-bottom:.4rem; }
.cred-big{ font-family:var(--serif); font-size:4.6rem; line-height:1; margin:.4rem 0 1rem; color:#fff; }
.cred-big span{ font-size:1.4rem; font-style:italic; opacity:.85; }
.cred-block p{ color:#cfe0e8; margin:0; }

.cred-facts{ display:grid; gap:0; }
.cred-facts > div{
  display:grid; grid-template-columns:minmax(120px,.4fr) 1fr; gap:1rem;
  padding:1.05rem 0; border-bottom:1px solid var(--line); align-items:baseline;
}
.cred-facts dt{ font-weight:600; font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--slate); }
.cred-facts dd{ margin:0; color:var(--slate-ink); font-size:1.05rem; }

.cred-provider{ font-size:1.12rem; color:var(--slate-deep); margin:.9rem 0 1.1rem; }
.cred-provider strong{ color:var(--slate); font-weight:600; letter-spacing:.03em; }
.pt-verified{
  display:inline-flex; align-items:center; gap:.5rem; text-decoration:none;
  background:#fff; border:1px solid var(--line); border-radius:999px;
  padding:.5rem .95rem; font-size:.86rem; color:var(--slate-deep);
  box-shadow:var(--shadow-sm); transition:border-color .3s var(--ease), transform .3s var(--ease);
}
.pt-verified:hover{ border-color:var(--slate-soft); transform:translateY(-2px); }
.pt-verified svg{ width:20px; height:20px; color:var(--slate); flex:none; }
.pt-verified strong{ font-weight:600; color:var(--slate); }

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews{
  padding:clamp(4rem,8vw,7rem) clamp(1rem,4vw,2rem);
  background:linear-gradient(180deg, var(--mist) 0%, #e5eff3 100%);
}
.section-head.center{ text-align:center; margin-left:auto; margin-right:auto; }
.rating-row{
  display:flex; flex-direction:column; align-items:center; gap:.55rem;
  margin-top:.7rem;
}
.stars{ color:#e0a94b; letter-spacing:.12em; font-size:1.15rem; line-height:1; }
.rating-row .stars{ font-size:1.5rem; }   /* larger, on its own line above the text */
.rating-detail{ margin:0; font-size:.98rem; color:var(--slate); }
.rating-detail strong{ font-family:var(--serif); font-weight:600; font-size:1.2rem; color:var(--slate-deep); }
/* prominent Google review stat strip */
.stars-lg{ display:block; font-size:1.9rem; margin:.5rem 0 .1rem; }
.review-stats{
  display:flex; justify-content:center; flex-wrap:wrap; gap:1rem 0;
  margin:.5rem 0 .4rem;
}
.rstat{ display:flex; flex-direction:column; align-items:center; gap:.25rem; padding:0 clamp(1.1rem,4vw,2.2rem); }
.rstat + .rstat{ border-left:1px solid var(--line); }
.rstat-num{ font-family:var(--serif); font-weight:600; font-size:clamp(2.1rem,5vw,2.6rem); line-height:1; color:var(--slate-deep); }
.rstat-num small{ font-size:.42em; color:var(--slate-soft); font-weight:400; }
.rstat-label{ font-family:var(--sans); font-size:.72rem; font-weight:600; letter-spacing:.13em; text-transform:uppercase; color:var(--slate); }
.review-source{ margin:.2rem 0 0; font-size:.92rem; font-style:italic; color:var(--slate-soft); }
.review-grid{
  max-width:var(--wrap); margin:2.2rem auto 2.4rem;
  display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:1.4rem;
}
.review-card{
  margin:0; background:#fff; border:1px solid var(--line); border-radius:20px;
  padding:2rem 2rem 1.6rem; box-shadow:var(--shadow-sm);
  display:flex; flex-direction:column; gap:.9rem;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.review-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.review-card .stars{ font-size:1.05rem; }
.review-card blockquote{
  margin:0; font-family:var(--serif); font-size:1.28rem; font-style:italic;
  line-height:1.45; color:var(--slate-deep);
}
.review-card figcaption{
  margin-top:auto; font-size:.82rem; font-weight:600; letter-spacing:.06em;
  text-transform:uppercase; color:var(--slate);
}
.review-card figcaption span{ font-weight:400; color:var(--slate-soft); text-transform:none; letter-spacing:0; }
.review-cta{ display:flex; flex-wrap:wrap; gap:.9rem; justify-content:center; }

/* ============================================================
   FEES
   ============================================================ */
.fees{ padding:clamp(4rem,8vw,7rem) clamp(1rem,4vw,2rem); }
.fees-grid{
  max-width:var(--wrap); margin:0 auto;
  display:grid; grid-template-columns:1.1fr .9fr; grid-template-areas:"head rate" "list list";
  gap:2.2rem clamp(2rem,5vw,4rem); align-items:center;
}
.fees-head{ grid-area:head; }
.fees-head h2{ margin:.5rem 0 .8rem; }
.fee-rate{
  grid-area:rate; justify-self:end; text-align:center;
  background:linear-gradient(160deg,#fff,#eef6f8); border:1px solid var(--line);
  border-radius:24px; padding:2rem 2.6rem; box-shadow:var(--shadow-sm); min-width:220px;
}
.rate-amount{ font-family:var(--serif); font-size:4.2rem; line-height:1; color:var(--slate-deep); margin:0; }
.rate-detail{ margin:.4rem 0 0; color:var(--slate); font-size:.98rem; }
.fee-list{
  grid-area:list; display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem;
  border-top:1px solid var(--line); padding-top:2rem;
}
.fee-list li{ display:flex; flex-direction:column; gap:.35rem; }
.fee-list strong{
  font-family:var(--sans); font-size:.76rem; font-weight:600; letter-spacing:.18em;
  text-transform:uppercase; color:var(--slate);
}
.fee-list span{ font-family:var(--serif); font-size:1.25rem; color:var(--slate-deep); line-height:1.3; }

/* ============================================================
   VERSE — full-bleed calm moment
   ============================================================ */
.verse{
  position:relative; overflow:hidden; text-align:center;
  padding:clamp(6rem,12vw,9rem) clamp(1.5rem,5vw,2rem);
  background:
    radial-gradient(70% 120% at 50% 0%, #f5efe3 0%, transparent 55%),
    linear-gradient(165deg, #dbe8ef 0%, #cadbe4 50%, #d5e3ea 100%);
}
.verse-ripple{ position:absolute; inset:0; display:grid; place-items:center; pointer-events:none; }
.verse-ripple span{
  position:absolute; width:120px; height:120px; border:1px solid rgba(95,125,146,.35);
  border-radius:50%; animation:ripple 7s var(--ease) infinite;
}
.verse-ripple span:nth-child(2){ animation-delay:2.3s; }
.verse-ripple span:nth-child(3){ animation-delay:4.6s; }
.verse blockquote{ margin:0; position:relative; z-index:2; }
.verse blockquote p{
  font-family:var(--serif); font-size:clamp(2rem,5vw,3.4rem); line-height:1.28;
  color:var(--slate-deep); font-weight:400; margin-bottom:1.2rem;
}
.verse blockquote em{ color:var(--slate); font-style:italic; }
.verse cite{ font-family:var(--sans); font-style:normal; letter-spacing:.24em; text-transform:uppercase; font-size:.8rem; font-weight:600; color:var(--slate); }

/* ============================================================
   CONTACT
   ============================================================ */
.contact{
  padding:clamp(4rem,8vw,7rem) clamp(1rem,4vw,2rem);
  background:linear-gradient(180deg,var(--mist) 0%, #e3edf1 100%);
}
.contact-grid{
  max-width:var(--wrap); margin:0 auto;
  display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(2rem,5vw,4rem); align-items:start;
}
.contact-info h2{ margin:.5rem 0 1rem; }
.contact-lede{ color:#4d6270; font-size:1.08rem; max-width:44ch; margin-bottom:1.8rem; }

.call-tile{
  display:flex; align-items:center; gap:1rem; text-decoration:none;
  background:linear-gradient(135deg,var(--slate),var(--slate-deep)); color:#fff;
  padding:1.1rem 1.4rem; border-radius:16px; box-shadow:0 14px 30px -14px rgba(63,90,109,.6);
  margin-bottom:1.6rem; transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.call-tile:hover{ transform:translateY(-3px); box-shadow:0 20px 40px -14px rgba(63,90,109,.7); }
.call-tile .i-phone{ width:1.8rem; height:1.8rem; }
.call-tile small{ display:block; font-size:.76rem; letter-spacing:.14em; text-transform:uppercase; opacity:.85; }
.call-tile strong{ font-size:1.5rem; font-weight:500; letter-spacing:.02em; }

.contact-meta{ display:grid; gap:1rem; }
.contact-meta li{ display:flex; flex-direction:column; gap:.15rem; color:var(--slate-ink); }
.contact-meta a{ color:var(--slate-deep); text-decoration:none; border-bottom:1px solid var(--line); width:max-content; transition:border-color .3s; }
.contact-meta a:hover{ border-color:var(--slate); }
.cm-label{ font-size:.72rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--slate); }

/* form */
.inquiry{
  background:#fff; border:1px solid var(--line); border-radius:24px;
  padding:clamp(1.6rem,4vw,2.6rem); box-shadow:var(--shadow);
}
.form-title{ font-family:var(--serif); font-size:1.7rem; color:var(--slate-deep); margin:0 0 .3rem; }
.form-sub{ font-size:.92rem; color:#6b7d87; margin-bottom:1.6rem; }
.field{ margin-bottom:1.1rem; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field label, .seg legend{
  display:block; font-size:.82rem; font-weight:500; color:var(--slate-deep);
  margin-bottom:.4rem; letter-spacing:.02em;
}
.field input, .field textarea{
  width:100%; font-family:var(--sans); font-size:1rem; color:var(--slate-ink);
  padding:.75rem .9rem; border:1px solid var(--line); border-radius:12px;
  background:#f8fbfc; transition:border-color .3s var(--ease), box-shadow .3s var(--ease), background .3s;
}
.field input:focus, .field textarea:focus{
  outline:none; border-color:var(--slate); background:#fff;
  box-shadow:0 0 0 4px rgba(95,125,146,.13);
}
.field textarea{ resize:vertical; min-height:110px; }
.seg{ border:none; padding:0; margin:0 0 1.1rem; }
.segments{ display:grid; grid-template-columns:1fr 1fr; gap:.6rem; }
.segments label{ margin:0; cursor:pointer; }
/* visually-hidden radio — MUST be size-clamped or it renders full-width and
   pushes horizontal overflow on narrow viewports */
.segments input{ position:absolute; width:1px; height:1px; margin:0; opacity:0; pointer-events:none; clip-path:inset(50%); }
.segments span{
  display:block; text-align:center; padding:.7rem; border-radius:12px;
  border:1px solid var(--line); background:#f8fbfc; color:var(--slate-ink);
  font-size:.95rem; transition:all .3s var(--ease);
}
.segments input:checked + span{
  background:linear-gradient(135deg,var(--slate),var(--slate-deep)); color:#fff;
  border-color:transparent; box-shadow:var(--shadow-sm);
}
.segments input:focus-visible + span{ outline:2.5px solid var(--slate); outline-offset:2px; }
.inquiry .btn-block{ margin-top:.5rem; }
.form-fallback{ font-size:.86rem; color:#6b7d87; margin:1rem 0 0; text-align:center; }
.form-fallback a{ color:var(--slate-deep); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--slate-ink); color:#c3d4dd; }
.footer-inner{
  max-width:var(--wrap); margin:0 auto; padding:clamp(3rem,6vw,4.5rem) clamp(1rem,4vw,2rem) 2.5rem;
  display:grid; grid-template-columns:1.2fr 2fr; gap:2.5rem;
}
.footer-brand .brand-script{ color:#e9f2f6; font-size:2.4rem; }
.footer-brand .brand-sub{ color:#9db6c3; }
.footer-tag{ margin-top:.8rem; color:#8fa8b6; font-size:.92rem; max-width:34ch; }
.footer-cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.footer-cols h4{ font-family:var(--sans); font-size:.76rem; letter-spacing:.2em; text-transform:uppercase; color:#8fa8b6; margin-bottom:1rem; font-weight:600; }
.footer-cols ul{ display:grid; gap:.6rem; }
.footer-cols a{ color:#c3d4dd; text-decoration:none; transition:color .3s; }
.footer-cols a:hover{ color:#fff; }
.footer-cols li{ font-size:.95rem; }

.footer-crisis{
  max-width:var(--wrap); margin:0 auto; padding:1.2rem clamp(1rem,4vw,2rem);
  border-top:1px solid rgba(255,255,255,.1); border-bottom:1px solid rgba(255,255,255,.1);
  font-size:.92rem; color:#b7cad4;
}
.footer-crisis strong{ color:#fff; }
.footer-crisis a{ color:#e9f2f6; font-weight:600; }
.footer-legal{
  max-width:var(--wrap); margin:0 auto; padding:1.8rem clamp(1rem,4vw,2rem) 3rem;
  font-size:.82rem; color:#7e97a5;
}
.footer-legal p{ margin:0 0 .5rem; }
.disclaimer{ max-width:80ch; }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1 !important; transform:none !important; transition:none; }
  .eyebrow .dot, .hero-ripples .ripple, .hero-ripples .drop, .verse-ripple span{ animation:none !important; }
  .btn:hover, .spec-feature:hover, .who-panel:hover, .call-tile:hover, .about-card:hover{ transform:none; }
  *{ scroll-behavior:auto !important; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:960px){
  .primary-nav, .header-call{ display:none; }
  .nav-toggle{ display:block; }
  .brand{ margin-right:auto; }

  .hero-grid{ grid-template-columns:1fr; }
  .hero-media{ max-width:380px; margin:0 auto; order:-1; }
  .hero-photo{ aspect-ratio:16/10; border-radius:26px; }
  .hero-ripples{ display:none; }

  .about-grid{ grid-template-columns:1fr; }
  /* When stacked, keep an explicit width so the media column can't shrink-wrap:
     the provider card's children are all absolutely positioned, so with auto
     margins the grid item would otherwise collapse to a sliver and the verse
     chip would float over the "My Approach" heading below it. */
  .about-media{ width:min(440px,100%); margin:0 auto 1.5rem; }
  .provider-card{ margin-inline:auto; }
  /* keep the decorative verse chip tucked onto the card, never past its edge */
  .about-verse-chip{ top:-14px; left:8px; }
  .cred-grid{ grid-template-columns:1fr; }
  .cred-block{ position:static; }
  .fees-grid{ grid-template-columns:1fr; grid-template-areas:"head" "rate" "list"; }
  .fee-rate{ justify-self:stretch; }
  .contact-grid{ grid-template-columns:1fr; }
  .footer-inner{ grid-template-columns:1fr; }
}

@media (max-width:720px){
  .top-specialties{ grid-template-columns:1fr; }
  .review-grid{ grid-template-columns:1fr; }
  /* keep the three review stats on one tidy row; equal columns so they never
     wrap into a lone stat with a dangling divider */
  .review-stats{ flex-wrap:nowrap; gap:0; width:100%; max-width:420px; margin-inline:auto; }
  .rstat{ flex:1; padding:0 .5rem; }
  .rstat-label{ font-size:.62rem; letter-spacing:.08em; }
  .expertise-cols{ grid-template-columns:1fr 1fr; gap:.3rem 1.4rem; }
  .fee-list{ grid-template-columns:1fr; }
  .who-panels{ grid-template-columns:1fr; }
  .values ul{ grid-template-columns:1fr 1fr; gap:1.6rem 0; }
  .values li:nth-child(2)::after{ display:none; }
  .values li:nth-child(2){ border-right:none; }
}

@media (max-width:460px){
  .expertise-cols{ grid-template-columns:1fr; }
  .field-row{ grid-template-columns:1fr; }
  .footer-cols{ grid-template-columns:1fr; }
  .hero-actions .btn{ width:100%; }
  .review-cta .btn{ width:100%; }
}

/* keep the 7-item nav + larger brand from crowding at mid widths */
@media (min-width:961px) and (max-width:1120px){
  .primary-nav ul{ gap:1.25rem; }
  .primary-nav a{ font-size:.9rem; }
  .brand-script{ font-size:2rem; }
  .header-inner{ gap:1rem; }
}
