/* =========================================================
   M & S Watch Gallery — Variant 02: Editorial Watchmaker
   Cream paper. Brass detail. Refined serif. Generous white.
   ========================================================= */

/* ---------- Tokens ---------- */
:root {
  --paper:        #F4EFE6;            /* page background */
  --paper-deep:   #ECE5D7;            /* soft secondary band */
  --ink:          #181412;            /* body text & headlines */
  --ink-soft:     rgba(24, 20, 18, 0.66);
  --ink-quiet:    rgba(24, 20, 18, 0.46);
  --hairline:     rgba(24, 20, 18, 0.12);
  --hairline-2:   rgba(24, 20, 18, 0.22);
  --brass:        #B08B4F;            /* accent */
  --brass-deep:   #8E6B36;            /* accessible on cream for small text */
  --midnight:     #1B2236;            /* visual signature, used sparingly */

  --serif:   "Fraunces", "Playfair Display", Georgia, "Times New Roman", serif;
  --sans:    "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;

  --measure: 64ch;        /* body line length */
  --measure-tight: 52ch;
  --gutter: clamp(20px, 4vw, 56px);
  --page-max: 1180px;

  /* Type scale, mobile-first; scaled up via clamp() */
  --fs-eyebrow: 0.78rem;
  --fs-body:    1.0625rem;
  --fs-lede:    1.125rem;
  --fs-h3:      1.375rem;
  --fs-h2:      clamp(2rem, 4vw + 1rem, 3.5rem);
  --fs-h1:      clamp(2.6rem, 6vw + 1rem, 5.75rem);
  --fs-mega:    clamp(3rem, 8vw + 1rem, 7.25rem);
}

/* ---------- Reset-lite ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: var(--fs-body);
  line-height: 1.55;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
img, svg, iframe { display: block; max-width: 100%; }
img { height: auto; }
a { color: var(--brass-deep); text-decoration: none; }
a:hover, a:focus-visible {
  color: var(--ink);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
:focus-visible {
  outline: 2px solid var(--brass);
  outline-offset: 3px;
  border-radius: 2px;
}
button { font: inherit; }
ul, ol { padding: 0; margin: 0; list-style: none; }
table { border-collapse: collapse; }

/* Skip link */
.skip-link {
  position: absolute;
  top: -100px; left: 0;
  background: var(--ink); color: var(--paper);
  padding: 12px 18px;
  font-family: var(--sans);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.75rem;
  z-index: 100;
}
.skip-link:focus { top: 8px; left: 8px; }

/* Subtle paper texture via repeating gradient noise — extremely soft */
body::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(176, 139, 79, 0.025) 0, transparent 40%),
    radial-gradient(circle at 80% 80%, rgba(24, 20, 18, 0.02) 0, transparent 40%);
  z-index: 0;
}
header, main, footer { position: relative; z-index: 1; }

/* ---------- Header / Nav ---------- */
.site-header {
  padding: clamp(14px, 2.4vw, 22px) var(--gutter);
  border-bottom: 1px solid var(--hairline);
  background: var(--paper);
}
.nav {
  max-width: var(--page-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: baseline;
  gap: 16px;
  column-gap: clamp(16px, 4vw, 40px);
}
.brand {
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  color: var(--ink);
  text-decoration: none;
  font-family: var(--serif);
}
.brand:hover, .brand:focus-visible { text-decoration: none; color: var(--ink); }
.brand__mark {
  font-family: var(--serif);
  font-size: 1.5rem;
  font-weight: 600;
  font-variation-settings: "opsz" 14, "SOFT" 30, "WONK" 0;
  letter-spacing: -0.01em;
  line-height: 1;
}
.brand__amp {
  color: var(--brass);
  font-style: italic;
  font-weight: 400;
  margin: 0 1px;
  font-variation-settings: "opsz" 14, "SOFT" 50, "WONK" 1;
}
.brand__sub {
  font-family: var(--sans);
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-soft);
  font-weight: 500;
}
.nav__list {
  display: none;
  gap: clamp(18px, 3vw, 36px);
  justify-content: center;
}
.nav__list li a {
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
  text-decoration: none;
  font-weight: 500;
  padding: 6px 0;
  border-bottom: 1px solid transparent;
  transition: color 0.2s ease, border-color 0.2s ease;
}
.nav__list li a:hover, .nav__list li a:focus-visible {
  color: var(--ink);
  border-bottom-color: var(--brass);
}
.nav__phone {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  font-family: var(--sans);
  color: var(--ink);
  text-decoration: none;
  white-space: nowrap;
}
.nav__phone-label {
  display: none;
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.nav__phone-num {
  font-family: var(--serif);
  font-size: 1rem;
  font-weight: 500;
  font-variation-settings: "opsz" 14;
  border-bottom: 1px solid var(--brass);
  padding-bottom: 1px;
}
.nav__phone:hover .nav__phone-num,
.nav__phone:focus-visible .nav__phone-num {
  border-bottom-color: var(--ink);
  color: var(--ink);
}

@media (min-width: 760px) {
  .nav__list { display: flex; }
  .nav__phone-label { display: inline; }
}

/* ---------- Section scaffolding ---------- */
main > section {
  padding: clamp(56px, 9vw, 120px) var(--gutter);
  max-width: var(--page-max);
  margin: 0 auto;
}
.section-head {
  margin-bottom: clamp(32px, 5vw, 64px);
}
.section-head--center { text-align: center; }
.section-num {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  color: var(--brass);
  font-size: 1.25rem;
  letter-spacing: 0.04em;
  margin: 0 0 6px;
  font-variation-settings: "opsz" 14, "SOFT" 100, "WONK" 1;
}
.section-title {
  font-family: var(--serif);
  font-weight: 400;
  font-variation-settings: "opsz" 144, "SOFT" 20, "WONK" 0;
  font-size: var(--fs-h2);
  line-height: 1.02;
  letter-spacing: -0.018em;
  margin: 0;
  color: var(--ink);
}
.section-deck {
  margin: 16px 0 0;
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-variation-settings: "opsz" 24, "SOFT" 80;
  font-size: 1.15rem;
  line-height: 1.4;
  color: var(--ink-soft);
  max-width: 36ch;
}
.section-head--center .section-deck { margin-left: auto; margin-right: auto; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--sans);
  font-weight: 500;
  font-size: 0.85rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 14px 26px;
  border: 1px solid var(--ink);
  background: var(--ink);
  color: var(--paper);
  text-decoration: none;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
  cursor: pointer;
}
.btn:hover, .btn:focus-visible {
  background: var(--brass-deep);
  border-color: var(--brass-deep);
  color: var(--paper);
  text-decoration: none;
}
.btn--ghost {
  background: transparent;
  color: var(--ink);
  border-color: var(--ink);
}
.btn--ghost:hover, .btn--ghost:focus-visible {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.btn--lg { padding: 18px 32px; font-size: 0.9rem; }

/* ---------- Hero ---------- */
.hero {
  position: relative;
  overflow: clip;
  padding-top: clamp(56px, 10vw, 140px) !important;
  padding-bottom: clamp(56px, 10vw, 140px) !important;
}
.hero__inner {
  display: grid;
  gap: clamp(28px, 5vw, 56px);
  position: relative;
}
.hero__eyebrow {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 0;
  font-family: var(--sans);
  font-size: var(--fs-eyebrow);
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--brass-deep);
}
.rule {
  display: inline-block;
  width: 56px;
  height: 1px;
  background: var(--brass);
}
.hero__title {
  font-family: var(--serif);
  font-weight: 400;
  font-variation-settings: "opsz" 144, "SOFT" 30, "WONK" 0;
  font-size: var(--fs-h1);
  line-height: 0.96;
  letter-spacing: -0.025em;
  margin: 0;
  color: var(--ink);
  max-width: 14ch;
}
.hero__title-em {
  font-style: italic;
  font-weight: 300;
  color: var(--brass-deep);
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
  display: block;
  margin-top: 0.1em;
}
.hero__meta {
  display: grid;
  gap: 22px;
  max-width: 52ch;
}
.hero__lede {
  margin: 0;
  font-size: var(--fs-lede);
  line-height: 1.55;
  color: var(--ink);
}
.hero__cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 16px;
  align-items: center;
  margin-top: 4px;
}
.hero__diagram {
  color: var(--brass);
  width: clamp(220px, 38vw, 360px);
  margin-left: auto;
  opacity: 0.96;
  filter: drop-shadow(0 1px 0 rgba(176, 139, 79, 0.06));
}
.hero__caption {
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.95rem;
  color: var(--ink-soft);
  margin: -16px 0 0;
  text-align: right;
  font-variation-settings: "opsz" 24, "SOFT" 80;
}
.hero__caption em { color: var(--brass-deep); font-style: italic; }

@media (min-width: 880px) {
  .hero__inner {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "eyebrow  diagram"
      "title    diagram"
      "meta     diagram"
      "caption  caption";
    column-gap: clamp(40px, 6vw, 96px);
    align-items: start;
  }
  .hero__eyebrow  { grid-area: eyebrow; }
  .hero__title    { grid-area: title; }
  .hero__meta     { grid-area: meta; }
  .hero__diagram  { grid-area: diagram; margin-top: 18px; align-self: start; }
  .hero__caption  { grid-area: caption; }
}

/* Hero diagram draw-in animation */
.diagram .dline { stroke-dasharray: 900; stroke-dashoffset: 900; }
.hero__diagram.is-drawn .dline {
  animation: drawIn 1800ms cubic-bezier(.6,.1,.25,1) forwards;
}
.hero__diagram.is-drawn .dline:nth-child(2) { animation-delay: 250ms; }
.hero__diagram.is-drawn .dline:nth-child(3) { animation-delay: 500ms; }
.hero__diagram.is-drawn .dline:nth-child(4) { animation-delay: 750ms; }
@keyframes drawIn { to { stroke-dashoffset: 0; } }
@media (prefers-reduced-motion: reduce) {
  .diagram .dline { stroke-dasharray: none; stroke-dashoffset: 0; }
}

/* ---------- Story ---------- */
.story {
  background: var(--paper-deep);
  max-width: none !important;
  margin: 0 !important;
}
.story > .section-head,
.story > .story__grid {
  max-width: var(--page-max);
  margin-left: auto;
  margin-right: auto;
}
.story__grid {
  display: grid;
  gap: clamp(28px, 4vw, 56px);
  align-items: start;
}
.story__col p {
  margin: 0 0 1em;
  max-width: var(--measure);
  font-size: 1.0625rem;
  line-height: 1.7;
}
.story__col p:last-child { margin-bottom: 0; }
.story__col--lead p { font-size: 1.125rem; }
.story__col em { font-style: italic; color: var(--ink); }

.dropcap .dc {
  float: left;
  font-family: var(--serif);
  font-size: 4.6em;
  line-height: 0.86;
  padding: 0.05em 0.12em 0 0;
  font-weight: 500;
  color: var(--brass-deep);
  font-variation-settings: "opsz" 144, "SOFT" 50, "WONK" 1;
  shape-outside: margin-box;
}

.pullquote {
  position: relative;
  border-top: 1px solid var(--hairline-2);
  border-bottom: 1px solid var(--hairline-2);
  padding: 36px 0;
  text-align: center;
  margin: 8px 0;
}
.pullquote__mark {
  color: var(--brass);
  width: 44px; height: 44px;
  margin: 0 auto 18px;
}
.pullquote__text {
  font-family: var(--serif);
  font-weight: 300;
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 80, "WONK" 1;
  font-size: clamp(1.35rem, 2.2vw + 0.6rem, 1.95rem);
  line-height: 1.28;
  letter-spacing: -0.008em;
  color: var(--ink);
  margin: 0 auto;
  max-width: 22ch;
}
.pullquote__attr {
  margin: 18px 0 0;
  font-family: var(--sans);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

@media (min-width: 880px) {
  .story__grid {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.9fr);
    grid-template-areas:
      "lead    side"
      "quote   quote";
    column-gap: clamp(40px, 6vw, 96px);
    row-gap: clamp(40px, 6vw, 80px);
  }
  .story__col--lead { grid-area: lead; }
  .story__col--side { grid-area: side; padding-top: 6px; }
  .pullquote        { grid-area: quote; padding: 48px 0; max-width: 800px; margin: 0 auto; }
  .pullquote__text  { max-width: 28ch; }
}

/* ---------- Divider ---------- */
.divider {
  padding: clamp(28px, 5vw, 56px) var(--gutter);
  max-width: var(--page-max);
  margin: 0 auto;
}
.divider__svg {
  color: var(--brass);
  width: 100%;
  max-width: 520px;
  height: 40px;
  margin: 0 auto;
}

/* ---------- Services ---------- */
.services__list {
  display: grid;
  gap: clamp(18px, 3vw, 28px);
  counter-reset: srv;
}
.service {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: clamp(16px, 3vw, 32px);
  padding: clamp(20px, 3vw, 32px) 0;
  border-top: 1px solid var(--hairline);
  align-items: baseline;
}
.service:last-child { border-bottom: 1px solid var(--hairline); }
.service__num {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 1.5rem;
  color: var(--brass);
  font-variation-settings: "opsz" 24, "SOFT" 80, "WONK" 1;
  line-height: 1;
}
.service__title {
  font-family: var(--serif);
  font-weight: 500;
  font-variation-settings: "opsz" 36, "SOFT" 30, "WONK" 0;
  font-size: var(--fs-h3);
  letter-spacing: -0.01em;
  margin: 0 0 8px;
  color: var(--ink);
}
.service__body {
  margin: 0;
  max-width: var(--measure);
  color: var(--ink);
  line-height: 1.6;
}
.service__by-appt {
  display: inline-block;
  font-family: var(--sans);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--brass-deep);
  margin-right: 8px;
  padding: 2px 8px;
  border: 1px solid var(--brass);
  border-radius: 2px;
}
.service--feature {
  background: linear-gradient(to bottom, transparent 0, rgba(176, 139, 79, 0.06) 100%);
  padding-left: clamp(16px, 3vw, 28px);
  padding-right: clamp(16px, 3vw, 28px);
  margin-left: calc(-1 * clamp(16px, 3vw, 28px));
  margin-right: calc(-1 * clamp(16px, 3vw, 28px));
}
.service--feature .service__title {
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 80, "WONK" 1;
  font-size: 1.55rem;
}
.service strong { font-weight: 600; color: var(--ink); }

/* ---------- Recognition ---------- */
.recognition {
  background: var(--ink);
  color: var(--paper);
  max-width: none !important;
  margin: 0 !important;
}
.recognition .section-num { color: var(--brass); }
.recognition .section-title { color: var(--paper); }
.recognition .section-deck { color: rgba(244, 239, 230, 0.7); }
.recognition > .section-head,
.recognition > .proof,
.recognition > .recognition__note {
  max-width: var(--page-max);
  margin-left: auto;
  margin-right: auto;
}
.proof {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-top: 1px solid rgba(244, 239, 230, 0.18);
  border-bottom: 1px solid rgba(244, 239, 230, 0.18);
}
.proof__item {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: baseline;
  column-gap: 24px;
  padding: 28px 0;
  border-bottom: 1px solid rgba(244, 239, 230, 0.12);
}
.proof__item:last-child { border-bottom: none; }
.proof__num {
  font-family: var(--serif);
  font-weight: 400;
  font-variation-settings: "opsz" 144, "SOFT" 40, "WONK" 0;
  font-size: clamp(2.2rem, 5vw, 3.4rem);
  line-height: 1;
  color: var(--brass);
  letter-spacing: -0.02em;
}
.proof__num small {
  font-size: 0.55em;
  font-weight: 300;
  margin-left: 2px;
  color: rgba(176, 139, 79, 0.75);
}
.proof__label {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.2rem;
  color: var(--paper);
  align-self: end;
}
.proof__meta {
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(244, 239, 230, 0.55);
  grid-column: 2;
  margin-top: 4px;
}
.recognition__note {
  margin: clamp(24px, 4vw, 40px) 0 0;
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.1rem;
  color: rgba(244, 239, 230, 0.78);
  text-align: center;
  font-variation-settings: "opsz" 24, "SOFT" 80;
}
.recognition__note strong { color: var(--paper); font-weight: 500; }

@media (min-width: 760px) {
  .proof__item {
    grid-template-columns: minmax(180px, 1fr) 2fr;
    column-gap: 48px;
    padding: 36px 0;
  }
  .proof__meta { grid-column: 2; margin-top: 8px; }
}

/* ---------- Visit ---------- */
.visit__grid {
  display: grid;
  gap: clamp(20px, 3vw, 32px);
  grid-template-columns: 1fr;
}
.visit__card {
  padding: clamp(22px, 3vw, 32px);
  border: 1px solid var(--hairline-2);
  background: rgba(255, 255, 255, 0.18);
}
.visit__h {
  font-family: var(--sans);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--brass-deep);
  font-weight: 500;
  margin: 0 0 14px;
}
.visit__address {
  font-style: normal;
  font-family: var(--serif);
  font-size: 1.25rem;
  line-height: 1.4;
  color: var(--ink);
  font-variation-settings: "opsz" 24, "SOFT" 30;
}
.visit__address span { display: block; }
.visit__note {
  margin: 14px 0 0;
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.95rem;
  color: var(--ink-soft);
  font-variation-settings: "opsz" 24, "SOFT" 80;
}
.visit__note--star {
  display: flex; align-items: center; gap: 8px;
  font-style: normal;
  font-family: var(--sans);
  font-size: 0.85rem;
  color: var(--ink);
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--hairline);
}
.lunch-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--midnight);
  display: inline-block;
  flex-shrink: 0;
}
.visit__map-link {
  display: inline-block;
  margin-top: 16px;
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--brass-deep);
  border-bottom: 1px solid var(--brass);
  padding-bottom: 2px;
}
.visit__map-link:hover, .visit__map-link:focus-visible {
  color: var(--ink);
  border-bottom-color: var(--ink);
  text-decoration: none;
}
.visit__phone {
  font-family: var(--serif);
  font-weight: 400;
  font-variation-settings: "opsz" 144, "SOFT" 30, "WONK" 0;
  font-size: clamp(1.8rem, 4vw + 0.4rem, 2.6rem);
  letter-spacing: -0.01em;
  color: var(--ink);
  line-height: 1;
  border-bottom: 1px solid var(--brass);
  padding-bottom: 6px;
  display: inline-block;
}
.visit__phone:hover, .visit__phone:focus-visible {
  color: var(--brass-deep);
  border-bottom-color: var(--brass-deep);
  text-decoration: none;
}

.hours {
  width: 100%;
  font-family: var(--sans);
  font-size: 0.95rem;
}
.hours th, .hours td { padding: 8px 0; text-align: left; font-weight: 400; }
.hours th {
  font-family: var(--serif);
  font-size: 1.05rem;
  color: var(--ink-soft);
  width: 64px;
  font-variation-settings: "opsz" 14, "SOFT" 30;
}
.hours td {
  font-variant-numeric: tabular-nums;
  color: var(--ink);
  text-align: right;
}
.hours__closed { color: var(--ink-quiet); font-style: italic; font-family: var(--serif); }
.hours tr { border-bottom: 1px dotted var(--hairline); }
.hours tr:last-child { border-bottom: none; }

.visit__photo {
  margin: 0;
  position: relative;
  background: var(--paper-deep);
  padding: 12px 12px 18px;
  border: 1px solid var(--hairline);
}
.visit__photo img {
  width: 100%; height: auto;
  display: block;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  object-position: center 30%;
  filter: saturate(0.85) contrast(1.02);
}
.visit__photo figcaption {
  margin-top: 12px;
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.9rem;
  color: var(--ink-soft);
  text-align: center;
  font-variation-settings: "opsz" 14, "SOFT" 80;
}

.visit__map {
  background: var(--paper-deep);
  border: 1px solid var(--hairline);
  padding: 12px;
  min-height: 280px;
}
.visit__map iframe {
  width: 100%;
  height: 100%;
  min-height: 256px;
  border: 0;
  display: block;
  filter: grayscale(0.4) contrast(0.95);
}

@media (min-width: 760px) {
  .visit__grid {
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "address   phone"
      "hours     photo"
      "map       map";
  }
  .visit__card--address { grid-area: address; }
  .visit__card--phone   { grid-area: phone; }
  .visit__card--hours   { grid-area: hours; }
  .visit__photo         { grid-area: photo; }
  .visit__map           { grid-area: map; min-height: 360px; }
}
@media (min-width: 1100px) {
  .visit__grid {
    grid-template-columns: 1.2fr 1fr 1.4fr;
    grid-template-areas:
      "address  phone  map"
      "hours    photo  map";
  }
  .visit__map { min-height: 100%; }
}

/* ---------- Final word ---------- */
.final {
  text-align: center;
  padding-top: clamp(64px, 10vw, 140px) !important;
  padding-bottom: clamp(64px, 10vw, 140px) !important;
}
.final__title {
  font-family: var(--serif);
  font-weight: 400;
  font-variation-settings: "opsz" 144, "SOFT" 40, "WONK" 1;
  font-style: italic;
  font-size: var(--fs-h1);
  line-height: 0.98;
  letter-spacing: -0.025em;
  margin: 0 0 20px;
  color: var(--ink);
  max-width: 16ch;
  margin-left: auto;
  margin-right: auto;
}
.final__body {
  max-width: 38ch;
  margin: 0 auto;
  font-size: 1.1rem;
  line-height: 1.6;
  color: var(--ink-soft);
}
.final__cta-row {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
  margin-top: 40px;
}

/* ---------- Footer ---------- */
.site-footer {
  background: var(--ink);
  color: rgba(244, 239, 230, 0.78);
  padding: clamp(48px, 7vw, 80px) var(--gutter) clamp(28px, 4vw, 40px);
}
.site-footer__inner {
  max-width: var(--page-max);
  margin: 0 auto;
  display: grid;
  gap: clamp(28px, 4vw, 48px);
  grid-template-columns: 1fr;
  padding-bottom: clamp(28px, 4vw, 40px);
  border-bottom: 1px solid rgba(244, 239, 230, 0.14);
}
.site-footer__brand {
  display: flex;
  align-items: baseline;
  gap: 12px;
}
.site-footer .brand__mark--footer { color: var(--paper); font-size: 1.6rem; }
.site-footer .brand__amp { color: var(--brass); }
.site-footer .brand__sub { color: rgba(244, 239, 230, 0.6); }

.site-footer__address {
  font-style: normal;
  display: grid;
  gap: 4px;
  font-family: var(--serif);
  font-size: 1.05rem;
  font-variation-settings: "opsz" 14, "SOFT" 30;
  color: rgba(244, 239, 230, 0.86);
}
.site-footer__address a {
  color: var(--brass);
  border-bottom: 1px solid rgba(176, 139, 79, 0.4);
  padding-bottom: 1px;
}
.site-footer__address a:hover, .site-footer__address a:focus-visible {
  color: var(--paper);
  border-bottom-color: var(--paper);
  text-decoration: none;
}
.site-footer__h {
  font-family: var(--sans);
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--brass);
  margin: 0 0 8px;
  font-weight: 500;
}
.site-footer__hours p { margin: 0 0 4px; font-family: var(--sans); font-size: 0.95rem; }
.site-footer__social {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
}
.site-footer__social a {
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(244, 239, 230, 0.7);
  text-decoration: none;
  border-bottom: 1px solid rgba(244, 239, 230, 0.2);
  padding-bottom: 2px;
}
.site-footer__social a:hover, .site-footer__social a:focus-visible {
  color: var(--paper);
  border-bottom-color: var(--brass);
}
.site-footer__copy {
  max-width: var(--page-max);
  margin: clamp(20px, 3vw, 32px) auto 0;
  text-align: center;
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(244, 239, 230, 0.42);
}

@media (min-width: 760px) {
  .site-footer__inner {
    grid-template-columns: 1.2fr 1fr 1fr auto;
    align-items: start;
  }
  .site-footer__social { justify-self: end; }
}

/* ---------- Reveal animations ----------
   Only hide content for reveal when JS has signaled it's ready
   (avoids invisible content if JS fails, IntersectionObserver isn't
   supported, or the browser captures a full-page screenshot that
   doesn't intersect every section). */
html.js-reveal .reveal {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 700ms ease, transform 700ms cubic-bezier(.22,.61,.36,1);
}
html.js-reveal .reveal.is-in {
  opacity: 1;
  transform: none;
}
@media (prefers-reduced-motion: reduce) {
  html.js-reveal .reveal { opacity: 1; transform: none; transition: none; }
}

/* ---------- Selection ---------- */
::selection { background: var(--brass); color: var(--paper); }

/* ---------- Tiny mobile fine-tuning ---------- */
@media (max-width: 540px) {
  .nav { grid-template-columns: 1fr auto; column-gap: 12px; }
  .nav__list { display: none; }
  .brand__sub { display: none; }
  .nav__phone-num { font-size: 0.92rem; }
  .hero__title { max-width: none; }
  .hero__diagram { width: 60vw; margin: 0 auto; }
  .hero__caption { text-align: center; margin-top: -10px; }
  .service { grid-template-columns: 36px 1fr; gap: 12px; }
  .service__num { font-size: 1.2rem; }
  .service--feature { padding-left: 16px; padding-right: 16px; }
  .final__title { font-size: clamp(2.3rem, 12vw, 3.4rem); }
}
