/* ===========================================================================
   DeWire Dental — one shared stylesheet for every page.
   Warm sage + cream "trusted neighbour" palette (deliberately not clinical
   blue-white). Fraunces (display) + Nunito Sans (humanist body).
   Type is a tight literal scale; spacing follows a 4px / 0.25rem base.
   Dark sections restate their background-color in every light-text rule.
   =========================================================================== */
:root {
  --bone: #f4f1e9;        /* warm page canvas */
  --paper: #ffffff;       /* raised card fill */
  --ink: #1e2a23;         /* primary text (very high contrast on bone) */
  --muted: #44564b;       /* secondary text (AA on bone) */
  --sage: #5d8068;        /* marks, borders, seal */
  --sage-fill: #e6ede4;   /* quiet band + seal background */
  --clay: #9c4221;        /* links / kickers / buttons (AA as text on bone) */
  --clay-soft: #eab38d;   /* warm accent for use ON the deep band only */
  --deep: #1f3329;        /* dark forest band background */

  --measure: 38rem;
  --gap: 1rem;
  --gap-2: 1.5rem;
  --gap-3: 2rem;
  --gap-4: 3rem;
  --gap-5: 4.5rem;
  --edge: clamp(1.25rem, 5vw, 4rem);
  --rule: 1px solid color-mix(in srgb, var(--ink) 14%, transparent);

  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body: 'Nunito Sans', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  margin: 0;
  background-color: var(--bone);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 1.125rem;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

/* ---- type: tight literal scale -> 13 / 16 / 18 / 22 / 28 / 32 / 40 / 52 px ---- */
h1 { font-family: var(--font-display); font-weight: 700; font-size: 2.5rem;
     line-height: 1.05; letter-spacing: -0.01em; margin: 0 0 1rem; color: var(--ink); }
h2 { font-family: var(--font-display); font-weight: 600; font-size: 1.75rem;
     line-height: 1.15; margin: 0 0 0.75rem; color: var(--ink); }
h3 { font-family: var(--font-body); font-weight: 800; font-size: 1.375rem;
     line-height: 1.3; margin: 0 0 0.5rem; color: var(--ink); }
p  { margin: 0 0 1rem; max-width: var(--measure); }
.lede { font-family: var(--font-body); font-size: 1.375rem; line-height: 1.5;
        color: var(--muted); max-width: 34rem; }
.kicker { font-family: var(--font-body); text-transform: uppercase;
          letter-spacing: 0.18em; font-size: 0.8125rem; font-weight: 800;
          color: var(--clay); margin: 0 0 0.75rem; }
.measure { max-width: var(--measure); }
.center-measure { max-width: 46rem; }

/* ---- links & buttons (hover + focus on everything interactive) ---- */
a { color: var(--clay); text-decoration: underline; text-underline-offset: 3px;
    text-decoration-thickness: 1px; }
a:hover { text-decoration-thickness: 2px; }
a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, textarea:focus-visible {
  outline: 3px solid var(--clay); outline-offset: 2px;
}
.skip { position: absolute; left: -9999px; }
.skip:focus { left: 1rem; top: 1rem; background-color: var(--ink); color: var(--bone);
              padding: 0.5rem 1rem; z-index: 40; text-decoration: none; }

.btn {
  display: inline-block; font-family: var(--font-body); font-weight: 800;
  font-size: 1rem; text-decoration: none; cursor: pointer; line-height: 1.2;
  background-color: var(--clay); color: var(--bone);
  border: 2px solid var(--clay); border-radius: 4px;
  padding: 0.75rem 1.5rem; transition: transform .12s ease, background-color .12s ease;
}
.btn:hover { transform: translateY(-2px); background-color: var(--ink);
             border-color: var(--ink); color: var(--bone); }
.btn-ghost { background-color: transparent; color: var(--clay); border-color: var(--clay); }
.btn-ghost:hover { background-color: var(--clay); color: var(--bone); border-color: var(--clay); }

/* ---- header: sticky, asymmetric, byte-identical across pages ---- */
.site-head {
  position: sticky; top: 0; z-index: 30;
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 0.75rem 1.5rem;
  padding: 1rem var(--edge);
  background-color: var(--bone);
  border-bottom: 2px solid var(--sage);
}
.brand { display: flex; align-items: baseline; gap: 0.6rem; }
.wordmark { font-family: var(--font-display); font-weight: 700; font-size: 1.375rem;
            color: var(--ink); text-decoration: none; letter-spacing: -0.01em; }
.brand-loc { font-size: 0.8125rem; color: var(--muted); letter-spacing: 0.14em;
             text-transform: uppercase; }
.site-head nav ul { display: flex; flex-wrap: wrap; gap: 1.25rem; margin: 0; padding: 0; list-style: none; }
.site-head nav a { color: var(--ink); text-decoration: none; font-weight: 600; }
.site-head nav a:hover { color: var(--clay); }
.head-cta { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.head-call { color: var(--ink); text-decoration: none; font-weight: 800; font-size: 1rem; }
.head-call:hover { color: var(--clay); }

main { display: block; }
section { padding: var(--gap-5) var(--edge); border-bottom: var(--rule); }
.section-tight { padding-top: var(--gap-4); padding-bottom: var(--gap-4); }
.page-intro { padding-top: var(--gap-5); }

/* ---- masthead: 3fr / 2fr, deliberately NOT a centered hero ---- */
.masthead { display: grid; grid-template-columns: 3fr 2fr; gap: var(--gap-4); align-items: stretch; }
.masthead-lead { min-width: 0; align-self: center; }
.cta-row { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; margin-top: var(--gap-2); }
.cta-call { font-weight: 800; color: var(--clay); text-decoration: none; }
.cta-call:hover { text-decoration: underline; text-underline-offset: 3px; }

/* the "open today + same-day emergency" panel: the page's warm focal point */
.now-card { background-color: var(--deep); border-radius: 6px; padding: var(--gap-3); min-width: 0; }
.now-card :is(h2, p, dt, dd, span) { background-color: var(--deep); }
.now-card .now-label { color: var(--clay-soft); background-color: var(--deep);
                       font-size: 0.8125rem; font-weight: 800; letter-spacing: 0.16em;
                       text-transform: uppercase; margin: 0 0 0.75rem; }
.now-card h2 { color: var(--bone); background-color: var(--deep); font-size: 1.75rem; }
.now-hours { margin: 0 0 var(--gap-2); }
.now-card .now-hours dt { color: var(--clay-soft); background-color: var(--deep);
                          font-weight: 800; font-size: 0.8125rem; letter-spacing: 0.08em;
                          text-transform: uppercase; margin-top: 0.75rem; }
.now-card .now-hours dd { color: var(--bone); background-color: var(--deep);
                          margin: 0.25rem 0 0; font-family: var(--font-display); font-size: 1.125rem; }
.now-emerg { border-top: 1px solid color-mix(in srgb, var(--clay-soft) 50%, transparent); padding-top: var(--gap-2); }
.now-card .now-emerg p { color: var(--bone); background-color: var(--deep); max-width: none; margin: 0 0 1rem; }
.now-card .now-emerg strong { color: var(--clay-soft); background-color: var(--deep); }
.btn-on-dark { background-color: var(--clay-soft); color: var(--deep); border-color: var(--clay-soft); }
.btn-on-dark:hover { background-color: var(--bone); border-color: var(--bone); color: var(--deep); }

/* ---- quiet sage band + reflowing lists (auto-fit, never a fixed 3-col grid) ---- */
.band-quiet { background-color: var(--sage-fill); }
.reflow { list-style: none; margin: var(--gap-2) 0 0; padding: 0; display: grid;
          grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr)); gap: var(--gap-3); }
.reflow-wide { grid-template-columns: repeat(auto-fit, minmax(18rem, 1fr)); }
.reflow li { padding: 1.5rem; border: var(--rule); border-top: 3px solid var(--sage);
             border-radius: 4px; background-color: var(--paper); }
.reflow li p { margin-bottom: 0; }
.reflow li .num { font-family: var(--font-display); font-weight: 700; color: var(--clay);
                  font-size: 1.375rem; display: block; margin-bottom: 0.25rem; }

/* plain sub-lists for service detail */
.sublist { list-style: none; margin: var(--gap-2) 0 0; padding: 0; display: grid;
           grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr)); gap: var(--gap-2); }
.sublist li { padding-left: 1.25rem; border-left: 3px solid var(--sage); }

/* ---- split layout for "meet the doctor" + content pages ---- */
.split { display: grid; grid-template-columns: 3fr 2fr; gap: var(--gap-4); align-items: start; }
.split-even { grid-template-columns: 1fr 1fr; }
.side-note { border-top: 3px solid var(--clay); padding-top: 1rem; }
.facts { margin: 0; border-left: 3px solid var(--clay); padding-left: 1.25rem; }
.facts dt { font-weight: 800; font-size: 0.8125rem; text-transform: uppercase;
            letter-spacing: 0.08em; color: var(--muted); margin-top: 1rem; }
.facts dd { margin: 0.25rem 0 0; font-family: var(--font-display); font-size: 1.125rem; }
.ticks { margin: var(--gap) 0 0; padding-left: 1rem; }
.ticks li { margin-bottom: 0.5rem; }

/* monogram seal — a small signature detail in place of a stock portrait */
.seal { width: 9rem; height: 9rem; border-radius: 50%; display: grid; place-items: center;
        background-color: var(--sage-fill); border: 2px solid var(--sage);
        font-family: var(--font-display); font-weight: 700; font-size: 2.5rem;
        color: var(--deep); letter-spacing: 0.02em; }
.portrait { display: flex; flex-direction: column; gap: var(--gap); align-items: flex-start; }
.portrait .seal-cap { font-size: 1rem; color: var(--muted); margin: 0; }

/* ---- dark invitation band (light text restates the dark bg in-rule) ---- */
.invite { background-color: var(--deep); }
.invite .kicker { color: var(--clay-soft); background-color: var(--deep); }
.invite h2 { color: var(--bone); background-color: var(--deep); max-width: 24rem; }
.invite p  { color: var(--bone); background-color: var(--deep); max-width: var(--measure); }
.invite .cta-row a.cta-call { color: var(--clay-soft); background-color: var(--deep); }

/* ---- hours table (patient info) ---- */
.hours-table { width: 100%; max-width: 32rem; border-collapse: collapse; margin-top: var(--gap); }
.hours-table caption { text-align: left; color: var(--muted); font-size: 1rem; margin-bottom: 0.5rem; }
.hours-table th, .hours-table td { text-align: left; padding: 0.5rem 0.75rem; border-bottom: var(--rule); }
.hours-table th { font-weight: 800; }
.hours-table td { font-family: var(--font-display); }
.hours-table .closed { color: var(--muted); font-family: var(--font-body); }

/* ---- contact: fields are unclassed <p> styled via parent>child ---- */
.contact-grid { display: grid; grid-template-columns: 3fr 2fr; gap: var(--gap-4); align-items: start; }
.contact-form { display: grid; gap: var(--gap-2); max-width: 32rem; }
.contact-form p { margin: 0; display: grid; gap: 0.5rem; max-width: none; }
.contact-form label { font-weight: 800; font-size: 1rem; }
.form-note { background-color: var(--sage-fill); border: var(--rule); border-left: 3px solid var(--clay);
             padding: 0.75rem 1rem; font-size: 1rem; color: var(--ink); }
input, select, textarea {
  font: inherit; color: var(--ink); background-color: var(--paper);
  border: 1px solid color-mix(in srgb, var(--ink) 28%, transparent);
  border-radius: 4px; padding: 0.5rem 0.75rem; width: 100%;
}
.contact-aside { border-left: 3px solid var(--sage); padding-left: 1.25rem; }
.map-embed { width: 100%; border: 0; border-radius: 6px; margin-top: var(--gap-2);
             aspect-ratio: 16 / 9; }

/* ---- footer (light text restates the dark bg in-rule), byte-identical ---- */
.site-foot { background-color: var(--deep); padding: var(--gap-4) var(--edge); border-bottom: none; }
.foot-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
             gap: var(--gap-3); margin-bottom: var(--gap-2); }
.site-foot p { color: var(--bone); background-color: var(--deep); max-width: none; margin: 0 0 0.5rem; }
.foot-mark { font-family: var(--font-display); font-size: 1.375rem; font-weight: 600;
             color: var(--bone); background-color: var(--deep); }
.foot-head { color: var(--clay-soft); background-color: var(--deep); font-size: 0.8125rem;
             font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; }
.site-foot .foot-contact a { color: var(--clay-soft); background-color: var(--deep); font-weight: 800; }
.foot-grid a { color: var(--bone); background-color: var(--deep); }
.foot-fine { color: var(--clay-soft); background-color: var(--deep); font-size: 0.8125rem;
             border-top: 1px solid color-mix(in srgb, var(--clay-soft) 40%, transparent); padding-top: var(--gap-2); }

/* ---- responsive ---- */
@media (max-width: 760px) {
  .masthead, .split, .split-even, .contact-grid { grid-template-columns: 1fr; }
  section { padding-top: var(--gap-4); padding-bottom: var(--gap-4); }
  .site-head { gap: 0.5rem 1rem; }
}
@media (min-width: 1000px) {
  h1 { font-size: 3.25rem; }
  h2 { font-size: 2rem; }
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { transition: none !important; }
}
