/* Capitol Facility Services — global styles
   Palette: warm neutral + navy + red (from logo)
   Type: Satoshi (body), General Sans (display) via Fontshare
*/

/* -------- design tokens -------- */
:root {
  /* brand */
  --navy:        #0f315a;
  --navy-deep:   #071c3a;
  --navy-soft:   #2b4e72;
  --red:         #9d443d;
  --red-deep:    #73302c;
  --brick-soft:  #6e5654;
  --concrete:    #d9e2e8;
  --steel:       #566572;

  /* light surfaces */
  --bg:          #e9eef2;     /* dusty blue */
  --surface:     #fbfbf5;
  --surface-alt: #d9e2e8;
  --border:      #bdc9d1;
  --border-strong:#95a7b2;

  /* text */
  --text:        #121826;
  --text-muted:  #566572;
  --text-faint:  #95a7b2;

  /* accents */
  --primary:        var(--navy);
  --primary-hover:  var(--navy-deep);
  --accent:         var(--red);
  --accent-hover:   var(--red-deep);
  --gold:           #786d60;

  /* radii / shadow */
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 14px;
  --r-xl: 22px;
  --shadow-sm: 0 1px 2px rgba(15,20,35,0.05), 0 1px 1px rgba(15,20,35,0.04);
  --shadow-md: 0 6px 18px -8px rgba(15,20,35,0.18), 0 2px 4px rgba(15,20,35,0.05);
  --shadow-lg: 0 24px 60px -20px rgba(15,20,35,0.25);

  /* type scale */
  --fs-xs:   12px;
  --fs-sm:   14px;
  --fs-base: 16px;
  --fs-md:   18px;
  --fs-lg:   20px;
  --fs-xl:   24px;
  --fs-2xl:  32px;
  --fs-3xl:  44px;
  --fs-4xl:  60px;
  --fs-hero: clamp(38px, 6vw, 76px);

  /* spacing */
  --sp-1: 4px;  --sp-2: 8px; --sp-3: 12px; --sp-4: 16px;
  --sp-5: 24px; --sp-6: 32px; --sp-7: 48px; --sp-8: 64px;
  --sp-9: 96px; --sp-10:128px;

  --max-w: 1200px;
  --max-narrow: 880px;

  --t-fast: 120ms ease;
  --t-base: 220ms cubic-bezier(.2,.7,.2,1);
}

/* dark mode */
:root[data-theme="dark"] {
  --bg:          #111a24;
  --surface:     #1a2632;
  --surface-alt: #253340;
  --border:      #3d4f5d;
  --border-strong:#5a7080;

  --text:        #edf2f3;
  --text-muted:  #b7c3c9;
  --text-faint:  #5a7080;

  --navy:        #203d66;
  --navy-deep:   #102641;
  --navy-soft:   #2b4d78;
  --red:         #d06e66;
  --red-deep:    #a9534c;

  --primary:        #f0eee7;
  --primary-hover:  #ffffff;
  --accent:         #d06e66;
  --accent-hover:   #a9534c;

  --shadow-sm: 0 1px 2px rgba(0,0,0,0.4);
  --shadow-md: 0 8px 24px -10px rgba(0,0,0,0.5);
  --shadow-lg: 0 26px 64px -20px rgba(0,0,0,0.6);
}

/* -------- reset -------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Satoshi', 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  font-size: var(--fs-base);
  line-height: 1.6;
  color: var(--text);
  background:
    radial-gradient(circle at 10% 4%, color-mix(in srgb, var(--navy) 8%, transparent), transparent 34rem),
    radial-gradient(circle at 90% 12%, color-mix(in srgb, var(--accent) 7%, transparent), transparent 30rem),
    linear-gradient(180deg, var(--surface) 0%, var(--bg) 34%, var(--surface-alt) 100%);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
:root[data-theme="dark"] body {
  background:
    radial-gradient(circle at 10% 4%, color-mix(in srgb, var(--navy) 14%, transparent), transparent 34rem),
    radial-gradient(circle at 90% 12%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 30rem),
    linear-gradient(180deg, #111a24 0%, var(--bg) 34%, #111a24 100%);
}

img, svg { display: block; max-width: 100%; height: auto; }

a {
  color: var(--primary);
  text-decoration: none;
  transition: color var(--t-fast);
}
a:hover { color: var(--accent); }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: 4px;
}

h1, h2, h3, h4, h5 {
  font-family: 'General Sans', 'Satoshi', 'Inter', system-ui, sans-serif;
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--text);
  margin: 0 0 var(--sp-4);
}
h1 { font-size: var(--fs-hero); font-weight: 600; letter-spacing: -0.025em; line-height: 1.05; }
h2 { font-size: var(--fs-3xl); letter-spacing: -0.02em; }
h3 { font-size: var(--fs-xl); }
h4 { font-size: var(--fs-md); }
p { margin: 0 0 var(--sp-4); }

::selection { background: var(--accent); color: #fff; }

/* -------- layout -------- */
.container {
  width: 100%;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--sp-5);
}
.narrow { max-width: var(--max-narrow); margin-inline: auto; }
.section { padding: 30px 0; }
.section + .section { padding-top: 10px; }
.section--tight { padding: 24px 0; }
.section:has(.standards) { padding-bottom: 16px; }
.section:has(.standards) + .section { padding-top: 0; }

.eyebrow {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--accent);
  font-weight: 600;
  margin-bottom: var(--sp-3);
}

.lede { font-size: var(--fs-md); color: var(--text-muted); max-width: 60ch; }

/* -------- buttons -------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 14px 22px;
  border-radius: var(--r-md);
  font-weight: 600;
  font-size: var(--fs-sm);
  letter-spacing: 0.01em;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background var(--t-base), border-color var(--t-base), color var(--t-base), transform var(--t-fast);
  text-decoration: none;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); }
.btn--primary { background: var(--primary); color: #fff; }
.btn--primary:hover { background: var(--primary-hover); color: #fff; }
:root[data-theme="dark"] .btn--primary, :root[data-theme="dark"] .btn--primary:hover {
  color: #101716;
}
.btn--ghost {
  background: transparent;
  color: var(--text);
  border-color: var(--border-strong);
}
.btn--ghost:hover { border-color: var(--accent); color: var(--accent); }
.btn--accent { background: var(--accent); color: #fff; }
.btn--accent:hover { background: var(--accent-hover); color: #fff; }
.btn--sm { padding: 10px 16px; font-size: var(--fs-xs); }

/* -------- header / nav -------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 60;
  background: color-mix(in srgb, var(--bg) 88%, transparent);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
}
.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-5);
  padding: 10px 0;
}
.brand {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-family: 'General Sans', sans-serif;
  font-weight: 600;
  font-size: 19px;
  letter-spacing: -0.005em;
  color: var(--text);
}
.brand:hover { color: var(--text); }
.brand-logo {
  width: 108px;
  height: 108px;
  border-radius: 50%;
  background: #fff;
  padding: 2px;
  box-shadow: 0 0 0 1px var(--border) inset, 0 2px 6px rgba(0,0,0,0.08);
}
:root[data-theme="dark"] .brand-logo { background: #fff; }
.brand-name { display: flex; flex-direction: column; line-height: 1.1; }
.brand-name strong { font-weight: 600; }

.nav-links {
  display: flex;
  align-items: center;
  gap: 26px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav-links a {
  color: var(--text-muted);
  font-size: 15.5px;
  font-weight: 650;
  padding: 6px 0;
  position: relative;
  transition: color var(--t-fast);
}
.nav-links a:hover { color: var(--text); }
.nav-links a.active { color: var(--text); }
.nav-links a.active::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  height: 2px;
  background: var(--accent);
  border-radius: 2px;
}
.nav-actions { display: flex; align-items: center; gap: var(--sp-3); }

.theme-toggle {
  background: transparent;
  border: 1px solid var(--border-strong);
  width: 38px; height: 38px;
  border-radius: var(--r-md);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--text-muted);
  cursor: pointer;
  transition: color var(--t-fast), border-color var(--t-fast), background var(--t-fast);
}
.theme-toggle:hover { color: var(--accent); border-color: var(--accent); }
.theme-toggle svg { width: 18px; height: 18px; }
.theme-toggle .icon-sun { display: none; }
:root[data-theme="dark"] .theme-toggle .icon-sun { display: block; }
:root[data-theme="dark"] .theme-toggle .icon-moon { display: none; }
.nav-toggle {
  display: none;
  background: transparent;
  border: 1px solid var(--border-strong);
  width: 38px; height: 38px;
  border-radius: var(--r-md);
  color: var(--text);
  cursor: pointer;
}
.nav-toggle svg { width: 20px; height: 20px; }

/* mobile nav */
@media (max-width: 880px) {
  .nav-links {
    position: fixed;
    top: 116px;
    left: 0;
    right: 0;
    width: 100%;
    height: calc(100vh - 116px);
    background: var(--bg);
    flex-direction: column;
    align-items: flex-start;
    padding: var(--sp-6) var(--sp-5);
    gap: var(--sp-4);
    border-top: 1px solid var(--border);
    transform: translateY(-110%);
    transition: transform var(--t-base);
    z-index: 50;
    visibility: hidden;
    overflow-y: auto;
  }
  .nav-links.open { transform: translateY(0); visibility: visible; }
  .nav-links a { font-size: var(--fs-lg); }
  .nav-toggle { display: inline-flex; align-items: center; justify-content: center; }
  .nav-actions .btn { display: none; }
  .brand-name { font-size: var(--fs-sm); }
  .brand-logo { width: 84px; height: 84px; }
}

/* -------- hero -------- */
.hero {
  position: relative;
  overflow: hidden;
  padding: 80px 0;
  background:
    radial-gradient(circle at 12% 22%, color-mix(in srgb, var(--brick-soft) 10%, transparent) 0 18%, transparent 36%),
    radial-gradient(circle at 92% 8%, color-mix(in srgb, var(--primary) 10%, transparent) 0 18%, transparent 38%),
    radial-gradient(circle at 72% 78%, color-mix(in srgb, var(--concrete) 22%, transparent) 0 15%, transparent 34%),
    linear-gradient(180deg, color-mix(in srgb, var(--surface-alt) 55%, transparent), transparent 62%);
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: var(--sp-8);
  align-items: center;
}
.hero h1 { margin-bottom: var(--sp-5); }
.hero p.lede { font-size: var(--fs-lg); color: var(--text-muted); max-width: 56ch; }
.hero-actions {
  display: flex; gap: var(--sp-3);
  margin-top: var(--sp-6);
  flex-wrap: wrap;
  align-items: flex-start;
}
.start-split {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 148px;
  min-height: 52px;
  transition: min-height var(--t-base);
  isolation: isolate;
}
.start-main {
  position: relative;
  z-index: 2;
  transform-origin: center;
  transition: opacity var(--t-base), transform var(--t-base), background var(--t-base), color var(--t-base);
}
.start-options {
  position: absolute;
  left: 50%;
  top: 70px;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  width: 318px;
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, -18px) scale(.72);
  transform-origin: center top;
  transition: opacity var(--t-base), transform var(--t-base);
}
.start-options::before,
.start-options::after {
  content: "";
  position: absolute;
  top: -24px;
  width: 82px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border-strong), transparent);
  opacity: 0;
  transition: opacity var(--t-base), transform var(--t-base);
  pointer-events: none;
}
.start-options::before {
  left: 68px;
  transform: rotate(-20deg) scaleX(.7);
}
.start-options::after {
  right: 68px;
  transform: rotate(20deg) scaleX(.7);
}
.start-split:hover,
.start-split:focus-within {
  width: 148px;
  min-height: 122px;
}
.start-split:hover .start-main,
.start-split:focus-within .start-main {
  opacity: .34;
  transform: scale(.96);
  background: color-mix(in srgb, var(--primary) 24%, transparent);
  border-color: color-mix(in srgb, var(--primary) 35%, transparent);
  color: var(--text);
}
.start-split:hover .start-options,
.start-split:focus-within .start-options {
  opacity: 1;
  transform: translate(-50%, 0) scale(1);
  pointer-events: auto;
}
.start-split:hover .start-options::before,
.start-split:hover .start-options::after,
.start-split:focus-within .start-options::before,
.start-split:focus-within .start-options::after {
  opacity: 1;
}
.start-split:hover .start-options::before,
.start-split:focus-within .start-options::before {
  transform: rotate(-20deg) scaleX(1);
}
.start-split:hover .start-options::after,
.start-split:focus-within .start-options::after {
  transform: rotate(20deg) scaleX(1);
}
.hero-visual {
  position: relative;
  border-radius: var(--r-xl);
  overflow: hidden;
  aspect-ratio: 4/5;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border);
}
.hero-visual img { width: 100%; height: 100%; object-fit: cover; }
.hero-visual::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(20,37,74,0) 30%, rgba(20,37,74,0.45) 100%);
  pointer-events: none;
}
.hero-badge {
  position: absolute;
  bottom: var(--sp-5); left: var(--sp-5);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 12px 16px;
  display: flex; align-items: center; gap: 10px;
  box-shadow: var(--shadow-md);
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--text);
}
.hero-badge .dot { width: 8px; height: 8px; border-radius: 50%; background: #2ea84a; box-shadow: 0 0 0 4px rgba(46,168,74,0.15); }
@media (max-width: 880px) {
  .hero { padding: var(--sp-7) 0; }
  .hero-grid { grid-template-columns: 1fr; gap: var(--sp-6); }
  .hero-visual { aspect-ratio: 4/3; order: -1; }
}

/* -------- trust strip -------- */
.trust-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-4);
  padding: var(--sp-5);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
}
.trust-strip::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 5px;
  background: linear-gradient(180deg, var(--accent), var(--primary));
}
.trust-item {
  display: flex; align-items: center; gap: 12px;
  font-size: var(--fs-sm); font-weight: 600; color: var(--text);
}
.trust-item svg { color: var(--accent); flex: none; width: 20px; height: 20px; }
@media (max-width: 720px) {
  .trust-strip { grid-template-columns: repeat(2, 1fr); }
}

/* -------- section heading -------- */
.section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--sp-5);
  margin-bottom: 22px;
  flex-wrap: wrap;
}
.section-head h2 { margin: 0; max-width: 22ch; }
.section-head p { color: var(--text-muted); max-width: 50ch; margin: 0; }

/* -------- service cards -------- */
.svc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--sp-4);
}
.svc-card {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 94%, var(--surface-alt)), var(--surface));
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  transition: transform var(--t-base), border-color var(--t-base), box-shadow var(--t-base);
  display: flex; flex-direction: column; gap: var(--sp-3);
  position: relative;
  overflow: hidden;
}
.svc-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 4px;
  background: linear-gradient(90deg, var(--navy), color-mix(in srgb, var(--accent) 72%, var(--navy)));
  opacity: .86;
}
.svc-card:hover { transform: translateY(-3px); border-color: var(--accent); box-shadow: var(--shadow-md); }
.svc-card h3 { font-size: var(--fs-md); margin: 0; }
.svc-card p { color: var(--text-muted); font-size: var(--fs-sm); margin: 0; }
.svc-icon {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent);
  display: inline-flex; align-items: center; justify-content: center;
}
.svc-icon svg { width: 20px; height: 20px; }
.svc-card .arrow {
  position: absolute;
  top: var(--sp-5); right: var(--sp-5);
  color: var(--text-faint);
  transition: color var(--t-base), transform var(--t-base);
}
.svc-card:hover .arrow { color: var(--accent); transform: translate(2px, -2px); }
.home-svc-grid {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}
.home-svc-grid .svc-card:nth-child(1) { grid-column: 2 / span 2; }
.home-svc-grid .svc-card:nth-child(2) { grid-column: 4 / span 2; }
.home-svc-grid .svc-card:nth-child(3) { grid-column: 1 / span 2; }
.home-svc-grid .svc-card:nth-child(4) { grid-column: 3 / span 2; }
.home-svc-grid .svc-card:nth-child(5) { grid-column: 5 / span 2; }
.home-svc-grid--spread {
  grid-template-columns: repeat(10, minmax(0, 1fr));
  column-gap: var(--sp-5);
  row-gap: var(--sp-7);
  padding-inline: clamp(0px, 1.5vw, var(--sp-5));
}
.home-svc-grid--spread .svc-card:nth-child(1) { grid-column: 2 / span 2; }
.home-svc-grid--spread .svc-card:nth-child(2) { grid-column: 7 / span 2; }
.home-svc-grid--spread .svc-card:nth-child(3) { grid-column: 1 / span 2; }
.home-svc-grid--spread .svc-card:nth-child(4) { grid-column: 5 / span 2; }
.home-svc-grid--spread .svc-card:nth-child(5) { grid-column: 9 / span 2; }

/* -------- standards block -------- */
.standards {
  background: var(--surface-alt);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-7);
}
.standards:has(.standards-path) {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(380px, .95fr);
  align-items: center;
  gap: var(--sp-9);
}
.standards:has(.standards-path) .section-head {
  display: block;
}
.standards-path {
  position: relative;
  min-height: 470px;
}
.path-step {
  position: absolute;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 245px;
  width: 245px;
  padding: 18px 20px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
}
.path-step span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  flex: 0 0 48px;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  font: 700 12px/1 'General Sans', sans-serif;
  letter-spacing: .1em;
}
.path-step strong {
  font-family: 'General Sans', sans-serif;
  font-size: var(--fs-md);
  color: var(--text);
}
.path-step--one { top: 0; left: 0; }
.path-step--two { top: 130px; left: 205px; right: auto; }
.path-step--three { top: 260px; left: 0; }
.path-step--four { top: 390px; left: 205px; right: auto; }
.path-line {
  position: absolute;
  width: 118px;
  height: 2px;
  background: linear-gradient(90deg, color-mix(in srgb, var(--accent) 20%, transparent), var(--accent));
  border-radius: 999px;
  opacity: .8;
}
.path-line::after {
  content: "";
  position: absolute;
  right: -3px;
  top: -3px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
}
.path-line--down { top: 100px; left: 230px; transform: rotate(31deg); }
.path-line--up { top: 230px; right: 230px; transform: rotate(-31deg); }
.path-line--last { top: 360px; left: 230px; transform: rotate(31deg); }
.standards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--sp-6);
  margin-top: var(--sp-6);
}
.stand-item h4 { display: flex; align-items: center; gap: 10px; margin: 0 0 6px; }
.stand-item h4 .num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  border-radius: 6px;
  background: var(--navy); color: #fff;
  font-size: var(--fs-xs); font-weight: 700;
  font-family: 'Satoshi', sans-serif;
}
:root[data-theme="dark"] .stand-item h4 .num { background: var(--accent); color: #fff; }
.stand-item p { color: var(--text-muted); font-size: var(--fs-sm); margin: 0; }

/* -------- market / areas teaser -------- */
.areas-teaser {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-7);
  align-items: center;
}
.areas-photo {
  border-radius: var(--r-xl);
  overflow: hidden;
  border: 1px solid var(--border);
  aspect-ratio: 4/3;
}
.areas-photo img { width: 100%; height: 100%; object-fit: cover; }
.areas-teaser--home {
  grid-template-columns: minmax(280px, .82fr) minmax(520px, 1.18fr);
  gap: var(--sp-8);
}
.areas-teaser--home > div:first-child {
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-6);
  box-shadow: var(--shadow-sm);
}
.areas-teaser--home .areas-photo {
  min-height: 430px;
  aspect-ratio: 16/10;
  box-shadow: var(--shadow-lg);
}
.areas-teaser--home .markets-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 14px;
}
.markets-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-3);
  margin: var(--sp-5) 0 var(--sp-6);
  padding: 0;
  list-style: none;
}
.markets-list li {
  display: flex; align-items: center; gap: 8px;
  font-weight: 500;
  color: var(--text);
  font-size: var(--fs-sm);
}
.markets-list li::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
}
@media (max-width: 880px) {
  .areas-teaser { grid-template-columns: 1fr; }
}

/* -------- partner cta -------- */
.cta-band {
  background: var(--navy);
  color: #fff;
  border-radius: var(--r-xl);
  padding: var(--sp-8);
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  align-items: center;
  gap: var(--sp-7);
  position: relative;
  overflow: hidden;
}
:root[data-theme="dark"] .cta-band {
  background: linear-gradient(135deg, #182135 0%, #0d121f 100%);
  border: 1px solid var(--border-strong);
}
.cta-band h2 { color: #fff; margin: 0 0 var(--sp-3); }
.cta-band p { color: rgba(255,255,255,0.78); margin: 0; max-width: 50ch; }
.cta-band .stripe {
  position: absolute;
  top: 0; bottom: 0; right: 32%;
  width: 4px;
  background: var(--red);
  opacity: 0.7;
}
.cta-band .btn-row { display: flex; gap: var(--sp-3); justify-content: flex-end; flex-wrap: wrap; }
.cta-band .btn--ghost { color: #fff; border-color: rgba(255,255,255,0.4); }
.cta-band .btn--ghost:hover { border-color: var(--red); color: var(--red); }
.cta-band .btn--accent { background: var(--red); color: #fff; }
.cta-band .btn--accent:hover { background: var(--red-deep); }
@media (max-width: 880px) {
  .cta-band { grid-template-columns: 1fr; padding: var(--sp-6); }
  .cta-band .stripe { display: none; }
  .cta-band .btn-row { justify-content: flex-start; }
}

/* -------- footer -------- */
.site-footer {
  border-top: 1px solid var(--border);
  background:
    linear-gradient(135deg, var(--navy-deep), var(--navy));
  padding: var(--sp-7) 0 var(--sp-5);
  margin-top: 48px;
  color: rgba(255,255,255,.86);
}
.foot-grid {
  display: grid;
  grid-template-columns: minmax(160px, .8fr) minmax(180px, .8fr) minmax(260px, 1.2fr);
  gap: var(--sp-6);
  margin-bottom: var(--sp-6);
  align-items: start;
}
.site-footer .brand { color: #fff; align-items: center; gap: var(--sp-5); column-gap: var(--sp-5); }
.site-footer .brand-logo { width: 82px; height: 82px; flex: none; }
.site-footer .brand-name { display: inline-block; padding-left: 2px; }
.site-footer p { color: rgba(255,255,255,.66) !important; }
.foot-grid h5 {
  font-family: 'Satoshi', sans-serif;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: rgba(255,255,255,.48);
  margin: 0 0 var(--sp-3);
}
.foot-grid a { color: rgba(255,255,255,.68); font-size: var(--fs-sm); display: block; padding: 4px 0; overflow-wrap: anywhere; }
.foot-grid a:hover { color: #fff; }
.foot-grid > div:last-child a {
  display: inline-block;
  max-width: 100%;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 999px;
  padding: 9px 13px;
  line-height: 1.25;
}
.foot-grid > div:last-child {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
}
.foot-grid > div:last-child h5 { margin-bottom: 0; }
.foot-grid > div:last-child p { margin-top: 2px !important; }
.foot-meta a { color: rgba(255,255,255,.62); }
.foot-meta a:hover { color: #fff; }
.foot-meta {
  border-top: 1px solid rgba(255,255,255,.14);
  padding-top: var(--sp-4);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--sp-3);
  font-size: var(--fs-xs); color: rgba(255,255,255,.46);
}
@media (max-width: 720px) {
  .foot-grid { grid-template-columns: 1fr 1fr; }
  .checkbox-grid { grid-template-columns: 1fr; }
}
@media (max-width: 440px) {
  .foot-grid { grid-template-columns: 1fr; }
}

/* -------- page header -------- */
.page-head {
  padding: 40px 0 28px;
  border-bottom: 1px solid var(--border);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--surface-alt) 86%, transparent), transparent),
    radial-gradient(circle at 84% 18%, color-mix(in srgb, var(--navy) 7%, transparent), transparent 28%);
}

/* -------- privacy and terms -------- */
.policy-layout {
  display: grid;
  grid-template-columns: minmax(220px, .72fr) minmax(0, 1.6fr);
  gap: var(--sp-7);
  align-items: start;
}
.policy-nav {
  position: sticky;
  top: 110px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-5);
  box-shadow: var(--shadow-sm);
}
.policy-nav h3 {
  font-size: var(--fs-sm);
  margin-bottom: var(--sp-3);
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--accent);
}
.policy-nav a {
  display: block;
  padding: 9px 0;
  color: var(--text-muted);
  font-size: var(--fs-sm);
  border-top: 1px solid color-mix(in srgb, var(--border) 72%, transparent);
}
.policy-nav a:first-of-type { border-top: 0; }
.policy-nav a:hover { color: var(--accent); }
.policy-content {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}
.policy-card {
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-7);
  box-shadow: var(--shadow-sm);
}
.policy-card h2 { font-size: var(--fs-2xl); }
.policy-card h3 {
  font-size: var(--fs-lg);
  margin-top: var(--sp-5);
}
.policy-card ul {
  margin: 0 0 var(--sp-4);
  padding-left: 1.1rem;
  color: var(--text-muted);
}
.policy-card li { margin-bottom: 8px; }
.policy-note {
  border-left: 3px solid var(--accent);
  background: color-mix(in srgb, var(--surface-alt) 68%, var(--surface));
  border-radius: var(--r-md);
  padding: var(--sp-4);
  color: var(--text-muted);
}
.page-head h1 { font-size: clamp(36px, 5vw, 60px); margin-bottom: var(--sp-3); }
.page-head .lede { font-size: var(--fs-md); color: var(--text-muted); max-width: 65ch; }

/* -------- services page -------- */
.services-stack {
  padding-top: var(--sp-8);
  padding-bottom: var(--sp-4);
  display: grid;
  gap: var(--sp-6);
}
.svc-block {
  position: relative;
  padding: var(--sp-5);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  background:
    radial-gradient(circle at 8% 0%, color-mix(in srgb, var(--accent) 7%, transparent), transparent 30%),
    linear-gradient(145deg, color-mix(in srgb, var(--surface) 94%, var(--surface-alt)), var(--surface));
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.svc-block:last-of-type { border-bottom: 1px solid var(--border); }
.svc-block-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(330px, .78fr);
  gap: var(--sp-6);
  align-items: stretch;
  margin-bottom: var(--sp-5);
}
.svc-block:nth-of-type(even) .svc-block-head {
  grid-template-columns: minmax(330px, .78fr) minmax(0, 1fr);
}
.svc-block:nth-of-type(even) .svc-block-head > div:first-child {
  grid-column: 2;
}
.svc-block:nth-of-type(even) .svc-block-img {
  grid-column: 1;
  grid-row: 1;
}
.svc-block-head .label {
  color: var(--accent);
  font-size: var(--fs-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: var(--sp-3);
}
.svc-block-head h2 { margin: 0 0 var(--sp-3); }
.svc-block-head p { color: var(--text-muted); margin: 0; max-width: 66ch; }
.svc-block-img {
  border-radius: var(--r-lg);
  overflow: hidden;
  aspect-ratio: 5/4;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-md);
}
.svc-block-img img { width: 100%; height: 100%; object-fit: cover; }
.sub-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: var(--sp-3);
}
.sub-card {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 14px 16px;
  background: color-mix(in srgb, var(--surface-alt) 42%, var(--surface));
  min-height: 112px;
}
#janitorial .sub-card { grid-column: span 3; }

#floor-care .sub-card { grid-column: span 4; }

#project .sub-card:nth-child(1) { grid-column: span 5; }
#project .sub-card:nth-child(2) { grid-column: span 4; }
#project .sub-card:nth-child(3) { grid-column: span 3; }

#painting .sub-card:nth-child(1) { grid-column: span 4; }
#painting .sub-card:nth-child(2) { grid-column: span 5; }
#painting .sub-card:nth-child(3) { grid-column: span 3; }

#supplies .sub-card:nth-child(1) { grid-column: span 3; }
#supplies .sub-card:nth-child(2) { grid-column: span 4; }
#supplies .sub-card:nth-child(3) { grid-column: span 5; }
.sub-card h4 { font-size: var(--fs-md); margin: 0 0 8px; }
.sub-card p { color: var(--text-muted); font-size: var(--fs-sm); margin: 0; }
@media (max-width: 880px) {
  .svc-block-head { grid-template-columns: 1fr; }
  .svc-block:nth-of-type(even) .svc-block-head { grid-template-columns: 1fr; }
  .svc-block:nth-of-type(even) .svc-block-head > div:first-child { grid-column: auto; }
  .svc-block-img { order: -1; }
  .svc-block:nth-of-type(even) .svc-block-img { grid-column: auto; grid-row: auto; }
  .sub-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  #janitorial .sub-card:nth-child(n),
  #floor-care .sub-card:nth-child(n),
  #project .sub-card:nth-child(n),
  #painting .sub-card:nth-child(n),
  #supplies .sub-card:nth-child(n) { grid-column: span 1; }
}
@media (max-width: 560px) {
  .sub-grid { grid-template-columns: 1fr; }
  #janitorial .sub-card:nth-child(n),
  #floor-care .sub-card:nth-child(n),
  #project .sub-card:nth-child(n),
  #painting .sub-card:nth-child(n),
  #supplies .sub-card:nth-child(n) { grid-column: 1; }
}

/* -------- service areas page / interactive map -------- */
.map-wrap {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--sp-6);
  align-items: stretch;
}
.map-wrap--solo {
  grid-template-columns: 1fr;
  max-width: 1040px;
  margin-inline: auto;
}
.map-card {
  background:
    radial-gradient(circle at 14% 18%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 30%),
    radial-gradient(circle at 86% 84%, color-mix(in srgb, var(--primary) 10%, transparent), transparent 32%),
    var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  overflow: hidden;
  position: relative;
  min-height: 460px;
  padding: var(--sp-5);
}
.map-wrap--solo .map-card { min-height: 620px; }
.map-card--real {
  min-height: auto;
  padding: var(--sp-4);
}
.real-texas-map {
  width: 100%;
  height: 560px;
  border-radius: calc(var(--r-xl) - 6px);
  border: 1px solid var(--border);
  background: #e8ebe5;
  overflow: hidden;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.45);
}
.real-texas-map .leaflet-tile {
  filter: saturate(.42) contrast(.92) brightness(1.03);
}
.real-texas-map .leaflet-pane,
.real-texas-map .leaflet-top,
.real-texas-map .leaflet-bottom {
  z-index: 1;
}
.market-pin {
  position: relative;
  z-index: 3;
  transform: translate(-50%, -50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  border: 1px solid color-mix(in srgb, var(--navy) 20%, transparent);
  border-radius: 999px;
  padding: 8px 12px 8px 10px;
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  color: var(--navy);
  box-shadow: 0 14px 34px -18px rgba(20,37,74,.42);
  font-family: 'General Sans', sans-serif;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  transition: transform var(--t-base), border-color var(--t-base), background var(--t-base), color var(--t-base), box-shadow var(--t-base);
}
.market-pin::before {
  content: "";
  width: 13px;
  height: 13px;
  flex: none;
  border-radius: 50%;
  background: var(--accent);
  border: 3px solid var(--surface);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 35%, transparent);
}
.market-pin:hover,
.market-pin.active {
  transform: translate(-50%, -50%) scale(1.04);
  border-color: color-mix(in srgb, var(--accent) 42%, transparent);
  background: var(--navy);
  color: #fff;
  box-shadow: 0 18px 38px -18px rgba(20,37,74,.58);
}
.tx-map { width: 100%; height: auto; display: block; }
.tx-map-stage {
  position: relative;
  width: min(720px, 100%);
  margin: 0 auto;
  aspect-ratio: 800 / 650;
}
.tx-map-img {
  width: 100%;
  height: 100%;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--navy) 24%, var(--concrete)), color-mix(in srgb, var(--accent) 12%, var(--concrete)));
  opacity: .92;
  -webkit-mask: url("../img/texas-outline.svg") center / contain no-repeat;
  mask: url("../img/texas-outline.svg") center / contain no-repeat;
  filter: drop-shadow(0 1px 0 color-mix(in srgb, var(--navy) 34%, transparent));
}
.map-marker {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-width: 18px;
  min-height: 18px;
  border: 0;
  background: transparent;
  color: var(--text);
  font-family: 'General Sans', sans-serif;
  font-weight: 700;
  font-size: 13px;
  cursor: pointer;
  transform: translate(-50%, -50%);
  transition: transform var(--t-base), color var(--t-base);
  z-index: 4;
}
.map-marker::before {
  content: "";
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background: var(--navy);
  border: 3px solid var(--surface);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--navy) 35%, transparent), 0 8px 16px rgba(20,37,74,.18);
  transition: background var(--t-base), transform var(--t-base);
}
.map-marker:hover,
.map-marker.active { color: var(--accent); transform: translate(-50%, -50%) scale(1.04); }
.map-marker:hover::before,
.map-marker.active::before { background: var(--accent); transform: scale(1.24); }
.map-marker--dfw { left: 54%; top: 30%; }
.map-marker--waco { left: 52%; top: 44%; }
.map-marker--austin { left: 50%; top: 56.5%; }
.map-marker--san-antonio { left: 46%; top: 65%; }
.map-marker--houston { left: 64%; top: 60%; }
.tx-region {
  fill: var(--surface-alt);
  stroke: var(--border-strong);
  stroke-width: 1.5;
  transition: fill var(--t-fast);
}
.tx-marker {
  fill: var(--navy);
  stroke: var(--surface);
  stroke-width: 3;
  cursor: pointer;
  transition: transform var(--t-base), fill var(--t-base);
  transform-origin: center;
  transform-box: fill-box;
}
.tx-marker:hover, .tx-marker.active { fill: var(--accent); transform: scale(1.25); }
.tx-marker-label {
  font-family: 'General Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  fill: var(--text);
  pointer-events: none;
}
.tx-marker--primary {
  fill: var(--accent);
  stroke: var(--surface);
}
.tx-marker--primary.active, .tx-marker--primary:hover { fill: var(--navy); }
.map-hint {
  margin: var(--sp-4) 0 0;
  font-size: var(--fs-xs);
  color: var(--text-faint);
}
.map-popover {
  position: absolute;
  width: min(310px, calc(100% - 32px));
  background: color-mix(in srgb, var(--surface) 96%, transparent);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-4);
  box-shadow: var(--shadow-lg);
  opacity: 0;
  transform: translateY(10px) scale(.98);
  pointer-events: none;
  transition: opacity var(--t-base), transform var(--t-base), left var(--t-base), top var(--t-base);
}
.map-popover.show {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
.map-card--real .map-popover {
  right: var(--sp-7);
  left: auto !important;
  top: var(--sp-7) !important;
  width: min(350px, calc(100% - 64px));
  z-index: 5;
}
.map-popover[data-market="austin"] { left: 60%; top: 47%; }
.map-popover[data-market="san-antonio"] { left: 55%; top: 62%; }
.map-popover[data-market="waco"] { left: 58%; top: 33%; }
.map-popover[data-market="houston"] { left: 66%; top: 50%; }
.map-popover[data-market="dfw"] { left: 59%; top: 20%; }
.map-popover h3 {
  margin: 0 0 4px;
  font-size: var(--fs-md);
}
.map-popover .tagline {
  display: block;
  margin-bottom: var(--sp-3);
  color: var(--accent);
  font-size: var(--fs-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
}
.map-popover p {
  color: var(--text-muted);
  font-size: var(--fs-sm);
  margin: 0 0 var(--sp-3);
}
.map-popover ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.map-popover li {
  font-size: 11px;
  color: var(--text-muted);
  border: 1px solid var(--border);
  background: var(--surface-alt);
  border-radius: 999px;
  padding: 4px 9px;
}
.market-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-6);
  display: flex; flex-direction: column;
}
.market-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.market-list button {
  width: 100%;
  text-align: left;
  background: transparent;
  border: 1px solid transparent;
  padding: 12px 14px;
  border-radius: var(--r-md);
  color: var(--text);
  font-family: inherit;
  font-size: var(--fs-sm);
  font-weight: 500;
  cursor: pointer;
  display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3);
  transition: all var(--t-base);
}
.market-list button:hover { border-color: var(--border); background: var(--surface-alt); }
.market-list button.active { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 8%, transparent); }
.market-list button .pill {
  font-size: 11px; padding: 2px 8px; border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.1em;
}
.market-detail {
  border-top: 1px solid var(--border);
  margin-top: var(--sp-5);
  padding-top: var(--sp-5);
}
.market-detail h3 { margin: 0 0 var(--sp-2); }
.market-detail p { color: var(--text-muted); margin: 0 0 var(--sp-3); font-size: var(--fs-sm); }
.market-detail .chips { display: flex; flex-wrap: wrap; gap: 6px; }
.market-detail .chips span {
  font-size: 11px;
  background: var(--surface-alt);
  border: 1px solid var(--border);
  padding: 4px 10px; border-radius: 999px;
  color: var(--text-muted);
}
.market-choice-grid {
  display: grid;
  grid-template-columns: minmax(280px, 430px);
  gap: var(--sp-3);
  justify-content: end;
}
.market-choice {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  padding: var(--sp-4);
  min-height: 128px;
  border-radius: var(--r-lg);
  border: 1px solid rgba(255,255,255,.22);
  color: #fff;
  background: rgba(255,255,255,.08);
  text-decoration: none;
  overflow-wrap: normal;
  word-break: normal;
}
.market-choice:hover {
  color: #fff;
  transform: translateY(-2px);
  background: rgba(255,255,255,.13);
}
.market-choice b {
  font-family: 'General Sans', sans-serif;
  font-size: var(--fs-md);
}
.market-choice span {
  color: rgba(255,255,255,.76);
  font-size: var(--fs-sm);
}
@media (max-width: 960px) {
  .map-wrap { grid-template-columns: 1fr; }
  .map-wrap--solo .map-card { min-height: auto; }
  .map-popover {
    position: relative;
    inset: auto !important;
    margin-top: var(--sp-4);
    width: 100%;
  }
  .map-card--real .map-popover { width: 100%; }
  .real-texas-map { height: 460px; }
  .market-choice-grid { grid-template-columns: minmax(0, 1fr); justify-content: stretch; }
}

/* -------- about -------- */
.values-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--sp-5);
}
.about-feature {
  grid-template-columns: 1fr;
  gap: var(--sp-5);
}
.about-feature > div:first-child {
  order: 2;
  max-width: 1080px;
  margin-inline: auto;
  text-align: left;
}
.about-feature > div:first-child p {
  margin-inline: 0;
}
.about-feature .areas-photo {
  order: 1;
  width: min(1080px, 100%);
  margin-inline: auto;
  min-height: 520px;
  aspect-ratio: 21 / 9;
  box-shadow: var(--shadow-lg);
}
.about-feature-copy {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--sp-8);
  padding-top: var(--sp-5);
  align-items: start;
}
.about-feature-copy::before {
  content: "";
  position: absolute;
  top: var(--sp-5);
  bottom: 0;
  left: 50%;
  width: 1px;
  transform: translateX(-50%);
  background: linear-gradient(
    180deg,
    transparent,
    color-mix(in srgb, var(--accent) 45%, var(--border)),
    color-mix(in srgb, var(--navy) 35%, var(--border)),
    transparent
  );
}
.about-feature-copy article {
  position: relative;
  z-index: 1;
}
.about-feature-copy h2 {
  max-width: 20ch;
}
.about-feature-copy article:nth-child(2) {
  padding-left: var(--sp-2);
}
.value-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
}
.value-card h4 { font-size: var(--fs-md); margin: 0 0 8px; }
.value-card p { color: var(--text-muted); font-size: var(--fs-sm); margin: 0; }
.value-card .v-num {
  font-family: 'General Sans', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--sp-3);
}
.values-flow {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  align-items: start;
}
.values-flow .value-card:nth-child(even) { transform: translateY(var(--sp-5)); }
.values-flow .value-card {
  min-height: 190px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 94%, var(--surface-alt)), var(--surface));
}
.values-bubble {
  position: relative;
  display: grid;
  grid-template-columns: minmax(210px, .9fr) minmax(260px, 1.15fr) minmax(210px, .9fr);
  grid-template-areas:
    "two . three"
    "core core core"
    "four . five";
  gap: var(--sp-5) var(--sp-6);
  align-items: center;
  padding: var(--sp-3) var(--sp-6);
  border-radius: 0;
  border: 0;
  background:
    radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--navy) 8%, transparent), transparent 35%);
  overflow: visible;
}
.bubble-core {
  grid-area: core;
  justify-self: center;
  width: min(520px, 100%);
  position: relative;
  z-index: 2;
  border-radius: 999px;
  padding: var(--sp-6) var(--sp-7);
  background: var(--navy);
  color: #fff;
  text-align: center;
  box-shadow: var(--shadow-lg);
}
.bubble-core h3 { color: #fff; margin-bottom: var(--sp-2); }
.bubble-core p { color: rgba(255,255,255,.75); margin: var(--sp-2) 0 0; font-size: var(--fs-sm); }
.bubble-core .v-num { color: #dbc9bd; margin: 0; }
.bubble-node {
  position: relative;
  z-index: 2;
  border-radius: 999px;
  min-height: 158px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  box-shadow: var(--shadow-sm);
}
.bubble-node p { max-width: 22ch; }
.belief-statement {
  max-width: 960px;
  margin-inline: auto;
  padding: var(--sp-8) var(--sp-6);
  text-align: center;
  position: relative;
  isolation: isolate;
}
.belief-statement::before,
.belief-statement::after {
  content: "";
  position: absolute;
  left: 50%;
  width: min(620px, 78%);
  height: 1px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 45%, var(--border)), color-mix(in srgb, var(--navy) 35%, var(--border)), transparent);
}
.belief-statement::before { top: 0; }
.belief-statement::after { bottom: 0; opacity: .55; }
.belief-statement h2,
.belief-statement p { margin-left: auto; margin-right: auto; }
.belief-statement .eyebrow { justify-content: center; }
.bubble-node--two { grid-area: two; transform: translate(18px, 12px); }
.bubble-node--three { grid-area: three; transform: translate(-18px, 12px); }
.bubble-node--four { grid-area: four; transform: translate(42px, -6px); }
.bubble-node--five { grid-area: five; transform: translate(-42px, -6px); }
.bubble-line {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 190px;
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 60%, var(--border)), transparent);
  transform-origin: left center;
  opacity: .75;
  z-index: 1;
}
.bubble-line--two { transform: translate(-70px, -40px) rotate(-150deg); }
.bubble-line--three { transform: translate(68px, -40px) rotate(-30deg); }
.bubble-line--four { transform: translate(-70px, 48px) rotate(150deg); }
.bubble-line--five { transform: translate(68px, 48px) rotate(30deg); }
.serve-mosaic {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--sp-4);
  align-items: stretch;
}
.serve-panel {
  border: 1px solid var(--border);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 94%, var(--surface-alt)), var(--surface));
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  min-height: 132px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: transform var(--t-base), border-color var(--t-base), box-shadow var(--t-base);
}
.serve-panel:hover { transform: translateY(-3px); border-color: var(--accent); box-shadow: var(--shadow-md); }
.serve-panel b,
.serve-panel h3 { font-family: 'General Sans', sans-serif; font-size: var(--fs-md); line-height: 1.18; margin: 0 0 var(--sp-3); }
.serve-panel span { color: var(--text-muted); font-size: var(--fs-sm); }
.serve-panel--lead {
  grid-column: span 2;
  grid-row: span 2;
  background:
    radial-gradient(circle at 16% 12%, color-mix(in srgb, var(--accent) 30%, transparent), transparent 26%),
    linear-gradient(135deg, var(--navy), var(--navy-deep));
  color: #fff;
  min-height: 100%;
}
.serve-panel--lead h3 { color: #fff; font-size: var(--fs-2xl); }
.serve-panel--lead span,
.serve-panel--lead p { color: rgba(255,255,255,.76); margin: 0; }
.serve-panel--wide { grid-column: span 2; }
.serve-mosaic--grouped {
  grid-template-columns: minmax(300px, .9fr) repeat(2, minmax(0, 1fr));
}
.serve-mosaic--grouped .serve-panel--lead {
  grid-column: auto;
  grid-row: span 2;
}
.serve-group {
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-6);
  background:
    radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--accent) 8%, transparent), transparent 34%),
    color-mix(in srgb, var(--surface) 94%, var(--surface-alt));
  box-shadow: var(--shadow-sm);
}
.serve-group h3 {
  font-size: var(--fs-xl);
  max-width: 18ch;
}
.serve-group p {
  color: var(--text-muted);
  margin: 0;
  max-width: 64ch;
}
.serve-group--wide { grid-column: span 2; }
.serve-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: var(--sp-5);
}
.serve-tags span {
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 8px 11px;
  background: var(--surface);
  color: var(--text-muted);
  font-size: var(--fs-sm);
}

/* -------- partner page doors visual -------- */
.doors-visual {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
  margin: var(--sp-6) 0;
}
.doors-visual::before {
  content: "";
  position: absolute;
  left: 12%;
  right: 12%;
  top: 50%;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), var(--gold), var(--primary));
  opacity: .75;
}
.door-card {
  position: relative;
  min-height: 150px;
  border-radius: 22px 22px 10px 10px;
  border: 1px solid var(--border);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--surface) 90%, var(--surface-alt)), var(--surface));
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  overflow: hidden;
  animation: doorFloat 5.5s ease-in-out infinite;
}
.door-card--two { animation-delay: .55s; }
.door-card--three { animation-delay: 1.1s; }
.door-card::before {
  content: "";
  position: absolute;
  inset: 10px 12px;
  border-radius: 18px 18px 8px 8px;
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--border));
}
.door-card::after {
  content: "";
  position: absolute;
  right: 26px;
  top: 50%;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--gold) 18%, transparent);
}
.door-card span {
  color: var(--accent);
  font-family: 'General Sans', sans-serif;
  font-weight: 800;
  letter-spacing: .16em;
  font-size: var(--fs-xs);
}
.door-card b {
  font-family: 'General Sans', sans-serif;
  font-size: var(--fs-lg);
  color: var(--text);
}
@keyframes doorFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

/* -------- forms -------- */
.form-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-7);
}
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
  margin-bottom: var(--sp-4);
}
.form-field { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.form-field.full { grid-column: 1 / -1; }
.form-field label {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-muted);
  font-weight: 600;
}
.form-field input,
.form-field select,
.form-field textarea {
  font-family: inherit;
  background: var(--bg);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-md);
  padding: 12px 14px;
  font-size: var(--fs-sm);
  color: var(--text);
  width: 100%;
  min-width: 0;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.form-field textarea { min-height: 130px; resize: vertical; }
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent);
}
.checkbox-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px 14px;
}
.check {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  padding: 11px 13px;
  min-height: 48px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  cursor: pointer;
  font-size: var(--fs-sm);
  line-height: 1.2;
  transition: border-color var(--t-fast), background var(--t-fast);
}
.check:hover { border-color: var(--border-strong); }
.check input {
  margin: 0;
  width: 15px;
  height: 15px;
  accent-color: var(--accent);
  justify-self: center;
}
.check span {
  display: flex;
  align-items: center;
  min-height: 22px;
}
.check input:checked + span { color: var(--text); font-weight: 600; }
.check:has(input:checked) {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
}
.radio-row {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.radio-row label {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  border: 1px solid var(--border);
  border-radius: 999px;
  cursor: pointer;
  font-size: var(--fs-sm);
  text-transform: none; letter-spacing: normal; color: var(--text);
}
.radio-row label input { accent-color: var(--accent); }
.radio-row label:has(input:checked) {
  border-color: var(--accent); color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
}

.form-note {
  font-size: var(--fs-xs); color: var(--text-faint);
  background: var(--surface-alt);
  border: 1px dashed var(--border-strong);
  padding: 12px 14px;
  border-radius: var(--r-md);
  margin-top: var(--sp-4);
}
.form-status {
  margin-top: var(--sp-4);
  padding: 12px 14px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: var(--surface-alt);
  font-size: var(--fs-sm);
  display: none;
}
.form-status.show { display: block; }
.form-status a { color: var(--accent); font-weight: 600; word-break: break-all; }

@media (max-width: 720px) {
  .form-row { grid-template-columns: 1fr; }
  .form-card { padding: var(--sp-5); }
}

@media (max-width: 960px) {
  .home-svc-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .home-svc-grid .svc-card,
  .home-svc-grid .svc-card:nth-child(4),
  .home-svc-grid .svc-card:nth-child(5) { grid-column: auto; }
  .standards:has(.standards-path) { grid-template-columns: 1fr; }
  .standards-path { min-height: 320px; max-width: 520px; }
  .values-flow { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .values-flow .value-card:nth-child(even) { transform: none; }
  .values-bubble {
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "core core"
      "two three"
      "four five";
  }
  .bubble-line { display: none; }
  .bubble-core { border-radius: var(--r-xl); }
  .bubble-node { border-radius: var(--r-lg); transform: none; }
  .serve-mosaic { grid-template-columns: 1fr 1fr; }
  .serve-panel--lead,
  .serve-panel--wide { grid-column: 1 / -1; grid-row: auto; }
  .serve-mosaic--grouped { grid-template-columns: 1fr; }
  .serve-mosaic--grouped .serve-panel--lead,
  .serve-group--wide { grid-column: 1 / -1; grid-row: auto; }
  .doors-visual { grid-template-columns: 1fr; }
  .doors-visual::before { display: none; }
  .policy-layout { grid-template-columns: 1fr; }
  .policy-nav { position: relative; top: auto; }
  .about-feature-copy {
    grid-template-columns: 1fr;
    gap: var(--sp-6);
    text-align: center;
  }
  .about-feature-copy::before {
    top: calc(50% - 1px);
    bottom: auto;
    left: 50%;
    width: min(620px, 78%);
    height: 1px;
    transform: translate(-50%, -50%);
    background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 45%, var(--border)), color-mix(in srgb, var(--navy) 35%, var(--border)), transparent);
  }
  .about-feature-copy article:nth-child(2) { padding-left: 0; }
  .about-feature-copy h2,
  .about-feature-copy p { margin-inline: auto; }
  .about-feature .areas-photo {
    min-height: 380px;
    aspect-ratio: 16 / 10;
  }
}

@media (max-width: 640px) {
  .start-split,
  .start-split:hover,
  .start-split:focus-within {
    width: 100%;
    min-height: 0;
  }
  .start-main { display: none; }
  .start-options {
    position: relative;
    inset: auto;
    opacity: 1;
    pointer-events: auto;
    transform: none;
    width: 100%;
    flex-direction: column;
  }
  .start-options::before,
  .start-options::after { display: none; }
  .start-options .btn { width: 100%; justify-content: center; }
  .hero-actions { flex-direction: column; align-items: stretch; }
  .hero-actions > .btn { justify-content: center; }
  .home-svc-grid,
  .values-flow { grid-template-columns: 1fr; }
  .values-bubble {
    grid-template-columns: 1fr;
    grid-template-areas:
      "core"
      "two"
      "three"
      "four"
      "five";
    padding: var(--sp-4);
  }
  .serve-mosaic { grid-template-columns: 1fr; }
  .map-marker { font-size: 11px; }
  .map-marker::before { width: 12px; height: 12px; border-width: 2px; }
  .standards { padding: var(--sp-5); }
  .path-step {
    position: relative;
    inset: auto !important;
    min-width: 0;
    width: 100%;
    margin-bottom: var(--sp-3);
  }
  .path-line { display: none; }
  .standards-path { min-height: 0; }
  .policy-card { padding: var(--sp-5); }
  .about-feature .areas-photo {
    min-height: 260px;
    aspect-ratio: 4 / 3;
  }
}

/* -------- contact intro split -------- */
.contact-split {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: var(--sp-7);
}
.contact-split > * { min-width: 0; }
.contact-info { display: flex; flex-direction: column; gap: var(--sp-4); }
.info-tile {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
}
.info-tile h4 { margin: 0 0 6px; font-size: var(--fs-md); }
.info-tile p { color: var(--text-muted); margin: 0; font-size: var(--fs-sm); overflow-wrap: anywhere; }
.info-tile a { font-weight: 600; word-break: break-all; }
@media (max-width: 960px) {
  .contact-split { grid-template-columns: 1fr; }
}

/* -------- partner page extras -------- */
.audience-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
}
.aud-card {
  border: 1px solid var(--border);
  background: var(--surface);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
}
.aud-card h4 { font-size: var(--fs-md); margin: 0 0 6px; }
.aud-card p { font-size: var(--fs-sm); color: var(--text-muted); margin: 0; }
.aud-card .tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--accent);
  margin-bottom: var(--sp-3);
}
@media (max-width: 880px) {
  .audience-grid { grid-template-columns: 1fr; }
}

/* -------- utility -------- */
.visually-hidden {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); border: 0;
}
hr.divider {
  border: 0; border-top: 1px solid var(--border);
  margin: var(--sp-7) 0;
}

/* -------- additive conversion sections -------- */
.assurance-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--sp-4);
}
.assurance-card,
.faq-grid article,
.fit-grid article,
.readiness-grid article {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  box-shadow: var(--shadow-sm);
}
.assurance-card span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
  color: var(--accent);
  font-size: 12px;
  font-weight: 800;
  margin-bottom: var(--sp-4);
}
.assurance-card h3,
.faq-grid h3,
.fit-grid h3,
.readiness-grid h3,
.step-list h3 {
  font-size: var(--fs-md);
  margin: 0 0 8px;
}
.assurance-card p,
.faq-grid p,
.readiness-grid p,
.step-list p,
.scope-panel p {
  color: var(--text-muted);
  font-size: var(--fs-sm);
  margin: 0;
}
.next-steps {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.4fr);
  gap: var(--sp-7);
  align-items: start;
  background: linear-gradient(135deg, color-mix(in srgb, var(--surface) 92%, var(--navy)), var(--surface));
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-7);
  box-shadow: var(--shadow-sm);
}
.next-steps > div:first-child p {
  color: var(--text-muted);
  margin: 0;
  max-width: 56ch;
}
.step-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--sp-4);
}
.step-list article {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
}
.step-list b {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--navy);
  color: #fff;
  font-size: 12px;
  margin-bottom: var(--sp-3);
}
:root[data-theme="dark"] .step-list b { background: var(--accent); color: #fff; }
.scope-panel {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.2fr);
  gap: var(--sp-7);
  align-items: center;
  background: var(--navy);
  border-radius: var(--r-xl);
  padding: var(--sp-7);
  color: #fff;
  box-shadow: var(--shadow-md);
}
.scope-panel h2,
.scope-panel .eyebrow { color: #fff; }
.scope-panel p { color: rgba(255,255,255,.76); max-width: 58ch; }
.scope-tags {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
}
.scope-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.2);
  color: rgba(255,255,255,.9);
  font-size: var(--fs-sm);
  font-weight: 600;
}
.service-action {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  flex-wrap: wrap;
  margin-top: var(--sp-5);
  padding: var(--sp-4);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: color-mix(in srgb, var(--surface-alt) 48%, var(--surface));
}
.service-action p {
  color: var(--text-muted);
  font-size: var(--fs-sm);
  margin: 0;
  max-width: 62ch;
}
.service-action--inline { margin-top: var(--sp-5); }
.faq-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--sp-4);
}
.readiness-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--sp-4);
}
.scope-panel--partner {
  grid-template-columns: 1fr;
}
.fit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--sp-4);
}
.fit-grid ul,
.info-tile--checklist ul {
  margin: var(--sp-3) 0 0;
  padding-left: 18px;
  color: var(--text-muted);
}
.fit-grid li,
.info-tile--checklist li {
  margin: 6px 0;
}
.mobile-leadbar { display: none; }

/* -------- service areas SEO hub -------- */
.market-hub-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--sp-4);
}
.market-hub-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  box-shadow: var(--shadow-sm);
}
.market-hub-card--lead {
  grid-column: 1 / -1;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--surface) 92%, var(--navy)), var(--surface));
}
.market-kicker {
  color: var(--accent);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: var(--sp-3);
}
.market-hub-card h3 {
  font-size: var(--fs-xl);
  margin: 0 0 var(--sp-3);
}
.market-hub-card p {
  color: var(--text-muted);
  font-size: var(--fs-sm);
  margin: 0;
}
.market-hub-card ul {
  margin: var(--sp-4) 0 0;
  padding-left: 18px;
  color: var(--text-muted);
  font-size: var(--fs-sm);
}
.market-hub-card li { margin: 6px 0; }
.service-area-scope { margin-top: 0; }

@media (max-width: 1100px) {
  .assurance-grid,
  .faq-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 880px) {
  .next-steps,
  .scope-panel {
    grid-template-columns: 1fr;
    padding: var(--sp-5);
  }
  .market-hub-grid,
  .market-hub-card--lead {
    grid-template-columns: 1fr;
  }
  .readiness-grid,
  .fit-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  body { padding-bottom: 74px; }
  .assurance-grid,
  .faq-grid,
  .step-list {
    grid-template-columns: 1fr;
  }
  .assurance-card,
  .faq-grid article,
  .fit-grid article,
  .readiness-grid article,
  .step-list article {
    padding: var(--sp-4);
  }
  .service-action {
    align-items: stretch;
  }
  .service-action .btn {
    width: 100%;
    justify-content: center;
  }
  .scope-tags span {
    width: 100%;
    justify-content: center;
  }
  .mobile-leadbar {
    position: fixed;
    left: 10px;
    right: 10px;
    bottom: 10px;
    z-index: 90;
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 8px;
    padding: 8px;
    border: 1px solid color-mix(in srgb, var(--border) 50%, transparent);
    border-radius: 18px;
    background: color-mix(in srgb, var(--navy-deep) 92%, transparent);
    box-shadow: var(--shadow-lg);
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
  }
  .mobile-leadbar a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 10px 12px;
    border-radius: 12px;
    color: #fff;
    font-size: 13px;
    font-weight: 800;
    text-align: center;
  }
  .mobile-leadbar a:first-child {
    border: 1px solid rgba(255,255,255,.22);
    background: rgba(255,255,255,.08);
  }
  .mobile-leadbar a:last-child {
    background: var(--red);
  }
}

/* -------- mobile polish layer -------- */
@media (max-width: 640px) {
  html {
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
  }

  body {
    overflow-x: hidden;
  }

  .container {
    padding-inline: 18px;
  }

  .site-header {
    background: color-mix(in srgb, var(--bg) 94%, transparent);
  }

  .nav {
    gap: 10px;
    padding: 8px 0;
  }

  .brand {
    gap: 10px;
    min-width: 0;
  }

  .brand-logo {
    width: 64px;
    height: 64px;
    flex: 0 0 64px;
  }

  .brand-name {
    max-width: 168px;
  }

  .brand-name strong {
    font-size: 14px;
    line-height: 1.12;
  }

  .theme-toggle,
  .nav-toggle {
    width: 42px;
    height: 42px;
    flex: 0 0 42px;
  }

  .nav-actions {
    gap: 8px;
  }

  .nav-links {
    top: 82px;
    height: calc(100vh - 82px);
    padding: 22px 18px calc(96px + env(safe-area-inset-bottom));
    gap: 6px;
  }

  .nav-links a {
    width: 100%;
    min-height: 48px;
    display: flex;
    align-items: center;
    padding: 12px 4px;
    font-size: 18px;
  }

  .nav-links a.active::after {
    left: 4px;
    right: auto;
    width: 44px;
    bottom: 6px;
  }

  h1 {
    font-size: clamp(34px, 11vw, 46px);
    line-height: 1.02;
    letter-spacing: -0.035em;
  }

  h2 {
    font-size: clamp(26px, 8vw, 34px);
    line-height: 1.08;
  }

  h3 {
    font-size: clamp(20px, 6vw, 24px);
  }

  .lede,
  .hero p.lede,
  .section-head p {
    font-size: 16px;
    line-height: 1.62;
  }

  .hero {
    padding: 30px 0 34px;
  }

  .hero-grid {
    gap: 24px;
  }

  .hero-visual {
    aspect-ratio: 1 / .82;
    border-radius: 22px;
    min-height: 0;
  }

  .hero-badge {
    left: 14px;
    right: 14px;
    bottom: 14px;
    justify-content: center;
    padding: 10px 12px;
  }

  .btn {
    min-height: 48px;
    padding: 13px 18px;
    justify-content: center;
    white-space: normal;
    text-align: center;
  }

  .section {
    padding: 24px 0;
  }

  .section + .section {
    padding-top: 6px;
  }

  .section-head {
    gap: 12px;
    margin-bottom: 18px;
  }

  .section-head h2,
  .section-head p {
    max-width: none;
  }

  .trust-strip {
    grid-template-columns: 1fr;
    padding: 18px;
    gap: 12px;
  }

  .trust-item {
    align-items: flex-start;
  }

  .svc-grid,
  .home-svc-grid,
  .market-hub-grid,
  .audience-grid,
  .contact-split,
  .assurance-grid,
  .faq-grid,
  .readiness-grid,
  .fit-grid,
  .step-list,
  .form-row {
    grid-template-columns: 1fr;
  }

  .home-svc-grid .svc-card:nth-child(n),
  .home-svc-grid--spread .svc-card:nth-child(n),
  .serve-panel:nth-child(n),
  .serve-panel--wide,
  .serve-mosaic--grouped .serve-panel--lead,
  .serve-group--wide {
    grid-column: 1 / -1;
    grid-row: auto;
  }

  .svc-card,
  .aud-card,
  .market-hub-card,
  .assurance-card,
  .faq-grid article,
  .readiness-grid article,
  .fit-grid article,
  .step-list article,
  .info-tile {
    border-radius: 18px;
    padding: 18px;
  }

  .sub-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  #janitorial .sub-card:nth-child(n),
  #floor-care .sub-card:nth-child(n),
  #project .sub-card:nth-child(n),
  #painting .sub-card:nth-child(n),
  #supplies .sub-card:nth-child(n) {
    grid-column: 1;
  }

  .sub-card {
    min-height: 0;
  }

  .service-action {
    padding: 16px;
    border-radius: 18px;
  }

  .next-steps,
  .scope-panel,
  .form-card {
    padding: 20px;
    border-radius: 22px;
  }

  .form-field input,
  .form-field select,
  .form-field textarea {
    min-height: 48px;
    font-size: 16px;
  }

  .checkbox-grid {
    grid-template-columns: 1fr;
  }

  .check,
  .radio-row label {
    min-height: 48px;
  }

  .radio-row {
    flex-direction: column;
  }

  .radio-row label {
    justify-content: flex-start;
    border-radius: var(--r-md);
  }

  .map-wrap,
  .areas-photo,
  .about-feature .areas-photo {
    border-radius: 22px;
  }

  .mobile-leadbar {
    left: 8px;
    right: 8px;
    bottom: max(8px, env(safe-area-inset-bottom));
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 420px) {
  .container {
    padding-inline: 16px;
  }

  .brand-name {
    max-width: 132px;
  }

  .brand-name strong {
    font-size: 13px;
  }

  .brand-logo {
    width: 58px;
    height: 58px;
    flex-basis: 58px;
  }

  .theme-toggle,
  .nav-toggle {
    width: 40px;
    height: 40px;
    flex-basis: 40px;
  }

  .nav-links {
    top: 76px;
    height: calc(100vh - 76px);
  }

  .mobile-leadbar a {
    font-size: 12px;
    padding-inline: 8px;
  }
}

/* -------- live phone browser hardening -------- */
@media (max-width: 700px) {
  *,
  *::before,
  *::after {
    max-width: 100%;
  }

  html,
  body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
  }

  main,
  .site-header,
  .site-footer,
  .hero,
  .section,
  .container {
    max-width: 100vw;
    overflow-x: clip;
  }

  .container {
    width: 100% !important;
    margin-inline: auto !important;
    padding-inline: 18px !important;
  }

  .hero-grid,
  .svc-grid,
  .home-svc-grid,
  .home-svc-grid--spread,
  .trust-strip,
  .standards,
  .standards-grid,
  .areas-teaser,
  .cta-band,
  .foot-grid,
  .svc-block-head,
  .sub-grid,
  .market-hub-grid,
  .audience-grid,
  .contact-split,
  .assurance-grid,
  .faq-grid,
  .readiness-grid,
  .fit-grid,
  .step-list,
  .serve-mosaic,
  .serve-mosaic--grouped,
  .form-row {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .home-svc-grid .svc-card,
  .home-svc-grid .svc-card:nth-child(n),
  .home-svc-grid--spread .svc-card,
  .home-svc-grid--spread .svc-card:nth-child(n),
  .svc-card,
  .sub-card,
  .serve-panel,
  .serve-panel--lead,
  .serve-panel--wide,
  .serve-group--wide,
  .market-hub-card,
  .market-hub-card--lead,
  .form-field,
  .form-field.full {
    grid-column: 1 / -1 !important;
    grid-row: auto !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .hero-visual,
  .svc-block-img,
  .areas-photo,
  .map-wrap {
    width: 100% !important;
    min-width: 0 !important;
  }

  .svc-card {
    min-height: auto !important;
    padding: 20px !important;
  }

  .svc-card p,
  .sub-card p,
  .market-hub-card p,
  .faq-grid p,
  .readiness-grid p,
  .fit-grid p {
    font-size: 15px;
    line-height: 1.58;
  }

  .trust-strip {
    grid-template-columns: 1fr 1fr !important;
  }

  .trust-item {
    min-width: 0;
    font-size: 14px;
  }

  .standards:has(.standards-path) {
    display: block !important;
  }

  .standards-path {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    min-height: 0 !important;
  }

  .path-step {
    position: relative !important;
    inset: auto !important;
    width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
  }

  .path-line {
    display: none !important;
  }

  .mobile-leadbar {
    width: auto !important;
    max-width: none !important;
  }
}

@media (max-width: 390px) {
  .container {
    padding-inline: 16px !important;
  }

  .trust-strip {
    grid-template-columns: 1fr !important;
  }

  .brand-name {
    max-width: 128px !important;
  }
}

/* reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition: none !important; animation: none !important; }
  html { scroll-behavior: auto; }
}
