/* ─── Reset ───────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { overflow-x: clip; scroll-behavior: smooth; }
body { overflow-x: clip; background: var(--color-paper); color: var(--color-ink); font-family: var(--font-body); font-size: var(--text-base); line-height: 1.6; -webkit-font-smoothing: antialiased; }
img, video { display: block; max-width: 100%; }
ul, ol { list-style: none; }
a { color: inherit; text-decoration: none; }
address { font-style: normal; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }

/* ─── Focus ───────────────────────────────────────────────────────────── */
:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

/* ─── Skip link ───────────────────────────────────────────────────────── */
.skip-link {
  position: absolute;
  top: var(--space-2);
  left: var(--space-2);
  z-index: 9999;
  padding: var(--space-2) var(--space-4);
  background: var(--color-accent);
  color: var(--color-accent-fg);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  border-radius: var(--radius-sm);
  transform: translateY(-120%);
  transition: transform var(--dur-fast) var(--ease-out);
}
.skip-link:focus { transform: translateY(0); }

/* ─── Container ───────────────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--max-w-content);
  margin-inline: auto;
  padding-inline: var(--container-px);
}

/* ─── Utility ─────────────────────────────────────────────────────────── */
.mt-md { margin-top: var(--space-md); }
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ─── Scroll fade-in ──────────────────────────────────────────────────── */
.fade-in {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity var(--dur-slow) var(--ease-out),
              transform var(--dur-slow) var(--ease-out);
}
.fade-in.is-visible { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  .fade-in { opacity: 1; transform: none; transition: none; }
}

/* ─── Buttons ─────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.75em 1.5em;
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  transition: background var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out),
              transform var(--dur-fast) var(--ease-out),
              box-shadow var(--dur-fast) var(--ease-out);
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn-lg { font-size: var(--text-xl); padding: 0.85em 1.75em; }

.btn-accent {
  background: var(--color-accent);
  color: var(--color-accent-fg);
}
.btn-accent:hover { background: var(--color-accent-hover); }
.btn-accent:focus-visible { outline-color: var(--color-white); outline-offset: 3px; }

.btn-primary {
  background: var(--color-ink);
  color: var(--color-paper);
}
.btn-primary:hover { background: var(--color-ink-2); }

.btn-ghost-light {
  background: transparent;
  color: var(--color-ink-xlight);
  border: var(--rule-thin) solid var(--color-border-dark);
}
.btn-ghost-light:hover {
  background: var(--color-surface-mid-2);
  border-color: var(--color-ink-light);
}

.btn-ghost {
  background: transparent;
  color: var(--color-ink);
  border: var(--rule-thin) solid var(--color-border);
}
.btn-ghost:hover { background: var(--color-paper-2); }

/* ─── Section shared ──────────────────────────────────────────────────── */
.section { padding-block: var(--space-section); }
.section--dark { background: var(--color-surface-dark); color: var(--color-ink-xlight); }
.section--mid  { background: var(--color-paper-2); }

.section-header { margin-bottom: var(--space-12); max-width: var(--max-w-text); }
.section-label {
  display: block;
  margin-bottom: var(--space-3);
  color: var(--color-accent);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.section-heading {
  font-family: var(--font-display);
  font-size: var(--text-display);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.01em;
  color: var(--color-ink);
  overflow-wrap: anywhere;
  min-width: 0;
}
.section-body {
  margin-top: var(--space-4);
  font-size: var(--text-lg);
  color: var(--color-ink-muted);
  max-width: 52ch;
}

/* ─── Top bar ─────────────────────────────────────────────────────────── */
.top-bar {
  background: var(--color-surface-dark);
  padding-block: var(--space-2);
  font-size: var(--text-sm);
}
.top-bar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}
.top-bar-text { color: var(--color-ink-light); }
.top-bar-phone {
  color: var(--color-accent);
  font-weight: 600;
  letter-spacing: 0.02em;
  transition: color var(--dur-fast) var(--ease-out);
}
.top-bar-phone:hover { color: var(--color-accent-hover); }

/* ─── Header ──────────────────────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--color-paper);
  border-bottom: var(--rule-hairline) solid var(--color-border);
  transition: box-shadow var(--dur-base) var(--ease-out);
}
.site-header.is-scrolled {
  box-shadow: 0 2px 12px oklch(12% 0.012 60 / 0.12);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  min-height: 64px;
}

/* ─── Logo ────────────────────────────────────────────────────────────── */
.site-logo {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  text-decoration: none;
  flex-shrink: 0;
}
.logo-primary {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 900;
  letter-spacing: 0.06em;
  color: var(--color-ink);
  line-height: 1;
}
.logo-sub {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.18em;
  color: var(--color-ink-muted);
  text-transform: uppercase;
}
/* Dark bg logo variant */
.footer-logo .logo-primary { color: var(--color-ink-xlight); }
.footer-logo .logo-sub     { color: var(--color-ink-light); }

/* ─── Nav ─────────────────────────────────────────────────────────────── */
.main-nav { display: none; }
.nav-list { display: flex; align-items: center; gap: var(--space-1); }
.nav-list a {
  display: block;
  padding: var(--space-2) var(--space-3);
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--color-ink-2);
  border-radius: var(--radius-sm);
  transition: color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
}
.nav-list a:hover { color: var(--color-ink); background: var(--color-paper-2); }
.nav-cta {
  background: var(--color-accent) !important;
  color: var(--color-accent-fg) !important;
  font-weight: 600 !important;
  padding: var(--space-2) var(--space-5) !important;
  border-radius: var(--radius-sm);
}
.nav-cta:hover { background: var(--color-accent-hover) !important; }

/* Dropdown */
.nav-has-dropdown { position: relative; }
.nav-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + var(--space-2));
  left: 0;
  min-width: 220px;
  background: var(--color-white);
  border: var(--rule-hairline) solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px oklch(12% 0.012 60 / 0.10);
  padding: var(--space-2);
  z-index: 200;
}
.nav-has-dropdown:hover .nav-dropdown,
.nav-has-dropdown:focus-within .nav-dropdown { display: block; }
.nav-dropdown a {
  display: block;
  padding: var(--space-2) var(--space-4) !important;
  font-size: var(--text-sm) !important;
  border-radius: var(--radius-sm);
  color: var(--color-ink-2) !important;
  background: transparent !important;
}
.nav-dropdown a:hover { background: var(--color-paper-2) !important; color: var(--color-ink) !important; }

/* Hamburger */
.nav-toggle {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 44px;
  height: 44px;
  gap: 5px;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}
.burger,
.burger::before,
.burger::after {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-ink);
  border-radius: 1px;
  transition: transform var(--dur-base) var(--ease-in-out),
              opacity var(--dur-base) var(--ease-in-out);
}
.burger { position: relative; }
.burger::before,
.burger::after { content: ''; position: absolute; left: 0; }
.burger::before { top: -6px; }
.burger::after  { top:  6px; }

[aria-expanded="true"] .burger  { background: transparent; }
[aria-expanded="true"] .burger::before { transform: translateY(6px) rotate(45deg); }
[aria-expanded="true"] .burger::after  { transform: translateY(-6px) rotate(-45deg); }

/* Mobile nav open state */
.main-nav.is-open {
  display: block;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--color-white);
  border-top: var(--rule-hairline) solid var(--color-border);
  border-bottom: var(--rule-thin) solid var(--color-border);
  padding: var(--space-4) var(--container-px) var(--space-6);
  z-index: 99;
}
.main-nav.is-open .nav-list { flex-direction: column; align-items: stretch; gap: var(--space-1); }
.main-nav.is-open .nav-dropdown { display: block; position: static; box-shadow: none; border: none; border-left: var(--rule-thick) solid var(--color-accent-light); border-radius: 0; margin-left: var(--space-4); padding: var(--space-2) 0; }
.main-nav.is-open .nav-cta { text-align: center; margin-top: var(--space-2); }

/* ─── Hero ────────────────────────────────────────────────────────────── */
.hero {
  background: var(--color-surface-dark);
  padding-block: clamp(4rem, 12vw, 7rem);
}
.hero-content {
  max-width: 800px;
}
.hero-eyebrow {
  display: block;
  margin-bottom: var(--space-5);
  color: var(--color-ink-light);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.hero-eyebrow::before {
  content: '';
  display: inline-block;
  width: 32px;
  height: 3px;
  background: var(--color-accent);
  vertical-align: middle;
  margin-right: var(--space-3);
  border-radius: 1px;
}
.hero-headline {
  font-family: var(--font-display);
  font-size: var(--text-display-l);
  font-weight: 900;
  line-height: 0.95;
  letter-spacing: -0.01em;
  color: var(--color-white);
  text-transform: uppercase;
  overflow-wrap: anywhere;
  min-width: 0;
  margin-bottom: var(--space-6);
}
.hero-body {
  font-size: var(--text-lg);
  line-height: 1.65;
  color: var(--color-ink-light);
  max-width: 52ch;
  margin-bottom: var(--space-10);
}
.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: center;
}

/* ─── Trust strip ─────────────────────────────────────────────────────── */
.trust-strip {
  background: var(--color-surface-mid);
  padding-block: var(--space-6);
  border-bottom: var(--rule-hairline) solid var(--color-border-dark);
}
.trust-strip-inner {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
  justify-content: center;
  align-items: center;
}
.trust-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.trust-number, .trust-icon {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 900;
  color: var(--color-accent);
  line-height: 1;
}
.trust-icon { font-size: var(--text-2xl); }
.trust-label {
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--color-ink-light);
  text-transform: uppercase;
  line-height: 1.3;
}

/* ─── Services section ────────────────────────────────────────────────── */
.section-services { background: var(--color-paper); }
.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  gap: var(--space-6);
}
.service-card {
  padding: var(--space-8) var(--space-6);
  border: var(--rule-hairline) solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-white);
  position: relative;
  overflow: hidden;
  will-change: transform;
  transform: perspective(1000px) rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg)) translateY(0);
  transition: border-color var(--dur-base) var(--ease-out),
              transform 0.1s ease,
              box-shadow var(--dur-base) var(--ease-out);
}
.service-card:hover {
  border-color: var(--color-accent);
  transform: perspective(1000px) rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg)) translateY(-6px);
  box-shadow: 0 12px 44px oklch(64% 0.138 55 / 0.16);
}
.service-card-icon {
  color: var(--color-accent);
  margin-bottom: var(--space-5);
}
.service-card-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 800;
  letter-spacing: 0.01em;
  margin-bottom: var(--space-3);
  line-height: 1.1;
}
.service-card-title a {
  color: var(--color-ink);
  transition: color var(--dur-fast) var(--ease-out);
}
.service-card-title a:hover { color: var(--color-accent); }
.service-card-body {
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--color-ink-muted);
  margin-bottom: var(--space-5);
}
.service-card-link {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-accent);
  letter-spacing: 0.03em;
  transition: color var(--dur-fast) var(--ease-out);
}
.service-card-link:hover { color: var(--color-accent-hover); }

/* ─── About section ───────────────────────────────────────────────────── */
.section-about { background: var(--color-paper-2); }
.about-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
}
.about-text .section-heading { color: var(--color-ink); }
.about-text p {
  margin-top: var(--space-4);
  font-size: var(--text-lg);
  line-height: 1.7;
  color: var(--color-ink-2);
  max-width: var(--max-w-text);
}
.about-text p + p { margin-top: var(--space-4); }
.about-text .btn { margin-top: var(--space-8); }
.about-credentials {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}
.credential-item {
  padding: var(--space-6);
  background: var(--color-white);
  border-radius: var(--radius-md);
  border: var(--rule-hairline) solid var(--color-border);
}
.credential-value {
  display: block;
  font-family: var(--font-display);
  font-size: var(--text-display-s);
  font-weight: 900;
  color: var(--color-accent);
  line-height: 1;
  margin-bottom: var(--space-2);
  overflow-wrap: anywhere;
  min-width: 0;
}
.credential-label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* ─── Coverage section ────────────────────────────────────────────────── */
.section-coverage { background: var(--color-paper); }
.coverage-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-8);
  margin-bottom: var(--space-10);
}
.coverage-state-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 800;
  letter-spacing: 0.04em;
  color: var(--color-ink);
  padding-bottom: var(--space-3);
  border-bottom: var(--rule-thin) solid var(--color-accent);
  margin-bottom: var(--space-4);
  text-transform: uppercase;
}
.coverage-list li + li { margin-top: var(--space-2); }
.coverage-list a {
  font-size: var(--text-base);
  color: var(--color-ink-2);
  border-bottom: var(--rule-hairline) solid transparent;
  transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
}
.coverage-list a:hover { color: var(--color-accent); border-color: var(--color-accent-light); }
.coverage-cta { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-6); }
.coverage-note { font-size: var(--text-sm); color: var(--color-ink-muted); }
.coverage-note a { color: var(--color-accent); font-weight: 600; }
.coverage-note a:hover { color: var(--color-accent-hover); }

/* ─── CTA section ─────────────────────────────────────────────────────── */
.section-cta {
  background: var(--color-surface-dark);
  padding-block: clamp(3rem, 8vw, 5rem);
}
.cta-inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-10);
}
.cta-label { color: var(--color-accent) !important; }
.cta-heading {
  font-family: var(--font-display);
  font-size: var(--text-display);
  font-weight: 800;
  line-height: 1.05;
  color: var(--color-white);
  overflow-wrap: anywhere;
  min-width: 0;
  max-width: 20ch;
}
.cta-body {
  margin-top: var(--space-4);
  font-size: var(--text-lg);
  color: var(--color-ink-light);
  max-width: 52ch;
  line-height: 1.65;
}
.cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: center;
}

/* ─── Footer ──────────────────────────────────────────────────────────── */
.site-footer {
  background: var(--color-ink);
  color: var(--color-ink-light);
}
.footer-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  padding-block: var(--space-12) var(--space-10);
}
.footer-brand p {
  margin-top: var(--space-5);
  font-size: var(--text-sm);
  line-height: 1.7;
  color: var(--color-ink-light);
}
.footer-phone {
  display: inline-block;
  margin-top: var(--space-5);
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 800;
  color: var(--color-accent);
  letter-spacing: 0.02em;
  transition: color var(--dur-fast) var(--ease-out);
}
.footer-phone:hover { color: var(--color-accent-hover); }
.footer-heading {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-ink-xlight);
  margin-bottom: var(--space-5);
}
.footer-nav ul { display: flex; flex-direction: column; gap: var(--space-3); }
.footer-nav a {
  font-size: var(--text-sm);
  color: var(--color-ink-light);
  transition: color var(--dur-fast) var(--ease-out);
}
.footer-nav a:hover { color: var(--color-accent); }
.footer-contact address { display: flex; flex-direction: column; gap: var(--space-2); }
.footer-contact address p { font-size: var(--text-sm); color: var(--color-ink-light); }
.footer-contact address a {
  color: var(--color-ink-light);
  transition: color var(--dur-fast) var(--ease-out);
}
.footer-contact address a:hover { color: var(--color-accent); }
.footer-contact .btn { margin-top: var(--space-6); }

.footer-bottom {
  border-top: var(--rule-hairline) solid var(--color-border-dark);
  padding-block: var(--space-5);
}
.footer-bottom-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}
.footer-bottom p { font-size: var(--text-xs); color: var(--color-ink-muted); }
.footer-legal a {
  font-size: var(--text-xs);
  color: var(--color-ink-muted);
  transition: color var(--dur-fast) var(--ease-out);
}
.footer-legal a:hover { color: var(--color-ink-light); }

/* ─── Page hero (inner pages) ─────────────────────────────────────────── */
.page-hero {
  background: var(--color-surface-dark);
  padding-block: clamp(2.5rem, 7vw, 4.5rem);
}
.page-hero-eyebrow {
  display: block;
  margin-bottom: var(--space-4);
  color: var(--color-ink-light);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.page-hero-title {
  font-family: var(--font-display);
  font-size: var(--text-display);
  font-weight: 900;
  line-height: 1.0;
  letter-spacing: -0.01em;
  color: var(--color-white);
  text-transform: uppercase;
  overflow-wrap: anywhere;
  min-width: 0;
  max-width: 18ch;
}
.page-hero-title--long { font-size: var(--text-display-s); max-width: 24ch; text-transform: none; }
.page-hero-body {
  margin-top: var(--space-5);
  font-size: var(--text-lg);
  color: var(--color-ink-light);
  max-width: 52ch;
  line-height: 1.65;
}

/* ─── Breadcrumb ──────────────────────────────────────────────────────── */
.breadcrumb {
  background: var(--color-paper-2);
  padding-block: var(--space-3);
  border-bottom: var(--rule-hairline) solid var(--color-border);
}
.breadcrumb-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
  font-size: var(--text-xs);
  color: var(--color-ink-muted);
}
.breadcrumb-list li:not(:last-child)::after { content: '›'; margin-left: var(--space-2); color: var(--color-border); }
.breadcrumb-list a { color: var(--color-ink-muted); transition: color var(--dur-fast) var(--ease-out); }
.breadcrumb-list a:hover { color: var(--color-accent); }
.breadcrumb-list [aria-current] { color: var(--color-ink-2); font-weight: 600; }

/* ─── Content page ────────────────────────────────────────────────────── */
.content-section { padding-block: var(--space-section); }
.content-section + .content-section {
  border-top: var(--rule-hairline) solid var(--color-border);
}
.content-lead {
  font-size: var(--text-xl);
  line-height: 1.65;
  color: var(--color-ink-2);
  max-width: var(--max-w-text);
  margin-bottom: var(--space-8);
}
.content-body {
  max-width: var(--max-w-text);
}
.content-body h2 {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 800;
  letter-spacing: 0.01em;
  color: var(--color-ink);
  margin-top: var(--space-10);
  margin-bottom: var(--space-4);
}
.content-body h3 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--color-ink);
  margin-top: var(--space-8);
  margin-bottom: var(--space-3);
}
.content-body p {
  font-size: var(--text-lg);
  line-height: 1.7;
  color: var(--color-ink-2);
  margin-bottom: var(--space-5);
}
.content-body ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
}
.content-body ul li {
  padding-left: var(--space-6);
  position: relative;
  font-size: var(--text-base);
  color: var(--color-ink-2);
  line-height: 1.6;
}
.content-body ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 14px;
  height: 3px;
  background: var(--color-accent);
  border-radius: 1px;
}

/* ─── Two-column service layout ───────────────────────────────────────── */
.service-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
}
.service-sidebar {
  padding: var(--space-8);
  background: var(--color-paper-2);
  border-radius: var(--radius-md);
  border: var(--rule-hairline) solid var(--color-border);
  height: fit-content;
}
.sidebar-heading {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 800;
  letter-spacing: 0.03em;
  color: var(--color-ink);
  margin-bottom: var(--space-5);
  text-transform: uppercase;
}
.sidebar-list { display: flex; flex-direction: column; gap: var(--space-3); }
.sidebar-list a {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-base);
  color: var(--color-ink-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  border: var(--rule-hairline) solid var(--color-border);
  background: var(--color-white);
  transition: border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
.sidebar-list a:hover { border-color: var(--color-accent); color: var(--color-accent); }
.sidebar-list a.is-current { border-color: var(--color-accent); color: var(--color-accent); font-weight: 600; background: var(--color-accent-light); }
.sidebar-cta {
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: var(--rule-hairline) solid var(--color-border);
}
.sidebar-cta p { font-size: var(--text-sm); color: var(--color-ink-muted); margin-bottom: var(--space-4); }

/* ─── City page ───────────────────────────────────────────────────────── */
.nearby-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 180px), 1fr));
  gap: var(--space-3);
  margin-top: var(--space-6);
}
.nearby-link {
  display: block;
  padding: var(--space-4) var(--space-5);
  background: var(--color-paper-2);
  border: var(--rule-hairline) solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-ink-2);
  text-align: center;
  transition: border-color var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out),
              background var(--dur-fast) var(--ease-out);
}
.nearby-link:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
  background: var(--color-accent-light);
}

/* ─── Contact / Form ──────────────────────────────────────────────────── */
.contact-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  padding-block: var(--space-section);
}
.contact-info h2 {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 800;
  color: var(--color-ink);
  margin-bottom: var(--space-5);
}
.contact-info p {
  font-size: var(--text-lg);
  color: var(--color-ink-2);
  line-height: 1.7;
  margin-bottom: var(--space-5);
  max-width: 48ch;
}
.contact-detail {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  padding: var(--space-5) 0;
  border-bottom: var(--rule-hairline) solid var(--color-border);
}
.contact-detail:first-of-type { border-top: var(--rule-hairline) solid var(--color-border); }
.contact-detail-label {
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ink-muted);
  min-width: 80px;
}
.contact-detail-value {
  font-size: var(--text-base);
  color: var(--color-ink-2);
  line-height: 1.5;
}
.contact-detail-value a { color: var(--color-accent); transition: color var(--dur-fast) var(--ease-out); }
.contact-detail-value a:hover { color: var(--color-accent-hover); }

.contact-form {
  background: var(--color-paper-2);
  padding: var(--space-8);
  border-radius: var(--radius-lg);
  border: var(--rule-hairline) solid var(--color-border);
}
.form-heading {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 800;
  color: var(--color-ink);
  margin-bottom: var(--space-6);
  letter-spacing: 0.02em;
}
.form-group { margin-bottom: var(--space-5); }
.form-label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-ink-2);
  letter-spacing: 0.03em;
  margin-bottom: var(--space-2);
}
.form-input,
.form-select,
.form-textarea {
  display: block;
  width: 100%;
  padding: var(--space-3) var(--space-4);
  background: var(--color-white);
  border: var(--rule-thin) solid var(--color-border);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-ink);
  transition: border-color var(--dur-fast) var(--ease-out),
              box-shadow var(--dur-fast) var(--ease-out);
  appearance: none;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px oklch(64% 0.138 55 / 0.15);
}
.form-textarea { min-height: 120px; resize: vertical; }
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}
.form-submit { margin-top: var(--space-6); }
.form-note {
  margin-top: var(--space-4);
  font-size: var(--text-xs);
  color: var(--color-ink-muted);
}

/* ─── Locations index ─────────────────────────────────────────────────── */
.locations-intro {
  max-width: 72ch;
  margin-bottom: var(--space-12);
}
.locations-intro p {
  font-size: var(--text-lg);
  color: var(--color-ink-2);
  line-height: 1.7;
  margin-bottom: var(--space-4);
}
.locations-region-block { margin-bottom: var(--space-12); }
.locations-region-heading {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-ink-muted);
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-3);
  border-bottom: var(--rule-thin) solid var(--color-border);
}
.locations-note {
  margin-top: var(--space-8);
  padding: var(--space-6);
  background: var(--color-paper-2);
  border-radius: var(--radius-md);
  border-left: 4px solid var(--color-accent);
}
.locations-note p { margin: 0; color: var(--color-ink-2); }
.locations-note a { color: var(--color-accent); font-weight: 600; }
.locations-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 220px), 1fr));
  gap: var(--space-4);
  list-style: none;
  padding: 0;
  margin: 0;
}
.location-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding: var(--space-5) var(--space-6);
  border: var(--rule-hairline) solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-white);
  text-decoration: none;
  transition: border-color var(--dur-base) var(--ease-out),
              transform var(--dur-base) var(--ease-out);
}
.location-card:hover { border-color: var(--color-accent); transform: translateY(-2px); }
.location-name {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 800;
  color: var(--color-ink);
  letter-spacing: 0.02em;
}
.location-meta {
  font-size: var(--text-sm);
  color: var(--color-ink-muted);
}
.location-card-state {
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-2);
}
.location-card-name {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 800;
  color: var(--color-ink);
  margin-bottom: var(--space-3);
}
.location-card-link {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-accent);
  transition: color var(--dur-fast) var(--ease-out);
}
.location-card-link:hover { color: var(--color-accent-hover); }

/* ─── Responsive: 640px ───────────────────────────────────────────────── */
@media (min-width: 640px) {
  .top-bar-inner { justify-content: space-between; }
  .trust-strip-inner { flex-wrap: nowrap; justify-content: space-between; }
  .trust-item { flex-direction: row; }
  .trust-label { white-space: nowrap; }
  .contact-layout { grid-template-columns: 1fr; }
}

/* ─── Responsive: 768px ───────────────────────────────────────────────── */
@media (min-width: 768px) {
  .form-row { grid-template-columns: 1fr 1fr; }
  .contact-layout { grid-template-columns: 1fr 1fr; }
  .about-inner { grid-template-columns: 1fr 1fr; align-items: start; }
}

/* ─── Responsive: 1024px ──────────────────────────────────────────────── */
@media (min-width: 1024px) {
  .main-nav { display: block; }
  .nav-toggle { display: none; }
  .service-layout { grid-template-columns: 2fr 1fr; }
  .cta-inner { flex-direction: row; align-items: flex-end; justify-content: space-between; }
  .footer-inner { grid-template-columns: 2fr 1fr 1fr 1.5fr; }
}

/* ─── Responsive: 1280px ──────────────────────────────────────────────── */
@media (min-width: 1280px) {
  .coverage-grid { grid-template-columns: 2fr 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   WOW — Animation layer
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── Scroll progress bar ──────────────────────────────────────────────── */
.scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  width: 0%;
  background: linear-gradient(90deg, var(--color-accent) 0%, oklch(72% 0.16 52) 100%);
  z-index: 10001;
  pointer-events: none;
  border-radius: 0 2px 2px 0;
  transition: width 0.08s linear;
}

/* ─── Button shimmer sweep ─────────────────────────────────────────────── */
.btn-accent { position: relative; overflow: hidden; }
.btn-accent::after {
  content: '';
  position: absolute;
  top: 0;
  left: -75%;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent 0%, oklch(100% 0 0 / 0.28) 50%, transparent 100%);
  transform: skewX(-20deg);
  pointer-events: none;
  transition: left 0.55s var(--ease-out);
}
.btn-accent:hover::after { left: 160%; }

/* ─── Nav underline animation ──────────────────────────────────────────── */
.nav-list > li > a:not(.nav-cta) { position: relative; }
.nav-list > li > a:not(.nav-cta)::after {
  content: '';
  position: absolute;
  bottom: 3px;
  left: var(--space-3);
  right: var(--space-3);
  height: 2px;
  background: var(--color-accent);
  transform: scaleX(0);
  transform-origin: right center;
  transition: transform 0.25s var(--ease-out);
  border-radius: 1px;
  pointer-events: none;
}
.nav-list > li > a:not(.nav-cta):hover::after {
  transform: scaleX(1);
  transform-origin: left center;
}

/* ─── Hero stripe overlay ──────────────────────────────────────────────── */
.hero { position: relative; overflow: hidden; }
.hero::before {
  content: '';
  position: absolute;
  inset: -200%;
  width: 500%;
  height: 500%;
  background-image: repeating-linear-gradient(
    -45deg,
    transparent 0px,
    transparent 58px,
    oklch(64% 0.138 55 / 0.05) 58px,
    oklch(64% 0.138 55 / 0.05) 60px
  );
  animation: stripe-drift 30s linear infinite;
  pointer-events: none;
  z-index: 0;
}
.hero > .container { position: relative; z-index: 1; }

/* ─── Hero entrance animations ─────────────────────────────────────────── */
@keyframes hero-rise {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}
.hero-eyebrow { animation: hero-rise 0.55s ease both 0.15s; }
.hero-body    { animation: hero-rise 0.55s ease both 0.58s; }
.hero-actions { animation: hero-rise 0.55s ease both 0.78s; }

/* ─── Hero headline line-reveal (set up by JS) ─────────────────────────── */
.hero-line { display: block; overflow: hidden; line-height: 0.95; }
.hero-line-inner {
  display: block;
  transform: translateY(108%);
  opacity: 0;
  transition: transform 0.72s cubic-bezier(0.16, 1, 0.3, 1),
              opacity 0.45s ease;
}
.hero-line-inner.is-revealed { transform: translateY(0); opacity: 1; }

/* ─── Service card cursor glow ─────────────────────────────────────────── */
.service-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at var(--mx, 50%) var(--my, 50%),
    oklch(64% 0.138 55 / 0.11) 0%,
    transparent 62%
  );
  opacity: 0;
  transition: opacity 0.35s ease;
  pointer-events: none;
  border-radius: inherit;
  z-index: 0;
}
.service-card:hover::before { opacity: 1; }
.service-card > * { position: relative; z-index: 1; }

/* ─── CTA section moving stripes ───────────────────────────────────────── */
.section-cta { position: relative; overflow: hidden; }
.section-cta::before {
  content: '';
  position: absolute;
  inset: -200%;
  width: 500%;
  height: 500%;
  background-image: repeating-linear-gradient(
    -45deg,
    transparent 0px,
    transparent 38px,
    oklch(64% 0.138 55 / 0.08) 38px,
    oklch(64% 0.138 55 / 0.08) 40px
  );
  animation: stripe-drift 20s linear infinite reverse;
  pointer-events: none;
  z-index: 0;
}
.cta-inner { position: relative; z-index: 1; }

/* ─── Trust strip hover lift ───────────────────────────────────────────── */
.trust-item { transition: transform 0.3s var(--ease-out); }
.trust-item:hover { transform: scale(1.06); }
.trust-number { font-variant-numeric: tabular-nums; display: inline-block; }

/* ─── Location card hover glow ─────────────────────────────────────────── */
.location-card {
  position: relative;
  overflow: hidden;
}
.location-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at var(--mx, 50%) var(--my, 50%),
    oklch(64% 0.138 55 / 0.09) 0%,
    transparent 60%
  );
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
  border-radius: inherit;
}
.location-card:hover::before { opacity: 1; }
.location-card > * { position: relative; z-index: 1; }

/* ─── Keyframes ─────────────────────────────────────────────────────────── */
@keyframes stripe-drift {
  from { transform: translateX(0)    translateY(0); }
  to   { transform: translateX(84px) translateY(-84px); }
}

/* ─── Reduced-motion safety net ─────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .hero::before,
  .section-cta::before,
  .btn-accent::after { animation: none; transition: none; }
  .hero-eyebrow,
  .hero-body,
  .hero-actions { animation: none; opacity: 1; transform: none; }
  .hero-line-inner { transform: none; opacity: 1; transition: none; }
  .service-card { will-change: auto; transform: none !important; transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out); }
  .service-card::before,
  .location-card::before { display: none; }
  .trust-item { transition: none; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   About page WOW upgrade: animated framing blueprint, glass facts, premium motion
   ═══════════════════════════════════════════════════════════════════════════ */
.about-wow-hero {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  padding-block: clamp(4.5rem, 10vw, 8rem);
  background:
    radial-gradient(circle at 76% 28%, oklch(64% 0.138 55 / 0.30), transparent 24rem),
    linear-gradient(135deg, oklch(10% 0.014 60) 0%, oklch(17% 0.018 62) 48%, oklch(24% 0.020 58) 100%);
}
.about-wow-hero::before {
  content: '';
  position: absolute;
  inset: -30%;
  z-index: -2;
  background-image:
    linear-gradient(oklch(100% 0 0 / 0.045) 1px, transparent 1px),
    linear-gradient(90deg, oklch(100% 0 0 / 0.035) 1px, transparent 1px),
    repeating-linear-gradient(-35deg, transparent 0 48px, oklch(64% 0.138 55 / 0.075) 48px 50px);
  background-size: 54px 54px, 54px 54px, 180px 180px;
  animation: blueprint-drift 24s linear infinite;
}
.about-wow-hero::after {
  content: '';
  position: absolute;
  inset: auto -8% -32% auto;
  width: min(62vw, 780px);
  aspect-ratio: 1;
  z-index: -1;
  border-radius: 50%;
  background: radial-gradient(circle, oklch(64% 0.138 55 / 0.22), transparent 62%);
  filter: blur(10px);
  animation: ember-breathe 5s ease-in-out infinite;
}
.about-wow-hero .container {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 430px);
  gap: clamp(2rem, 6vw, 5rem);
  align-items: center;
}
.about-wow-hero .page-hero-eyebrow,
.about-wow-hero .page-hero-title,
.about-wow-hero .page-hero-body { animation: about-rise .8s var(--ease-out) both; }
.about-wow-hero .page-hero-title {
  max-width: 11ch;
  font-size: clamp(4rem, 12vw, 8.8rem);
  line-height: .82;
  letter-spacing: -.035em;
  text-shadow: 0 22px 70px oklch(0% 0 0 / .46);
}
.about-wow-hero .page-hero-title::first-line { color: var(--color-white); }
.about-wow-hero .page-hero-body { animation-delay: .12s; font-size: clamp(1.15rem, 2vw, 1.45rem); }
.about-frame-card {
  position: relative;
  min-height: 430px;
  border: 1px solid oklch(100% 0 0 / .16);
  border-radius: 18px;
  background: linear-gradient(180deg, oklch(100% 0 0 / .12), oklch(100% 0 0 / .035));
  box-shadow: 0 34px 110px oklch(0% 0 0 / .42), inset 0 1px 0 oklch(100% 0 0 / .16);
  backdrop-filter: blur(14px);
  transform-style: preserve-3d;
  overflow: hidden;
  animation: frame-float 6s ease-in-out infinite, about-rise .9s var(--ease-out) .18s both;
}
.about-frame-card::before {
  content: '';
  position: absolute;
  inset: 18px;
  border: 1px solid oklch(64% 0.138 55 / .34);
  background:
    linear-gradient(oklch(64% 0.138 55 / .12) 1px, transparent 1px),
    linear-gradient(90deg, oklch(64% 0.138 55 / .10) 1px, transparent 1px);
  background-size: 34px 34px;
  opacity: .8;
}
.frame-skyline { position: absolute; inset: 44px 36px 118px; transform: perspective(720px) rotateX(8deg) rotateY(-9deg); }
.frame-skyline span { position: absolute; display: block; background: linear-gradient(180deg, var(--color-accent), oklch(76% 0.13 70)); box-shadow: 0 0 28px oklch(64% 0.138 55 / .34); }
.stud { width: 14px; bottom: 0; top: 34%; border-radius: 10px; animation: stud-pop 2.8s ease-in-out infinite; }
.stud-1{left:14%;animation-delay:.05s}.stud-2{left:36%;animation-delay:.18s}.stud-3{left:58%;animation-delay:.31s}.stud-4{left:80%;animation-delay:.44s}
.roof { height: 14px; width: 56%; top: 26%; border-radius: 999px; transform-origin: center; }
.roof-left { left: 6%; transform: rotate(-27deg); }
.roof-right { right: 6%; transform: rotate(27deg); }
.beam-floor { left: 8%; right: 8%; bottom: 0; height: 16px; border-radius: 999px; }
.frame-card-copy { position: absolute; left: 28px; right: 28px; bottom: 28px; padding: 22px; border: 1px solid oklch(100% 0 0 / .16); background: oklch(12% 0.012 60 / .78); backdrop-filter: blur(12px); border-radius: 14px; }
.frame-card-copy span { display:block; color: var(--color-accent); font-size: var(--text-xs); font-weight: 800; letter-spacing: .16em; text-transform: uppercase; margin-bottom: 6px; }
.frame-card-copy strong { color: var(--color-white); font-family: var(--font-display); font-size: clamp(1.8rem, 4vw, 2.7rem); line-height: .92; text-transform: uppercase; }
.about-wow-content { background: linear-gradient(180deg, var(--color-paper) 0%, var(--color-paper-2) 100%); }
.about-wow-content .content-lead { position: relative; padding: clamp(1.4rem, 4vw, 2rem); border-left: 6px solid var(--color-accent); background: var(--color-white); box-shadow: 0 18px 60px oklch(12% 0.012 60 / .10); }
.about-wow-content .content-body h2 { position: relative; display: inline-block; padding-left: 1.1rem; }
.about-wow-content .content-body h2::before { content: ''; position: absolute; left: 0; top: .22em; bottom: .18em; width: 5px; border-radius: 999px; background: linear-gradient(180deg, var(--color-accent), var(--color-accent-hover)); box-shadow: 0 0 20px oklch(64% 0.138 55 / .36); }
.about-wow-content .content-body h2,
.about-wow-content .content-body p,
.about-wow-content .service-sidebar { animation: about-rise .75s var(--ease-out) both; }
.about-wow-content .service-sidebar {
  position: sticky;
  top: 92px;
  background: oklch(100% 0 0 / .74);
  border: 1px solid oklch(64% 0.138 55 / .25);
  box-shadow: 0 24px 80px oklch(12% 0.012 60 / .14);
  backdrop-filter: blur(12px);
  transition: transform .28s var(--ease-out), box-shadow .28s var(--ease-out), border-color .28s var(--ease-out);
}
.about-wow-content .service-sidebar:hover { transform: translateY(-8px); border-color: var(--color-accent); box-shadow: 0 34px 100px oklch(12% 0.012 60 / .20); }
.about-wow-content .service-sidebar > div > div { padding: 1rem; border-radius: 12px; background: linear-gradient(135deg, var(--color-white), oklch(96% .012 75)); transition: transform .22s var(--ease-out), box-shadow .22s var(--ease-out); }
.about-wow-content .service-sidebar > div > div:hover { transform: translateX(6px) scale(1.02); box-shadow: 0 14px 34px oklch(12% 0.012 60 / .10); }
@keyframes blueprint-drift { to { transform: translate3d(70px, 70px, 0); } }
@keyframes ember-breathe { 0%,100% { opacity: .55; transform: scale(.96); } 50% { opacity: .95; transform: scale(1.06); } }
@keyframes about-rise { from { opacity: 0; transform: translateY(26px); filter: blur(8px); } to { opacity: 1; transform: translateY(0); filter: blur(0); } }
@keyframes frame-float { 0%,100% { transform: translateY(0) rotateX(0) rotateY(0); } 50% { transform: translateY(-14px) rotateX(1.5deg) rotateY(-2deg); } }
@keyframes stud-pop { 0%,100% { opacity: .86; transform: scaleY(.96); } 50% { opacity: 1; transform: scaleY(1.04); } }
@media (max-width: 900px) {
  .about-wow-hero .container { grid-template-columns: 1fr; }
  .about-frame-card { min-height: 330px; }
  .about-wow-content .service-sidebar { position: static; }
}
@media (max-width: 560px) {
  .about-wow-hero { padding-block: 3.5rem; }
  .about-wow-hero .page-hero-title { font-size: clamp(3.3rem, 18vw, 5.2rem); }
  .about-frame-card { min-height: 285px; border-radius: 12px; }
  .frame-skyline { inset: 32px 24px 102px; }
  .frame-card-copy { left: 18px; right: 18px; bottom: 18px; padding: 16px; }
}
@media (prefers-reduced-motion: reduce) {
  .about-wow-hero::before,
  .about-wow-hero::after,
  .about-frame-card,
  .stud,
  .about-wow-hero .page-hero-eyebrow,
  .about-wow-hero .page-hero-title,
  .about-wow-hero .page-hero-body,
  .about-wow-content .content-body h2,
  .about-wow-content .content-body p,
  .about-wow-content .service-sidebar { animation: none !important; transform: none !important; filter: none !important; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   Premium framing hero animation
   ═══════════════════════════════════════════════════════════════════════════ */
.hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 76% 24%, oklch(64% 0.138 55 / .32), transparent 24rem),
    linear-gradient(135deg, oklch(10% .012 60), oklch(17% .014 62) 48%, oklch(24% .018 58));
}
.hero .container { display: grid; grid-template-columns: minmax(0, 1fr); gap: clamp(2rem, 5vw, 4rem); align-items: center; position: relative; z-index: 2; }
.hero::after, .hero-animated::after {
  content:""; position:absolute; inset:-40%; pointer-events:none; z-index:0;
  background-image: linear-gradient(oklch(100% 0 0 / .045) 1px, transparent 1px), linear-gradient(90deg, oklch(100% 0 0 / .035) 1px, transparent 1px), repeating-linear-gradient(-35deg, transparent 0 50px, oklch(64% .138 55 / .075) 50px 53px);
  background-size: 58px 58px, 58px 58px, 190px 190px;
  animation: blueprint-drift 26s linear infinite;
}
.hero-build-visual {
  position: relative; min-height: clamp(340px, 44vw, 520px); border: 1px solid oklch(100% 0 0 / .16); border-radius: 18px;
  background: linear-gradient(180deg, oklch(100% 0 0 / .10), oklch(100% 0 0 / .035));
  box-shadow: 0 34px 90px oklch(0% 0 0 / .36), inset 0 1px 0 oklch(100% 0 0 / .12);
  overflow: hidden; perspective: 1100px; transform-style: preserve-3d;
}
.hero-build-visual::before { content:""; position:absolute; inset:18px; border:1px solid oklch(64% .138 55 / .34); background: radial-gradient(circle at 50% 44%, oklch(64% .138 55 / .16), transparent 19rem); }
.hero-saw-blade { position:absolute; width:190px; height:190px; right:-42px; top:-42px; border-radius:50%; opacity:.22; background: conic-gradient(from 0deg, oklch(64% .138 55 / .95) 0 8deg, transparent 8deg 16deg); animation: spin-slow 18s linear infinite; filter: drop-shadow(0 0 24px oklch(64% .138 55 / .34)); }
.hero-frame-house { position:absolute; inset: 16% 11% 24%; transform: rotateX(58deg) rotateZ(-4deg); transform-origin:center bottom; animation: frame-tilt 6s ease-in-out infinite; }
.frame-roof,.frame-stud,.frame-beam { position:absolute; display:block; background: linear-gradient(90deg, oklch(64% .138 55), oklch(76% .14 67)); box-shadow: 0 0 22px oklch(64% .138 55 / .42); border-radius: 999px; }
.frame-roof { height:10px; width:55%; top:8%; }
.frame-roof-left { left:3%; transform:rotate(-28deg); transform-origin:right center; animation: draw-in 1.2s ease both .25s; }
.frame-roof-right { right:3%; transform:rotate(28deg); transform-origin:left center; animation: draw-in 1.2s ease both .45s; }
.frame-stud { width:9px; bottom:4%; top:28%; animation: stud-pop .65s cubic-bezier(.16,1,.3,1) both; }
.stud-a{left:16%;animation-delay:.65s}.stud-b{left:38%;animation-delay:.78s}.stud-c{left:61%;animation-delay:.91s}.stud-d{left:83%;animation-delay:1.04s}
.frame-beam { left:10%; right:10%; height:10px; animation: draw-in 1.1s ease both; }
.beam-top{top:30%;animation-delay:1.12s}.beam-bottom{bottom:4%;animation-delay:1.28s}
.hero-measure-card { position:absolute; left:24px; bottom:24px; padding:18px 20px; border:1px solid oklch(100% 0 0 / .18); border-radius:12px; background:oklch(10% .012 60 / .78); color:var(--color-white); backdrop-filter: blur(14px); box-shadow:0 18px 45px oklch(0% 0 0 / .28); animation: float-card 4.8s ease-in-out infinite; }
.hero-measure-card.second { left:auto; right:24px; bottom:102px; animation-delay:.7s; }
.hero-measure-card span { display:block; color:var(--color-accent); font-size:var(--text-xs); font-weight:800; letter-spacing:.14em; text-transform:uppercase; }
.hero-measure-card strong { display:block; margin-top:4px; font-family:var(--font-display); font-size:var(--text-2xl); text-transform:uppercase; line-height:1; }
.hero-animated { position:relative; overflow:hidden; isolation:isolate; }
.hero-animated > .container { position:relative; z-index:2; }
.hero-animated .page-hero-title, .hero-headline { text-shadow: 0 16px 44px oklch(0% 0 0 / .38); }
.content-body h2 { position:relative; padding-left:18px; }
.content-body h2::before { content:""; position:absolute; left:0; top:.2em; bottom:.18em; width:5px; background:linear-gradient(var(--color-accent), oklch(72% .14 65)); border-radius:999px; box-shadow:0 0 18px oklch(64% .138 55 / .32); }
.service-sidebar, .contact-form, .credential-item, .location-card, .service-card { box-shadow: 0 18px 46px oklch(12% .012 60 / .08); }
.service-sidebar:hover, .credential-item:hover { transform: translateY(-4px); box-shadow:0 22px 60px oklch(64% .138 55 / .12); border-color:var(--color-accent); }
.service-sidebar, .credential-item { transition: transform .25s var(--ease-out), box-shadow .25s var(--ease-out), border-color .25s var(--ease-out); }
@keyframes blueprint-drift { from{transform:translate3d(0,0,0)} to{transform:translate3d(90px,-90px,0)} }
@keyframes spin-slow { to{transform:rotate(360deg)} }
@keyframes frame-tilt { 0%,100%{transform:rotateX(58deg) rotateZ(-4deg) translateY(0)} 50%{transform:rotateX(54deg) rotateZ(-2deg) translateY(-8px)} }
@keyframes draw-in { from{clip-path:inset(0 100% 0 0); opacity:0} to{clip-path:inset(0 0 0 0); opacity:1} }
@keyframes stud-pop { from{transform:scaleY(0); transform-origin:bottom; opacity:0} to{transform:scaleY(1); transform-origin:bottom; opacity:1} }
@keyframes float-card { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
@media (min-width: 900px) { .hero .container { grid-template-columns: minmax(0, .95fr) minmax(340px, .85fr); } }
@media (max-width: 700px) { .hero-build-visual{min-height:330px}.hero-measure-card{left:14px;right:14px;bottom:14px}.hero-measure-card.second{left:14px;right:14px;bottom:88px}.hero-measure-card strong{font-size:var(--text-xl)} }
@media (prefers-reduced-motion: reduce) { .hero::after,.hero-animated::after,.hero-saw-blade,.hero-frame-house,.frame-roof,.frame-stud,.frame-beam,.hero-measure-card{animation:none!important} }

/* ═══════════════════════════════════════════════════════════════════════════
   Crawlable final hero upgrade: animated timber-frame hero system
   ═══════════════════════════════════════════════════════════════════════════ */
.hero,
.page-hero{
  position:relative;
  overflow:hidden;
  isolation:isolate;
  background:
    radial-gradient(circle at 78% 20%, oklch(64% 0.138 55 / .28), transparent 24rem),
    radial-gradient(circle at 8% 82%, oklch(64% 0.138 55 / .12), transparent 18rem),
    linear-gradient(135deg, oklch(10% .014 60), oklch(18% .016 62) 52%, oklch(24% .018 58));
}
.hero::before,
.page-hero::before{
  content:"";
  position:absolute;
  inset:-35%;
  z-index:-2;
  background-image:
    linear-gradient(oklch(100% 0 0 / .045) 1px, transparent 1px),
    linear-gradient(90deg, oklch(100% 0 0 / .035) 1px, transparent 1px),
    repeating-linear-gradient(-35deg, transparent 0 54px, oklch(64% .138 55 / .08) 54px 57px);
  background-size:56px 56px,56px 56px,190px 190px;
  animation:af-blueprint-drift 26s linear infinite;
  transform-origin:center;
}
.hero::after,
.page-hero::after{
  content:"";
  position:absolute;
  right:clamp(-9rem,-8vw,-3rem);
  bottom:clamp(-13rem,-12vw,-5rem);
  width:min(54vw,760px);
  aspect-ratio:1;
  z-index:-1;
  border-radius:50%;
  background:radial-gradient(circle, oklch(64% .138 55 / .22), transparent 62%);
  filter:blur(10px);
  animation:af-ember-breathe 5.2s ease-in-out infinite;
}
.hero-shell{display:grid;grid-template-columns:minmax(0,1fr) minmax(330px,.72fr);gap:clamp(2rem,6vw,5rem);align-items:center}
.hero-frame-stage{position:relative;min-height:420px;border:1px solid oklch(100% 0 0 / .16);border-radius:var(--radius-lg);background:linear-gradient(180deg,oklch(100% 0 0 / .10),oklch(100% 0 0 / .035));box-shadow:0 34px 90px oklch(0% 0 0 / .36);overflow:hidden;transform:perspective(950px) rotateY(-7deg) rotateX(3deg);animation:af-stage-enter .85s var(--ease-out) both .18s, af-stage-float 5.6s ease-in-out infinite 1.1s}
.stage-grid{position:absolute;inset:18px;background:linear-gradient(oklch(64% .138 55 / .16) 1px,transparent 1px),linear-gradient(90deg,oklch(64% .138 55 / .12) 1px,transparent 1px);background-size:36px 36px;border:1px solid oklch(64% .138 55 / .22);animation:af-grid-pulse 4.8s ease-in-out infinite}
.stage-stud,.stage-roof,.stage-beam{position:absolute;display:block;background:linear-gradient(90deg,oklch(76% .13 62),var(--color-accent));box-shadow:0 0 26px oklch(64% .138 55 / .36)}
.stage-stud{bottom:78px;width:12px;height:215px;transform-origin:bottom;animation:af-build-up .9s var(--ease-out) both}.s1{left:18%;animation-delay:.3s}.s2{left:34%;animation-delay:.42s}.s3{left:50%;animation-delay:.54s}.s4{left:66%;animation-delay:.66s}.s5{left:82%;animation-delay:.78s}.stage-roof{height:12px;width:47%;top:112px;transform-origin:left center;animation:af-draw-beam 1.2s var(--ease-out) both 1s}.r1{left:13%;transform:rotate(-27deg)}.r2{right:13%;transform:rotate(27deg);transform-origin:right center}.stage-beam{height:13px;left:13%;right:13%;animation:af-draw-beam 1.2s var(--ease-out) both}.stage-beam.floor{bottom:75px;animation-delay:.2s}.stage-beam.header{top:238px;animation-delay:.88s}.stage-spark{position:absolute;width:12px;height:12px;border-radius:50%;background:var(--color-accent);box-shadow:0 0 32px var(--color-accent);animation:af-spark 1.8s ease-in-out infinite}.sp1{left:30%;top:34%}.sp2{right:24%;top:55%;animation-delay:.65s}.stage-badge{position:absolute;left:24px;right:24px;bottom:22px;padding:18px 20px;border:1px solid oklch(100% 0 0 / .18);background:oklch(10% .014 60 / .82);backdrop-filter:blur(14px);box-shadow:0 18px 48px oklch(0% 0 0 / .28)}.stage-badge span{display:block;color:var(--color-accent);font-size:var(--text-xs);font-weight:800;letter-spacing:.14em;text-transform:uppercase}.stage-badge strong{display:block;margin-top:3px;color:var(--color-white);font-family:var(--font-display);font-size:clamp(1.35rem,3vw,2.25rem);line-height:1;text-transform:uppercase}.page-hero-title,.hero-headline{text-shadow:0 16px 52px oklch(0% 0 0 / .46)}.page-hero .container{position:relative;z-index:1}.content-body h2{position:relative}.content-body h2::after{content:"";display:block;width:64px;height:4px;margin-top:.45rem;background:linear-gradient(90deg,var(--color-accent),transparent);border-radius:999px}.service-sidebar,.credential-item,.content-body,.contact-form{box-shadow:0 18px 60px oklch(12% .012 60 / .08);transition:transform .28s var(--ease-out),box-shadow .28s var(--ease-out),border-color .28s var(--ease-out)}.service-sidebar:hover,.credential-item:hover,.contact-form:hover{transform:translateY(-5px);border-color:var(--color-accent);box-shadow:0 26px 76px oklch(64% .138 55 / .16)}
@keyframes af-blueprint-drift{from{transform:translate3d(0,0,0)}to{transform:translate3d(96px,-96px,0)}}
@keyframes af-ember-breathe{0%,100%{opacity:.65;transform:scale(.94)}50%{opacity:1;transform:scale(1.08)}}
@keyframes af-stage-enter{from{opacity:0;transform:perspective(950px) rotateY(-16deg) rotateX(8deg) translateY(28px)}to{opacity:1;transform:perspective(950px) rotateY(-7deg) rotateX(3deg) translateY(0)}}
@keyframes af-stage-float{0%,100%{translate:0 0}50%{translate:0 -12px}}
@keyframes af-build-up{from{transform:scaleY(0);opacity:0}to{transform:scaleY(1);opacity:1}}
@keyframes af-draw-beam{from{clip-path:inset(0 100% 0 0);opacity:.4}to{clip-path:inset(0 0 0 0);opacity:1}}
@keyframes af-grid-pulse{0%,100%{opacity:.55}50%{opacity:1}}
@keyframes af-spark{0%,100%{opacity:.15;transform:scale(.5)}45%{opacity:1;transform:scale(1.25)}}
@keyframes af-mobile-frame-stage{0%,9%{opacity:0;transform:translateY(18px) scale(.98)}16%,82%{opacity:1;transform:translateY(0) scale(1)}100%{opacity:0;transform:translateY(-8px) scale(.995)}}
@keyframes af-mobile-build-up{0%,18%{transform:scaleY(0);opacity:0}28%,82%{transform:scaleY(1);opacity:1}100%{transform:scaleY(1);opacity:0}}
@keyframes af-mobile-draw-beam{0%,24%{clip-path:inset(0 100% 0 0);opacity:0}36%,82%{clip-path:inset(0 0 0 0);opacity:1}100%{clip-path:inset(0 0 0 0);opacity:0}}
@keyframes af-mobile-spark{0%,22%,100%{opacity:0;transform:scale(.35)}42%{opacity:1;transform:scale(1.25)}62%{opacity:.35;transform:scale(.75)}}
@media(max-width:900px){.hero-shell{grid-template-columns:1fr}.hero-frame-stage{min-height:310px;transform:none;animation:af-stage-enter .7s var(--ease-out) both}.stage-stud{height:150px}.stage-roof{top:84px}.stage-beam.header{top:178px}.stage-badge{left:16px;right:16px;bottom:16px}.hero::before,.page-hero::before{animation-duration:42s}}
@media(max-width:700px){.hero-frame-stage{animation:af-mobile-frame-stage 6.4s var(--ease-out) infinite}.hero-frame-stage .stage-stud{bottom:76px;width:10px;height:138px;animation:af-mobile-build-up 6.4s var(--ease-out) infinite}.hero-frame-stage .stud-a{left:18%;animation-delay:.1s}.hero-frame-stage .stud-b{left:39%;animation-delay:.28s}.hero-frame-stage .stud-c{left:60%;animation-delay:.46s}.hero-frame-stage .stud-d{left:81%;animation-delay:.64s}.hero-frame-stage .stage-beam{left:14%;right:14%;height:11px;animation:af-mobile-draw-beam 6.4s var(--ease-out) infinite}.hero-frame-stage .beam-bottom{bottom:74px;animation-delay:0s}.hero-frame-stage .beam-top{top:178px;animation-delay:.72s}.hero-frame-stage .stage-roof{height:11px;width:46%;top:86px;animation:af-mobile-draw-beam 6.4s var(--ease-out) infinite}.hero-frame-stage .roof-a{left:13%;transform:rotate(-27deg);transform-origin:right center;animation-delay:1.02s}.hero-frame-stage .roof-b{right:13%;transform:rotate(27deg);transform-origin:left center;animation-delay:1.18s}.hero-frame-stage .stage-spark{animation:af-mobile-spark 2.4s ease-in-out infinite}.hero-frame-stage .spark-a{left:30%;top:34%;animation-delay:.2s}.hero-frame-stage .spark-b{right:24%;top:55%;animation-delay:1.05s}}
@media(prefers-reduced-motion:reduce){.hero::before,.page-hero::before,.hero::after,.page-hero::after,.hero-frame-stage,.stage-grid,.stage-stud,.stage-roof,.stage-beam,.stage-spark{animation:none!important}.hero-frame-stage{transform:none}}

/* About hero dead-space repair: keep the text together and fill the hero with the framing visual. */
.about-wow-hero .container{
  grid-template-areas:
    "eyebrow frame"
    "title frame"
    "body frame";
  grid-template-rows:auto auto auto;
}
.about-wow-hero .page-hero-eyebrow{grid-area:eyebrow;align-self:end;margin-bottom:0}
.about-wow-hero .page-hero-title{grid-area:title;align-self:center;margin-block:.4rem .6rem}
.about-wow-hero .page-hero-body{grid-area:body;align-self:start;margin-top:0;max-width:44rem}
.about-wow-hero .about-frame-card{grid-area:frame;align-self:stretch;min-height:clamp(360px,42vw,520px)}
.about-wow-hero .page-hero-eyebrow::after{
  content:"";
  display:block;
  width:min(220px,42vw);
  height:3px;
  margin-top:14px;
  background:linear-gradient(90deg,var(--color-accent),transparent);
  border-radius:999px;
}
@media (max-width:900px){
  .about-wow-hero .container{grid-template-areas:"eyebrow" "title" "body" "frame";grid-template-columns:1fr;gap:1.15rem}
  .about-wow-hero .about-frame-card{min-height:320px;margin-top:.5rem}
}
@media (max-width:560px){
  .about-wow-hero .about-frame-card{min-height:280px}
}

/* About hero title repair: keep REPUTATION readable instead of breaking into single letters. */
.about-wow-hero .page-hero-title{
  max-width: 13ch;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
  line-height: .9;
}
.about-wow-hero .page-hero-title .title-line{
  display: block;
  white-space: nowrap;
}
@media (max-width: 900px){
  .about-wow-hero .page-hero-title{max-width: 100%; font-size: clamp(3.2rem, 13vw, 6.2rem);}
}
@media (max-width: 560px){
  .about-wow-hero .page-hero-title{font-size: clamp(2.65rem, 14vw, 4.4rem); letter-spacing: -.025em;}
}


/* ═══════════════════════════════════════════════════════════════════════════
   Photo proof band: cinematic jobsite imagery + premium hover motion
   ═══════════════════════════════════════════════════════════════════════════ */
.photo-proof-band{
  position:relative;
  padding-block:clamp(3rem,7vw,6rem);
  background:linear-gradient(180deg,var(--color-surface-dark) 0%, var(--color-paper) 100%);
  overflow:hidden;
}
.photo-proof-band::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 0%,oklch(64% .138 55 / .22),transparent 28rem);pointer-events:none}
.photo-proof-inner{position:relative;display:grid;grid-template-columns:minmax(0,1.35fr) minmax(260px,.65fr);gap:clamp(1rem,3vw,2rem);align-items:stretch}
.proof-photo{position:relative;min-height:260px;border-radius:22px;overflow:hidden;border:1px solid oklch(100% 0 0 / .16);box-shadow:0 32px 90px oklch(0% 0 0 / .28);background:var(--color-ink);isolation:isolate;transform:translateZ(0);transition:transform .45s var(--ease-out),box-shadow .45s var(--ease-out)}
.proof-photo:hover{transform:translateY(-8px) scale(1.012);box-shadow:0 42px 120px oklch(0% 0 0 / .38)}
.proof-photo img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;filter:saturate(1.08) contrast(1.04);transition:transform .8s var(--ease-out),filter .45s var(--ease-out)}
.proof-photo:hover img{transform:scale(1.07);filter:saturate(1.18) contrast(1.08)}
.proof-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,oklch(8% .012 60 / .82));z-index:1}
.proof-photo figcaption{position:absolute;left:24px;right:24px;bottom:22px;z-index:2;color:var(--color-white);font-family:var(--font-display);font-weight:800;font-size:clamp(1.45rem,3vw,2.6rem);line-height:.98;text-transform:uppercase;text-shadow:0 10px 32px oklch(0% 0 0 / .5)}
.proof-photo figcaption span{display:block;margin-bottom:8px;color:var(--color-accent);font-family:var(--font-body);font-size:var(--text-xs);letter-spacing:.16em;text-transform:uppercase}
.proof-photo-stack{display:grid;gap:clamp(1rem,3vw,2rem)}
.proof-photo-stack .proof-photo{min-height:220px}
.proof-photo-stack .proof-photo figcaption{font-size:clamp(1.2rem,2.3vw,1.8rem)}
.service-card-photo{height:170px;margin:calc(var(--space-8) * -1) calc(var(--space-6) * -1) var(--space-6);overflow:hidden;border-bottom:1px solid var(--color-border)}
.service-card-photo img{width:100%;height:100%;object-fit:cover;transition:transform .65s var(--ease-out),filter .35s var(--ease-out);filter:saturate(1.05) contrast(1.03)}
.service-card:hover .service-card-photo img{transform:scale(1.08);filter:saturate(1.18) contrast(1.08)}
@media(max-width:820px){.photo-proof-inner{grid-template-columns:1fr}.proof-photo-main{min-height:360px}.proof-photo-stack{grid-template-columns:1fr 1fr}.proof-photo-stack .proof-photo{min-height:190px}}
@media(max-width:560px){.proof-photo-stack{grid-template-columns:1fr}.proof-photo-main{min-height:320px}.proof-photo figcaption{left:18px;right:18px;bottom:18px}.service-card-photo{height:190px}}
@media(prefers-reduced-motion:reduce){.proof-photo,.proof-photo img,.service-card-photo img{transition:none!important}.proof-photo:hover{transform:none}.proof-photo:hover img,.service-card:hover .service-card-photo img{transform:none}}


/* Service/detail page photography polish */
.service-page-photo,
.about-story-photo{
  margin: var(--space-8) 0 var(--space-10);
  border-radius: var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--color-border);
  box-shadow:0 24px 70px oklch(12% .012 60 / .16);
  background:var(--color-white);
}
.service-page-photo img,
.about-story-photo img{
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
  transform:scale(1.01);
  transition:transform .6s var(--ease-out), filter .6s var(--ease-out);
}
.service-page-photo:hover img,
.about-story-photo:hover img{transform:scale(1.055);filter:saturate(1.12) contrast(1.05)}
.about-story-photo figcaption{padding:var(--space-4) var(--space-5);font-size:var(--text-sm);font-weight:600;color:var(--color-ink-2);background:var(--color-white);border-top:1px solid var(--color-border)}
@media(prefers-reduced-motion:reduce){.service-page-photo img,.about-story-photo img{transition:none!important;transform:none!important}}

/* ─── Coverage section wow factor overrides ───────────────────────────── */
.section-coverage {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 20%, color-mix(in srgb, var(--color-accent) 16%, transparent), transparent 28rem),
    radial-gradient(circle at 82% 18%, color-mix(in srgb, var(--color-paper-2) 72%, transparent), transparent 26rem),
    linear-gradient(180deg, var(--color-paper) 0%, var(--color-paper-2) 100%);
  color: var(--color-ink);
}
.section-coverage::before,
.section-coverage::after {
  content: "";
  position: absolute;
  pointer-events: none;
}
.section-coverage::before {
  inset: 0;
  opacity: 0.55;
  background-image:
    linear-gradient(30deg, transparent 0 46%, color-mix(in srgb, var(--color-border) 52%, transparent) 47% 48%, transparent 49% 100%),
    linear-gradient(150deg, transparent 0 46%, color-mix(in srgb, var(--color-border) 42%, transparent) 47% 48%, transparent 49% 100%);
  background-size: 6.5rem 6.5rem;
}
.section-coverage::after {
  right: -8rem;
  bottom: -10rem;
  width: 28rem;
  height: 28rem;
  border: var(--rule-hairline) solid var(--color-border);
  border-radius: 50%;
  box-shadow: 0 0 0 4rem color-mix(in srgb, var(--color-white) 55%, transparent), 0 0 0 8rem color-mix(in srgb, var(--color-paper-2) 55%, transparent);
}
.coverage-glow {
  position: absolute;
  inset: auto auto 8% 7%;
  width: min(36vw, 28rem);
  height: min(36vw, 28rem);
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--color-accent) 18%, transparent), transparent 66%);
  filter: blur(10px);
  pointer-events: none;
}
.coverage-shell {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(17rem, 0.9fr) minmax(0, 1.25fr);
  align-items: center;
  gap: clamp(2rem, 6vw, 5rem);
}
.coverage-content { min-width: 0; }
.coverage-header { text-align: left; margin-inline: 0; }
.coverage-header .section-label { color: var(--color-accent); }
.coverage-header .section-heading {
  color: var(--color-ink);
  max-width: 12ch;
  text-shadow: none;
}
.coverage-header .section-body { color: var(--color-ink-2); max-width: 58ch; font-size: clamp(1.12rem, 1.6vw, 1.35rem); line-height: 1.65; }
.coverage-map-card {
  position: relative;
  min-height: clamp(26rem, 45vw, 36rem);
  border: var(--rule-hairline) solid var(--color-border);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, var(--color-white), var(--color-paper)),
    radial-gradient(circle at center, color-mix(in srgb, var(--color-accent) 10%, transparent), transparent 58%);
  box-shadow: var(--shadow-lg), inset 0 1px 0 var(--color-white);
  overflow: hidden;
}
.coverage-map-card::before {
  content: "SERVICE RADIUS";
  position: absolute;
  top: 1.2rem;
  left: 1.2rem;
  z-index: 2;
  font-family: var(--font-display);
  font-size: clamp(0.95rem, 1.2vw, 1.08rem);
  font-weight: 800;
  letter-spacing: 0.12em;
  color: var(--color-ink-muted);
}
.coverage-map-art {
  position: absolute;
  inset: 2.5rem 1.25rem 7rem;
  border-radius: 50%;
}
.map-ring,
.map-pathline,
.map-pin { position: absolute; display: block; }
.map-ring {
  inset: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  border: var(--rule-hairline) solid var(--color-border);
}
.map-ring-outer { width: 92%; height: 92%; border-color: color-mix(in srgb, var(--color-accent) 58%, var(--color-border)); box-shadow: 0 0 2.5rem color-mix(in srgb, var(--color-accent) 14%, transparent); }
.map-ring-middle { width: 66%; height: 66%; }
.map-ring-inner { width: 36%; height: 36%; border-color: var(--color-border-dark); }
.map-pathline {
  left: 50%;
  top: 50%;
  width: 38%;
  height: 2px;
  transform-origin: left center;
  background: linear-gradient(90deg, var(--color-accent), transparent);
}
.pathline-ok { transform: rotate(-18deg); }
.pathline-ar { transform: rotate(34deg); }
.pathline-mo { transform: rotate(-145deg); }
.map-pin {
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 3.45rem;
  min-height: 3.45rem;
  padding: 0.75rem 0.95rem;
  border-radius: 999px;
  background: var(--color-white);
  color: var(--color-ink);
  font-family: var(--font-display);
  font-weight: 800;
  border: var(--rule-hairline) solid var(--color-border);
  box-shadow: var(--shadow-md);
}
.pin-home {
  left: 50%;
  top: 50%;
  flex-direction: column;
  min-width: 7.25rem;
  min-height: 7.25rem;
  transform: translate(-50%, -50%);
  background: var(--color-accent);
  color: var(--color-accent-fg);
  border-color: var(--color-accent);
  text-align: center;
}
.pin-home strong { font-size: clamp(1.45rem, 2.3vw, 2rem); line-height: 1; }
.pin-home em { margin-top: 0.3rem; font-family: var(--font-body); font-size: clamp(0.78rem, 1vw, 0.92rem); font-style: normal; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; }
.pin-ok { right: 12%; top: 35%; }
.pin-ar { right: 18%; bottom: 21%; }
.pin-mo { left: 13%; top: 31%; }
.coverage-map-stats {
  position: absolute;
  left: 1.25rem;
  right: 1.25rem;
  bottom: 1.25rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
}
.coverage-map-stats div {
  padding: 1rem 0.75rem;
  border-radius: var(--radius-md);
  background: var(--color-paper-2);
  border: var(--rule-hairline) solid var(--color-border);
  text-align: center;
}
.coverage-map-stats strong {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 4vw, 3rem);
  line-height: 1;
  color: var(--color-accent);
}
.coverage-map-stats span {
  display: block;
  margin-top: 0.3rem;
  font-size: clamp(0.82rem, 1.05vw, 0.95rem);
  font-weight: 800;
  letter-spacing: 0.06em;
  color: var(--color-ink-2);
  text-transform: uppercase;
}
.coverage-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-8);
  margin-bottom: var(--space-8);
}
.coverage-region {
  padding: clamp(1.35rem, 3vw, 1.85rem);
  border-radius: var(--radius-md);
  background: var(--color-white);
  border: var(--rule-hairline) solid var(--color-border);
  box-shadow: var(--shadow-sm);
}
.coverage-region-featured { grid-row: span 2; background: var(--color-white); }
.coverage-region-topline {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-3);
  color: var(--color-ink-muted);
  font-size: clamp(0.86rem, 1.1vw, 1rem);
  font-weight: 800;
  letter-spacing: 0.09em;
  text-transform: uppercase;
}
.coverage-region-topline strong { color: var(--color-accent); }
.coverage-region .coverage-state-title {
  color: var(--color-ink);
  border-color: var(--color-accent);
}
.coverage-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}
.coverage-chip-list li + li { margin-top: 0; }
.coverage-chip-list a {
  display: inline-flex;
  align-items: center;
  min-height: 2.75rem;
  padding: 0.62rem 1rem;
  border: var(--rule-hairline) solid var(--color-border);
  border-radius: 999px;
  background: var(--color-paper-2);
  color: var(--color-ink);
  font-size: clamp(1rem, 1.2vw, 1.12rem);
  font-weight: 800;
}
.coverage-chip-list a:hover {
  color: var(--color-accent-fg);
  background: var(--color-accent);
  border-color: var(--color-accent);
  transform: translateY(-1px);
}
.coverage-cta {
  padding-top: var(--space-2);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-6);
}
.section-coverage .coverage-note { color: var(--color-ink-2); max-width: 42rem; font-size: clamp(1rem, 1.25vw, 1.12rem); line-height: 1.6; }
.section-coverage .coverage-note a { color: var(--color-accent); }
.section-coverage .coverage-note a:hover { color: var(--color-accent-hover); }
@media (max-width: 900px) {
  .coverage-shell { grid-template-columns: 1fr; }
  .coverage-map-card { min-height: 30rem; order: 2; }
  .coverage-content { order: 1; }
  .coverage-header .section-heading { max-width: 13ch; }
}
@media (max-width: 640px) {
  .coverage-card-grid { grid-template-columns: 1fr; }
  .coverage-region-featured { grid-row: auto; }
  .coverage-map-card { min-height: 28rem; }
  .coverage-map-stats { grid-template-columns: 1fr; }
  .coverage-map-art { bottom: 12rem; }
  .pin-home { min-width: 6.75rem; min-height: 6.75rem; }
  .coverage-chip-list a { width: 100%; justify-content: center; }
}



/* Service and service-area hero motion polish — clean blueprint/framing treatment */
.service-hero-motion,
.area-hero-motion {
  min-height: clamp(18rem, 34vw, 28rem);
}
.service-hero-motion .page-hero-eyebrow,
.area-hero-motion .page-hero-eyebrow,
.service-hero-motion .page-hero-title,
.area-hero-motion .page-hero-title,
.service-hero-motion .page-hero-body,
.area-hero-motion .page-hero-body {
  animation: af-hero-copy-rise .72s var(--ease-out) both;
}
.service-hero-motion .page-hero-title,
.area-hero-motion .page-hero-title { animation-delay: .06s; }
.service-hero-motion .page-hero-body,
.area-hero-motion .page-hero-body { animation-delay: .14s; }
.service-hero-motion::before,
.area-hero-motion::before { animation-duration: 34s; opacity: .72; }
.service-hero-motion::after,
.area-hero-motion::after { animation-duration: 7s; opacity: .72; }
.service-hero-motion .container::before,
.area-hero-motion .container::before,
.service-hero-motion .container::after,
.area-hero-motion .container::after {
  content: "";
  position: absolute;
  pointer-events: none;
  z-index: -1;
}

/* Services: subtle roofline + studs, like a framing elevation drawing. */
.service-hero-motion .container::before {
  right: clamp(.5rem, 4vw, 3rem);
  top: 50%;
  width: min(34vw, 24rem);
  height: min(20vw, 14rem);
  opacity: .42;
  transform: translateY(-42%);
  background:
    linear-gradient(26deg, transparent 0 49%, var(--color-accent) 49.5% 51%, transparent 51.5% 100%),
    linear-gradient(-26deg, transparent 0 49%, var(--color-accent) 49.5% 51%, transparent 51.5% 100%),
    linear-gradient(90deg, transparent 0 10%, oklch(100% 0 0 / .22) 10% 11%, transparent 11% 28%, oklch(100% 0 0 / .22) 28% 29%, transparent 29% 47%, oklch(100% 0 0 / .22) 47% 48%, transparent 48% 66%, oklch(100% 0 0 / .22) 66% 67%, transparent 67% 86%, oklch(100% 0 0 / .22) 86% 87%, transparent 87%),
    linear-gradient(0deg, transparent 0 74%, oklch(100% 0 0 / .18) 74% 76%, transparent 76% 100%);
  filter: drop-shadow(0 1.2rem 2.4rem oklch(0% 0 0 / .18));
  clip-path: polygon(0 100%, 0 40%, 50% 0, 100% 40%, 100% 100%);
  animation: af-blueprint-settle 8s ease-in-out infinite;
}
.service-hero-motion .container::after {
  right: clamp(.5rem, 4vw, 3rem);
  top: 50%;
  width: min(34vw, 24rem);
  height: min(20vw, 14rem);
  opacity: .36;
  transform: translateY(-42%);
  background:
    linear-gradient(0deg, transparent 0 88%, var(--color-accent) 88% 91%, transparent 91% 100%),
    linear-gradient(90deg, transparent 0 5%, var(--color-accent) 5% 6.5%, transparent 6.5% 93.5%, var(--color-accent) 93.5% 95%, transparent 95%);
  clip-path: polygon(0 100%, 0 40%, 50% 0, 100% 40%, 100% 100%);
  animation: af-line-draw-soft 3.8s var(--ease-out) infinite;
}

/* Service areas: measured service radius, not a radar or random graphic. */
.area-hero-motion .container::before {
  right: clamp(.75rem, 5vw, 4rem);
  top: 50%;
  width: min(28vw, 20rem);
  aspect-ratio: 1;
  opacity: .44;
  transform: translateY(-50%);
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, var(--color-accent) 0 .42rem, transparent .46rem),
    radial-gradient(circle at 22% 38%, oklch(100% 0 0 / .55) 0 .28rem, transparent .32rem),
    radial-gradient(circle at 74% 32%, oklch(100% 0 0 / .48) 0 .26rem, transparent .3rem),
    radial-gradient(circle at 70% 72%, oklch(100% 0 0 / .42) 0 .24rem, transparent .28rem),
    radial-gradient(circle, transparent 0 32%, oklch(100% 0 0 / .16) 32.5% 33.5%, transparent 34% 58%, oklch(100% 0 0 / .12) 58.5% 59.5%, transparent 60%),
    linear-gradient(90deg, transparent 0 49.4%, oklch(100% 0 0 / .15) 49.4% 50.6%, transparent 50.6%),
    linear-gradient(0deg, transparent 0 49.4%, oklch(100% 0 0 / .15) 49.4% 50.6%, transparent 50.6%);
  filter: drop-shadow(0 1.2rem 2.4rem oklch(0% 0 0 / .16));
  animation: af-radius-breathe 7s ease-in-out infinite;
}
.area-hero-motion .container::after {
  right: clamp(.75rem, 5vw, 4rem);
  top: 50%;
  width: min(28vw, 20rem);
  aspect-ratio: 1;
  opacity: .36;
  transform: translateY(-50%);
  border-radius: 50%;
  background:
    conic-gradient(from -35deg, transparent 0 18deg, var(--color-accent) 18deg 20deg, transparent 20deg 360deg);
  animation: af-radius-sweep 9s linear infinite;
}
.service-hero-motion .page-hero-title::after,
.area-hero-motion .page-hero-title::after {
  content: "";
  display: block;
  width: clamp(5rem, 18vw, 13rem);
  height: 4px;
  margin-top: var(--space-4);
  border-radius: 999px;
  background: linear-gradient(90deg, var(--color-accent), transparent);
  animation: af-hero-rule-draw .9s var(--ease-out) both .28s;
}
@keyframes af-hero-copy-rise {
  from { opacity: 0; transform: translateY(18px); filter: blur(5px); }
  to { opacity: 1; transform: translateY(0); filter: blur(0); }
}
@keyframes af-hero-rule-draw {
  from { clip-path: inset(0 100% 0 0); opacity: .25; }
  to { clip-path: inset(0 0 0 0); opacity: 1; }
}
@keyframes af-blueprint-settle {
  0%, 100% { transform: translateY(-42%) translateX(0); opacity: .36; }
  50% { transform: translateY(-45%) translateX(-4px); opacity: .5; }
}
@keyframes af-line-draw-soft {
  0%, 100% { clip-path: polygon(0 100%, 0 40%, 50% 0, 100% 40%, 100% 100%); opacity: .22; }
  50% { clip-path: polygon(0 100%, 0 40%, 50% 0, 100% 40%, 100% 100%); opacity: .46; }
}
@keyframes af-radius-breathe {
  0%, 100% { transform: translateY(-50%) scale(.985); opacity: .34; }
  50% { transform: translateY(-50%) scale(1.02); opacity: .5; }
}
@keyframes af-radius-sweep {
  from { transform: translateY(-50%) rotate(0deg); opacity: .22; }
  50% { opacity: .42; }
  to { transform: translateY(-50%) rotate(360deg); opacity: .22; }
}
@media (max-width: 760px) {
  .service-hero-motion .container::before,
  .service-hero-motion .container::after { opacity: .18; right: -3rem; width: 16rem; height: 10rem; }
  .area-hero-motion .container::before,
  .area-hero-motion .container::after { opacity: .18; right: -2.6rem; width: 13rem; }
}
@media (prefers-reduced-motion: reduce) {
  .service-hero-motion .page-hero-eyebrow,
  .area-hero-motion .page-hero-eyebrow,
  .service-hero-motion .page-hero-title,
  .area-hero-motion .page-hero-title,
  .service-hero-motion .page-hero-body,
  .area-hero-motion .page-hero-body,
  .service-hero-motion .container::before,
  .area-hero-motion .container::before,
  .service-hero-motion .container::after,
  .area-hero-motion .container::after,
  .service-hero-motion .page-hero-title::after,
  .area-hero-motion .page-hero-title::after { animation: none !important; filter: none; }
}
