:root{
  --teal-950:#002f35;
  --teal-900:#003f45;
  --teal-800:#005961;
  --teal-700:#08717a;
  --teal-600:#0d8790;
  --aqua-100:#eaf5f3;
  --aqua-150:#dcefed;
  --aqua-200:#cce5e2;
  --ink:#153236;
  --muted:#5d6f73;
  --line:#d9e6e4;
  --white:#fff;
  --shadow:0 18px 48px rgba(0,47,53,.13);
  --shadow-soft:0 8px 28px rgba(0,47,53,.09);
  --radius-lg:20px;
  --radius-md:14px;
  --container:1440px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit}
address{font-style:normal}
:focus-visible{outline:3px solid rgba(13,135,144,.55);outline-offset:3px}
.container{width:min(var(--container), calc(100% - 64px));margin-inline:auto}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.svg-sprite{position:absolute;width:0;height:0;overflow:hidden}
.icon{display:inline-block;flex:0 0 auto;color:var(--teal-800);fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;vertical-align:middle}
.button-icon{width:19px;height:19px}
.button-primary .button-icon,.nav-chat .button-icon{color:currentColor}
.contact-icon{width:36px;height:36px;color:#fff;border:1.5px solid rgba(255,255,255,.62);border-radius:50%;padding:7px}
.service-icon{width:48px;height:48px;margin-bottom:13px;color:var(--teal-700)}
.resource-icon{width:44px;height:44px;color:var(--teal-700)}
.skip-link{position:absolute;left:18px;top:-100px;z-index:999;background:var(--teal-900);color:#fff;padding:10px 14px;border-radius:999px;transition:top .2s}
.skip-link:focus{top:18px}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.94);
  border-bottom:1px solid rgba(217,230,228,.86);
  backdrop-filter:saturate(180%) blur(16px);
}
.nav-wrap{display:flex;align-items:center;gap:34px;min-height:106px}
.brand{display:inline-flex;align-items:center;min-width:315px}
.brand img{width:305px}
.site-nav{margin-left:auto;display:flex;align-items:center;gap:44px;font-size:1.02rem;font-weight:800;color:#183d42}
.site-nav a{position:relative;padding:39px 0 34px;transition:color .18s ease}
.site-nav a:hover,.site-nav a:focus-visible{color:var(--teal-700)}
.site-nav a::after{content:"";position:absolute;left:0;right:0;bottom:30px;height:3px;border-radius:99px;background:var(--teal-700);transform:scaleX(0);transform-origin:left;transition:transform .18s ease}
.site-nav a:hover::after,.site-nav a.active::after{transform:scaleX(1)}
.nav-chat{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--teal-800),var(--teal-950));color:#fff;font-weight:850;padding:15px 24px;border-radius:16px;box-shadow:0 12px 30px rgba(0,89,97,.25);white-space:nowrap;transition:transform .18s ease, box-shadow .18s ease}
.nav-chat:hover{transform:translateY(-1px);box-shadow:0 14px 34px rgba(0,89,97,.27)}
.nav-toggle{display:none;margin-left:auto;width:46px;height:42px;border:1px solid var(--line);border-radius:12px;background:#fff;align-items:center;justify-content:center;flex-direction:column;gap:5px;cursor:pointer}
.nav-toggle span{width:22px;height:2px;background:var(--teal-900);border-radius:10px;transition:transform .18s ease, opacity .18s ease}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.hero{position:relative;overflow:hidden;background:linear-gradient(100deg,#f8fffd 0%,#edf8f6 30%,#d9eeeb 61%,#b9dcda 100%)}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 72% 47%, rgba(255,255,255,.5) 0 18%, rgba(255,255,255,0) 44%), linear-gradient(90deg, rgba(255,255,255,.36), rgba(255,255,255,.08) 52%, rgba(0,63,69,.1));pointer-events:none}
.stethoscope-bg{position:absolute;left:18px;top:82px;width:365px;height:365px;opacity:.22;background:url("assets/favicon.svg") center / contain no-repeat;filter:grayscale(1) brightness(2.75)}
.hero-grid{position:relative;display:grid;grid-template-columns:minmax(560px, .96fr) minmax(560px, 1.04fr);align-items:center;gap:42px;min-height:660px;padding:56px 0 0}
.hero-grid>*{min-width:0}
.hero-copy{position:relative;z-index:2}
.eyebrow{text-transform:uppercase;letter-spacing:.16em;font-weight:900;font-size:.82rem;color:var(--teal-700);margin:0 0 12px}
h1,h2,h3{line-height:1.08;margin:0;color:var(--teal-900)}
h1,h2{font-family:Georgia, "Times New Roman", serif}
h1{font-size:clamp(4rem, 4.45vw, 5.35rem);letter-spacing:-.02em;max-width:760px}
.hero-lede{font-size:1.12rem;max-width:620px;margin:24px 0 30px;color:#29484d;line-height:1.62}
.hero-actions{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:20px}
.button{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:54px;padding:14px 25px;border-radius:13px;border:1.5px solid var(--teal-800);font-weight:850;transition:transform .18s ease, box-shadow .18s ease, background .18s ease;color:var(--teal-900);text-align:center}
.button:hover{transform:translateY(-1px)}
.button-primary{background:linear-gradient(135deg,var(--teal-800),var(--teal-950));color:#fff;border-color:transparent;box-shadow:0 12px 26px rgba(0,89,97,.22)}
.button-primary:hover{box-shadow:0 16px 34px rgba(0,89,97,.29)}
.button-secondary{background:rgba(255,255,255,.82)}
.button-secondary:hover{background:#fff;box-shadow:var(--shadow-soft)}
.klara-card{display:flex;align-items:center;gap:14px;width:min(100%, 455px);background:rgba(255,255,255,.9);border:1px solid rgba(217,230,228,.95);border-radius:16px;box-shadow:0 14px 36px rgba(0,47,53,.13);padding:15px 17px;margin-top:8px}
.klara-icon{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#effffc,#bfe8e6);display:grid;place-items:center;color:var(--teal-800);font-weight:900;font-size:.92rem;flex:0 0 auto}
.klara-icon .icon{width:29px;height:29px;color:var(--teal-800)}
.klara-card h2{font-family:inherit;font-size:1rem;color:#1c383d}
.klara-card p{margin:4px 0 0;color:var(--muted);font-size:.86rem}
.chevron{position:relative;margin-left:auto;width:16px;height:16px;flex:0 0 auto}
.chevron::before{content:"";position:absolute;inset:2px;border-right:2px solid var(--teal-900);border-top:2px solid var(--teal-900);transform:rotate(45deg)}
.hero-visual{align-self:center;position:relative;min-height:635px;display:flex;align-items:center;justify-content:center;margin:0;isolation:isolate}
.hero-visual::before{content:"";position:absolute;right:1%;top:12%;width:min(700px, 96%);height:76%;background:radial-gradient(ellipse at 55% 48%, rgba(255,255,255,.66) 0 22%, rgba(186,222,220,.72) 58%, rgba(0,89,97,.14) 100%);border-radius:34px;filter:blur(.2px);z-index:-2}
.hero-visual::after{content:"";position:absolute;right:8%;bottom:9%;width:52%;height:34%;background:linear-gradient(135deg, rgba(255,255,255,.46), rgba(184,226,223,.2));border-radius:999px;filter:blur(18px);z-index:-1}
.hero-visual img{width:min(690px, 48vw);height:520px;object-fit:cover;object-position:72% center;border:1px solid rgba(255,255,255,.78);border-radius:28px;box-shadow:0 26px 58px rgba(0,47,53,.18);background:#d9e7e4}

.quick-contact{background:linear-gradient(90deg,var(--teal-950),var(--teal-800));color:#fff}
.quick-contact-grid{display:grid;grid-template-columns:1.35fr 1fr 1fr;align-items:center;min-height:78px}
.quick-contact-grid>a,.quick-contact-grid>div{display:flex;align-items:center;justify-content:center;gap:18px;padding:15px 34px;min-height:78px;border-left:1px solid rgba(255,255,255,.34);font-weight:800;font-size:1.22rem}
.quick-contact-grid>*:first-child{border-left:0}
.quick-contact a:hover{text-decoration:underline;text-underline-offset:4px}

.section{padding:42px 0}
.section-heading{display:grid;grid-template-columns:1fr auto 1fr;gap:22px;align-items:center;margin-bottom:24px}
.section-heading span{height:1px;background:linear-gradient(90deg,transparent,var(--aqua-200),transparent)}
.section-heading h2{font-size:clamp(2.15rem,2.8vw,3rem);text-align:center;letter-spacing:-.015em}
.service-grid{display:grid;grid-template-columns:repeat(10,minmax(0,1fr));gap:12px}
.service-card{min-height:160px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:#fff;border:1px solid var(--line);border-radius:15px;padding:20px 12px;box-shadow:0 8px 22px rgba(0,47,53,.055);transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
.service-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft);border-color:#afd7d4}
.service-card h3{font-family:inherit;font-size:.92rem;line-height:1.17;color:var(--teal-900)}

.about{background:linear-gradient(180deg,#fff 0%, #f7fbfa 100%);padding-top:24px}
.team-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;align-items:stretch}
.provider-card,.team-card{background:#fff;border:1px solid var(--line);border-radius:17px;box-shadow:var(--shadow-soft);overflow:hidden}
.provider-card{grid-column:1/-1;display:grid;grid-template-columns:minmax(320px,.72fr) 1fr;align-items:stretch}
.provider-photo{min-height:410px;background:#d9e7e4}
.provider-photo img{width:100%;height:100%;object-fit:cover;object-position:center 24%}
.provider-content{position:relative;padding:38px 42px;display:flex;flex-direction:column;justify-content:center}
.provider-content::after{content:"";position:absolute;right:26px;bottom:24px;width:48px;height:48px;border-radius:50%;border:1px solid var(--aqua-200);background:#f7fbfa url("assets/favicon.svg") center / 31px 31px no-repeat}
.provider-content h3{font-size:clamp(1.85rem,2.4vw,2.5rem);margin-bottom:8px}
.provider-content p:not(.eyebrow):not(.team-role){max-width:780px;margin:14px 0 0;color:#334f54;font-size:1rem;line-height:1.6}
.team-card{display:flex;flex-direction:column}
.team-card img{width:100%;height:330px;aspect-ratio:4/5;object-fit:cover;object-position:center top;background:#d9e7e4}
.team-card-body{padding:16px 18px 20px;text-align:center}
.team-card h3{font-family:Georgia,"Times New Roman",serif;font-size:1.35rem}
.team-role{margin:3px 0 0;color:var(--teal-800);font-weight:750;font-size:.92rem}
.team-bio{margin:11px 0 0;color:#496066;font-size:.86rem;line-height:1.42;font-weight:500}

.resources{padding-top:24px}
.resource-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.resource-card{min-height:112px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;display:flex;align-items:center;gap:17px;box-shadow:0 8px 22px rgba(0,47,53,.05);transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
.resource-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft);border-color:#afd7d4}
.pending-resource{background:linear-gradient(180deg,#fff,#fbfdfd)}
.resource-card h3{font-family:inherit;font-size:1rem}
.resource-card p{margin:4px 0 0;color:var(--muted);font-size:.85rem;line-height:1.3}
.lab-links{display:flex;flex-wrap:wrap;gap:7px;margin-top:9px}
.lab-links a{border:1px solid var(--aqua-200);background:#f4fbfa;color:var(--teal-800);border-radius:999px;padding:4px 8px;font-weight:800;font-size:.75rem;line-height:1.2}
.lab-links a:hover,.lab-links a:focus-visible{border-color:var(--teal-600);background:#e9f7f6}
.resource-note{color:var(--muted);font-size:.93rem;text-align:center;margin:18px 0 0}

.location-cta{padding:24px 0 0}
.cta-grid{display:grid;grid-template-columns:1.15fr .88fr 1.1fr;gap:20px;align-items:stretch}
.building-card,.care-card,.map-card{border-radius:18px;overflow:hidden;box-shadow:var(--shadow-soft);border:1px solid var(--line);background:#fff;min-height:230px}
.building-card img{width:100%;height:100%;object-fit:cover}
.care-card{padding:32px 30px;text-align:center;display:flex;flex-direction:column;justify-content:center}
.care-card h2{font-size:2rem;margin-bottom:12px}
.care-card p:not(.eyebrow){color:#496066;margin:0 0 20px}
.care-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.map-card{position:relative;min-height:320px}
.map-card iframe{position:absolute;inset:0;border:0;width:100%;height:100%;filter:saturate(.9) contrast(1.02)}

.site-footer{margin-top:42px;background:linear-gradient(90deg,var(--teal-950),var(--teal-800));color:#fff}
.footer-grid{display:grid;grid-template-columns:auto 1.5fr auto auto;gap:24px;align-items:center;min-height:95px}
.footer-brand img{width:210px;filter:brightness(0) invert(1)}
.footer-grid p,.footer-grid address{margin:0;color:#edfafa;font-weight:700}
.footer-grid a:hover{text-decoration:underline}
.legal{border-top:1px solid rgba(255,255,255,.2);display:flex;justify-content:space-between;gap:20px;padding:16px 0 20px;color:#e3f3f1;font-size:.82rem}
.legal p{margin:0}

.appointment-page .hero-small{background:linear-gradient(135deg,#eaf5f3,#ffffff);padding:70px 0 40px;border-bottom:1px solid var(--line)}
.hero-small h1{font-size:clamp(2.6rem,5vw,4.8rem);max-width:840px}
.hero-small p{max-width:760px;color:#405a5f;font-size:1.08rem}
.appointment-shell{padding:34px 0 70px;background:#f8fbfa}
.appointment-notice{display:flex;justify-content:space-between;gap:20px;align-items:center;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft);border-radius:18px;padding:20px 22px;margin-bottom:20px}
.appointment-notice h2{font-family:inherit;font-size:1.15rem;margin-bottom:5px}
.appointment-notice p{margin:0;color:#496066}
.iframe-wrap{background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);overflow:hidden}
.iframe-wrap iframe{display:block;width:100%;height:min(980px, 115vh);border:0;background:#fff}
.fallback-panel{margin-top:18px;background:#fffbe8;border:1px solid #eadf9d;border-radius:16px;padding:18px;color:#5c511b}
.fallback-panel p{margin:0}
.fallback-panel a{text-decoration:underline;text-underline-offset:3px}

@media (max-width:1100px){
  .nav-wrap{gap:18px}
  .brand{min-width:220px}
  .brand img{width:220px}
  .site-nav{gap:20px}
  .nav-chat{padding:12px 15px}
  .hero-grid{grid-template-columns:1fr .88fr}
  h1{font-size:clamp(3.25rem, 5.6vw, 4.25rem)}
  .service-grid{grid-template-columns:repeat(5,1fr)}
  .team-grid{grid-template-columns:1fr 1fr}
  .provider-card{grid-column:1/-1;grid-template-columns:minmax(300px,.75fr) 1fr}
  .resource-grid{grid-template-columns:1fr 1fr}
  .cta-grid{grid-template-columns:1fr}
  .building-card img{max-height:360px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:12px;padding:22px 0}
  .legal{flex-direction:column;gap:6px}
}
@media (max-width:860px){
  .nav-wrap{min-height:78px}
  .brand img{width:210px}
  .nav-toggle{display:flex}
  .site-nav{position:absolute;left:20px;right:20px;top:82px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);display:none;flex-direction:column;align-items:stretch;gap:0;padding:10px}
  .site-nav.open{display:flex}
  .site-nav a{padding:14px 15px;border-radius:12px}
  .site-nav a::after{display:none}
  .nav-chat{display:none}
  .hero-grid{grid-template-columns:1fr;min-height:auto;padding-top:44px;gap:16px}
  .hero-grid,.hero-copy{width:calc(100vw - 40px);max-width:calc(100vw - 40px)}
  h1{font-size:clamp(2.2rem, 7vw, 3rem);max-width:100%}
  .hero-lede{max-width:680px}
  .hero-visual{min-height:0;align-items:center}
  .hero-visual::before{width:100%;height:86%;right:auto;top:7%}
  .hero-visual::after{display:none}
  .hero-visual img{width:min(680px, 100%);height:clamp(300px, 54vw, 460px);object-position:72% center;border-radius:24px}
  .quick-contact-grid{grid-template-columns:1fr}
  .quick-contact-grid>a,.quick-contact-grid>div{border-left:0;border-top:1px solid rgba(255,255,255,.25);padding-left:0}
  .quick-contact-grid>*:first-child{border-top:0}
  .provider-card{grid-template-columns:1fr}
  .provider-photo{min-height:0}
  .provider-photo img{height:auto;max-height:560px;object-position:center 20%}
  .provider-content{padding:30px 28px 38px}
  .team-card img{height:360px}
  .appointment-notice{align-items:flex-start;flex-direction:column}
}
@media (max-width:640px){
  .container{width:min(100% - 28px, var(--container))}
  .brand{min-width:auto}
  .brand img{width:195px}
  .hero-grid,.hero-copy{width:calc(100vw - 28px);max-width:calc(100vw - 28px)}
  h1{font-size:2.28rem;letter-spacing:0;max-width:100%}
  .hero-lede{font-size:1rem;max-width:100%}
  .hero-actions,.care-actions{flex-direction:column}
  .button{width:100%}
  .klara-card{align-items:flex-start;width:100%;max-width:100%}
  .hero-visual{margin-inline:auto;width:100%}
  .hero-visual img{width:100%;height:300px;max-height:none;border-radius:20px}
  .quick-contact-grid>a,.quick-contact-grid>div{font-size:1rem}
  .service-grid{grid-template-columns:1fr 1fr}
  .team-grid,.resource-grid{grid-template-columns:1fr}
  .section{padding:36px 0}
  .section-heading{gap:12px}
  .provider-content{padding:26px 22px 34px}
  .provider-content::after{right:18px;bottom:18px;width:42px;height:42px;background-size:27px 27px}
  .provider-photo img,.team-card img{height:auto;max-height:520px}
  .care-card{text-align:left;padding:26px 22px}
  .care-actions{align-items:stretch}
  .footer-grid{grid-template-columns:1fr}
  .footer-brand img{width:190px}
  .iframe-wrap iframe{height:760px}
  .appointment-notice .button{width:100%}
}
@media (max-width:420px){
  h1{font-size:2.05rem}
  .section-heading{grid-template-columns:36px auto 36px}
  .service-grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{scroll-behavior:auto!important;transition:none!important}
}
