  /* Bitstream Charter — self-hosted so the serif voice ships on every platform.
     Freely licensed (Bitstream 1992 grant); see assets/fonts/charter-license.txt.
     local() first: Apple devices use the system copy and download nothing. */
  @font-face{
    font-family:'Charter';
    src:local('Charter'), url('fonts/charter_regular.woff2') format('woff2');
    font-weight:300 500; font-style:normal; font-display:swap;
  }
  @font-face{
    font-family:'Charter';
    src:local('Charter Italic'), local('Charter-Italic'), url('fonts/charter_italic.woff2') format('woff2');
    font-weight:300 500; font-style:italic; font-display:swap;
  }
  @font-face{
    font-family:'Charter';
    src:local('Charter Bold'), local('Charter-Bold'), url('fonts/charter_bold.woff2') format('woff2');
    font-weight:600 700; font-style:normal; font-display:swap;
  }
  :root{
    /* coastal + warm neutral palette, refined */
    --ink: #0e1b24;
    --ink-2:#2a3b46;
    --muted:#57646d;
    --hair:#e4e2dc;
    --paper:#faf7f1;       /* warm off-white */
    --paper-2:#f3efe6;
    --bay:#2f7a95;         /* deep bay blue (anchor) */
    --bay-ink:#1f4b5c;
    --tide:#bcd6da;        /* soft tide */
    --sand:#e9dfca;        /* sand */
    --sun:#d48a4a;         /* warm accent (subtle) */
    --leaf:#4a6b55;        /* verdant, subtle */
    --radius:4px;
    --radius-md:6px;
    --radius-lg:10px;
    /* Type voices + house easing — single sources of truth */
    --font-serif:'Charter','Iowan Old Style','Palatino Linotype','Book Antiqua',Georgia,serif;
    --font-mono:ui-monospace,SFMono-Regular,Menlo,Consolas,'Liberation Mono',monospace;
    --ease:cubic-bezier(.2,.7,.2,1);
    /* Space scale — 4px base, on-scale values only. Off-scale (10,14,20,28,36,40,56,72,80) stay as px. */
    --space-3xs:4px;
    --space-2xs:8px;
    --space-xs:12px;
    --space-sm:16px;
    --space-md:24px;
    --space-lg:32px;
    --space-xl:48px;
    --space-2xl:64px;
    --space-3xl:96px;
  }
  *{box-sizing:border-box}
  [hidden]{display:none !important}
  html,body{margin:0;padding:0}
  @media (prefers-reduced-motion: no-preference){
    html{scroll-behavior:smooth}
  }
  .skip-link{
    position:absolute; top:-60px; left:16px;
    background:var(--ink); color:var(--paper);
    padding:10px var(--space-sm); border-radius:var(--radius-md);
    font-family:var(--font-mono); font-size:12px;
    letter-spacing:0.1em; text-transform:uppercase;
    z-index:1000; transition:top .15s ease;
  }
  .skip-link:focus{top:12px; outline:2px solid var(--bay); outline-offset:2px}
  main:focus{
    outline:2px solid var(--bay);
    outline-offset:-4px;
  }
  main:focus:not(:focus-visible){outline:none}
  a:focus-visible,
  button:focus-visible,
  [tabindex]:focus-visible,
  summary:focus-visible{
    outline:2px solid var(--bay);
    outline-offset:3px;
    border-radius:var(--radius);
    box-shadow:0 0 0 5px color-mix(in oklab, var(--bay) 16%, transparent);
  }
  body{
    font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
    color:var(--ink);
    background:var(--paper);
    font-size:16px;
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
  }
  .serif{font-family:var(--font-serif); font-optical-sizing:auto; letter-spacing:-0.01em;}
  .mono{font-family:var(--font-mono); font-size:12px; letter-spacing:0.14em; text-transform:uppercase;}
  a{color:inherit; text-decoration:none}
  button{font:inherit; cursor:pointer; border:none; background:none; color:inherit}
  img{max-width:100%; display:block}
  .container{max-width:1240px; margin:0 auto; padding:0 var(--space-lg)}
  hr.rule{border:none; border-top:1px solid var(--hair); margin:0}

/* ============ APP STYLES ============ */

/* --- Top bar / nav --- */
.topbar{
  position:sticky; top:0; z-index:50;
  background:rgba(250,247,241,0.86);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--hair);
}
.topbar-inner{
  display:flex; align-items:center; justify-content:space-between;
  height:84px;
}
.brand{display:flex; align-items:center; gap:14px; cursor:pointer; margin-right:var(--space-xl); flex-shrink:0}
.brand-logo{height:56px; width:auto; display:block}
.nav{display:flex; gap:2px; align-items:center}
.nav a{
  position:relative;
  padding:10px 14px; font-size:13.5px; font-weight:500;
  color:var(--ink-2);
  white-space:nowrap;
  letter-spacing:-0.005em;
  background:transparent;
  -webkit-tap-highlight-color:transparent;
  transition:color .2s ease;
}
.nav a:focus{outline:none; background:transparent}
.nav a:focus-visible{
  outline:2px solid var(--bay);
  outline-offset:3px;
  border-radius:999px;
  background:color-mix(in oklab, var(--paper) 78%, #fff);
  box-shadow:0 0 0 5px color-mix(in oklab, var(--bay) 16%, transparent);
}
.nav a:focus-visible::after{transform:scaleX(1); opacity:1}
.nav a::after{
  content:""; position:absolute;
  left:14px; right:14px; bottom:4px; height:1.5px;
  background:var(--ink);
  transform:scaleX(0); transform-origin:center;
  transition:transform .26s var(--ease), opacity .2s ease;
  opacity:0;
}
.nav a:hover{color:var(--ink)}
.nav a:hover::after{transform:scaleX(1); opacity:1}
.nav a.active{color:var(--ink)}
.nav a.active::after{transform:scaleX(1); opacity:1; background:var(--bay)}
.nav-group{position:relative; display:inline-flex; align-items:center}
.nav-group > a{display:inline-flex; align-items:center; gap:5px}
.nav-group > a svg{transition:transform .25s var(--ease); opacity:.45}
.nav-group:hover > a svg{transform:rotate(180deg); opacity:.9}
.nav-group:hover > a{color:var(--ink)}
.nav-group:hover > a::after{transform:scaleX(1); opacity:1}
.nav-group::after{content:""; position:absolute; top:100%; left:-16px; right:-16px; height:14px}
.nav-dropdown{
  position:absolute; top:calc(100% + 6px); left:-8px;
  min-width:240px; padding:6px;
  background:var(--paper); border:1px solid var(--hair);
  border-radius:var(--radius-md);
  box-shadow:0 24px 56px -20px rgba(14,27,36,0.22), 0 2px 6px rgba(14,27,36,0.04);
  z-index:60;
  display:none; flex-direction:column;
  animation:dropIn .2s var(--ease);
}
/* Keyboard always opens the menu; hover only on real hover devices (touch tablets tap through to the page) */
.nav-group:focus-within .nav-dropdown{display:flex}
@media (hover:hover) and (pointer:fine){
  .nav-group:hover .nav-dropdown{display:flex}
}
/* Escape suppression hook (site.js) — wins over the reveal rules above */
.nav-group[data-suppressed] .nav-dropdown{display:none !important}
@keyframes dropIn{from{opacity:0; transform:translateY(-4px)}to{opacity:1; transform:translateY(0)}}
.nav-dropdown a{
  padding:var(--space-xs) var(--space-sm); font-size:13.5px; font-weight:500;
  color:var(--ink-2); border-radius:4px;
  white-space:nowrap;
  transition:color .15s ease, background .15s ease, padding-left .2s var(--ease);
}
.nav-dropdown a::before, .nav-dropdown a::after{display:none}
.nav-dropdown a:hover, .nav-dropdown a:focus-visible{color:var(--ink); background:var(--paper-2); padding-left:20px}
.nav-dropdown a:focus-visible{outline:2px solid var(--bay); outline-offset:-2px}
.nav a.nav-cta{
  margin-left:var(--space-xs);
  padding:10px 18px; font-size:13px; font-weight:500;
  background:var(--ink); color:#ffffff;
  border-radius:999px;
  border:0; cursor:pointer;
  display:inline-flex; align-items:center; gap:var(--space-2xs);
  text-decoration:none; white-space:nowrap;
  letter-spacing:-0.005em;
  transition:background .22s ease, transform .22s ease;
}
.nav a.nav-cta svg{stroke:#ffffff; opacity:.85}
.nav a.nav-cta::after{display:none}
.nav a.nav-cta:hover{background:var(--bay); color:#ffffff; transform:translateY(-1px)}
.nav a.nav-cta:focus-visible{
  outline:2px solid var(--bay);
  outline-offset:3px;
  box-shadow:0 0 0 5px color-mix(in oklab, var(--bay) 16%, transparent);
}
.nav a.nav-portal-link{
  display:inline-flex; align-items:center; gap:5px;
  margin-left:14px; padding:10px var(--space-3xs); font-size:13px; font-weight:500;
  color:var(--ink-2); background:transparent;
  border:0; border-radius:0;
  position:relative;
  letter-spacing:-0.005em;
  transition:color .2s ease;
}
.nav a.nav-portal-link::after{
  content:""; position:absolute;
  left:4px; right:4px; bottom:4px; height:1px;
  background:var(--bay);
  transform:scaleX(0); transform-origin:center;
  transition:transform .26s var(--ease);
  opacity:1;
}
.nav a.nav-portal-link:hover{color:var(--bay)}
.nav a.nav-portal-link:hover::after{transform:scaleX(1)}
.nav a.nav-portal-link svg{width:11px; height:11px; stroke:currentColor; opacity:.7; transition:transform .2s ease}
.nav a.nav-portal-link:hover svg{transform:translate(1px,-1px); opacity:1}

/* --- Buttons --- */
.btn{
  display:inline-flex; align-items:center; gap:var(--space-2xs);
  min-height:44px;
  padding:13px 22px; font-size:13.5px; font-weight:500;
  border-radius:999px;
  transition:background .25s ease, color .25s ease, border-color .25s ease, gap .28s var(--ease);
  white-space:nowrap;
  letter-spacing:-0.005em;
}
.btn svg{transition:transform .28s var(--ease)}
.btn-primary{background:var(--ink); color:var(--paper)}
.btn-primary:hover{background:var(--bay-ink); gap:11px; box-shadow:0 10px 28px -14px color-mix(in oklab, var(--bay-ink) 60%, transparent)}
.btn-ghost{background:transparent; color:var(--ink); border:1px solid var(--ink)}
.btn-ghost:hover{background:var(--ink); color:var(--paper); gap:11px}
.btn-light{background:var(--paper); color:var(--ink); border:1px solid var(--hair)}
.btn-light:hover{border-color:var(--ink); gap:11px}
.btn-glass{background:rgba(255,255,255,0.12); color:#fff; border:1px solid rgba(255,255,255,0.25)}
.btn-glass:hover{background:rgba(255,255,255,0.24); border-color:rgba(255,255,255,0.5); gap:11px}
.btn-sm{padding:9px var(--space-sm); font-size:12.5px; gap:7px}
.btn-sm:hover{gap:9px}
.btn-block-center{width:100%; justify-content:center}

/* --- Eyebrow / section labels --- */
.eyebrow{
  font-family:var(--font-mono); font-size:12px;
  letter-spacing:0.18em; text-transform:uppercase;
  color:var(--muted); font-weight:500;
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{
  content:""; width:24px; height:1px; background:var(--sun);
}
.eyebrow.plain::before{display:none}
.eyebrow-center{justify-content:center}

/* --- Hero (typography variant — editorial) --- */
.hero{
  position:relative;
  padding:20px 0 40px;
  border-bottom:1px solid var(--hair);
}
.hero-tag{
  font-family:var(--font-serif); font-weight:400;
  font-size:clamp(44px, 5.2vw, 76px); line-height:1.02;
  letter-spacing:-0.025em;
  color:var(--ink);
  margin:28px 0 0;
  text-wrap:balance;
}
.hero-tag em{
  font-style:italic; font-weight:400;
  color:var(--bay);
}
.hero-sub{
  font-size:18px; line-height:1.55; color:var(--muted);
  max-width:460px; margin-top:28px;
}
.hero-ctas{display:flex; gap:var(--space-xs); margin-top:36px; flex-wrap:wrap}

.hero-type{
  padding:72px 0 var(--space-2xl); text-align:center; position:relative;
  isolation:isolate;
}
.hero-type-bg{
  position:absolute; inset:0; z-index:-1; pointer-events:none; overflow:hidden;
}
.hero-type[data-hero-bg="dots"] .hero-type-bg{
  background-image: radial-gradient(color-mix(in oklab, var(--ink) 18%, transparent) 1px, transparent 1.2px);
  background-size: 22px 22px;
  mask-image: radial-gradient(ellipse 90% 95% at 50% 50%, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0.4) 55%, transparent 95%);
  -webkit-mask-image: radial-gradient(ellipse 90% 95% at 50% 50%, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0.4) 55%, transparent 95%);
}
.hero-type > :not(.hero-type-bg){ position:relative; z-index:1; }
.hero-type .hero-rule{
  display:flex; align-items:center; justify-content:center; gap:20px;
  margin-bottom:28px;
}
.hero-type .hero-rule::before,
.hero-type .hero-rule::after{
  content:""; flex:0 0 80px; height:1px; background:var(--hair);
}
.hero-type .eyebrow{
  margin-bottom:clamp(20px, 2.2vw, var(--space-lg));
}
.hero-type .hero-rule .eyebrow{margin-bottom:0}
.hero-type .hero-tag{
  font-size:clamp(40px, 4.8vw, 68px);
  line-height:1.08; letter-spacing:-0.022em;
  margin:0 auto; max-width:1120px;
  text-wrap:balance;
  font-feature-settings:"liga","onum","kern";
}
.hero-type .hero-sub{
  margin:28px auto 0; max-width:42ch; text-align:center;
  font-size:18px; text-wrap:pretty;
}
.hero-type .hero-ctas{
  margin-top:clamp(36px, 4vw, 52px);
  justify-content:center;
}

/* --- Arrival motion (hero staggered reveal) --- */
@media (prefers-reduced-motion: no-preference) {
  @keyframes hero-rise {
    from { opacity:0; transform:translate3d(0,10px,0); }
    to   { opacity:1; transform:none; }
  }
  .hero-type .eyebrow,
  .hero-type .hero-rule,
  .hero-type .hero-tag,
  .hero-type .hero-sub,
  .hero-type .hero-ctas,
  .page-hero .eyebrow,
  .page-hero h1,
  .page-hero p,
  .page-hero .hero-ctas{
    animation:hero-rise 720ms var(--ease) both;
  }
  .hero-type .eyebrow   { animation-delay: 80ms; }
  .hero-type .hero-rule { animation-delay: 80ms; }
  .hero-type .hero-tag  { animation-delay: 160ms; }
  .hero-type .hero-sub  { animation-delay: 260ms; }
  .hero-type .hero-ctas { animation-delay: 340ms; }
  .page-hero .eyebrow   { animation-delay: 60ms; }
  .page-hero h1         { animation-delay: 140ms; }
  .page-hero p          { animation-delay: 240ms; }
  .page-hero .hero-ctas { animation-delay: 320ms; }
  @keyframes hero-bg-develop{from{opacity:0}to{opacity:1}}
  .hero-type .hero-type-bg{animation:hero-bg-develop 1100ms ease-out 160ms both}
}

/* --- Section shell --- */
section.sec{padding:var(--space-3xl) 0; border-bottom:1px solid var(--hair)}
section.sec[id]{scroll-margin-top:120px}
section.sec.dark{
  position:relative; isolation:isolate;
  background:
    radial-gradient(ellipse 100% 80% at 50% -10%, color-mix(in oklab, var(--bay) 16%, transparent), transparent 60%),
    var(--ink);
  color:var(--paper); border-bottom:none;
}
/* Same grain as the footer — one ink material everywhere */
section.sec.dark::before{
  content:""; position:absolute; inset:0; z-index:-1; pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.98 0 0 0 0 0.97 0 0 0 0 0.94 0 0 0 0.6 0'/></filter><rect width='240' height='240' filter='url(%23n)'/></svg>");
  background-size:240px 240px; opacity:0.10;
  mask-image:radial-gradient(ellipse 95% 90% at 50% 0%, #000 0%, rgba(0,0,0,0.5) 55%, transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 95% 90% at 50% 0%, #000 0%, rgba(0,0,0,0.5) 55%, transparent 100%);
}
section.sec.dark .sec-title{color:var(--paper)}
section.sec.dark .sec-lede{color:rgba(250,247,241,0.65)}
section.sec.dark .eyebrow{color:var(--tide)}
section.sec.dark .eyebrow::before{background:var(--tide)}
section.sec.dark a{color:inherit}
section.sec.sand{background:color-mix(in oklab, var(--sand) 55%, var(--paper))}

.sec-head{display:flex; flex-direction:column; gap:var(--space-sm); margin-bottom:56px}
.sec-head .sec-lede{margin-top:0; max-width:620px}
@media (min-width: 981px){
  .sec-head{flex-direction:row; align-items:flex-end; justify-content:space-between; gap:var(--space-2xl)}
  .sec-head .sec-title{margin-bottom:0}
  .sec-head .sec-lede{max-width:480px; margin-bottom:var(--space-3xs); text-wrap:pretty}
}
.sec-head-row{flex-direction:row; align-items:flex-end; justify-content:space-between; gap:var(--space-lg)}
.sec-head-count{font-family:var(--font-mono); font-size:12px; letter-spacing:0.14em; color:var(--muted); white-space:nowrap; padding-bottom:var(--space-2xs)}
.sec-title{font-family:var(--font-serif); font-weight:400; font-size:clamp(28px,3.2vw,44px); line-height:1.08; letter-spacing:-0.018em; max-width:640px; text-wrap:balance}
.sec-title-kicker{margin-top:var(--space-sm)}
.sec-title-flush{margin:0}
.sec-lede{color:var(--ink-2); max-width:440px; font-size:17px; line-height:1.55}

/* --- About block --- */
.about-grid{display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start}
.about-copy{padding-top:var(--space-md)}
.about-body{font-size:18px; line-height:1.65; color:var(--ink-2); max-width:62ch}
.about-body p{margin:0 0 20px; text-wrap:pretty}
.about-body p:first-child{font-size:18px; line-height:1.6; color:var(--ink); font-weight:400}
.about-lead{font-family:var(--font-serif); font-size:21px; line-height:1.5; letter-spacing:-0.008em; color:var(--ink); margin:0 0 var(--space-md)}
.about-body-offset{margin-top:var(--space-md)}
.about-body-spacious{margin-top:var(--space-lg)}
.section-center{text-align:center}
.services-all{margin-top:var(--space-lg); display:flex; justify-content:center}
.about-home-intro{max-width:780px}
.about-home-title{margin:var(--space-sm) 0 var(--space-lg)}
.about-home-link{margin-top:28px}
.about-aside{position:sticky; top:100px}
.contact-about-title{margin-top:var(--space-sm)}
.contact-about-body{margin-top:var(--space-lg)}
.contact-about-actions{display:flex; gap:10px; margin-top:var(--space-lg); flex-wrap:wrap}
.contact-sms-note{font-size:15px; color:var(--muted)}

.info-card{
  position:relative;
  background:color-mix(in oklab, var(--paper-2) 82%, var(--sand) 18%);
  border:1px solid color-mix(in oklab, var(--bay) 22%, transparent);
  border-radius:var(--radius);
  padding:30px var(--space-lg) var(--space-md);
  isolation:isolate;
  overflow:hidden;
  box-shadow:
    0 1px 0 color-mix(in oklab, var(--paper) 85%, transparent) inset,
    0 12px 28px -22px color-mix(in oklab, var(--ink) 30%, transparent);
}
.info-card::before{
  content:""; position:absolute; top:0; left:0; right:0;
  height:2px; background:var(--sun);
}
.info-card::after{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:-1;
  background-image:radial-gradient(color-mix(in oklab, var(--ink) 10%, transparent) 1px, transparent 1.2px);
  background-size:18px 18px;
  -webkit-mask-image:radial-gradient(ellipse 110% 90% at 100% 0%, rgba(0,0,0,0.5), transparent 70%);
  mask-image:radial-gradient(ellipse 110% 90% at 100% 0%, rgba(0,0,0,0.5), transparent 70%);
}
.info-card-head{
  display:flex; align-items:baseline; justify-content:space-between;
  gap:var(--space-sm);
  padding-bottom:var(--space-sm);
  border-bottom:1px solid color-mix(in oklab, var(--ink) 14%, transparent);
  margin-bottom:6px;
}
.info-card-specs{display:block; margin:0}
.info-card-row{
  display:grid; grid-template-columns:88px 1fr; gap:20px;
  padding:14px 0;
  border-bottom:1px solid color-mix(in oklab, var(--ink) 7%, transparent);
}
.info-card-row:last-child{border-bottom:0}
.info-card dt{
  margin:0;
  font-family:var(--font-mono);
  font-size:12px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--muted); font-weight:500;
  padding-top:var(--space-3xs); align-self:start;
}
.info-card dd{
  margin:0;
  font-family:var(--font-serif);
  font-size:15.5px; color:var(--ink);
  line-height:1.45;
  font-feature-settings:"liga","kern";
}
.info-card dd small{display:block; font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif; font-size:13px; color:var(--muted); margin-top:2px; letter-spacing:0}

/* --- Patients / Services page (sticky side-nav + stacked sections) --- */
.pat-layout{
  display:grid; grid-template-columns:260px 1fr; gap:88px;
  align-items:start;
}
.pat-sticky{
  position:sticky; top:120px;
}
.pat-sticky-label{
  font-family:var(--font-mono);
  font-size:12px; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--muted); margin-bottom:var(--space-3xs);
}
.pat-sticky-count{
  font-family:var(--font-serif);
  font-size:32px; font-weight:400; color:var(--ink);
  letter-spacing:-0.02em; line-height:1;
  margin-bottom:var(--space-md);
  font-variant-numeric:lining-nums tabular-nums;
}
.pat-sticky-count em{font-style:normal; color:var(--muted); font-size:18px; margin-left:var(--space-3xs)}
.pat-sticky-nav{
  display:flex; flex-direction:column;
  border-top:1px solid var(--hair);
  border-bottom:1px solid var(--hair);
  margin-bottom:28px;
}
.pat-sticky-nav a,
.pat-sticky-nav button{
  display:grid; grid-template-columns:32px 1fr auto;
  align-items:center; gap:var(--space-2xs);
  text-align:left; padding:var(--space-sm) 0 var(--space-sm) var(--space-3xs); background:none; border:0;
  font-family:inherit; font-size:14.5px; font-weight:500;
  color:var(--ink-2); cursor:pointer;
  transition:color .18s ease;
  border-bottom:1px solid var(--hair);
  position:relative;
}
.pat-sticky-nav a:last-child,
.pat-sticky-nav button:last-child{border-bottom:0}
.pat-sticky-nav a:hover,
.pat-sticky-nav button:hover{color:var(--ink)}
.pat-sticky-nav a:hover .pat-sticky-nav-num,
.pat-sticky-nav button:hover .pat-sticky-nav-num{color:var(--ink-2)}
.pat-sticky-nav a.on,
.pat-sticky-nav button.on{color:var(--bay)}
.pat-sticky-nav-num{
  font-family:var(--font-mono);
  font-size:12px; color:var(--muted); letter-spacing:0.08em;
  transition:color .18s ease;
}
.pat-sticky-nav a.on .pat-sticky-nav-num,
.pat-sticky-nav button.on .pat-sticky-nav-num{color:var(--bay)}
.pat-sticky-nav-arrow{
  color:var(--muted); opacity:0;
  transition:opacity .18s ease, transform .18s ease;
}
.pat-sticky-nav a:hover .pat-sticky-nav-arrow,
.pat-sticky-nav a.on .pat-sticky-nav-arrow,
.pat-sticky-nav button:hover .pat-sticky-nav-arrow,
.pat-sticky-nav button.on .pat-sticky-nav-arrow{
  opacity:1;
}
.pat-sticky-nav a.on .pat-sticky-nav-arrow,
.pat-sticky-nav button.on .pat-sticky-nav-arrow{color:var(--bay); transform:translateX(2px)}
.pat-sticky-nav a::before,
.pat-sticky-nav button::before{
  content:""; position:absolute; left:-8px; top:18px; bottom:18px;
  width:2px; background:var(--bay);
  transform:scaleY(0); transform-origin:center;
  transition:transform .2s var(--ease);
}
.pat-sticky-nav a.on::before,
.pat-sticky-nav button.on::before{transform:scaleY(1)}
.pat-sticky-ctas{display:flex; flex-direction:column; gap:var(--space-2xs); margin-bottom:28px}
.pat-sticky-info{
  padding-top:var(--space-md); border-top:1px solid var(--hair);
  display:flex; flex-direction:column; gap:18px;
}
.pat-sticky-info-row{display:flex; flex-direction:column; gap:var(--space-3xs)}
.pat-sticky-info-lbl{
  font-family:var(--font-mono);
  font-size:12px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--muted);
}
.pat-sticky-info-val{
  font-size:13.5px; color:var(--ink); line-height:1.45;
}
.pat-sticky-info-val small{color:var(--muted); font-size:12px; display:block; margin-top:2px}

.pat-sections{display:flex; flex-direction:column; gap:var(--space-2xl)}
.pat-sec{
  scroll-margin-top:120px;
  padding-bottom:var(--space-2xl);
  border-bottom:1px solid var(--hair);
}
.pat-sec:last-child{border-bottom:0; padding-bottom:0}
/* Ghost numeral — the article-scale echo of the sidebar's serif counter.
   Sub-AA by design: aria-hidden decoration, duplicated by the eyebrow text. */
.pat-sec-num{
  font-family:var(--font-serif);
  font-size:clamp(56px, 6vw, 80px);
  font-weight:400; line-height:0.85;
  letter-spacing:-0.02em;
  color:color-mix(in oklab, var(--ink) 10%, transparent);
  margin:0 0 var(--space-sm) -0.04em;
  font-feature-settings:"lnum","kern";
  user-select:none;
}
.pat-sec .sec-title{font-size:clamp(26px, 2.7vw, 36px); letter-spacing:-0.015em}
.pat-sec .about-body{max-width:640px}
.pat-bring{
  margin-top:var(--space-lg);
  position:relative;
  background:color-mix(in oklab, var(--sand) 30%, var(--paper));
  border:1px solid color-mix(in oklab, var(--sand) 50%, var(--hair));
  padding:var(--space-md) 28px var(--space-md) 40px;
  border-radius:var(--radius-md);
  overflow:hidden;
}
.pat-bring::before{
  content:""; position:absolute; left:0; top:0; bottom:0;
  width:4px; background:var(--sun);
}
.pat-bring-title{
  font-family:var(--font-mono);
  font-size:12px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--muted); margin-bottom:14px;
}
.pat-bring ul{margin:0; padding:0; list-style:none; display:grid; grid-template-columns:1fr 1fr; gap:var(--space-xs) var(--space-md)}
.pat-bring li{
  position:relative; padding-left:24px;
  font-size:16px; color:var(--ink); line-height:1.5;
}
.pat-bring li::before{
  content:"✓"; position:absolute; left:0; top:1px;
  color:var(--sun); font-weight:600;
}
/* Action bar — paper + bay spine: the thing to DO, vs the sand+sun note to read */
.pat-action{
  margin-top:40px;
  position:relative; isolation:isolate;
  display:flex; align-items:center; justify-content:space-between; gap:var(--space-md);
  padding:28px var(--space-lg) 28px 40px;
  background:var(--paper);
  border:1px solid var(--hair); box-shadow:0 1px 2px rgba(14,27,36,0.04);
  border-radius:var(--radius-md);
  flex-wrap:wrap;
  overflow:hidden;
  transition:transform .24s var(--ease), box-shadow .24s var(--ease), border-color .24s;
}
.pat-action::before{
  content:""; position:absolute; left:0; top:0; bottom:0;
  width:4px; background:var(--bay);
}
.pat-action::after{
  content:""; position:absolute; inset:0; z-index:-1; pointer-events:none;
  background:radial-gradient(circle at 1px 1px, color-mix(in oklab, var(--sand) 70%, transparent) 1px, transparent 1.5px);
  background-size:14px 14px;
  opacity:.55;
  -webkit-mask-image:radial-gradient(ellipse 80% 140% at 100% 50%, #000 10%, transparent 75%);
          mask-image:radial-gradient(ellipse 80% 140% at 100% 50%, #000 10%, transparent 75%);
}
.pat-action:has(.btn:hover),
.pat-action:focus-within{
  transform:translateY(-1px);
  box-shadow:0 6px 22px -14px color-mix(in oklab, var(--ink) 55%, transparent);
  border-color:color-mix(in oklab, var(--bay) 30%, var(--hair));
}
.pat-action-label{
  font-family:var(--font-serif);
  font-size:22px; font-weight:400; color:var(--ink);
  letter-spacing:-0.012em;
  font-feature-settings:"liga","onum","kern";
}
.pat-action-label em{
  font-style:italic; color:var(--bay);
}
.pat-action-sub{
  font-size:13.5px; color:var(--muted); margin-top:6px;
  max-width:52ch; text-wrap:pretty;
}
.pat-action-spaced{margin-top:var(--space-lg)}
.pat-action-buttons{display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end}
.pat-detail-link-wrap{margin-top:var(--space-md)}
.topic-card-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:var(--space-sm);
  margin-top:var(--space-lg);
}
.topic-card{
  background:var(--paper);
  border:1px solid var(--hair);
  border-radius:var(--radius-md);
  padding:var(--space-md);
}
.topic-card h3{
  font-family:var(--font-serif);
  font-size:22px;
  line-height:1.12;
  font-weight:400;
  letter-spacing:-0.01em;
  margin:0 0 var(--space-xs);
  color:var(--ink);
}
.topic-card p{
  margin:0;
  color:var(--ink-2);
  font-size:14.5px;
  line-height:1.6;
}
.center-ctas{justify-content:center}

.patient-status-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-md);
  margin:0 0 var(--space-xl);
  padding:var(--space-md) var(--space-lg);
  background:var(--paper);
  border:1px solid color-mix(in oklab, var(--bay) 26%, var(--hair));
  border-left:4px solid var(--bay);
  border-radius:var(--radius-md);
  box-shadow:0 12px 28px -24px color-mix(in oklab, var(--ink) 45%, transparent);
}
.patient-status-card p{
  margin:8px 0 0;
  color:var(--ink-2);
  max-width:68ch;
  line-height:1.55;
}

/* Closing CTA — sub-page tail */
.closing-cta{
  position:relative; isolation:isolate;
  padding:var(--space-3xl) 0;
  background:color-mix(in oklab, var(--sand) 22%, var(--paper));
  border-top:1px solid color-mix(in oklab, var(--sand) 55%, var(--hair));
  overflow:hidden;
}
.closing-cta::before{
  content:""; position:absolute; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(circle at 1px 1px, color-mix(in oklab, var(--sand) 75%, transparent) 1px, transparent 1.6px);
  background-size:16px 16px;
  opacity:.5;
  -webkit-mask-image:radial-gradient(ellipse 70% 120% at 50% 40%, #000 15%, transparent 75%);
          mask-image:radial-gradient(ellipse 70% 120% at 50% 40%, #000 15%, transparent 75%);
}
.closing-cta::after{
  content:""; position:absolute; left:50%; top:0; transform:translateX(-50%);
  width:clamp(120px, 28vw, 260px); height:2px;
  background:linear-gradient(90deg, transparent, var(--sun) 50%, transparent);
  opacity:.7;
}
.closing-cta-inner{
  max-width:720px; margin:0 auto; text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:20px;
}
.closing-cta-eyebrow{
  justify-content:center;
}
.closing-cta-eyebrow::after{content:""; width:24px; height:1px; background:var(--sun)}
.closing-cta-title{
  font-family:var(--font-serif);
  font-size:clamp(36px, 4.4vw, 52px);
  line-height:1.06;
  letter-spacing:-0.022em;
  font-weight:400;
  color:var(--ink);
  margin:var(--space-3xs) 0 0;
  font-feature-settings:"liga","onum","kern";
  text-wrap:balance;
}
.closing-cta-title em{
  font-style:italic; color:var(--bay);
}
.closing-cta-lede{
  font-size:17px; line-height:1.55; color:var(--muted);
  max-width:48ch; margin:0;
}
.closing-cta-actions{
  margin-top:var(--space-sm);
  display:flex; gap:var(--space-xs); flex-wrap:wrap; justify-content:center;
}
.closing-cta-phone{
  background:var(--paper);
  border-color:color-mix(in oklab, var(--sand) 60%, var(--hair));
}
@media (max-width: 720px){
  .closing-cta{ padding:72px 0; }
}

/* Form list (downloadable PDFs) */
.form-list{display:flex; flex-direction:column; border-top:1px solid var(--hair); margin-top:var(--space-md)}
.form-row{
  display:grid; grid-template-columns:48px 1fr auto; gap:var(--space-md); align-items:start;
  min-height:72px;
  padding:22px 0 22px 0; border-bottom:1px solid var(--hair);
  color:var(--ink); cursor:pointer;
  position:relative;
  transition:padding .22s var(--ease);
}
.form-row::before{
  content:""; position:absolute; left:-16px; top:50%;
  width:2px; height:28px; background:var(--bay);
  transform:translateY(-50%) scaleY(0); transform-origin:center;
  transition:transform .22s var(--ease);
}
.form-row:hover{padding-left:var(--space-xs)}
.form-row:hover::before{transform:translateY(-50%) scaleY(1)}
.form-row-num{font-family:var(--font-mono); font-size:12px; color:var(--muted); letter-spacing:0.08em; transition:color .2s ease; padding-top:5px}
.form-row:hover .form-row-num{color:var(--bay)}
.form-row-title{font-family:var(--font-serif); font-weight:400; font-size:20px; letter-spacing:-0.01em; line-height:1.3}
.form-row-sub{font-size:13.5px; color:var(--muted); margin-top:2px; text-wrap:pretty}
.form-row-meta{
  display:inline-flex; align-items:center; gap:var(--space-2xs);
  min-height:44px;
  font-family:var(--font-mono); font-size:12px;
  letter-spacing:0.14em; text-transform:uppercase; color:var(--muted);
  transition:color .2s ease, gap .25s var(--ease);
  padding-top:5px;
}
.form-row:hover .form-row-meta{color:var(--bay); gap:11px}
.form-row-meta svg{width:12px; height:12px; stroke:currentColor}

/* --- Services grid --- */
.services{display:grid; grid-template-columns:repeat(3, 1fr); gap:1px; background:var(--hair); border:1px solid var(--hair); border-radius:var(--radius-lg); overflow:hidden}
.svc{
  background:var(--paper); padding:36px var(--space-lg);
  transition:background .25s ease;
  position:relative;
  min-height:240px;
  display:flex; flex-direction:column; justify-content:space-between;
  overflow:hidden;
}
.svc.clickable{cursor:pointer}
.svc.clickable:hover{background:color-mix(in oklab, var(--tide) 12%, var(--paper))}
.services .svc:focus-visible{outline-offset:-3px; box-shadow:none}
.svc-num{
  font-family:var(--font-mono); font-size:12px;
  color:var(--muted); letter-spacing:0.12em;
  transition:color .2s ease;
}
.svc.clickable:hover .svc-num{color:var(--bay)}
.svc-title{
  font-family:var(--font-serif); font-weight:400; font-size:24px;
  letter-spacing:-0.01em;
  margin:14px 0 14px;
  position:relative; display:inline-block; padding-bottom:6px; align-self:flex-start;
}
.svc-title::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:2px;
  background:var(--bay);
  transform:scaleX(0); transform-origin:left center;
  transition:transform .3s var(--ease);
}
.svc.clickable:hover .svc-title::after{transform:scaleX(1)}
.svc-desc{font-size:14px; color:var(--muted); line-height:1.55}
.svc-arrow{
  align-self:flex-end;
  margin-top:var(--space-md);
  width:34px; height:34px; border-radius:999px;
  border:1px solid var(--hair);
  display:flex; align-items:center; justify-content:center;
  transition:border-color .25s ease, color .25s ease, background .25s ease;
  color:var(--ink-2);
  flex-shrink:0;
}
.svc-arrow svg{transition:transform .28s var(--ease)}
.svc.clickable:hover .svc-arrow{border-color:var(--bay); color:var(--paper); background:var(--bay)}
.svc.clickable:hover .svc-arrow svg{transform:translateX(2px)}

/* --- Provider list (About page) --- */
.provider-list{display:flex; flex-direction:column; border-top:1px solid var(--hair)}
.provider-row{
  display:grid; grid-template-columns:80px 1fr; gap:var(--space-lg);
  align-items:start;
  padding:36px 0;
  border-bottom:1px solid var(--hair);
  position:relative;
}
.provider-row-num{
  font-family:var(--font-mono); font-size:12px;
  letter-spacing:0.14em; color:var(--bay-ink);
  padding-top:var(--space-2xs);
}
.provider-row-name{
  font-family:var(--font-serif); font-weight:400; font-size:28px;
  letter-spacing:-0.015em; margin:0;
  color:var(--ink);
}
.provider-row-meta{
  display:flex; flex-wrap:wrap; gap:var(--space-2xs);
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:0.08em; text-transform:uppercase;
  color:var(--muted);
  margin-top:10px;
}
.provider-row-meta .sep{color:var(--sun)}
.provider-row-meta .provider-row-school{text-transform:none; letter-spacing:0.02em; font-size:12px}
.provider-row-bio{
  font-size:16px; line-height:1.65; color:var(--ink-2);
  margin:var(--space-sm) 0 0; max-width:60ch;
  text-wrap:pretty;
}

/* --- Staff roster (About page, dark section) --- */
.staff-title{margin:var(--space-sm) auto var(--space-md)}
.staff-intro{
  color:rgba(250,247,241,0.7);
  max-width:520px;
  margin:0 auto 56px;
  font-size:16px;
  line-height:1.55;
}
.staff-roster{max-width:900px; margin:0 auto; text-align:left}
.staff-head{
  display:flex; justify-content:space-between; align-items:baseline;
  font-family:var(--font-mono); font-size:12px; font-weight:500;
  letter-spacing:0.14em; text-transform:uppercase; color:var(--tide);
  margin:0 0 var(--space-sm); padding-bottom:var(--space-xs);
  border-bottom:1px solid rgba(250,247,241,0.12);
}
.staff-head-count{color:var(--sun); letter-spacing:0.08em}
.staff-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  background:rgba(250,247,241,0.08); border:1px solid rgba(250,247,241,0.08);
  border-radius:var(--radius-lg); overflow:hidden;
  list-style:none; margin:0; padding:0;
}
.staff-grid + .staff-head{margin-top:var(--space-xl)}
.staff-cell{
  display:flex; flex-direction:column; justify-content:center; gap:2px;
  min-height:64px; padding:18px 20px;
  background:color-mix(in oklab, var(--paper) 3%, var(--ink));
}
.staff-cell-empty{pointer-events:none}
.staff-cell-name{font-family:var(--font-serif); font-size:17px; letter-spacing:-0.005em; line-height:1.25; color:var(--paper)}
.staff-cell-cred{font-family:var(--font-mono); font-size:12px; letter-spacing:0.08em; text-transform:uppercase; color:var(--tide)}

/* --- Patient Center / portals --- */
.portal-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:20px}
.portal-card{
  background:var(--paper); border:1px solid var(--hair);
  border-radius:var(--radius-lg); padding:var(--space-lg);
  display:flex; flex-direction:column; justify-content:space-between;
  min-height:220px;
  color:var(--ink);
  cursor:pointer;
  position:relative;
  overflow:hidden;
  transition:border-color .25s ease, transform .22s var(--ease), box-shadow .22s ease;
}
.portal-card:hover{border-color:var(--ink-2); transform:translateY(-3px); box-shadow:0 16px 32px -18px rgba(0,0,0,0.55)}
.portal-card .mono{color:var(--muted); font-family:var(--font-mono); font-size:12px; letter-spacing:0.14em; text-transform:uppercase; transition:color .2s ease}
.portal-card:hover .mono{color:var(--bay)}
.portal-card h3{
  font-family:var(--font-serif); font-weight:400; font-size:24px;
  margin:var(--space-xs) 0 var(--space-2xs); letter-spacing:-0.01em;
  color:var(--ink);
  position:relative; align-self:flex-start; padding-bottom:6px;
}
.portal-card h3::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:2px;
  background:var(--bay);
  transform:scaleX(0); transform-origin:left center;
  transition:transform .3s var(--ease);
}
.portal-card:hover h3::after{transform:scaleX(1)}
.portal-card p{margin:0; font-size:14px; color:var(--ink-2); line-height:1.55}
.portal-card .go{
  margin-top:20px;
  display:flex; justify-content:space-between; align-items:center;
  padding-top:20px; border-top:1px solid var(--hair);
  font-size:13px; font-weight:500;
  color:var(--ink);
  transition:color .25s ease;
}
.portal-card .go svg{transition:transform .28s var(--ease)}
.portal-card:hover .go{color:var(--bay)}
.portal-card:hover .go svg{transform:translateX(3px)}
/* --- Contact / visit block --- */
.visit-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:0;
  background:var(--bay); color:#fff; border-radius:var(--radius-lg); overflow:hidden;
}
.visit-left{padding:56px var(--space-xl); display:flex; flex-direction:column; justify-content:space-between}
.visit-left h2{font-family:var(--font-serif); font-weight:400; font-size:48px; letter-spacing:-0.02em; margin:0 0 var(--space-lg); line-height:1.02}
.visit-info{display:grid; grid-template-columns:1fr 1fr; gap:var(--space-lg) var(--space-md); margin-top:var(--space-lg)}
.visit-actions{display:flex; gap:10px; margin-top:40px; flex-wrap:wrap}
.visit-actions a:focus-visible{
  outline-color:var(--paper);
  box-shadow:0 0 0 5px rgba(14,27,36,0.35);
}
.visit-info .lbl{font-family:var(--font-mono); font-size:12px; letter-spacing:0.16em; text-transform:uppercase; margin-bottom:6px}
.visit-info .val{font-family:var(--font-serif); font-weight:400; font-size:18px; line-height:1.3}
.visit-info .val small{display:block; font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif; font-size:12px; margin-top:2px; font-weight:400}
.visit-map{
  position:relative;
  min-height:420px;
  background:var(--paper-2);
  overflow:hidden;
}
.visit-map iframe{
  position:absolute; inset:0;
  width:100%; height:100%;
  border:0;
  filter:saturate(0.85) contrast(0.95);
}
.visit-map .map-badge,
.contact-map-wrap .map-badge{
  position:absolute; top:16px; left:16px; z-index:2;
  font-family:var(--font-mono); font-size:12px;
  letter-spacing:0.14em; text-transform:uppercase;
  color:#fff; background:rgba(14,27,36,0.82);
  padding:var(--space-2xs) 14px; border-radius:4px;
  backdrop-filter:blur(8px);
}
.visit-map .map-dir{
  position:absolute; bottom:16px; right:16px; z-index:2;
  display:inline-flex; align-items:center; gap:var(--space-2xs);
  min-height:48px;
  font-family:var(--font-mono); font-size:12px;
  letter-spacing:0.12em; text-transform:uppercase;
  color:var(--paper); background:var(--ink);
  padding:var(--space-xs) 18px; border-radius:999px;
  text-decoration:none;
  box-shadow:0 4px 20px rgba(0,0,0,0.25), 0 1px 2px rgba(0,0,0,0.1);
  transition:background .25s ease, gap .28s var(--ease);
}
.visit-map .map-dir svg{width:12px; height:12px; stroke:currentColor; transition:transform .28s var(--ease)}
.visit-map .map-dir:hover{background:var(--bay-ink); gap:11px}
.visit-map .map-dir:hover svg{transform:translate(2px,-2px)}


/* --- Philosophy quote --- */
.quote{
  font-family:var(--font-serif); font-weight:400; font-style:italic;
  font-size:clamp(32px,3.5vw,48px); line-height:1.22;
  letter-spacing:-0.015em;
  max-width:900px; text-wrap:balance;
}
.quote-spaced{margin:var(--space-md) auto 0}
.quote::before{
  content:"\201C"; display:block;
  font-size:1.5em; line-height:0.55;
  color:var(--bay); font-style:normal;
  margin-bottom:var(--space-sm);
}
/* --- Footer --- Quiet ink with fine grain (printed-stock quality) */
footer{
  position:relative;
  background:var(--ink);
  color:var(--paper);
  padding:var(--space-xl) 0 var(--space-md);
  overflow:hidden;
  isolation:isolate;
}
/* Fine grain — gives the ink a tactile, printed-paper quality without pattern */
.foot-bg{
  position:absolute; inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.98 0 0 0 0 0.97 0 0 0 0 0.94 0 0 0 0.6 0'/></filter><rect width='240' height='240' filter='url(%23n)'/></svg>");
  background-size:240px 240px;
  opacity:0.12;
  mask-image:radial-gradient(ellipse 95% 100% at 50% 30%, #000 0%, rgba(0,0,0,0.55) 55%, transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 95% 100% at 50% 30%, #000 0%, rgba(0,0,0,0.55) 55%, transparent 100%);
  pointer-events:none;
  z-index:0;
}
footer > .container{position:relative; z-index:1}

.foot-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:var(--space-xl);
  padding-bottom:var(--space-xl);
}
.foot-logo{display:inline-flex; align-items:center}
.foot-logo img{display:block; height:64px; width:auto}
.foot-blurb{
  max-width:320px;
  margin:16px 0 0;
  font-family:var(--font-serif);
  font-size:14.5px; line-height:1.6;
  color:rgba(250,247,241,0.6);
  font-style:italic;
}
.foot-ctas{
  margin-top:var(--space-md);
  display:flex; gap:10px; flex-wrap:wrap;
}
.foot-phone{background:var(--paper); color:var(--ink)}
.foot-portal{color:var(--paper); border-color:rgba(250,247,241,0.25)}

footer a{color:rgba(250,247,241,0.78); transition:color .18s ease, text-decoration-color .18s ease}
footer a:hover{color:var(--paper)}
.foot-col h2{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:rgba(188,214,218,0.85);
  margin:0 0 16px;
  font-weight:500;
}
.foot-col ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px}
.foot-col li{font-size:14px; line-height:1.55; color:rgba(250,247,241,0.62)}
.foot-col a{font-size:14px}
.foot-col ul a{
  display:inline-block; padding:4px 0;
  text-decoration:underline; text-underline-offset:3px;
  text-decoration-color:rgba(250,247,241,0.4);
}
.foot-col ul a:hover{text-decoration-color:currentColor}

.foot-bottom{
  display:flex; align-items:center; justify-content:space-between;
  gap:var(--space-md);
  padding-top:var(--space-md);
  border-top:1px solid rgba(250,247,241,0.08);
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:rgba(250,247,241,0.6);
  font-variant-numeric:tabular-nums;
}
.foot-bottom a{
  color:rgba(250,247,241,0.7);
  display:inline-block; padding:4px 0;
  text-decoration:underline; text-underline-offset:3px;
  text-decoration-color:rgba(250,247,241,0.35);
}
.foot-bottom a:hover{color:var(--paper); text-decoration-color:currentColor}

/* Page headers (sub-pages) */
.page-hero{
  position:relative;
  padding:var(--space-2xl) 0 72px;
  border-bottom:1px solid var(--hair);
  isolation:isolate;
  overflow:hidden;
}
.page-hero::before{
  content:"";
  position:absolute; inset:0; z-index:-1;
  pointer-events:none;
  background-image: radial-gradient(color-mix(in oklab, var(--ink) 14%, transparent) 1px, transparent 1.2px);
  background-size: 22px 22px;
  -webkit-mask-image: radial-gradient(ellipse 80% 90% at 50% 40%, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.28) 55%, transparent 92%);
  mask-image: radial-gradient(ellipse 80% 90% at 50% 40%, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.28) 55%, transparent 92%);
}
.page-hero h1{font-family:var(--font-serif); font-weight:400; font-size:clamp(38px,4vw,58px); line-height:1.05; letter-spacing:-0.02em; margin:20px 0 0; text-wrap:balance; max-width:20ch; font-feature-settings:"liga","onum","kern"}
.page-hero h1 em{font-style:italic; font-weight:400; color:var(--bay)}
.page-hero p{color:var(--muted); font-size:17px; max-width:540px; margin-top:20px; line-height:1.55}
.page-hero .hero-ctas{margin-top:var(--space-lg)}

/* System pages (404 / legacy interstitials): chromeless, centered */
.sys{min-height:100vh; min-height:100svh; display:flex; flex-direction:column}
.sys main{flex:1; display:flex; flex-direction:column; justify-content:center}
.sys .page-hero{border-bottom:none; padding:var(--space-2xl) 0}
.sys-top{padding:var(--space-md) 0; border-bottom:1px solid var(--hair)}
.sys-brand{font-family:var(--font-mono); font-size:12px; font-weight:500; letter-spacing:0.18em; text-transform:uppercase; color:var(--ink-2); transition:color .2s ease}
.sys-brand:hover{color:var(--bay)}
.sys-foot{padding:var(--space-md) 0; border-top:1px solid var(--hair)}
.sys-foot .container{
  display:flex; justify-content:space-between; align-items:baseline; gap:var(--space-sm); flex-wrap:wrap;
  font-family:var(--font-mono); font-size:12px; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted);
}
.sys-foot a{color:var(--ink-2); transition:color .2s ease}
.sys-foot a:hover{color:var(--bay)}
/* 404 figure — display-scale oldstyle numerals in the eyebrow slot */
.page-hero .eyebrow.sys-code{
  font-family:var(--font-serif);
  font-size:clamp(40px,5vw,54px); font-weight:400; line-height:1;
  letter-spacing:0.06em; color:var(--bay);
  font-feature-settings:"onum","kern";
  gap:var(--space-sm);
}
.eyebrow.sys-code::before{width:40px; background:var(--sun)}

/* Contact hero — compact (less vertical breathing room) */
.contact-hero-compact{padding:40px 0 40px}
.contact-hero-compact h1{margin-top:var(--space-xs)}
.contact-hero-compact p{margin-top:14px; max-width:520px}
.contact-hero-compact + section.sec{padding-top:56px}


/* Contact page: map section */
.contact-map-wrap{
  position:relative;
  aspect-ratio: 21 / 9;
  border-radius:var(--radius-lg); overflow:hidden;
  background:var(--paper-2);
  border:1px solid color-mix(in oklab, var(--sand) 55%, var(--hair));
  box-shadow:0 1px 2px rgba(0,0,0,0.04), 0 28px 56px -40px color-mix(in oklab, var(--ink) 50%, transparent);
}
.contact-map-wrap iframe{position:absolute; inset:0; width:100%; height:100%; border:0; filter:saturate(0.85) contrast(0.95)}
.contact-map-dir{
  position:absolute; right:20px; bottom:20px;
  display:inline-flex; align-items:center; gap:var(--space-2xs);
  min-height:48px;
  padding:var(--space-xs) 18px; border-radius:999px;
  font-family:var(--font-mono); font-size:12px;
  letter-spacing:0.12em; text-transform:uppercase;
  background:var(--ink); color:var(--paper); text-decoration:none;
  box-shadow:0 4px 20px rgba(0,0,0,0.25), 0 1px 2px rgba(0,0,0,0.1);
  transition:background .25s ease, gap .28s var(--ease);
}
.contact-map-dir svg{width:12px; height:12px; stroke:currentColor; transition:transform .28s var(--ease)}
.contact-map-dir:hover{background:var(--bay-ink); gap:11px}
.contact-map-dir:hover svg{transform:translate(2px,-2px)}
@media(max-width:720px){
  .contact-map-wrap{aspect-ratio:4/3}
  .contact-map-dir{
    right:12px;
    bottom:12px;
    padding:10px 14px;
  }
}

/* Contact page: "At a glance" aside card */
.contact-card{
  background:var(--paper); border:1px solid var(--hair);
  border-radius:var(--radius-lg); overflow:hidden;
  display:flex; flex-direction:column;
  box-shadow:0 1px 0 color-mix(in oklab, #fff 70%, transparent) inset, 0 18px 44px -30px color-mix(in oklab, var(--ink) 38%, transparent);
}
.contact-card-head{
  display:flex; justify-content:space-between; align-items:center;
  padding:20px 28px; border-bottom:1px solid var(--hair);
  background: var(--paper-2);
}
.contact-card-head .mono{
  font-family:var(--font-mono); font-size:12px;
  letter-spacing:0.16em; text-transform:uppercase;
  color:var(--muted); font-weight:500;
}
.contact-card-badge{
  display:inline-flex; align-items:center; gap:var(--space-2xs);
  font-family:var(--font-mono); font-size:12px; letter-spacing:0.08em; text-transform:uppercase;
  color:var(--muted); font-weight:500;
}
.contact-card-dot{
  width:6px; height:6px; border-radius:999px;
  background:var(--leaf);
  box-shadow:0 0 0 3px color-mix(in oklab, var(--leaf) 22%, transparent);
}
.contact-card-hero{
  display:flex; flex-direction:column; gap:var(--space-3xs);
  padding:var(--space-md) 28px; text-decoration:none;
  border-bottom:1px solid var(--hair);
  position:relative;
  transition:background .2s ease;
}
.contact-card-hero::before{
  content:""; position:absolute; left:0; top:50%;
  width:2px; height:40px; background:var(--bay);
  transform:translateY(-50%) scaleY(0); transform-origin:center;
  transition:transform .22s var(--ease);
}
.contact-card-hero:hover,
.contact-card-hero:focus-visible{background:color-mix(in oklab, var(--paper-2) 55%, var(--paper))}
.contact-card-hero:hover::before,
.contact-card-hero:focus-visible::before{transform:translateY(-50%) scaleY(1)}
.contact-card-hero:focus-visible{outline-offset:-3px; box-shadow:none}
.contact-card-hero:hover .contact-card-v{color:var(--bay-ink)}
.contact-card-k{
  font-family:var(--font-mono); font-size:12px;
  letter-spacing:0.16em; text-transform:uppercase;
  color:var(--muted); font-weight:500;
}
.contact-card-v{
  font-family:var(--font-serif); font-weight:400;
  font-size:32px; letter-spacing:-0.018em; color:var(--ink);
  margin-top:6px;
  transition:color .2s ease;
}
.contact-card-hero.alt .contact-card-v{font-size:22px}
.contact-card-sub{font-size:13px; color:var(--muted); margin-top:2px}
.contact-card-grid{
  display:grid; grid-template-columns:1fr 1fr;
  border-bottom:1px solid var(--hair);
}
.contact-card-grid > div{
  padding:20px 28px;
  display:flex; flex-direction:column; gap:var(--space-3xs);
}
.contact-card-grid > div + div{border-left:1px solid var(--hair)}
.contact-card-line{
  font-size:15px; color:var(--ink); font-weight:500;
  margin-top:6px;
}
.contact-card-line.link{
  color:var(--bay); text-decoration:none;
  display:inline-flex; align-items:center; gap:5px; align-self:flex-start;
  background-image:linear-gradient(currentColor,currentColor);
  background-size:0% 1px; background-repeat:no-repeat;
  background-position:0 100%;
  transition:background-size .3s var(--ease), color .2s ease;
}
.contact-card-line.link:hover{color:var(--bay-ink); background-size:100% 1px}
.contact-card-line.link svg{width:11px; height:11px; stroke:currentColor; transition:transform .2s ease}
.contact-card-line.link:hover svg{transform:translate(1px,-1px)}
.contact-card-hours{padding:20px 28px}
.contact-card-hours table{
  width:100%; border-collapse:collapse;
  margin-top:var(--space-3xs); font-size:14px;
  font-variant-numeric:tabular-nums;
}
.contact-card-hours td{
  padding:var(--space-2xs) 0; border-bottom:1px dashed var(--hair);
  color:var(--muted);
}
.contact-card-hours td:first-child{font-family:var(--font-mono); font-size:12px; letter-spacing:0.08em; text-transform:uppercase}
.contact-card-hours tr:last-child td{border-bottom:none}
.contact-card-hours td:last-child{text-align:right; color:var(--ink)}
.contact-card-hours tr.muted td{color:var(--muted)}

@media(max-width:720px){
  .contact-card-grid{grid-template-columns:1fr}
  .contact-card-grid > div + div{border-left:none; border-top:1px solid var(--hair)}
  .contact-card-hero,.contact-card-head,.contact-card-grid > div,.contact-card-hours{padding-left:22px; padding-right:22px}
}

/* Responsive */
/* Hamburger - hidden on desktop, shown on narrow */
.nav-burger{
  display:none;
  background:transparent; border:1px solid var(--hair); border-radius:999px;
  width:48px; height:48px; align-items:center; justify-content:center;
  color:var(--ink-2); cursor:pointer;
  transition:color .2s ease, border-color .2s ease;
}
.nav-burger:hover{color:var(--bay); border-color:var(--bay)}

/* Mobile nav overlay + drawer */
.mobile-nav-overlay{
  position:fixed; inset:0; background:rgba(14,27,36,0.45);
  z-index:200; animation:fadein .18s ease;
  display:flex; justify-content:flex-end;
}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.mobile-nav-panel{
  width:min(360px, 88vw); height:100%; background:var(--paper);
  padding:var(--space-md); overflow-y:auto; display:flex; flex-direction:column; gap:20px;
  box-shadow:-20px 0 60px rgba(0,0,0,0.15);
  animation:slidein .22s var(--ease);
}
@keyframes slidein{from{transform:translateX(100%)}to{transform:translateX(0)}}
.mobile-nav-head{display:flex; justify-content:space-between; align-items:center; padding-bottom:var(--space-sm); border-bottom:1px solid var(--hair)}
.mobile-nav-close{
  background:transparent; cursor:pointer; color:var(--muted);
  width:48px; height:48px; display:inline-flex; align-items:center; justify-content:center;
  border-radius:999px; border:1px solid transparent;
  transition:color .2s ease, border-color .2s ease;
}
.mobile-nav-close svg{transition:transform .25s var(--ease)}
.mobile-nav-close:hover{color:var(--ink); border-color:var(--hair)}
.mobile-nav-close:hover svg{transform:rotate(90deg)}
.mobile-nav-list{display:flex; flex-direction:column; gap:18px; flex:1}
.mobile-nav-item > a{
  display:flex; align-items:center; gap:14px;
  min-height:48px;
  font-size:22px; font-weight:400; color:var(--ink);
  font-family:var(--font-serif);
  letter-spacing:-0.01em;
  padding:4px 0; cursor:pointer;
}
.mobile-nav-num{font-family:var(--font-mono); font-size:12px; letter-spacing:0.08em; color:var(--muted)}
.mobile-nav-item > a.active{color:var(--bay); text-decoration:underline; text-underline-offset:4px}
.mobile-nav-item > a.active .mobile-nav-num{color:var(--bay)}
.mobile-nav-sub{
  display:flex; flex-direction:column; gap:4px;
  margin-top:var(--space-2xs); padding-left:var(--space-sm); border-left:2px solid var(--hair);
}
.mobile-nav-sub a{
  display:flex; align-items:center;
  min-height:44px;
  font-size:15px; color:var(--muted); cursor:pointer; padding:8px 0;
}
.mobile-nav-sub a:hover{color:var(--ink)}
.mobile-nav-foot{display:flex; flex-direction:column; gap:10px; padding-top:var(--space-sm); border-top:1px solid var(--hair)}

/* Tighten nav between 1040px and 1320px so it stays visible longer */
@media (max-width: 1320px){
  .nav a{padding:9px 10px; font-size:12.5px}
  .nav a::after{left:10px; right:10px}
  .nav a.nav-cta{padding:9px 14px; font-size:12.5px}
  .nav a.nav-portal-link{padding:9px var(--space-3xs); font-size:12.5px; margin-left:10px}
  .brand{margin-right:var(--space-md)}
}
@media (max-width: 1120px){
  .nav a{padding:var(--space-2xs) 7px; font-size:12px}
  .nav a::after{left:7px; right:7px}
  .nav a.nav-cta{padding:var(--space-2xs) var(--space-xs); font-size:12px; margin-left:6px}
  .nav a.nav-portal-link{padding:var(--space-2xs) 3px; font-size:12px; margin-left:6px}
  .brand{margin-right:var(--space-2xs)}
}
@media (max-width: 1040px){
  .nav{display:none}
  .nav-burger{display:inline-flex}
}
@media (max-width: 980px){
  .about-grid{grid-template-columns:1fr; gap:40px}
  .about-copy{padding-top:0}
  .about-aside{position:static}
  .services{grid-template-columns:1fr 1fr}
  .portal-grid{grid-template-columns:1fr 1fr}
  .visit-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr; gap:var(--space-lg)}
  .foot-lead{grid-column:1 / -1}
  .pat-layout{grid-template-columns:1fr; gap:var(--space-lg)}
  .pat-sticky{position:static}
  .pat-sticky-count{display:none}
  .pat-sticky-label{margin-bottom:var(--space-xs)}
  .pat-sticky-nav{margin-bottom:0}
  .pat-sticky-ctas{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:10px;
    margin:var(--space-sm) 0;
  }
  .pat-sticky-info{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:10px;
    padding-top:0;
    border-top:0;
  }
  .pat-sticky-info-row{
    padding:var(--space-xs);
    border:1px solid var(--hair);
    border-radius:var(--radius-md);
    background:color-mix(in oklab, var(--paper-2) 55%, var(--paper));
  }
  .pat-bring ul{grid-template-columns:1fr}
  .topic-card-grid{grid-template-columns:1fr}
  .staff-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 720px){
  section.sec{padding:72px 0}
  .page-hero{padding:56px 0 60px}
  .hero-type{padding:56px 0 60px}
  .patient-status-card{align-items:flex-start; flex-direction:column; padding:var(--space-md)}
  .patient-status-card .btn{width:100%; justify-content:center}
  .pat-action{align-items:flex-start; flex-direction:column; padding:var(--space-md) var(--space-md) var(--space-md) 28px}
  .pat-action-buttons{width:100%; flex-direction:column}
  .pat-action-buttons .btn{width:100%; justify-content:center}
  .form-row{
    grid-template-columns:36px 1fr;
    gap:var(--space-sm);
    padding:18px 0;
  }
  .form-row-meta{
    grid-column:2;
    justify-self:start;
    padding-top:0;
  }
  .hero-type .hero-tag br{display:none}
}
@media (max-width: 680px){
  .services{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .visit-left{padding:40px var(--space-md)}
  .visit-left h2{font-size:40px; line-height:1.08}
  .visit-info{grid-template-columns:1fr; gap:var(--space-md)}
  .visit-actions{margin-top:var(--space-lg); flex-direction:column; gap:10px}
  .visit-actions > .btn{width:100%; justify-content:center}
  .visit-map{min-height:320px}
  .contact-about-col{display:flex; flex-direction:column}
  .contact-about-col > .eyebrow{order:1}
  .contact-about-actions{order:2; margin-top:20px; flex-direction:column}
  .contact-about-actions > .btn{width:100%; justify-content:center}
  .contact-about-title{order:3; margin-top:var(--space-lg)}
  .contact-about-body{order:4; margin-top:var(--space-md)}
  .provider-row{grid-template-columns:1fr; gap:var(--space-2xs)}
  .provider-row-num{padding-top:0}
  .provider-row-name{font-size:23px}
  .info-card-row{grid-template-columns:72px 1fr; gap:12px}
}
@media (max-width: 640px){
  .portal-grid{grid-template-columns:1fr}
  .pat-sticky-ctas,
  .pat-sticky-info{grid-template-columns:1fr}
}
@media (max-width:520px){
  .foot-bottom{flex-direction:column; align-items:flex-start; gap:10px}
}
@media (max-width: 480px){
  .container{padding:0 20px}
  section.sec{padding:60px 0}
  .page-hero{padding:44px 0 52px}
  .pat-sections{gap:var(--space-xl)}
  .pat-sec{padding-bottom:var(--space-xl)}
  .topbar-inner{height:68px}
  .brand-logo{height:44px}
  .contact-card-v{font-size:28px}
}
@media (max-width: 400px){
  .staff-grid{grid-template-columns:1fr}
  .staff-cell-empty{display:none}
}
@media (max-width: 380px){
  .contact-card-v{font-size:24px}
}

/* Print — patients print the forms and policy pages */
@media print{
  .topbar,.mobile-nav-overlay,.skip-link,footer,.closing-cta,
  .visit-map,.contact-map-wrap,.pat-sticky-ctas,.svc-arrow{display:none}
  section.sec.dark{background:none}
  section.sec.dark, section.sec.dark *{color:var(--ink) !important}
  .staff-cell{background:none}
  .visit-grid{background:none; color:var(--ink)}
  .visit-grid *{color:var(--ink) !important}
  .pat-layout{grid-template-columns:1fr}
  .pat-sticky{position:static}
  .page-hero::before,.hero-type-bg,.foot-bg{display:none}
}

/* Reduced motion — blanket kill switch for every animation/transition above */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
  }
  html{scroll-behavior:auto !important}
}
