/* ============================================================
   St. Clair Medical, PC — shared design system
   Palette: green-from-logo (teal) + relaxing terracotta + cream
   Fonts: Fraunces (display serif) + Inter (body)
   ============================================================ */
:root{
  --teal:#2f7d72; --teal-dark:#1f5a51; --teal-deep:#15403a;
  --sage:#6fa394; --terra:#d98b5f; --terra-deep:#a85a30;
  --cream:#faf6ef; --sand:#f1e9dc; --ink:#262b29; --muted:#5b625c;
  --line:#e7ded0; --white:#fff;
  --radius:22px; --radius-sm:14px;
  --shadow:0 14px 36px rgba(31,90,81,.12);
  --shadow-lg:0 26px 60px rgba(21,64,58,.18);
  --maxw:1160px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
h1,h2,h3,.serif{font-family:'Fraunces',Georgia,serif;letter-spacing:-.01em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
:focus-visible{outline:3px solid var(--terra);outline-offset:3px;border-radius:6px}
.skip{position:absolute;left:-999px;top:0;background:#fff;color:var(--teal-dark);padding:12px 18px;border-radius:0 0 10px 0;font-weight:600;z-index:200}
.skip:focus{left:0}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:14px 26px;border-radius:999px;font-weight:600;font-size:.96rem;font-family:'Inter',sans-serif;transition:transform .18s ease,background .18s ease,box-shadow .18s ease;cursor:pointer;border:none;line-height:1}
.btn svg{flex:0 0 auto}
.btn-teal{background:var(--teal);color:#fff;box-shadow:0 10px 24px rgba(47,125,114,.28)}
.btn-teal:hover{background:var(--teal-dark);transform:translateY(-2px)}
.btn-terra{background:var(--terra-deep);color:#fff;box-shadow:0 10px 24px rgba(168,90,48,.26)}
.btn-terra:hover{background:#90471f;transform:translateY(-2px)}
.btn-soft{background:#fff;color:var(--teal-dark);border:1.5px solid var(--line)}
.btn-soft:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.5)}
.btn-ghost:hover{background:rgba(255,255,255,.22)}

/* top bar */
.topbar{background:var(--teal-deep);color:#cfe2dc;font-size:.85rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;min-height:42px;gap:16px;flex-wrap:wrap;padding-top:6px;padding-bottom:6px}
.topbar a{color:#cfe2dc}.topbar a:hover{color:#fff}
.topbar .tag{display:inline-flex;align-items:center;flex-wrap:wrap}
.topbar .phones{display:flex;gap:14px;align-items:center;font-size:.92rem}
.topbar .phones a{color:#eaf3ef;font-weight:500}
.topbar .phones a b{color:#fff;font-weight:700}
.topbar .phones a:hover b{color:var(--terra)}
.topbar .phones .sep{opacity:.45}
.topbar .dot{width:7px;height:7px;border-radius:50%;background:var(--terra);display:inline-block;margin-right:7px;vertical-align:middle}
@media(max-width:680px){.topbar .tag{display:none}.topbar .wrap{justify-content:center}.topbar .phones{font-size:.85rem;gap:10px}}

/* header / nav */
header.nav{position:sticky;top:0;z-index:100;background:rgba(250,246,239,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:box-shadow .25s ease}
header.nav.scrolled{box-shadow:0 6px 24px rgba(31,90,81,.08)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:80px;gap:18px}
.nav .logo img{height:50px;width:auto}
.nav ul{display:flex;gap:22px;list-style:none;font-weight:600;font-size:.94rem}
.nav ul a{padding:8px 0;position:relative;color:var(--ink)}
.nav ul a:hover,.nav ul a[aria-current="page"]{color:var(--teal)}
.nav ul a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--terra);transition:width .2s ease}
.nav ul a:hover::after,.nav ul a[aria-current="page"]::after{width:100%}
.nav .cta{display:flex;gap:10px;align-items:center}
.menu-btn{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--teal-dark)}
@media(max-width:1040px){.nav ul,.nav .cta{display:none}.menu-btn{display:inline-flex}}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:150;visibility:hidden;opacity:0;transition:opacity .25s ease,visibility .25s ease}
.drawer.open{visibility:visible;opacity:1}
.drawer .scrim{position:absolute;inset:0;background:rgba(21,64,58,.45)}
.drawer .panel{position:absolute;right:0;top:0;height:100%;width:min(82%,340px);background:var(--cream);padding:26px;display:flex;flex-direction:column;gap:8px;transform:translateX(100%);transition:transform .28s ease;box-shadow:var(--shadow-lg);overflow-y:auto}
.drawer.open .panel{transform:translateX(0)}
.drawer .panel .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.drawer .panel a.link{padding:14px 6px;font-weight:600;border-bottom:1px solid var(--line);color:var(--ink)}
.drawer .panel a.link:hover{color:var(--teal)}
.drawer .panel .btn{margin-top:8px}
.drawer .x{background:none;border:none;cursor:pointer;color:var(--teal-dark);padding:6px}

/* generic section */
section{padding:90px 0}
.sec-head{max-width:660px;margin:0 auto 52px;text-align:center}
.sec-head .tag{color:var(--terra-deep);font-weight:700;letter-spacing:.09em;text-transform:uppercase;font-size:.78rem}
.sec-head h2{font-size:clamp(2rem,3.6vw,2.6rem);font-weight:600;color:#23332f;margin:9px 0 14px}
.sec-head p{color:var(--muted);font-size:1.06rem}
.eyebrow{color:var(--terra-deep);font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:.78rem;display:inline-flex;align-items:center;gap:11px;margin-bottom:20px}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--terra-deep)}

/* ---------- HOME: hero ---------- */
.hero{background:radial-gradient(125% 120% at 82% -10%,var(--sand),var(--cream) 58%);overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.04fr .96fr;gap:54px;align-items:center;padding:74px 26px 86px}
.hero h1{font-size:clamp(2.3rem,4.6vw,3.5rem);line-height:1.04;font-weight:600;color:#23332f;margin-bottom:22px}
.hero h1 em{font-style:italic;color:var(--teal)}
.hero p.lead{font-size:1.14rem;color:var(--muted);max-width:500px;margin-bottom:30px}
.hero .actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-art{position:relative}
.hero-art img{border-radius:var(--radius);height:452px;width:100%;object-fit:cover;box-shadow:var(--shadow-lg)}
.hero-art .badge{position:absolute;bottom:-24px;left:-22px;background:#fff;border-radius:18px;padding:16px 22px;box-shadow:var(--shadow);display:flex;gap:14px;align-items:center;max-width:240px}
.hero-art .badge .n{font-family:'Fraunces',serif;font-size:2.1rem;font-weight:600;color:var(--teal);line-height:1}
.hero-art .badge .l{font-size:.83rem;color:var(--muted);line-height:1.35}
@media(max-width:1000px){.hero .wrap{grid-template-columns:1fr;gap:36px;padding:52px 26px 64px}.hero-art{max-width:520px;margin:0 auto;width:100%}.hero-art img{height:340px}}
@media(max-width:520px){.hero-art .badge{left:0;padding:13px 16px}}

/* quick strip */
.quick{position:relative;z-index:5;margin-top:-36px}
.quick .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.qcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:22px 22px 20px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease}
.qcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.qcard .ic{width:46px;height:46px;border-radius:13px;background:var(--sand);color:var(--teal-dark);display:grid;place-items:center;margin-bottom:8px}
.qcard h3{font-family:'Inter';font-size:1.04rem;font-weight:700}
.qcard p{font-size:.86rem;color:var(--muted)}
.qcard .go{margin-top:6px;font-size:.82rem;font-weight:700;color:var(--terra-deep)}
@media(max-width:860px){.quick .grid{grid-template-columns:repeat(2,1fr)}}

/* about (home) */
.about .wrap{display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:center}
.about-img{position:relative}
.about-img img{border-radius:var(--radius);height:440px;width:100%;object-fit:cover;box-shadow:var(--shadow)}
.about-img .tab{position:absolute;top:22px;left:-18px;background:var(--terra-deep);color:#fff;padding:10px 18px;border-radius:999px;font-size:.82rem;font-weight:600;box-shadow:var(--shadow)}
.about h2{font-size:clamp(1.9rem,3.4vw,2.5rem);font-weight:600;color:#23332f;margin-bottom:18px;line-height:1.12}
.about p{color:var(--muted);margin-bottom:16px}
.about .quote{border-left:3px solid var(--terra);padding-left:20px;font-family:'Fraunces';font-style:italic;font-size:1.2rem;color:var(--teal-dark);margin-top:24px;line-height:1.5}
@media(max-width:980px){.about .wrap{grid-template-columns:1fr;gap:32px}.about-img img{height:320px}}

/* services cards */
.services{background:var(--white)}
.scards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.scard{background:var(--cream);border:1px solid transparent;border-radius:var(--radius);padding:30px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.scard:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line)}
.scard .ic{width:56px;height:56px;border-radius:16px;background:var(--teal);color:#fff;display:grid;place-items:center;margin-bottom:18px}
.scard:nth-child(3n+2) .ic{background:var(--terra-deep)}
.scard:nth-child(3n) .ic{background:var(--sage)}
.scard h3{font-size:1.28rem;font-weight:600;color:#23332f;margin-bottom:8px}
.scard p{color:var(--muted);font-size:.95rem}
@media(max-width:860px){.scards{grid-template-columns:1fr}}

/* providers — centered flex so any count looks balanced */
.providers{background:var(--sand)}
.pgrid{display:flex;flex-wrap:wrap;justify-content:center;gap:34px 30px}
.pcard{text-align:center;width:200px}
.pcard .ph{width:158px;height:158px;border-radius:50%;margin:0 auto 16px;object-fit:cover;border:5px solid #fff;box-shadow:var(--shadow)}
.pcard h3{font-family:'Fraunces';font-size:1.16rem;font-weight:600;color:#23332f}
.pcard .role{color:var(--terra-deep);font-weight:600;font-size:.85rem}

/* locations */
.locations{background:var(--teal-deep);color:#eef6f3}
.locations .sec-head h2{color:#fff}.locations .sec-head .tag{color:#f2b489}.locations .sec-head p{color:#bcd6cf}
.lgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:24px}
.lcard{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:30px}
.lcard h3{font-family:'Fraunces';font-size:1.22rem;font-weight:600;color:#fff;margin-bottom:6px}
.lcard .sub{color:#a8cabf;font-size:.86rem;margin-bottom:14px}
.lcard .addr{color:#cfe2dc;margin-bottom:12px}
.lcard .ph{font-weight:700;color:#fff;font-size:1.06rem;display:inline-block;margin-bottom:12px}
.lcard .dir{font-size:.86rem;font-weight:700;color:var(--terra)}
.lcard .dir:hover{color:#fff}
.lcard .tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:6px}
.lcard .tags span{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);color:#dcebe4;font-size:.76rem;padding:4px 10px;border-radius:999px}
.hours{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:26px 32px;display:flex;flex-wrap:wrap;gap:24px 36px;justify-content:space-between;align-items:center}
.hours .row b{color:#fff}.hours .row span{color:#cfe2dc;margin-left:10px}
.hours .oncall{color:#cfe2dc}.hours .oncall b{color:var(--terra)}
@media(max-width:860px){.lgrid{grid-template-columns:1fr}}

/* cta band */
.ctaband{background:var(--white)}
.ctaband .box{background:linear-gradient(135deg,var(--teal),var(--sage));border-radius:30px;padding:62px 30px;text-align:center;color:#fff;box-shadow:var(--shadow)}
.ctaband h2{font-size:clamp(1.9rem,3.4vw,2.5rem);font-weight:600;margin-bottom:12px;color:#fff}
.ctaband p{opacity:.94;margin-bottom:26px;font-size:1.06rem}
.ctaband .btn-terra{background:#fff;color:var(--terra-deep);box-shadow:none}
.ctaband .btn-terra:hover{background:#fff;color:#90471f}

/* footer */
footer{background:#15211d;color:#a7bdb6;padding:58px 0 28px;font-size:.92rem}
footer .grid{display:grid;grid-template-columns:1.5fr 1fr 1.1fr;gap:42px;margin-bottom:36px}
footer .logo img{height:44px;filter:brightness(0) invert(1);opacity:.92;margin-bottom:16px}
footer p{max-width:300px}
footer h4{color:#fff;font-family:'Fraunces';font-size:1.05rem;margin-bottom:14px;font-weight:600}
footer a{color:#a7bdb6;display:block;margin-bottom:9px}footer a:hover{color:#fff}
footer .bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;text-align:center;font-size:.83rem;color:#7f968f}
@media(max-width:820px){footer .grid{grid-template-columns:1fr;gap:30px}}

/* ============================================================
   INNER PAGES
   ============================================================ */
.page-hero{background:radial-gradient(120% 130% at 85% -20%,var(--sand),var(--cream) 60%);padding:54px 0 46px;border-bottom:1px solid var(--line)}
.page-hero .crumb{font-size:.82rem;color:var(--muted);margin-bottom:14px}
.page-hero .crumb a:hover{color:var(--teal)}
.page-hero h1{font-size:clamp(2rem,4vw,3rem);font-weight:600;color:#23332f;line-height:1.06;margin-bottom:14px}
.page-hero p{color:var(--muted);font-size:1.1rem;max-width:640px}

.prose{max-width:760px;margin:0 auto}
.prose h2{font-size:1.7rem;font-weight:600;color:#23332f;margin:34px 0 10px}
.prose h2:first-child{margin-top:0}
.prose p{color:var(--muted);margin-bottom:14px}
.prose ul{color:var(--muted);margin:0 0 16px 1.1rem}
.prose li{margin-bottom:7px}

/* story / about page two-col */
.story .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:start}
.story p{color:var(--muted);margin-bottom:16px}
.story .lead-q{font-family:'Fraunces';font-style:italic;font-size:1.3rem;color:var(--teal-dark);line-height:1.5;margin:10px 0 22px}
.story-aside{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow);position:sticky;top:104px}
.story-aside h3{font-family:'Fraunces';font-size:1.2rem;margin-bottom:14px;color:#23332f}
.timeline{list-style:none}
.timeline li{position:relative;padding:0 0 18px 24px;border-left:2px solid var(--line)}
.timeline li:last-child{border-left-color:transparent;padding-bottom:0}
.timeline li::before{content:"";position:absolute;left:-7px;top:3px;width:12px;height:12px;border-radius:50%;background:var(--terra-deep);border:2px solid var(--cream)}
.timeline .yr{font-weight:700;color:var(--teal-dark);font-size:.9rem}
.timeline .ev{color:var(--muted);font-size:.9rem}
@media(max-width:980px){.story .wrap{grid-template-columns:1fr;gap:30px}.story-aside{position:static}}

/* services page grouped */
.svc-group{margin-bottom:40px}
.svc-group h2{font-size:1.55rem;font-weight:600;color:#23332f;margin-bottom:6px;display:flex;align-items:center;gap:12px}
.svc-group h2 .ic{width:42px;height:42px;border-radius:12px;background:var(--teal);color:#fff;display:grid;place-items:center;flex:0 0 auto}
.svc-group:nth-child(3n+2) h2 .ic{background:var(--terra-deep)}
.svc-group:nth-child(3n) h2 .ic{background:var(--sage)}
.svc-group .desc{color:var(--muted);margin:0 0 18px 54px}
.chiplist{display:flex;flex-wrap:wrap;gap:10px;margin-left:54px}
.chiplist span{background:var(--white);border:1px solid var(--line);border-radius:999px;padding:9px 16px;font-size:.9rem;font-weight:500;color:var(--ink)}
@media(max-width:680px){.svc-group .desc,.chiplist{margin-left:0}}

/* provider detail cards (providers page) */
.bio-list{display:flex;flex-direction:column;gap:22px;max-width:920px;margin:0 auto}
.bio{display:grid;grid-template-columns:170px 1fr;gap:28px;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:26px 30px;box-shadow:var(--shadow);align-items:start}
.bio .ph{width:150px;height:150px;border-radius:50%;object-fit:cover;border:5px solid var(--cream);box-shadow:var(--shadow)}
.bio h3{font-family:'Fraunces';font-size:1.4rem;font-weight:600;color:#23332f;margin-bottom:2px}
.bio .role{color:var(--terra-deep);font-weight:600;font-size:.9rem;margin-bottom:12px}
.bio p{color:var(--muted);margin-bottom:10px}
.bio p:last-child{margin-bottom:0}
.gen-band{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:24px 28px;max-width:920px;margin:0 auto 30px;color:var(--muted);font-size:.96rem}
.gen-band b{color:var(--teal-dark)}
@media(max-width:640px){.bio{grid-template-columns:1fr;text-align:center;justify-items:center}}

/* insurance */
.ins-grid{display:flex;flex-wrap:wrap;gap:10px;max-width:860px;margin:0 auto}
.ins-grid span{background:var(--white);border:1px solid var(--line);border-radius:10px;padding:11px 16px;font-size:.92rem;font-weight:500;display:flex;align-items:center;gap:9px}
.ins-grid span::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--teal);flex:0 0 auto}
.callout{background:var(--sand);border:1px solid var(--line);border-left:4px solid var(--terra-deep);border-radius:var(--radius-sm);padding:20px 24px;max-width:760px;margin:0 auto 24px;color:var(--ink)}
.callout b{color:var(--teal-dark)}

/* policies cards */
.policy-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:920px;margin:0 auto}
.policy{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:26px 28px;box-shadow:var(--shadow)}
.policy .ic{width:44px;height:44px;border-radius:12px;background:var(--sand);color:var(--teal-dark);display:grid;place-items:center;margin-bottom:14px}
.policy h3{font-size:1.2rem;font-weight:600;color:#23332f;margin-bottom:8px}
.policy p{color:var(--muted);font-size:.94rem}
.policy.flag{border-left:4px solid var(--terra-deep)}
@media(max-width:760px){.policy-grid{grid-template-columns:1fr}}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contact-form{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow)}
.contact-form label{display:block;font-weight:600;font-size:.88rem;margin:14px 0 6px;color:var(--ink)}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;font-family:'Inter';font-size:.95rem;background:var(--cream)}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:var(--teal)}
.contact-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact-form .btn{margin-top:18px;width:100%}
.contact-form .hint{font-size:.8rem;color:var(--muted);margin-top:12px}
.loc-detail{display:flex;flex-direction:column;gap:16px}
.loc-detail .lc{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow)}
.loc-detail .lc h3{font-family:'Fraunces';font-size:1.18rem;color:#23332f;margin-bottom:4px}
.loc-detail .lc .sub{color:var(--terra-deep);font-weight:600;font-size:.82rem;margin-bottom:8px}
.loc-detail .lc .addr{color:var(--muted);margin-bottom:8px}
.loc-detail .lc a.ph{font-weight:700;color:var(--teal-dark)}
.loc-detail .lc .dir{font-size:.85rem;font-weight:700;color:var(--terra-deep);margin-left:14px}
.hours-card{background:var(--teal-deep);color:#eef6f3;border-radius:var(--radius);padding:24px 26px}
.hours-card h3{color:#fff;font-family:'Fraunces';margin-bottom:12px}
.hours-card .r{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:.94rem}
.hours-card .r:last-child{border-bottom:none}
.hours-card .r span{color:#cfe2dc}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr;gap:28px}.contact-form .row2{grid-template-columns:1fr}}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .btn,.qcard,.scard,.pcard{transition:none}
}
