/* KC Hearing Center — healthcare site, navy + teal palette, warm ivory neutrals */
:root{
  --navy-900:#0B2545;
  --navy-800:#13315C;
  --navy-700:#1C4273;
  --teal-600:#06A0B5;
  --teal-500:#14B8C9;
  --teal-100:#E6F7FA;
  --ivory:#FBF9F4;
  --cream:#F4EFE6;
  --line:#E3DDD0;
  --text:#1C2434;
  --text-muted:#51607A;
  --white:#FFFFFF;
  --amber:#E9A53D;
  --shadow-sm:0 1px 2px rgba(11,37,69,.06), 0 1px 3px rgba(11,37,69,.06);
  --shadow-md:0 6px 18px rgba(11,37,69,.08), 0 2px 6px rgba(11,37,69,.05);
  --shadow-lg:0 20px 50px rgba(11,37,69,.12);
  --radius-sm:6px;
  --radius:12px;
  --radius-lg:20px;
  --radius-xl:28px;
  --container:1200px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  font-size:17px;
  line-height:1.65;
  color:var(--text);
  background:var(--ivory);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--teal-600);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--navy-900)}
h1,h2,h3,h4{
  font-family:"Fraunces", Georgia, "Times New Roman", serif;
  font-weight:600;
  letter-spacing:-.01em;
  color:var(--navy-900);
  line-height:1.15;
  margin:0 0 .5em;
}
h1{font-size:clamp(2.1rem,4.2vw,3.6rem);letter-spacing:-.02em}
h2{font-size:clamp(1.7rem,3vw,2.5rem)}
h3{font-size:clamp(1.25rem,1.8vw,1.55rem)}
h4{font-size:1.1rem}
p{margin:0 0 1em}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.container-narrow{max-width:820px;margin:0 auto;padding:0 24px}

/* ———— Top contact strip ———— */
.topbar{
  background:var(--navy-900);
  color:#D8E3F2;
  font-size:.85rem;
}
.topbar-inner{display:flex;flex-wrap:wrap;gap:18px;align-items:center;justify-content:space-between;padding:8px 24px;max-width:var(--container);margin:0 auto}
.topbar a{color:#D8E3F2}
.topbar a:hover{color:var(--teal-500)}
.topbar-links{display:flex;gap:18px;flex-wrap:wrap}
.topbar-links span{opacity:.7}

/* ———— Header ———— */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,249,244,.94);
  backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;max-width:var(--container);margin:0 auto;gap:16px}
.brand{display:flex;align-items:center;gap:12px;color:var(--navy-900)}
.brand:hover{color:var(--navy-900)}
.brand-mark{width:40px;height:40px;display:block}
.brand-name{font-family:"Fraunces",serif;font-weight:600;font-size:1.2rem;letter-spacing:-.01em;line-height:1.05}
.brand-name small{display:block;font-family:"Inter",sans-serif;font-weight:500;font-size:.7rem;color:var(--teal-600);letter-spacing:.12em;text-transform:uppercase;margin-top:2px}

.nav-links{display:flex;gap:6px;align-items:center}
.nav-links a{
  display:inline-block;
  padding:10px 14px;
  color:var(--navy-800);
  font-weight:500;
  font-size:.95rem;
  border-radius:8px;
}
.nav-links a:hover,.nav-links a.active{background:var(--teal-100);color:var(--navy-900)}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 22px;
  border-radius:999px;
  font-weight:600;
  font-size:.95rem;
  text-decoration:none;
  transition:transform .15s var(--ease), background .2s, color .2s, box-shadow .2s;
  border:none;cursor:pointer;
  white-space:nowrap;
}
.btn-primary{background:var(--teal-600);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--navy-900);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-ghost{background:transparent;color:var(--navy-900);border:1.5px solid var(--navy-900)}
.btn-ghost:hover{background:var(--navy-900);color:#fff}
.btn-light{background:#fff;color:var(--navy-900);border:1px solid var(--line)}
.btn-light:hover{background:var(--navy-900);color:#fff;border-color:var(--navy-900)}
.btn-lg{padding:16px 28px;font-size:1rem}

.menu-toggle{display:none;background:transparent;border:0;padding:10px;cursor:pointer}
.menu-toggle svg{width:28px;height:28px;stroke:var(--navy-900)}

@media (max-width:900px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:#fff;padding:16px;gap:4px;border-bottom:1px solid var(--line);box-shadow:var(--shadow-md)}
  .nav-links.open{display:flex}
  .nav-links a{width:100%}
  .menu-toggle{display:inline-flex}
  .nav .btn{display:none}
  .topbar-inner{font-size:.78rem;gap:10px;justify-content:center}
}

/* ———— Hero ———— */
.hero{
  position:relative;
  min-height:560px;
  display:flex;align-items:center;
  color:#fff;
  overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg, rgba(11,37,69,.85) 0%, rgba(11,37,69,.55) 55%, rgba(6,160,181,.25) 100%);
}
.hero-inner{position:relative;z-index:1;padding:72px 24px;max-width:var(--container);margin:0 auto;width:100%}
.hero-eyebrow{display:inline-block;padding:6px 14px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);border-radius:999px;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:#E6F7FA;margin-bottom:16px}
.hero h1{color:#fff;max-width:840px;margin-bottom:18px}
.hero .lede{font-size:1.2rem;max-width:660px;color:#EBF2FA;margin-bottom:30px;line-height:1.55}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:40px;flex-wrap:wrap;margin-top:56px;padding-top:28px;border-top:1px solid rgba(255,255,255,.18)}
.hero-stat strong{display:block;font-family:"Fraunces",serif;font-size:2rem;color:#fff}
.hero-stat span{font-size:.88rem;color:#B7C6DC;letter-spacing:.06em;text-transform:uppercase}

/* Compact hero (inner pages) */
.hero.hero-sm{min-height:320px}
.hero.hero-sm .hero-inner{padding:56px 24px}

/* ———— Sections ———— */
section{padding:72px 0}
.section-eyebrow{
  display:inline-block;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--teal-600);font-weight:600;margin-bottom:10px;
}
.section-title{margin-bottom:12px}
.section-lede{max-width:680px;color:var(--text-muted);font-size:1.08rem;margin:0 auto 40px}
.section-lede.left{margin-left:0}
.section-head{max-width:780px;margin-bottom:40px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}

/* ———— Services grid ———— */
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid-4{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}

.service-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:28px;
  transition:transform .25s var(--ease), box-shadow .25s;
  position:relative;
  display:flex;flex-direction:column;
  color:inherit;
}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);color:inherit}
.service-card .icon{
  width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:var(--teal-100);color:var(--teal-600);margin-bottom:18px;
}
.service-card .icon svg{width:26px;height:26px;stroke:currentColor;fill:none;stroke-width:1.8}
.service-card h3{margin-bottom:10px;font-size:1.25rem}
.service-card p{color:var(--text-muted);font-size:.98rem;margin-bottom:16px}
.service-card .learn{margin-top:auto;font-weight:600;font-size:.92rem;color:var(--teal-600)}
.service-card .learn::after{content:" →"}

/* ———— Value props ———— */
.value-card{padding:32px 28px;background:var(--cream);border-radius:var(--radius-lg);border:1px solid var(--line)}
.value-card .num{font-family:"Fraunces",serif;font-size:2.2rem;color:var(--teal-600);line-height:1;margin-bottom:12px}
.value-card h3{margin-bottom:8px}
.value-card p{color:var(--text-muted);margin-bottom:0}

/* ———— Staff / cards ———— */
.staff-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
  display:flex;flex-direction:column;
  transition:box-shadow .25s;
}
.staff-card:hover{box-shadow:var(--shadow-md)}
.staff-photo{aspect-ratio:1/1;overflow:hidden;background:var(--cream)}
.staff-photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.staff-card:hover .staff-photo img{transform:scale(1.04)}
.staff-body{padding:22px 24px 26px}
.staff-body h3{margin-bottom:4px;font-size:1.22rem}
.staff-role{color:var(--teal-600);font-weight:600;font-size:.88rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:12px}
.staff-locs{font-size:.85rem;color:var(--text-muted);margin-bottom:14px;display:block}
.staff-bio{color:var(--text-muted);font-size:.96rem}

/* ———— Location cards ———— */
.location-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
  display:flex;flex-direction:column;
}
.location-media{aspect-ratio:16/10;overflow:hidden;background:var(--cream)}
.location-media img{width:100%;height:100%;object-fit:cover}
.location-body{padding:26px 28px 28px;display:flex;flex-direction:column;gap:10px;flex:1}
.location-body h3{margin-bottom:4px}
.location-detail{display:flex;gap:10px;align-items:flex-start;font-size:.98rem;color:var(--text);line-height:1.5}
.location-detail svg{width:18px;height:18px;stroke:var(--teal-600);fill:none;stroke-width:2;flex-shrink:0;margin-top:4px}
.location-detail strong{display:block;font-size:.78rem;color:var(--navy-900);text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px}
.location-card .map{aspect-ratio:16/10;width:100%;border:0}
.location-card .btn{margin-top:12px;align-self:flex-start}

/* ———— Testimonials ———— */
.review-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;
  display:flex;flex-direction:column;gap:18px;
}
.review-stars{color:var(--amber);letter-spacing:3px;font-size:1.1rem}
.review-text{font-family:"Fraunces",serif;font-size:1.12rem;line-height:1.55;color:var(--navy-900);margin:0}
.review-meta{color:var(--text-muted);font-size:.92rem;font-weight:600;margin-top:auto}

/* ———— CTA band ———— */
.cta-band{
  background:linear-gradient(120deg,var(--navy-900) 0%,var(--navy-800) 60%, var(--teal-600) 100%);
  color:#fff;padding:72px 0;
}
.cta-band h2{color:#fff;margin-bottom:10px}
.cta-band p{color:#D8E3F2;font-size:1.1rem}
.cta-band .btn-primary{background:#fff;color:var(--navy-900)}
.cta-band .btn-primary:hover{background:var(--teal-100);color:var(--navy-900)}
.cta-band .btn-ghost{border-color:#fff;color:#fff}
.cta-band .btn-ghost:hover{background:#fff;color:var(--navy-900)}

/* ———— Alt section (warm cream) ———— */
.bg-cream{background:var(--cream)}
.bg-navy{background:var(--navy-900);color:#fff}
.bg-navy h2,.bg-navy h3{color:#fff}
.bg-navy p{color:#D8E3F2}

/* ———— Feature split ———— */
.split{display:grid;gap:48px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));align-items:center}
.split-media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.split-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}

/* ———— Forms ———— */
.form{display:grid;gap:18px}
.form-row{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.form label{display:block;font-weight:600;font-size:.92rem;color:var(--navy-900);margin-bottom:6px}
.form input,.form select,.form textarea{
  width:100%;padding:13px 14px;
  border:1px solid var(--line);border-radius:10px;background:#fff;font-family:inherit;font-size:1rem;color:var(--text);
  transition:border .2s, box-shadow .2s;
}
.form input:focus,.form select:focus,.form textarea:focus{outline:0;border-color:var(--teal-600);box-shadow:0 0 0 3px var(--teal-100)}
.form textarea{min-height:140px;resize:vertical}
.form .consent{font-size:.88rem;color:var(--text-muted)}

/* ———— FAQ accordion ———— */
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line);padding:20px 0}
.faq summary{
  list-style:none;cursor:pointer;
  display:flex;justify-content:space-between;gap:20px;align-items:center;
  font-family:"Fraunces",serif;font-size:1.2rem;color:var(--navy-900);font-weight:600;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-family:"Inter",sans-serif;font-size:1.6rem;color:var(--teal-600);font-weight:300;transition:transform .2s;
}
.faq details[open] summary::after{content:"−"}
.faq-answer{padding-top:14px;color:var(--text-muted);font-size:1rem;line-height:1.65}
.faq-answer p{margin-bottom:.8em}

/* ———— Footer ———— */
.site-footer{background:var(--navy-900);color:#B7C6DC;padding:64px 0 28px;margin-top:0}
.site-footer a{color:#D8E3F2}
.site-footer a:hover{color:var(--teal-500)}
.footer-grid{display:grid;gap:40px;grid-template-columns:1.2fr 1fr 1fr 1fr}
.footer-col h4{color:#fff;font-family:"Inter",sans-serif;font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:16px}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:.95rem}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:16px;color:#fff}
.footer-brand .brand-mark{color:#fff}
.footer-tagline{font-size:.95rem;line-height:1.6;max-width:320px}
.footer-bottom{
  margin-top:48px;padding-top:20px;
  border-top:1px solid rgba(255,255,255,.12);
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  font-size:.85rem;color:#8397B2
}
@media (max-width:800px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.footer-grid{grid-template-columns:1fr}}

/* ———— Misc ———— */
.anchor-offset{scroll-margin-top:90px}
.pill{display:inline-block;background:var(--teal-100);color:var(--navy-900);padding:4px 12px;border-radius:999px;font-size:.78rem;font-weight:600;letter-spacing:.04em}

.info-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}

.breadcrumb{font-size:.88rem;color:var(--text-muted);margin-bottom:14px}
.breadcrumb a{color:var(--teal-600)}
.breadcrumb span{margin:0 8px;opacity:.5}

.callout{
  padding:22px 26px;border-radius:var(--radius);border-left:4px solid var(--teal-600);
  background:var(--teal-100);color:var(--navy-900);
  font-size:1rem;line-height:1.6;
}

/* Reveal — subtle fade-in once visible. Always visible even if JS fails. */
.reveal{opacity:1;transform:none;transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.js .reveal:not(.in){opacity:0;transform:translateY(18px)}
html.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  html.js .reveal, html.js .reveal:not(.in){opacity:1;transform:none;transition:none}
}

/* Services long-form */
.service-section{padding:60px 0;border-bottom:1px solid var(--line)}
.service-section:last-of-type{border-bottom:0}
.service-section .split-media img{aspect-ratio:4/3}
.service-section h2{margin-bottom:14px}
.service-section ul{padding-left:20px;color:var(--text-muted)}
.service-section li{margin-bottom:6px}

/* Map helpers */
.map{border:0;border-radius:var(--radius);width:100%;aspect-ratio:16/10}

@media (max-width:700px){
  section{padding:56px 0}
  .hero-stats{gap:24px;margin-top:36px}
  .hero-stat strong{font-size:1.6rem}
  .hero .lede{font-size:1.05rem}
  body{font-size:16.5px}
}

/* Item 4: Re-crop provider portraits to show full head/face (heads were getting cut off) */
.staff-photo img[src*="haley-womack"],
.staff-photo img[src*="kara-barrus"],
.staff-photo img[src*="karen-poletis"],
.staff-photo img[src*="liz-devoss"]{
  object-position: center 22%;
}
/* Defensive: hide any lingering Pamela Nelson card if it reappears after migration */
.staff-card:has(img[src*="pam-nelson"]){ display: none !important; }


/* Proof changes 2026-05-12: ensure provider headshots are centered */
.team-member img, .provider-card img {
  object-fit: cover;
  object-position: center top;
}
