  :root {
    --bg: #FAF8F5;
    --bg-tint: #F1EDE6;
    --ink: #2E2C29;
    --ink-soft: #5A564F;
    --accent: #20655F;
    --accent-deep: #174D48;
    --gold: #B0741F;
    --gold-deep: #9A6516;
    --line: #DDD7CC;
    --white: #FFFFFF;
  }
  * { margin: 0; padding: 0; box-sizing: border-box; }
  html { scroll-behavior: smooth; }
  body {
    background: var(--bg);
    color: var(--ink);
    font-family: "Public Sans", "Segoe UI", system-ui, sans-serif;
    font-size: 1.125rem;
    line-height: 1.65;
  }
  h1, h2, h3 {
    font-family: "Fraunces", Georgia, serif;
    font-weight: 600;
    line-height: 1.18;
    letter-spacing: -0.01em;
  }
  img { max-width: 100%; display: block; }
  a { color: var(--accent); }
  .wrap { max-width: 1100px; margin: 0 auto; padding: 0 1.25rem; }

  /* Header */
  header {
    border-bottom: 1px solid var(--line);
    background: var(--bg);
  }
  .header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding-top: 0.85rem;
    padding-bottom: 0.85rem;
    flex-wrap: wrap;
  }
  .brand {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    text-decoration: none;
    color: var(--ink);
    min-height: 44px;
  }
  .brand-logo { width: 42px; height: 42px; flex-shrink: 0; }
  .brand-name { font-weight: 700; font-size: 1.02rem; line-height: 1.25; }
  .brand-name small { display: block; font-weight: 500; color: var(--ink-soft); font-size: 0.78rem; letter-spacing: 0.04em; text-transform: uppercase; }
  .header-actions { display: flex; align-items: center; gap: 0.9rem; flex-wrap: wrap; }
  .header-phone {
    text-decoration: none;
    color: var(--ink);
    font-weight: 700;
    font-size: 1.05rem;
    padding: 0.6rem 0.2rem;
    display: inline-flex;
    align-items: center;
    min-height: 44px;
  }
  .header-phone span { color: var(--ink-soft); font-weight: 500; font-size: 0.85rem; margin-right: 0.45rem; }
  .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--accent);
    color: var(--white);
    text-decoration: none;
    font-weight: 600;
    font-size: 1rem;
    padding: 0.75rem 1.4rem;
    border-radius: 6px;
    border: none;
    cursor: pointer;
    min-height: 48px;
  }
  .btn:hover { background: var(--accent-deep); }
  .btn-outline {
    background: transparent;
    color: var(--accent);
    border: 2px solid var(--accent);
  }
  .btn-outline:hover { background: var(--accent); color: var(--white); }

  /* Hero */
  .hero { padding: 3rem 0 3.5rem; }
  .hero-grid { display: grid; gap: 2.25rem; align-items: center; }
  .eyebrow {
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 1rem;
  }
  .hero h1 { font-size: clamp(2.1rem, 5vw, 3.1rem); margin-bottom: 1.1rem; }
  .hero-sub { color: var(--ink-soft); font-size: 1.15rem; max-width: 34em; margin-bottom: 1.6rem; }
  .hero-cta { display: flex; gap: 0.9rem; flex-wrap: wrap; align-items: center; margin-bottom: 1.4rem; }
  .hero-phone {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--ink);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    min-height: 44px;
  }
  .hero-note { font-size: 0.95rem; color: var(--ink-soft); }
  .hero-photo img { border-radius: 10px; width: 100%; height: auto; }
  .photo-caption { font-size: 0.85rem; color: var(--ink-soft); margin-top: 0.55rem; }

  /* Sections */
  section { padding: 3.5rem 0; }
  .section-head { max-width: 38em; margin-bottom: 2.25rem; }
  .section-head h2 { font-size: clamp(1.7rem, 3.4vw, 2.35rem); margin-bottom: 0.7rem; }
  .section-head p { color: var(--ink-soft); }

  /* Services */
  .services { border-top: 1px solid var(--line); }
  .services-list { display: grid; gap: 0; }
  .service {
    display: grid;
    grid-template-columns: 3rem 1fr;
    gap: 0.4rem 1.1rem;
    padding: 1.5rem 0;
    border-top: 1px solid var(--line);
    align-items: baseline;
  }
  .service:last-child { border-bottom: 1px solid var(--line); }
  .service-num {
    font-family: "Fraunces", Georgia, serif;
    font-size: 1.15rem;
    color: var(--gold-deep);
    font-weight: 600;
  }
  .service h3 { font-size: 1.3rem; margin-bottom: 0.3rem; }
  .service p { color: var(--ink-soft); max-width: 38em; }

  /* Why families */
  .why { background: var(--bg-tint); }
  .why-grid { display: grid; gap: 2.5rem; }
  .why-intro h2 { font-size: clamp(1.7rem, 3.4vw, 2.35rem); margin-bottom: 0.9rem; }
  .why-intro p { color: var(--ink-soft); }
  .why-photo { margin-top: 1.6rem; }
  .why-photo img { border-radius: 10px; }
  .why-list { display: grid; gap: 1.5rem; align-content: start; }
  .why-item { border-left: 3px solid var(--accent); padding-left: 1.1rem; }
  .why-item h3 { font-size: 1.18rem; margin-bottom: 0.35rem; }
  .why-item p { color: var(--ink-soft); font-size: 1.02rem; }

  /* Physicians */
  .physicians { background: var(--accent-deep); color: var(--white); }
  .physicians-grid { display: grid; gap: 2rem; align-items: center; }
  .physicians .eyebrow { color: #9FCFC6; }
  .physicians h2 { font-size: clamp(1.7rem, 3.4vw, 2.3rem); margin-bottom: 0.9rem; }
  .physicians p { color: #DDE9E4; max-width: 36em; }
  .fax-card {
    background: rgba(255, 255, 255, 0.07);
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 10px;
    padding: 1.75rem 1.6rem;
  }
  .fax-card .fax-label { font-size: 0.85rem; font-weight: 700; letter-spacing: 0.09em; text-transform: uppercase; color: #9FCFC6; margin-bottom: 0.4rem; }
  .fax-card .fax-number { font-family: "Fraunces", Georgia, serif; font-size: clamp(1.7rem, 4vw, 2.2rem); font-weight: 600; color: var(--white); }
  .fax-card p { font-size: 0.98rem; margin-top: 0.7rem; }
  .fax-card a { color: var(--white); }

  /* Contact */
  .contact-grid { display: grid; gap: 2.5rem; }
  .contact-details { display: grid; gap: 1.1rem; align-content: start; }
  .contact-item strong { display: block; font-size: 0.85rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 0.15rem; }
  .contact-item a { color: var(--ink); font-weight: 600; text-decoration: none; font-size: 1.15rem; display: inline-flex; align-items: center; min-height: 44px; }
  .contact-item a:hover { color: var(--accent); }
  .contact-static { font-weight: 600; font-size: 1.15rem; }
  .map-frame { margin-top: 1rem; border: 1px solid var(--line); border-radius: 10px; overflow: hidden; background: var(--bg-tint); }
  .map-frame iframe { display: block; width: 100%; height: 260px; border: 0; }
  form { display: grid; gap: 1rem; background: var(--white); border: 1px solid var(--line); border-radius: 10px; padding: 1.75rem 1.5rem; }
  form h3 { font-size: 1.35rem; }
  label { font-weight: 600; font-size: 0.98rem; display: block; margin-bottom: 0.35rem; }
  input, textarea {
    width: 100%;
    font: inherit;
    color: var(--ink);
    padding: 0.75rem 0.85rem;
    border: 1.5px solid var(--line);
    border-radius: 6px;
    background: var(--bg);
    min-height: 48px;
  }
  textarea { min-height: 120px; resize: vertical; }
  input:focus, textarea:focus { outline: 2px solid var(--accent); outline-offset: 1px; border-color: var(--accent); }
  .form-note { font-size: 0.92rem; color: var(--ink-soft); }

  /* Footer */
  footer {
    border-top: 1px solid var(--line);
    padding: 2.25rem 0 2.5rem;
    font-size: 0.95rem;
    color: var(--ink-soft);
  }
  .footer-grid { display: grid; gap: 1rem; }
  footer a { color: var(--ink-soft); }

  /* Skip link */
  .skip-link {
    position: absolute;
    left: -9999px;
    background: var(--accent);
    color: var(--white);
    padding: 0.7rem 1.2rem;
    border-radius: 0 0 6px 0;
    z-index: 10;
  }
  .skip-link:focus { left: 0; top: 0; }

  /* Desktop */
  @media (min-width: 800px) {
    .hero { padding: 4.5rem 0 5rem; }
    .hero-grid { grid-template-columns: 7fr 5fr; gap: 3.5rem; }
    .services-list { grid-template-columns: 1fr 1fr; column-gap: 4rem; }
    .service:nth-child(2) { border-top: 1px solid var(--line); }
    .why-grid { grid-template-columns: 5fr 6fr; gap: 4rem; }
    .physicians-grid { grid-template-columns: 7fr 5fr; gap: 4rem; }
    .contact-grid { grid-template-columns: 6fr 5fr; gap: 4rem; }
    section { padding: 4.5rem 0; }
  }

  /* ===== Multi-page additions (appended; do not modify rules above) ===== */

  /* Primary navigation */
  .site-nav { order: 3; flex-basis: 100%; }
  .nav-list { list-style: none; display: flex; flex-wrap: wrap; gap: 0 1.35rem; }
  .nav-item { position: relative; }
  .nav-list a {
    display: inline-flex;
    align-items: center;
    color: var(--ink);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.98rem;
    padding: 0.45rem 0;
    min-height: 44px;
  }
  .nav-list a:hover { color: var(--accent); }
  .nav-list a[aria-current="page"] { color: var(--accent); box-shadow: inset 0 -2px 0 var(--accent); }
  .nav-sub { display: none; }

  /* Footer columns */
  .footer-logo { width: 36px; height: 36px; margin-bottom: 0.65rem; }
  .footer-col p { margin-bottom: 0.7rem; }
  .footer-col p:last-child { margin-bottom: 0; }
  .footer-links { list-style: none; display: grid; gap: 0.1rem; }
  .footer-links a { display: inline-flex; align-items: center; min-height: 32px; }

  @media (min-width: 800px) {
    /* Services dropdown: CSS-only, hover + keyboard (:focus-within) */
    .nav-item.has-sub > .nav-sub {
      position: absolute;
      top: 100%;
      left: -0.95rem;
      min-width: 15.5rem;
      background: var(--white);
      border: 1px solid var(--line);
      border-radius: 0 0 8px 8px;
      box-shadow: 0 12px 28px rgba(46, 44, 41, 0.1);
      padding: 0.45rem 0;
      z-index: 20;
    }
    .nav-item.has-sub:hover > .nav-sub,
    .nav-item.has-sub:focus-within > .nav-sub { display: block; }
    .nav-sub li { list-style: none; }
    .nav-sub a {
      display: flex;
      width: 100%;
      padding: 0.4rem 0.95rem;
      font-weight: 500;
      font-size: 0.95rem;
    }
    .nav-sub a:hover { background: var(--bg-tint); color: var(--accent); }
    .footer-grid { grid-template-columns: 1.1fr 0.8fr 1.3fr; gap: 3rem; }
  }

  @media (min-width: 1080px) {
    .site-nav { order: 0; flex-basis: auto; }
  }

  /* Content utilities for inner pages (unused on index.html) */
  .prose { color: var(--ink-soft); max-width: 42em; display: grid; gap: 1rem; }
  .prose strong, .prose a { color: var(--accent); }
  .content-list { list-style: disc; padding-left: 1.35rem; display: grid; gap: 0.45rem; color: var(--ink-soft); max-width: 38em; }
  .content-list strong { color: var(--ink); }

  /* FAQ accordions (faq.html) — native details/summary, no JS */
  .faq-group { margin-bottom: 2.75rem; }
  .faq-group h2 { font-size: 1.5rem; margin-bottom: 1rem; }
  .faq-item { border-top: 1px solid var(--line); }
  .faq-group .faq-item:last-child { border-bottom: 1px solid var(--line); }
  .faq-item summary {
    cursor: pointer;
    font-family: "Fraunces", Georgia, serif;
    font-size: 1.18rem;
    font-weight: 600;
    line-height: 1.3;
    padding: 1.05rem 0;
  }
  .faq-item summary:hover { color: var(--accent); }
  .faq-item summary:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
  .faq-item[open] > summary { color: var(--accent); }
  .faq-answer { padding: 0 0 1.3rem; color: var(--ink-soft); max-width: 42em; display: grid; gap: 0.8rem; }

  /* Brand icon set (assets/icons) — inline accents, light backgrounds only */
  .icon-inline { display: inline-block; width: 1.05em; height: 1.05em; vertical-align: -0.14em; margin-right: 0.4rem; }
  .icon-hero { width: 44px; height: 44px; margin-bottom: 0.9rem; }

  /* Responsive header: mobile = hamburger panel, tablet = nav row, desktop = inline */
  .nav-toggle { display: none; }
  .nav-panel-extra { display: none; }
  @media (max-width: 799px) {
    .header-inner { gap: 0.4rem 0.5rem; }
    .brand { margin-right: auto; gap: 0.5rem; }
    .brand-logo { width: 36px; height: 36px; }
    .brand-name { font-size: 0.95rem; }
    .brand-name small { font-size: 0.72rem; }
    .phone-label, .phone-num { display: none; }
    .header-phone {
      width: 44px;
      justify-content: center;
      padding: 0;
      border: 1.5px solid var(--line);
      border-radius: 8px;
    }
    .header-phone .icon-inline { width: 20px; height: 20px; margin-right: 0; }
    .header-actions { gap: 0.6rem; }
    .header-actions .btn { display: none; }
    .nav-toggle {
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      min-height: 44px;
      padding: 0 0.65rem;
      background: transparent;
      border: 1.5px solid var(--line);
      border-radius: 8px;
      font: inherit;
      font-size: 0.9rem;
      font-weight: 600;
      color: var(--ink);
      cursor: pointer;
    }
    .nav-toggle-icon { position: relative; width: 18px; height: 2px; background: var(--ink); transition: background 0.15s; }
    .nav-toggle-icon::before, .nav-toggle-icon::after {
      content: "";
      position: absolute;
      left: 0;
      width: 18px;
      height: 2px;
      background: var(--ink);
      transition: transform 0.15s, top 0.15s;
    }
    .nav-toggle-icon::before { top: -5px; }
    .nav-toggle-icon::after { top: 5px; }
    body.nav-open .nav-toggle-icon { background: transparent; }
    body.nav-open .nav-toggle-icon::before { top: 0; transform: rotate(45deg); }
    body.nav-open .nav-toggle-icon::after { top: 0; transform: rotate(-45deg); }
    .site-nav {
      display: none;
      order: 4;
      margin: 0.45rem -1.25rem -0.85rem;
      padding: 0.2rem 1.25rem 1.25rem;
      border-top: 1px solid var(--line);
      background: var(--bg);
    }
    body.nav-open .site-nav { display: block; }
    .nav-list { display: block; }
    .nav-list a {
      display: flex;
      width: 100%;
      align-items: center;
      min-height: 48px;
      font-size: 1.05rem;
      padding: 0.35rem 0;
      border-bottom: 1px solid var(--line);
    }
    .nav-list a[aria-current="page"] { box-shadow: none; border-left: 3px solid var(--accent); padding-left: 0.7rem; }
    .nav-panel-extra { display: block; padding-top: 1.1rem; }
    .nav-panel-extra .btn { width: 100%; }
  }
  @media (min-width: 800px) and (max-width: 1079px) {
    .site-nav { border-top: 1px solid var(--line); margin-top: 0.15rem; }
  }
  @media (min-width: 1080px) {
    /* single-row header: icon + number say "call us" on their own */
    .phone-label { display: none; }
  }
