/* =====================================================================
   DAYSTAR FAMILY CARE — Design System  ("Evergreen Homestead")
   Primary care / family medicine. Warm, rooted, calm.
   Fraunces (display) · Hanken Grotesk (body)
   Evergreen + sage + warm oat, honey "daystar" accent.
   ===================================================================== */

:root{
  /* greens */
  --pine:#0f2747; --evergreen:#1a3c70; --evergreen-700:#142e57; --evergreen-600:#27508c;
  --sage:#7e96bf; --sage-300:#aebfdb; --mint:#e6edf7; --mint-50:#eef3fb;
  /* warm neutrals */
  --oat:#f7f3ea; --oat-2:#f2ecdd; --cream:#fffdf7; --white:#ffffff;
  --ink:#1c2333; --ink-soft:#48566b; --muted:#6b7689; --muted-2:#8a93a3;
  --line:#e8e2d3; --line-2:#ddd5c2;
  /* accents */
  --honey:#e0a836; --honey-deep:#c68f23; --clay:#cf7a57; --rose:#d98c6a;
  --green-ok:#2f9e6b;
  /* gradients */
  --dawn:linear-gradient(178deg,#fdf6e8 0%,#fbedce 44%,#f6d6a3 100%);
  --sun-glow:radial-gradient(circle,rgba(224,168,54,.55) 0%,rgba(224,168,54,.12) 45%,transparent 70%);
  --evergreen-grad:linear-gradient(152deg,#27508c 0%,#0f2747 70%);
  --honey-grad:linear-gradient(96deg,#f0bd55 0%,#e0a836 52%,#cf8f2e 100%);
  /* shadows (green-tinted) */
  --sh-sm:0 1px 2px rgba(20,58,47,.05),0 4px 14px rgba(20,58,47,.07);
  --sh:0 2px 8px rgba(20,58,47,.06),0 22px 44px rgba(20,58,47,.11);
  --sh-lg:0 10px 30px rgba(20,58,47,.10),0 40px 84px rgba(20,58,47,.17);
  /* type + system */
  --ff-display:'Plus Jakarta Sans',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --ff-body:'Inter',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --wrap:1240px;
  --r:18px; --r-sm:12px; --r-lg:28px; --r-pill:999px;
  --ease:cubic-bezier(.22,.61,.36,1); --ease-out:cubic-bezier(.16,1,.3,1);
}

/* ---------- base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; overflow-x:clip; }
body{ overflow-x:clip; }
body{ margin:0; font-family:var(--ff-body); color:var(--ink); background:var(--oat);
  font-size:17px; line-height:1.65; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
img{ max-width:100%; display:block; }
.ico{ width:1.2em; height:1.2em; flex:none; vertical-align:middle; }
a{ color:var(--evergreen); text-decoration:none; transition:color .18s var(--ease); }
a:hover{ color:var(--honey-deep); }
::selection{ background:rgba(224,168,54,.24); color:var(--pine); }
h1,h2,h3,h4{ font-family:var(--ff-display); color:var(--evergreen); font-weight:700;
  line-height:1.08; letter-spacing:-.015em; margin:0 0 .5em; text-wrap:balance; }
h1{ font-size:clamp(2.4rem,1.5rem+3.2vw,4rem); letter-spacing:-.025em; line-height:1.02; }
h2{ font-size:clamp(1.9rem,1.3rem+2vw,2.95rem); letter-spacing:-.02em; }
h3{ font-size:1.3rem; }
p{ margin:0 0 1rem; text-wrap:pretty; }
strong{ font-weight:700; }
:focus-visible{ outline:3px solid var(--honey); outline-offset:3px; border-radius:6px; }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:24px; }
.sec{ position:relative; padding:clamp(60px,5vw+38px,108px) 0; }
.sec--tight{ padding:clamp(42px,3vw+26px,68px) 0; }
.sec--cream{ background:var(--cream); }
.sec--mint{ background:var(--mint-50); }
.sec--ever{ background:var(--evergreen-grad); color:#d7e0ef; }
.sec--ever h2,.sec--ever h3,.sec--ever h4{ color:#fff; }
.center{ text-align:center; }
.skip{ position:absolute; left:-999px; top:0; background:var(--evergreen); color:#fff; padding:.7rem 1.1rem; border-radius:0 0 10px 0; z-index:200; }
.skip:focus{ left:0; color:#fff; }

/* ---------- reveal (no-JS safe) ---------- */
.reveal{ opacity:1; }
html.js .reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease-out),transform .7s var(--ease-out); }
html.js .reveal.in{ opacity:1; transform:none; }
.rd-1{ transition-delay:.08s; } .rd-2{ transition-delay:.16s; } .rd-3{ transition-delay:.24s; } .rd-4{ transition-delay:.32s; }
@media(prefers-reduced-motion:reduce){ html.js .reveal{ opacity:1!important; transform:none!important; transition:none!important; } }

/* ---------- kicker / eyebrow / heads ---------- */
.kicker{ display:inline-flex; align-items:center; gap:.55rem; font-family:var(--ff-body); font-weight:700;
  font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--evergreen);
  background:var(--mint); border:1px solid var(--sage-300); padding:.42rem .8rem; border-radius:var(--r-pill); }
.kicker .lf{ width:15px; height:15px; color:var(--honey-deep); }
.eyebrow{ font-family:var(--ff-body); font-weight:700; font-size:.76rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--honey-deep); display:flex; align-items:center; gap:.6rem; margin:0 0 1rem; }
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--honey); border-radius:2px; }
.eyebrow svg{ width:17px; height:17px; flex:none; }
.center .eyebrow{ justify-content:center; }
.center .eyebrow::after{ content:""; width:26px; height:2px; background:var(--honey); border-radius:2px; }
.sec-head{ max-width:680px; margin:0 auto clamp(34px,3vw,56px); }
.sec-head.center{ text-align:center; }
.lead{ font-size:1.12rem; line-height:1.62; color:var(--ink-soft); margin:.7rem 0 0; }
.serif-accent{ font-style:italic; color:var(--honey-deep); }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.55rem; cursor:pointer;
  font-family:var(--ff-body); font-weight:700; font-size:1rem; line-height:1; white-space:nowrap;
  padding:.92rem 1.55rem; border-radius:var(--r-pill); border:1.6px solid transparent;
  transition:transform .16s var(--ease),box-shadow .24s,background .24s,color .24s,border-color .24s; }
.btn svg{ width:18px; height:18px; }
.btn:active{ transform:translateY(0) scale(.985); }
.btn-primary{ background:var(--evergreen); color:#fff; box-shadow:0 8px 22px rgba(20,58,47,.22); }
.btn-primary:hover{ background:var(--evergreen-700); color:#fff; transform:translateY(-2px); box-shadow:0 14px 30px rgba(20,58,47,.3); }
.btn-honey{ background:var(--honey-grad); color:#3a2a06; box-shadow:0 10px 24px rgba(224,168,54,.34); }
.btn-honey:hover{ color:#3a2a06; transform:translateY(-2px); box-shadow:0 15px 32px rgba(224,168,54,.44); }
.btn-ghost{ background:var(--cream); color:var(--evergreen); border-color:var(--line-2); }
.btn-ghost:hover{ color:var(--evergreen-700); border-color:var(--sage); transform:translateY(-2px); box-shadow:var(--sh-sm); }
.btn-white{ background:#fff; color:var(--evergreen); }
.btn-white:hover{ color:var(--evergreen-700); transform:translateY(-2px); box-shadow:var(--sh); }
.btn-outline-light{ background:transparent; color:#fff; border-color:rgba(255,255,255,.55); }
.btn-outline-light:hover{ background:rgba(255,255,255,.12); color:#fff; border-color:#fff; transform:translateY(-2px); }
.btn-lg{ padding:1.05rem 1.95rem; font-size:1.06rem; }
.btn-sm{ padding:.66rem 1.15rem; font-size:.9rem; }
.btn-block{ width:100%; }

/* ---------- topbar ---------- */
.topbar{ background:var(--pine); color:#b6c4dc; font-size:.85rem; }
.topbar a{ color:#cfd9ec; } .topbar a:hover{ color:#fff; }
.topbar-in{ display:flex; align-items:center; justify-content:space-between; gap:14px; min-height:42px; flex-wrap:wrap; }
.topbar-left,.topbar-right{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.tb-item{ display:inline-flex; align-items:center; gap:.4rem; }
.tb-item svg{ width:15px; height:15px; color:var(--honey); }
.lang-wrap{ position:relative; }
.lang-pill{ appearance:none; -webkit-appearance:none; background:rgba(255,255,255,.1); color:#fff; border:1px solid rgba(255,255,255,.22);
  border-radius:var(--r-pill); padding:.32rem 1.9rem .32rem .8rem; font:inherit; font-size:.8rem; cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23fff' stroke-width='2'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right .65rem center; }
.lang-pill option{ color:#1c2333; }
#google_translate_element{ position:absolute; height:0; overflow:hidden; opacity:0; pointer-events:none; }
@media(max-width:760px){
  .hide-sm{ display:none!important; }
  .topbar{ font-size:.8rem; }
  .topbar-in{ gap:8px; min-height:38px; flex-wrap:nowrap; }
  .topbar-left,.topbar-right{ gap:10px; flex-wrap:nowrap; min-width:0; }
  .topbar-left{ flex:1; min-width:0; }
  .tb-item{ font-size:.82rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .lang-pill{ font-size:.72rem; padding:.28rem 1.45rem .28rem .6rem; background-position:right .5rem center; }
}
@media(max-width:380px){
  .tb-item{ font-size:.78rem; }
  .lang-pill{ font-size:.68rem; }
}

/* ---------- header / nav ---------- */
.site-header{ position:sticky; top:0; z-index:90; background:rgba(247,243,234,.82);
  backdrop-filter:saturate(160%) blur(12px); -webkit-backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid transparent; transition:background .3s,border-color .3s,box-shadow .3s; }
.site-header.scrolled{ background:rgba(247,243,234,.94); border-bottom-color:var(--line); box-shadow:0 8px 30px rgba(20,58,47,.07); }
.nav{ display:flex; align-items:center; gap:16px; min-height:74px; }
.brand{ display:inline-flex; align-items:center; gap:.6rem; flex:none; }
.brand-mark{ width:38px; height:38px; }
.brand-logo{ height:56px; width:auto; display:block; }
@media(max-width:560px){ .brand-logo{ height:44px; } }
.brand-mark-img{ height:46px; width:auto; display:block; }
@media(max-width:560px){ .brand-mark-img{ height:40px; } }
.site-footer .brand-mark-img{ height:46px; }
.brand-txt{ display:flex; flex-direction:column; line-height:1; }
.brand-txt .bt-1{ font-family:var(--ff-display); font-weight:600; font-size:1.18rem; color:var(--evergreen); letter-spacing:-.01em; }
.brand-txt .bt-2{ font-family:var(--ff-body); font-weight:700; font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--honey-deep); margin-top:2px; }
.site-footer .brand-txt .bt-1{ color:#fff; } .site-footer .brand-txt .bt-2{ color:var(--honey); }
.primary-nav{ margin-left:auto; }
.nav-links{ display:flex; align-items:center; gap:2px; list-style:none; margin:0; padding:0; }
.nav-links>li>a{ display:inline-flex; align-items:center; gap:.3rem; padding:.55rem .62rem; border-radius:10px;
  font-weight:600; font-size:.96rem; color:var(--ink); }
.nav-links>li>a:hover,.nav-links>li>a.active{ color:var(--evergreen); background:var(--mint); }
.nav-links .caret{ width:14px; height:14px; transform:rotate(90deg); opacity:.6; }
.has-drop{ position:relative; }
.dropdown{ position:absolute; top:calc(100% + 8px); left:50%; transform:translateX(-50%) translateY(8px);
  min-width:520px; background:var(--cream); border:1px solid var(--line); border-radius:var(--r);
  box-shadow:var(--sh-lg); padding:12px; display:grid; grid-template-columns:1fr 1fr; gap:4px;
  opacity:0; visibility:hidden; transition:opacity .2s,transform .2s; z-index:60; }
.dropdown.narrow{ min-width:330px; grid-template-columns:1fr; }
.has-drop:hover .dropdown,.has-drop:focus-within .dropdown{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.dropdown a{ display:flex; gap:.7rem; align-items:flex-start; padding:11px 12px; border-radius:12px; color:var(--ink); }
.dropdown a:hover{ background:var(--mint); }
.dropdown .di{ width:38px; height:38px; border-radius:10px; flex:none; display:grid; place-items:center; background:var(--mint); color:var(--evergreen); }
.dropdown .di svg{ width:20px; height:20px; }
.dropdown strong{ display:block; font-family:var(--ff-display); font-weight:600; font-size:.98rem; color:var(--evergreen); }
.dropdown small{ display:block; font-size:.8rem; color:var(--muted); margin-top:1px; }
.dropdown .drop-all{ grid-column:1/-1; justify-content:center; background:var(--mint-50); margin-top:4px; }
.dropdown .drop-all strong{ color:var(--evergreen); }
.nav-cta{ display:flex; align-items:center; gap:10px; flex:none; }
.menu-toggle{ display:none; width:46px; height:46px; border-radius:12px; border:1.6px solid var(--line-2);
  background:var(--cream); color:var(--evergreen); cursor:pointer; align-items:center; justify-content:center; }
.menu-toggle svg{ width:22px; height:22px; }

@media(max-width:1160px){ .hide-md{ display:none!important; } .primary-nav{ display:none; } .menu-toggle{ display:inline-flex; } }

/* ---------- mobile nav ---------- */
.nav-backdrop{ position:fixed; inset:0; background:rgba(20,40,32,.5); opacity:0; visibility:hidden; transition:.3s; z-index:95; }
.nav-backdrop.show{ opacity:1; visibility:visible; }
.mobile-nav{ position:fixed; top:0; right:0; width:min(360px,86vw); height:100dvh; background:var(--cream);
  z-index:100; padding:78px 18px 28px; overflow-y:auto; transform:translateX(100%); visibility:hidden;
  transition:transform .34s var(--ease),visibility .34s; box-shadow:var(--sh-lg); display:flex; flex-direction:column; gap:4px; }
.mobile-nav.open{ transform:none; visibility:visible; }
.mobile-nav>a{ display:flex; align-items:center; gap:.7rem; padding:14px 14px; border-radius:12px; font-weight:600; color:var(--ink); font-size:1.02rem; }
.mobile-nav>a:hover{ background:var(--mint); color:var(--evergreen); }
.mobile-nav svg{ width:20px; height:20px; color:var(--evergreen); }
.mnav-group{ border-radius:12px; }
.mnav-toggle{ width:100%; display:flex; align-items:center; gap:.7rem; padding:14px 14px; border:0; background:none;
  font:inherit; font-weight:600; font-size:1.02rem; color:var(--ink); cursor:pointer; border-radius:12px; }
.mnav-toggle svg:last-child{ margin-left:auto; transform:rotate(90deg); transition:transform .25s; width:16px; height:16px; }
.mnav-toggle.active{ background:var(--mint); color:var(--evergreen); }
.mnav-toggle.active svg:last-child{ transform:rotate(-90deg); }
.mnav-sub{ max-height:0; overflow:hidden; transition:max-height .3s var(--ease); }
.mnav-sub.open{ max-height:640px; }
.mnav-sub a{ display:flex; align-items:center; gap:.6rem; padding:11px 14px 11px 26px; font-size:.94rem; color:var(--ink-soft); border-radius:10px; }
.mnav-sub a:hover{ background:var(--mint); color:var(--evergreen); }
.mnav-sub a.sub svg{ width:17px; height:17px; }
.mobile-nav .mt{ margin-top:12px; }
.mobile-nav .btn{ margin-top:8px; }

/* ---------- sticky mobile CTA ---------- */
.sticky-cta{ position:fixed; left:0; right:0; bottom:0; z-index:80; display:none; gap:10px; padding:10px 14px;
  background:rgba(255,253,247,.92); backdrop-filter:blur(10px); border-top:1px solid var(--line); }
.sticky-cta>.btn{ flex:1 1 0; min-width:0; justify-content:center; padding-inline:12px; white-space:nowrap; }
@media(max-width:760px){ .sticky-cta{ display:flex; } body{ padding-bottom:74px; } }
@media(max-width:360px){ .sticky-cta{ gap:8px; padding:8px 10px; } .sticky-cta>.btn{ font-size:.9rem; padding-inline:10px; } }

/* ---------- loader ---------- */
#dfc-loader{ position:fixed; inset:0; z-index:300; display:grid; place-items:center; background:var(--oat); transition:opacity .5s; }
#dfc-loader.done{ opacity:0; pointer-events:none; }
.dl-day{ transform-origin:60px 33px; animation:dl-pop .7s var(--ease-out) both; }
.dl-s{ animation:dl-pop .6s var(--ease-out) both; } .dl-s1{ animation-delay:.12s; } .dl-s2{ animation-delay:.22s; } .dl-s3{ animation-delay:.32s; }
.dl-lines{ stroke-dasharray:120; stroke-dashoffset:120; animation:dl-draw .9s .15s var(--ease-out) forwards; }
@keyframes dl-pop{ from{ opacity:0; transform:scale(.4); } to{ opacity:1; transform:scale(1); } }
@keyframes dl-draw{ to{ stroke-dashoffset:0; } }

/* =====================================================================
   HERO — arched "dawn window" + family constellation
   ===================================================================== */
.hero{ position:relative; overflow:hidden; padding:clamp(40px,4vw,76px) 0 clamp(60px,5vw,104px);
  background:radial-gradient(70% 50% at 100% 0,rgba(251,237,206,.7) 0%,transparent 60%),
             radial-gradient(60% 60% at -5% 100%,rgba(231,240,234,.9) 0%,transparent 60%), var(--oat); }
.hero-blob{ position:absolute; border-radius:50%; filter:blur(8px); z-index:0; pointer-events:none; }
.hero-blob.b1{ width:340px; height:340px; top:-90px; left:-110px; background:radial-gradient(circle,rgba(169,195,180,.5),transparent 70%); }
.hero-blob.b2{ width:280px; height:280px; bottom:-60px; right:18%; background:radial-gradient(circle,rgba(224,168,54,.16),transparent 70%); }
.hero-inner{ position:relative; z-index:2; display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,4vw,68px); align-items:center; }
.hero-visual{ position:relative; }

.hero-copy{ max-width:600px; }
.hero h1{ margin:.9rem 0 0; }
.hero h1 .u{ position:relative; white-space:nowrap; color:var(--evergreen); }
.hero h1 .u::after{ content:""; position:absolute; left:0; right:0; bottom:.06em; height:.36em;
  background:linear-gradient(180deg,transparent 60%,rgba(224,168,54,.45) 60%); z-index:-1; border-radius:3px; }
.hero-sub{ font-size:clamp(1.05rem,1rem+.35vw,1.24rem); line-height:1.6; color:var(--ink-soft); margin:1.35rem 0 0; max-width:34em; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:.7rem; margin:1.9rem 0 0; }
.hero-trust{ display:flex; align-items:center; gap:1rem 1.3rem; flex-wrap:wrap; margin:1.7rem 0 0; }
.stars{ display:inline-flex; gap:2px; color:var(--honey); } .stars svg{ width:18px; height:18px; }
.hero-trust .tx{ font-size:.92rem; color:var(--ink-soft); font-weight:600; } .hero-trust .tx b{ color:var(--ink); }
.hero-trust .dot{ width:5px; height:5px; border-radius:50%; background:var(--sage-300); }
.hero-trust .ti{ display:inline-flex; align-items:center; gap:.4rem; font-size:.92rem; font-weight:600; color:var(--ink); }
.hero-trust .ti svg{ width:17px; height:17px; color:var(--green-ok); }

/* arched window */
.hero-sky{ position:relative; aspect-ratio:1/1.04; border-radius:300px 300px 26px 26px; overflow:hidden;
  border:1px solid var(--line); box-shadow:var(--sh-lg); background:var(--dawn); }
.hero-sky-inner{ position:absolute; inset:0; }
.hero-photo{ width:100%; height:100%; object-fit:cover; object-position:50% 26%; display:block; }
.hero-sky::after{ content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.45); }
.hero-sun{ position:absolute; left:50%; bottom:18%; width:60%; aspect-ratio:1; transform:translateX(-50%);
  background:var(--sun-glow); border-radius:50%; }
.hero-sun-core{ position:absolute; left:50%; bottom:30%; transform:translateX(-50%); width:84px; height:84px; border-radius:50%;
  background:radial-gradient(circle at 40% 38%,#ffe6a6,#f4b740 60%,#e89a2f); box-shadow:0 0 50px rgba(232,154,47,.5); }
.hero-constellation{ position:absolute; inset:0; }
.hero-constellation .cl{ stroke:rgba(29,74,61,.32); stroke-width:1; }
.hero-constellation .st{ transform-box:fill-box; transform-origin:center; animation:twinkle 4s ease-in-out infinite; }
.hero-constellation .st2{ animation-delay:.8s; } .hero-constellation .st3{ animation-delay:1.6s; } .hero-constellation .st4{ animation-delay:2.4s; }
.hero-hill{ position:absolute; left:0; right:0; bottom:0; height:34%;
  background:linear-gradient(180deg,#e9c887,#dcae5e); border-radius:50% 50% 0 0/26px 26px 0 0; }
.hero-hill::before{ content:""; position:absolute; inset:0; background:radial-gradient(120% 80% at 50% 0,rgba(255,255,255,.25),transparent 60%); }
@keyframes twinkle{ 0%,100%{ opacity:.55; transform:scale(.9); } 50%{ opacity:1; transform:scale(1.12); } }

/* floating warm info chips */
.hero-chip{ position:absolute; z-index:3; display:flex; align-items:center; gap:.6rem; background:var(--cream);
  border:1px solid var(--line); border-radius:14px; padding:.6rem .8rem; box-shadow:var(--sh); animation:floaty 7s ease-in-out infinite; }
.hero-chip .ci{ width:34px; height:34px; border-radius:9px; display:grid; place-items:center; flex:none; color:#fff; }
.hero-chip .ci svg{ width:18px; height:18px; }
.hero-chip .ci.ever{ background:var(--evergreen); } .hero-chip .ci.honey{ background:var(--honey-grad); color:#3a2a06; }
.hero-chip small{ display:block; font-size:.68rem; color:var(--muted); font-weight:600; }
.hero-chip strong{ display:block; font-family:var(--ff-display); font-size:.92rem; color:var(--evergreen); }
.hero-chip.c1{ top:12%; left:-5%; animation-delay:-1s; } .hero-chip.c2{ bottom:8%; right:-6%; animation-delay:-4s; }
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-9px); } }

/* ---------- wave divider ---------- */
.wave{ display:block; width:100%; height:60px; }
.wave path{ fill:var(--cream); }
.wave--oat path{ fill:var(--oat); } .wave--mint path{ fill:var(--mint-50); }

/* =====================================================================
   TRUST STRIP
   ===================================================================== */
.trust-strip{ background:var(--cream); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.trust-in{ display:flex; align-items:center; justify-content:center; gap:1.4rem; flex-wrap:wrap; padding:16px 0; }
.trust-in .t{ display:inline-flex; align-items:center; gap:.5rem; font-size:.92rem; font-weight:600; color:var(--ink); }
.trust-in .t svg{ width:18px; height:18px; color:var(--evergreen); }
.trust-in .t.rate svg{ color:var(--honey); }
.trust-in .sep{ width:5px; height:5px; border-radius:50%; background:var(--line-2); }

/* =====================================================================
   STATS
   ===================================================================== */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.stat{ background:var(--cream); border:1px solid var(--line); border-radius:var(--r); padding:26px 22px; text-align:center; box-shadow:var(--sh-sm); }
.stat .n{ font-family:var(--ff-display); font-weight:600; font-size:clamp(2rem,1.4rem+1.6vw,2.7rem); color:var(--evergreen); line-height:1; letter-spacing:-.02em; }
.stat .n .u{ color:var(--honey-deep); }
.stat .l{ margin-top:.5rem; font-size:.94rem; color:var(--ink-soft); font-weight:600; }
.stat .s{ font-size:.78rem; color:var(--muted-2); margin-top:.15rem; }

/* =====================================================================
   CARE / SERVICES GRID
   ===================================================================== */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.card{ position:relative; display:flex; flex-direction:column; background:var(--cream); border:1px solid var(--line);
  border-radius:var(--r); padding:26px 24px; box-shadow:var(--sh-sm); text-decoration:none; color:inherit; overflow:hidden;
  transition:transform .3s var(--ease-out),box-shadow .3s,border-color .3s; }
.card::after{ content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none; opacity:0; transition:opacity .3s;
  background:radial-gradient(360px circle at var(--mx,50%) var(--my,0%),rgba(224,168,54,.08),transparent 60%); }
.card:hover{ transform:translateY(-6px); box-shadow:var(--sh); border-color:var(--sage-300); }
.card:hover::after{ opacity:1; }
.card-top{ display:flex; align-items:flex-start; justify-content:space-between; gap:.6rem; margin-bottom:1rem; }
.ico-tile{ width:52px; height:52px; border-radius:14px; display:grid; place-items:center; flex:none;
  background:var(--mint); color:var(--evergreen); border:1px solid var(--sage-300); transition:.3s; }
.ico-tile svg{ width:26px; height:26px; }
.card:hover .ico-tile{ background:var(--honey-grad); border-color:transparent; color:#3a2a06; }
.chip{ font-family:var(--ff-body); font-size:.62rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; padding:.32rem .6rem; border-radius:var(--r-pill); }
.chip.inperson{ background:var(--mint); color:var(--evergreen); }
.chip.virtual{ background:rgba(207,122,87,.13); color:#b35b39; }
.card h3{ margin:0 0 .4rem; font-size:1.22rem; }
.card p{ font-size:.95rem; color:var(--ink-soft); margin:0 0 1.1rem; line-height:1.55; }
.card .more{ margin-top:auto; display:inline-flex; align-items:center; gap:.4rem; font-weight:700; font-size:.85rem;
  letter-spacing:.02em; color:var(--evergreen); }
.card .more svg{ width:16px; height:16px; transition:transform .25s; }
.card:hover .more svg{ transform:translateX(4px); }

/* =====================================================================
   "WHY US" / VALUE EDITORIAL
   ===================================================================== */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,4vw,64px); align-items:center; }
.split.media-right .split-media{ order:2; }
.values{ list-style:none; padding:0; margin:1.5rem 0 0; display:grid; gap:1rem; }
.values li{ display:flex; gap:.9rem; align-items:flex-start; }
.values .vi{ width:44px; height:44px; border-radius:12px; flex:none; display:grid; place-items:center; background:var(--mint); color:var(--evergreen); border:1px solid var(--sage-300); }
.values .vi svg{ width:22px; height:22px; }
.values h4{ font-size:1.06rem; margin:.1rem 0 .25rem; }
.values p{ font-size:.94rem; color:var(--ink-soft); margin:0; line-height:1.55; }

/* portrait / illustration card */
.portrait{ position:relative; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--sh-lg); aspect-ratio:4/5;
  background:linear-gradient(157deg,#27508c 0%,#1a3c70 46%,#0f2747 100%); display:grid; place-items:center; }
.portrait::before{ content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(120% 90% at 80% -10%,rgba(224,168,54,.22),transparent 55%); }
.portrait .ph-note{ position:relative; color:rgba(255,255,255,.9); font-family:var(--ff-display); font-size:1.1rem; text-align:center; padding:30px 26px; }
.ph-note .bm-wrap{ display:inline-flex; }
.ph-rule{ width:46px; height:3px; border-radius:3px; background:var(--honey-grad); margin:16px auto 14px; }
.ph-tag{ color:#fff; font-size:1.16rem; line-height:1.42; }
.ph-sub{ display:block; margin-top:10px; font-family:var(--ff-body); font-size:.82rem; letter-spacing:.04em; color:rgba(255,255,255,.66); text-transform:uppercase; }
.portrait img{ width:100%; height:100%; object-fit:cover; }
.portrait-badge{ position:absolute; left:-16px; bottom:28px; background:var(--cream); border:1px solid var(--line);
  border-radius:16px; padding:14px 18px; box-shadow:var(--sh); }
.portrait-badge .pb-n{ font-family:var(--ff-display); font-weight:600; font-size:1.6rem; color:var(--evergreen); line-height:1; }
.portrait-badge .pb-l{ font-size:.78rem; color:var(--muted); margin-top:.25rem; max-width:150px; }
.portrait-roundel{ position:absolute; right:-12px; top:24px; background:var(--honey-grad); color:#3a2a06; font-weight:700;
  font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; padding:.6rem .95rem; border-radius:var(--r-pill); box-shadow:var(--sh); display:inline-flex; align-items:center; gap:.4rem; }
.portrait-roundel svg{ width:15px; height:15px; }

/* =====================================================================
   CONDITIONS chips
   ===================================================================== */
.cond-grid{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }
.cond{ display:inline-flex; align-items:center; gap:.5rem; background:var(--cream); border:1px solid var(--line);
  border-radius:var(--r-pill); padding:.7rem 1.15rem; font-weight:600; font-size:.96rem; color:var(--ink); transition:.22s; }
.cond:hover{ border-color:var(--sage); transform:translateY(-2px); box-shadow:var(--sh-sm); }
.cond::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--honey); }

/* =====================================================================
   PROVIDERS
   ===================================================================== */
.providers{ display:flex; flex-wrap:wrap; justify-content:center; gap:22px; }
.providers>*{ flex:1 1 300px; max-width:360px; }
.prov{ background:var(--cream); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; box-shadow:var(--sh-sm);
  transition:transform .3s var(--ease-out),box-shadow .3s; }
.prov:hover{ transform:translateY(-5px); box-shadow:var(--sh); }
.prov-photo{ aspect-ratio:1/1; background:linear-gradient(155deg,var(--mint),#dce4f2); display:grid; place-items:center; position:relative; }
.prov-photo img{ width:100%; height:100%; object-fit:cover; }
.prov-mono{ font-family:var(--ff-display); font-weight:600; font-size:3.4rem; color:var(--evergreen); opacity:.6; }
.prov-photo::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:40%; background:linear-gradient(transparent,rgba(20,58,47,.06)); }
.prov-body{ padding:22px 22px 24px; }
.prov-body h3{ margin:0 0 .15rem; font-size:1.22rem; }
.prov-role{ font-family:var(--ff-body); font-weight:700; font-size:.82rem; letter-spacing:.04em; text-transform:uppercase; color:var(--honey-deep); }
.prov-body p{ font-size:.93rem; color:var(--ink-soft); margin:.7rem 0 0; line-height:1.55; }
.prov-tags{ display:flex; flex-wrap:wrap; gap:6px; margin-top:1rem; }
.prov-tags span{ font-size:.74rem; font-weight:600; color:var(--evergreen); background:var(--mint); border-radius:var(--r-pill); padding:.3rem .65rem; }

/* =====================================================================
   TESTIMONIALS carousel
   ===================================================================== */
.carousel{ position:relative; }
.c-viewport{ overflow:hidden; }
.c-track{ display:flex; gap:22px; transition:transform .55s var(--ease); will-change:transform; }
.c-slide{ flex:0 0 calc((100% - 44px)/3); box-sizing:border-box; }
.review{ height:100%; background:var(--cream); border:1px solid var(--line); border-radius:var(--r); padding:28px 26px; box-shadow:var(--sh-sm); display:flex; flex-direction:column; }
.review .stars{ margin-bottom:.85rem; }
.review blockquote{ margin:0 0 1.2rem; font-family:var(--ff-display); font-size:1.08rem; line-height:1.5; color:var(--ink); font-weight:500; }
.review .who{ display:flex; align-items:center; gap:.75rem; margin-top:auto; }
.review .av{ width:44px; height:44px; border-radius:50%; flex:none; display:grid; place-items:center; color:#fff; font-family:var(--ff-display); font-weight:600; background:var(--evergreen-grad); }
.review .who strong{ display:block; font-family:var(--ff-display); font-weight:600; font-size:.96rem; color:var(--evergreen); }
.review .who span{ font-size:.8rem; color:var(--muted); }
.review .src{ display:inline-flex; align-items:center; gap:.35rem; margin-top:.9rem; font-size:.74rem; color:var(--muted); }
.review .src svg{ width:14px; height:14px; color:var(--honey); }
.c-arrow{ position:absolute; top:-64px; width:44px; height:44px; border-radius:50%; border:1px solid var(--line-2); background:var(--cream);
  color:var(--evergreen); display:grid; place-items:center; cursor:pointer; box-shadow:var(--sh-sm); transition:.2s; }
.c-arrow:hover{ background:var(--evergreen); color:#fff; border-color:var(--evergreen); }
.c-arrow svg{ width:18px; height:18px; } .c-prev{ right:58px; } .c-prev svg{ transform:rotate(180deg); } .c-next{ right:8px; }
.c-dots{ display:flex; gap:8px; justify-content:center; margin-top:26px; }
.c-dots button{ width:8px; height:8px; border-radius:50%; border:0; background:var(--line-2); cursor:pointer; padding:0; transition:.2s; }
.c-dots button.active{ background:var(--evergreen); width:24px; border-radius:5px; }

/* =====================================================================
   INSURANCE marquee
   ===================================================================== */
.ins-marquee{ overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.ins-track{ display:flex; gap:14px; width:max-content; animation:marq 36s linear infinite; }
.ins-marquee:hover .ins-track{ animation-play-state:paused; }
.ins-card{ flex:none; min-width:170px; height:76px; display:grid; place-items:center; padding:0 22px; background:var(--cream);
  border:1px solid var(--line); border-radius:14px; font-family:var(--ff-display); font-weight:600; color:var(--evergreen); }
@keyframes marq{ to{ transform:translateX(-50%); } }

/* =====================================================================
   FAQ
   ===================================================================== */
.faq-grid{ display:grid; grid-template-columns:1.2fr .8fr; gap:clamp(28px,3.4vw,52px); align-items:start; }
.faq{ border-top:1px solid var(--line); margin-top:1.3rem; }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; text-align:left; background:none; border:0; cursor:pointer; font-family:var(--ff-display); font-weight:600;
  font-size:1.08rem; color:var(--evergreen); padding:19px 42px 19px 0; position:relative; }
.faq-q .qi{ position:absolute; right:0; top:50%; transform:translateY(-50%); width:28px; height:28px; border-radius:50%;
  border:1px solid var(--line-2); display:grid; place-items:center; color:var(--evergreen); transition:.3s; }
.faq-q .qi svg{ width:15px; height:15px; transition:.3s; }
.faq-q[aria-expanded="true"] .qi{ background:var(--evergreen); border-color:var(--evergreen); color:#fff; transform:translateY(-50%) rotate(90deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .35s var(--ease); }
.faq-a p{ padding:0 0 19px; margin:0; color:var(--ink-soft); font-size:.97rem; line-height:1.62; }
.aside-card{ background:var(--cream); border:1px solid var(--line); border-radius:var(--r); padding:28px; box-shadow:var(--sh); position:sticky; top:96px; }
.aside-card h3{ margin:0 0 1rem; }
.aside-list{ list-style:none; padding:0; margin:0 0 1.1rem; display:grid; gap:8px; }
.aside-list a{ display:flex; align-items:center; gap:.7rem; padding:13px 15px; border-radius:12px; background:var(--mint-50); border:1px solid var(--line); font-weight:600; font-size:.94rem; color:var(--ink); transition:.2s; }
.aside-list a:hover{ background:var(--evergreen); color:#fff; border-color:var(--evergreen); transform:translateX(3px); }
.aside-list a svg{ width:18px; height:18px; }
.aside-note{ background:var(--mint); border:1px solid var(--sage-300); border-radius:12px; padding:13px 15px; font-size:.86rem; color:var(--evergreen-700); }

/* =====================================================================
   CTA BANDS
   ===================================================================== */
.cta-band{ position:relative; overflow:hidden; border-radius:var(--r-lg); background:var(--evergreen-grad); color:#d7e0ef;
  padding:clamp(38px,4.4vw,64px); display:flex; gap:30px; align-items:center; justify-content:space-between; flex-wrap:wrap; }
.cta-band::before{ content:""; position:absolute; right:-110px; top:-130px; width:420px; height:420px; border-radius:50%; background:var(--sun-glow); }
.cta-band .ct{ position:relative; z-index:1; max-width:40ch; }
.cta-band h2{ color:#fff; margin:0 0 .55rem; }
.cta-band p{ color:#c4d2e6; margin:0; }
.cta-actions{ position:relative; z-index:1; display:flex; gap:.7rem; flex-wrap:wrap; }
.cta-stars{ position:absolute; inset:0; z-index:0; opacity:.5; }

/* =====================================================================
   INNER PAGE HERO
   ===================================================================== */
.page-hero{ position:relative; overflow:hidden; padding:clamp(48px,5vw,84px) 0 clamp(36px,4vw,60px);
  background:radial-gradient(60% 70% at 100% 0,rgba(251,237,206,.6),transparent 60%), var(--oat); border-bottom:1px solid var(--line); }
.crumbs{ font-size:.82rem; color:var(--muted); margin-bottom:1rem; display:flex; gap:.4rem; align-items:center; flex-wrap:wrap; }
.crumbs a{ color:var(--muted); } .crumbs a:hover{ color:var(--evergreen); }
.crumbs span{ color:var(--line-2); }
.page-hero h1{ max-width:18ch; }
.page-hero .lead{ max-width:60ch; }

/* prose for content pages */
.prose{ max-width:760px; }
.prose h2{ margin-top:2.2rem; font-size:1.7rem; }
.prose h3{ margin-top:1.6rem; }
.prose p{ color:var(--ink-soft); }
.prose ul{ margin:0 0 1.2rem; padding-left:0; list-style:none; display:grid; gap:.6rem; }
.prose ul li{ display:flex; gap:.6rem; align-items:flex-start; color:var(--ink-soft); }
.prose ul li::before{ content:""; width:20px; height:20px; flex:none; margin-top:2px; border-radius:50%; background:var(--mint);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231d4a3d' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 12l5 5L20 6'/%3E%3C/svg%3E"); background-size:13px; background-repeat:no-repeat; background-position:center; }

/* =====================================================================
   FORMS (appointment / contact)
   ===================================================================== */
.form-card{ background:var(--cream); border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(26px,3vw,40px); box-shadow:var(--sh); }
.field{ margin-bottom:16px; }
.field label{ display:block; font-weight:600; font-size:.9rem; color:var(--evergreen); margin-bottom:.4rem; }
.field input,.field select,.field textarea{ width:100%; font:inherit; font-size:1rem; color:var(--ink); background:var(--white);
  border:1.5px solid var(--line-2); border-radius:12px; padding:.8rem 1rem; transition:border-color .2s,box-shadow .2s; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--evergreen); box-shadow:0 0 0 4px rgba(29,74,61,.12); }
.field textarea{ resize:vertical; min-height:120px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-note{ font-size:.82rem; color:var(--muted); margin-top:.5rem; }
.form-success{ display:flex; align-items:center; gap:.6rem; background:linear-gradient(100deg,rgba(29,74,61,.08),rgba(224,168,54,.1)); border:1px solid rgba(29,74,61,.2); color:var(--evergreen); font-weight:600; padding:1rem 1.2rem; border-radius:16px; margin-bottom:1.4rem; }
.form-success svg{ width:22px; height:22px; flex:none; color:var(--evergreen); }

/* contact info cards */
.info-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.info-card{ background:var(--cream); border:1px solid var(--line); border-radius:var(--r); padding:24px; box-shadow:var(--sh-sm); }
.info-card .ii{ width:46px; height:46px; border-radius:12px; display:grid; place-items:center; background:var(--mint); color:var(--evergreen); border:1px solid var(--sage-300); margin-bottom:1rem; }
.info-card .ii svg{ width:23px; height:23px; }
.info-card h4{ margin:0 0 .4rem; font-size:1.1rem; }
.info-card p{ font-size:.94rem; color:var(--ink-soft); margin:0; }
.info-card a{ font-weight:600; }
.map-frame{ border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--sh-sm); }
.map-frame iframe{ display:block; width:100%; height:380px; border:0; filter:saturate(.85); }
.hours-table{ width:100%; border-collapse:collapse; }
.hours-table td{ padding:.6rem 0; border-bottom:1px solid var(--line); font-size:.96rem; }
.hours-table td:last-child{ text-align:right; font-weight:600; color:var(--evergreen); }
.hours-table tr:last-child td{ border-bottom:0; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.site-footer{ position:relative; background:var(--evergreen-grad); color:#b6c4dc; padding:0 0 36px; margin-top:0; }
.footer-wave{ line-height:0; } .footer-wave svg{ display:block; width:100%; height:64px; } .footer-wave path{ fill:var(--cream); }
.site-footer .wrap{ padding-top:46px; }
.footer-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1.3fr; gap:36px; padding-bottom:34px; }
@media(max-width:900px){ .footer-grid{ grid-template-columns:1fr 1fr; gap:32px 40px; } }
@media(max-width:540px){ .footer-grid{ grid-template-columns:1fr; gap:30px; } }
.footer-brand p{ font-size:.94rem; color:#a9bcd6; margin:1rem 0 0; max-width:34ch; }
.footer-brand .brand-mark{ width:40px; height:40px; }
.social{ display:flex; gap:10px; margin-top:1.2rem; }
.social a{ width:38px; height:38px; border-radius:10px; display:grid; place-items:center; background:rgba(255,255,255,.08); color:#fff; }
.social a:hover{ background:var(--honey); color:#3a2a06; } .social svg{ width:18px; height:18px; }
.footer-col h4{ color:#fff; font-size:1rem; margin:0 0 1rem; }
.footer-col ul{ list-style:none; padding:0; margin:0; display:grid; gap:.6rem; }
.footer-col a{ color:#b6c4dc; font-size:.92rem; } .footer-col a:hover{ color:#fff; }
.contact-list{ list-style:none; padding:0; margin:0 0 1.2rem; display:grid; gap:.85rem; }
.contact-list li{ display:flex; gap:.6rem; align-items:flex-start; font-size:.92rem; color:#b6c4dc; }
.contact-list svg{ width:18px; height:18px; color:var(--honey); flex:none; margin-top:1px; }
.contact-list a{ color:#b6c4dc; } .contact-list a:hover{ color:#fff; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); padding-top:24px; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.86rem; color:#9fb1cc; }
.footer-legal a{ color:#b6c4dc; } .footer-legal a:hover{ color:#fff; }
.footer-disclaimer{ margin:18px 0 0; font-size:.8rem; color:#8a93a3; }

/* ---------- back to top ---------- */
.to-top{ position:fixed; right:18px; bottom:18px; z-index:70; width:46px; height:46px; border-radius:50%; border:0;
  background:var(--evergreen); color:#fff; cursor:pointer; box-shadow:var(--sh); display:grid; place-items:center;
  opacity:0; visibility:hidden; transform:translateY(10px); transition:.3s; }
.to-top.show{ opacity:1; visibility:visible; transform:none; } .to-top svg{ width:20px; height:20px; }
@media(max-width:760px){ .to-top{ bottom:84px; } }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media(max-width:1080px){
  .hero-inner{ grid-template-columns:1fr; gap:34px; }
  .hero-sky{ max-width:440px; margin-inline:auto; width:100%; }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .cards,.providers,.info-grid{ grid-template-columns:repeat(2,1fr); }
  .split,.split.media-right .split-media,.faq-grid{ grid-template-columns:minmax(0,1fr); }
  .split>*,.cards>*,.info-grid>*,.providers>*{ min-width:0; }
  .split.media-right .split-media{ order:0; }
  .aside-card{ position:static; }
  .c-slide{ flex-basis:calc((100% - 22px)/2); }
  .hero-chip.c1{ left:1%; } .hero-chip.c2{ right:1%; }
}
@media(max-width:760px){
  .sec{ padding:54px 0; }
  .nav{ gap:10px; }
  .nav-cta{ gap:8px; }
  .nav-cta .btn-primary .cta-label{ display:none; }
  .nav-cta .btn-primary{ padding:.78rem .95rem; }
  .carousel{ overflow-x:clip; }
  .cards,.providers,.info-grid,.field-row{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:repeat(2,1fr); gap:12px; }
  .hero-actions .btn{ flex:1 1 auto; justify-content:center; }
  .c-slide{ flex-basis:100%; }
  .cta-band,.cta-actions{ }
  .hero-chip.c1{ left:-2%; } .hero-chip.c2{ right:-2%; }
  .footer-bottom{ flex-direction:column; }
}
@media(max-width:480px){
  .wrap{ padding-inline:16px; }
  .btn-lg{ padding:.95rem 1.35rem; font-size:1rem; }
  .btn{ max-width:100%; }
  .cta-actions{ width:100%; } .cta-actions .btn{ flex:1 1 auto; }
}
@media(max-width:360px){
  .wrap{ padding-inline:13px; }
  .btn-lg{ padding:.9rem 1.1rem; }
}

@media(prefers-reduced-motion:reduce){
  .hero-constellation .st,.hero-chip,.dl-day,.dl-s,.ins-track{ animation:none!important; }
  *{ scroll-behavior:auto!important; }
}

/* =====================================================================
   AI FRONT-DESK CHAT WIDGET
   ===================================================================== */
.dfc-chat{ position:fixed; right:20px; bottom:20px; z-index:90; font-family:var(--ff-body); }
.chat-launch{ width:62px; height:62px; border-radius:50%; border:0; cursor:pointer; position:relative;
  background:linear-gradient(140deg,var(--evergreen),#142e57); color:#fff; box-shadow:0 14px 34px rgba(20,58,47,.4);
  display:grid; place-items:center; transition:transform .25s var(--ease),box-shadow .25s; }
.chat-launch:hover{ transform:translateY(-2px) scale(1.04); box-shadow:0 18px 40px rgba(20,58,47,.5); }
.chat-launch::after{ content:""; position:absolute; inset:-4px; border-radius:50%; border:2px solid var(--honey); opacity:0; transition:.3s; }
.chat-launch:hover::after{ opacity:.7; }
.chat-launch .cl-icon, .chat-launch .cl-close{ grid-area:1/1; display:grid; place-items:center; transition:opacity .25s,transform .25s; }
.chat-launch svg{ width:26px; height:26px; display:block; }
.chat-launch .cl-close{ opacity:0; transform:rotate(-90deg) scale(.6); }
.dfc-chat.open .chat-launch .cl-icon{ opacity:0; transform:rotate(90deg) scale(.6); }
.dfc-chat.open .chat-launch .cl-close{ opacity:1; transform:none; }
.dfc-chat.open .chat-launch{ background:#142e57; }

.chat-panel{ position:absolute; right:0; bottom:78px; width:374px; max-width:calc(100vw - 32px); height:540px; max-height:calc(100vh - 130px);
  background:var(--cream); border:1px solid var(--line); border-radius:22px; overflow:hidden; display:flex; flex-direction:column;
  box-shadow:0 30px 80px rgba(20,58,47,.32); transform:translateY(14px) scale(.98); opacity:0; visibility:hidden; transform-origin:bottom right;
  transition:transform .3s var(--ease),opacity .3s,visibility .3s; }
.dfc-chat.open .chat-panel{ transform:none; opacity:1; visibility:visible; }
.chat-head{ display:flex; align-items:center; justify-content:space-between; gap:10px; padding:14px 16px;
  background:linear-gradient(120deg,var(--evergreen),#142e57); color:#fff; }
.ch-id{ display:flex; align-items:center; gap:10px; }
.ch-av{ width:38px; height:38px; border-radius:11px; background:rgba(255,255,255,.12); display:grid; place-items:center; }
.ch-av svg{ width:24px; height:24px; }
.ch-id b{ font-family:var(--ff-display); font-weight:600; font-size:1.04rem; line-height:1; display:block; }
.ch-id span{ font-size:.74rem; color:rgba(255,255,255,.7); }
.ch-x{ background:rgba(255,255,255,.1); border:0; color:#fff; width:32px; height:32px; border-radius:9px; cursor:pointer; display:grid; place-items:center; }
.ch-x:hover{ background:rgba(255,255,255,.2); } .ch-x svg{ width:16px; height:16px; }
.chat-log{ flex:1; overflow-y:auto; padding:16px; display:flex; flex-direction:column; gap:10px; background:
  radial-gradient(60% 30% at 100% 0,rgba(224,168,54,.06),transparent),var(--cream); }
.msg{ display:flex; max-width:85%; }
.msg.me{ align-self:flex-end; } .msg.bot{ align-self:flex-start; }
.bubble{ padding:.62rem .85rem; border-radius:15px; font-size:.92rem; line-height:1.45; }
.bubble--emergency{ background:#fdeceb !important; border:1px solid #f1b4b0 !important; color:#7a1410 !important; }
.bubble--crisis{ background:#eef2fb !important; border:1px solid #c2cde9 !important; color:#1d2a52 !important; }
.chat-sos{ display:block; margin-top:.55rem; text-align:center; background:#c0392b; color:#fff !important; font-weight:700; padding:.5rem .9rem; border-radius:999px; text-decoration:none; font-size:.9rem; }
.chat-sos--crisis{ background:#2b4a8b; }
.msg.bot .bubble{ background:#fff; border:1px solid var(--line); color:var(--ink); border-bottom-left-radius:5px; }
.msg.me .bubble{ background:var(--evergreen); color:#fff; border-bottom-right-radius:5px; }
.bubble.typing{ display:flex; gap:4px; }
.bubble.typing span{ width:7px; height:7px; border-radius:50%; background:var(--sage); opacity:.5; animation:chatdot 1s infinite; }
.bubble.typing span:nth-child(2){ animation-delay:.15s; } .bubble.typing span:nth-child(3){ animation-delay:.3s; }
@keyframes chatdot{ 0%,60%,100%{ transform:translateY(0); opacity:.4; } 30%{ transform:translateY(-4px); opacity:1; } }
.chat-quick{ display:flex; flex-wrap:wrap; gap:6px; padding:0 16px 10px; }
.chat-quick button{ font:inherit; font-size:.78rem; font-weight:600; color:var(--evergreen); background:rgba(29,74,61,.07);
  border:1px solid rgba(29,74,61,.16); border-radius:999px; padding:.4rem .7rem; cursor:pointer; transition:.15s; }
.chat-quick button:hover{ background:rgba(29,74,61,.13); }
.chat-input{ display:flex; gap:8px; padding:12px 14px 6px; border-top:1px solid var(--line); background:#fff; }
.chat-input input{ flex:1; font:inherit; font-size:.92rem; border:1.5px solid var(--line); border-radius:999px; padding:.62rem .95rem; background:var(--oat); }
.chat-input input:focus{ outline:none; border-color:var(--evergreen); box-shadow:0 0 0 3px rgba(29,74,61,.12); }
.chat-input button{ width:42px; height:42px; flex:none; border-radius:50%; border:0; cursor:pointer; background:var(--honey); color:#3a2a06; display:grid; place-items:center; transition:.15s; }
.chat-input button:hover{ background:var(--honey-deep,#cf9a2c); } .chat-input button svg{ width:18px; height:18px; }
.chat-note{ text-align:center; font-size:.7rem; color:var(--muted); padding:4px 14px 12px; margin:0; background:#fff; }

/* keep the scroll-to-top button stacked above the chat launcher */
.to-top{ bottom:96px; }
@media(max-width:760px){
  .dfc-chat{ right:14px; bottom:84px; }
  .chat-panel{ bottom:74px; height:min(560px,calc(100vh - 120px)); width:calc(100vw - 28px); }
  .to-top{ bottom:158px; }
}
@media(prefers-reduced-motion:reduce){ .chat-panel,.chat-launch{ transition:none; } .bubble.typing span{ animation:none; } }

/* ---- step cards (telehealth "how it works") ---- */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.step{ background:var(--white); border:1px solid var(--line); border-radius:var(--r-lg); padding:1.8rem 1.7rem; box-shadow:var(--sh-sm); position:relative; }
.step-n{ display:grid; place-items:center; width:44px; height:44px; border-radius:50%; background:var(--evergreen-grad); color:#fff; font-family:var(--ff-display); font-weight:600; font-size:1.2rem; margin-bottom:14px; }
.step h4{ font-family:var(--ff-display); font-weight:600; font-size:1.18rem; color:var(--evergreen); margin:0 0 .4rem; }
.step p{ color:var(--ink-soft); margin:0; line-height:1.55; }
@media(max-width:820px){ .steps{ grid-template-columns:1fr; } }

/* ---- FAQ accordion (faq.php) ---- */
.faq-item{ border:1px solid var(--line); border-radius:14px; background:var(--white); margin-bottom:12px; overflow:hidden; }
.faq-item summary{ cursor:pointer; list-style:none; padding:1.05rem 1.3rem; font-family:var(--ff-display); font-weight:600; font-size:1.1rem; color:var(--evergreen); display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:"+"; font-size:1.4rem; color:var(--honey-deep); font-weight:400; line-height:1; transition:transform .2s; }
.faq-item[open] summary::after{ transform:rotate(45deg); }
.faq-item .faq-a{ padding:0 1.3rem 1.2rem; color:var(--ink-soft); line-height:1.6; }
details.faq-item .faq-a{ max-height:none; overflow:visible; }
details.faq-item[open] summary{ border-bottom:1px solid var(--line); margin-bottom:.2rem; }

/* ---- self-pay pricing tables (pricing.php) ---- */
.price-wrap{ margin:0 0 2.4rem; overflow-x:auto; -webkit-overflow-scrolling:touch; }
.price-wrap h2{ font-family:var(--ff-display); font-weight:600; font-size:1.4rem; color:var(--evergreen); margin:0 0 .5rem; }
.price-sec-note{ font-size:.88rem; color:var(--muted); margin:0 0 .75rem; }
.price-table{ width:100%; border-collapse:collapse; background:var(--white); border:1px solid var(--line); border-radius:14px; overflow:hidden; }
.price-table th{ text-align:left; font-family:var(--ff-body); font-weight:700; font-size:.72rem; letter-spacing:.07em; text-transform:uppercase; color:var(--muted); background:var(--mint-50); padding:11px 16px; border-bottom:1px solid var(--line); }
.price-table td{ padding:11px 16px; border-bottom:1px solid var(--line); color:var(--ink); font-size:.95rem; vertical-align:top; }
.price-table tr:last-child td{ border-bottom:0; }
.price-table th.price, .price-table td.price{ text-align:right; white-space:nowrap; }
.price-table td.price{ font-weight:700; color:var(--evergreen); font-variant-numeric:tabular-nums; }
.price-call{ display:inline-flex; align-items:center; gap:.3rem; background:var(--mint-50); color:var(--evergreen)!important; border:1px solid var(--line); border-radius:999px; padding:.18rem .6rem; font-size:.85rem; font-weight:700; text-decoration:none; white-space:nowrap; }
.price-call:hover{ background:var(--honey); color:#3a2a06!important; border-color:var(--honey); }
.price-call svg{ width:13px; height:13px; }
.price-table th.code, .price-table td.code{ text-align:right; white-space:nowrap; }
.price-table td.code{ color:var(--muted); font-size:.85rem; font-variant-numeric:tabular-nums; }
.price-notes{ margin:.2rem 0 0; padding-left:1.1rem; color:var(--ink-soft); line-height:1.6; }
.price-notes li{ margin-bottom:.5rem; }
@media(max-width:560px){ .price-table th, .price-table td{ padding:9px 11px; font-size:.88rem; } }
@media(max-width:400px){ .price-table th, .price-table td{ padding:8px 9px; font-size:.82rem; } .price-table td.code, .price-table th.code{ font-size:.76rem; } }

/* ---- trust + payment badges strip (includes/badges.php) ---- */
.badge-band .wrap{ display:flex; flex-direction:column; gap:1.1rem; align-items:center; text-align:center; }
.trust-row{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; justify-content:center; gap:.6rem 1.6rem; }
.trust-row li{ display:inline-flex; align-items:center; gap:.45rem; font-weight:600; color:var(--evergreen); font-size:.95rem; }
.trust-row li svg{ width:19px; height:19px; flex:none; color:var(--honey-deep); }
.pay-row{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:.6rem .9rem; padding-top:.4rem; border-top:1px solid var(--line); width:100%; max-width:760px; }
.pay-label{ display:inline-flex; align-items:center; gap:.4rem; font-weight:700; color:var(--ink); font-size:.9rem; }
.pay-label svg{ width:17px; height:17px; flex:none; color:var(--evergreen); }
.pay-pills{ display:inline-flex; flex-wrap:wrap; gap:.4rem; justify-content:center; }
.pay-pill{ background:var(--white); border:1px solid var(--line); border-radius:999px; padding:.28rem .7rem; font-size:.82rem; font-weight:600; color:var(--ink-soft); }
