.elementor-kit-396{--e-global-color-primary:#6EC1E4;--e-global-color-secondary:#54595F;--e-global-color-text:#7A7A7A;--e-global-color-accent:#61CE70;--e-global-typography-primary-font-family:"Roboto";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Roboto Slab";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Roboto";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Roboto";--e-global-typography-accent-font-weight:500;}.elementor-kit-396 e-page-transition{background-color:#FFBC7D;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}
/* Start custom CSS *//* ============================================================
   Loyal North - Quietude component styles, ported VERBATIM from
   _shared.css (approved HTML pack, 11 Jun 2026).
   Canonical source: LN website - approved HTML (11 Jun 2026)/_shared.css
   Do not hand-edit: re-port from the canonical stylesheet.
   ============================================================ */
:root {
  --ink: #1F3148;
  --bone: #EDE7DA;
  --clay: #A86F58;
  --slate: #586068;
  --mist: #D6D9DC;

  --ink-lift: #2A4060;
  --clay-lift: #B8826B;
  --bone-press: #E2DBCB;

  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body: 'Inter', system-ui, -apple-system, sans-serif;

  --type-display: 64px;
  --type-h1: 48px;
  --type-h2: 32px;
  --type-h3: 22px;
  --type-lead: 22px;
  --type-body: 18px;
  --type-body-sm: 16px;
  --type-eyebrow: 12px;
  --type-caption: 13px;

  --type-metric: 56px;
  --type-chapter: 84px;
  --type-tile-marker: 22px;

  --space-xs: 8px;
  --space-s: 16px;
  --space-m: 24px;
  --space-l: 40px;
  --space-xl: 80px;
  --space-2xl: 120px;
  --space-3xl: 160px;

  --content-max: 1200px;
  --reading-max: 720px;
  --margin-desktop: 80px;
  --margin-tablet: 48px;
  --margin-mobile: 24px;

  --ease: cubic-bezier(0.4, 0.0, 0.2, 1);
  --duration-fast: 150ms;
  --duration-base: 300ms;

  --masthead-h: 80px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; text-rendering: optimizeLegibility; }
body {
  font-family: var(--font-body);
  font-size: var(--type-body);
  line-height: 1.6;
  color: var(--ink);
  background: var(--bone);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; background: none; border: none; color: inherit; }
img, svg { display: block; max-width: 100%; height: auto; }
ul { list-style: none; }
:focus { outline: none; }
:focus-visible { outline: 2px solid var(--clay); outline-offset: 4px; }

.container {
  max-width: var(--content-max);
  margin: 0 auto;
  padding-left: var(--margin-desktop);
  padding-right: var(--margin-desktop);
}

.eyebrow {
  font-family: var(--font-body);
  font-size: var(--type-eyebrow);
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--clay);
  line-height: 1.4;
}

.hairline-short {
  width: 32px;
  height: 1px;
  background: var(--clay);
  border: none;
  margin: var(--space-m) 0;
}

.skip-link {
  position: absolute;
  top: -100px;
  left: var(--space-m);
  background: var(--ink);
  color: var(--bone);
  padding: 12px 20px;
  z-index: 1000;
  font-size: 14px;
  letter-spacing: 0.04em;
  transition: top var(--duration-fast) var(--ease);
}
.skip-link:focus { top: var(--space-m); }

/* ============================================================
   WORDMARK
   Set in true uppercase, Fraunces 500, +0.04em tracking (brand §7).
   ============================================================ */
.wordmark {
  font-family: var(--font-display);
  font-weight: 500;
  font-variation-settings: "opsz" 144;
  letter-spacing: 0.04em;
  font-size: 22px;
  line-height: 1;
  color: var(--bone);
  display: inline-block;
  white-space: nowrap;
}
.wordmark--ink { color: var(--ink); }

/* ============================================================
   MASTHEAD
   ============================================================ */
.masthead {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--ink);
  height: var(--masthead-h);
  display: flex;
  align-items: center;
  border-bottom: 1px solid transparent;
  transition: border-color var(--duration-base) var(--ease);
}
.masthead.is-scrolled { border-bottom-color: rgba(168, 111, 88, 0.4); }
.masthead-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}
.nav-primary ul { display: flex; gap: 36px; align-items: center; }
.nav-link {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--bone);
  letter-spacing: 0.04em;
  transition: color var(--duration-fast) var(--ease);
  padding: 6px 0;
}
.nav-link:hover { color: var(--clay-lift); }
.nav-toggle { display: none; }
.mobile-nav { display: none; }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  background: var(--ink);
  color: var(--bone);
  min-height: calc(100vh - var(--masthead-h));
  display: flex;
  align-items: center;
  padding: var(--space-2xl) 0;
}
.hero > .container { width: 100%; }
.hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-2xl);
  align-items: center;
  width: 100%;
}
.hero-content { max-width: 880px; }
.hero-visual { width: 220px; height: 340px; flex-shrink: 0; opacity: 0.85; }
.hero-visual svg { width: 100%; height: 100%; display: block; }
.hero-eyebrow { color: var(--clay); margin-bottom: var(--space-xl); }
.hero-headline {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--type-display);
  font-variation-settings: "opsz" 144;
  letter-spacing: -0.02em;
  line-height: 1.05;
  color: var(--bone);
  margin-bottom: var(--space-m);
}
.hero-subheadline {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--type-h2);
  font-variation-settings: "opsz" 96;
  letter-spacing: -0.015em;
  line-height: 1.15;
  color: var(--bone);
  margin-bottom: var(--space-l);
}
.hero-body {
  font-family: var(--font-body);
  font-size: var(--type-lead);
  font-weight: 400;
  line-height: 1.5;
  color: var(--mist);
  max-width: 680px;
}

.hero--subpage .hero-inner { grid-template-columns: 1fr; gap: 0; }
.hero--subpage .hero-content { max-width: 1040px; }
.hero--short { min-height: 60vh; padding: var(--space-xl) 0; }
.hero--post { min-height: 40vh; padding: var(--space-xl) 0; }

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
.section { padding: 60px 0; }
.section--ink { background: var(--ink); color: var(--bone); padding: var(--space-2xl) 0; }
.section-inner { max-width: 1040px; }
.section-head { margin-bottom: var(--space-l); }
.section-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--type-h2);
  font-variation-settings: "opsz" 96;
  letter-spacing: -0.015em;
  line-height: 1.15;
  color: var(--ink);
  max-width: 820px;
}
.section--ink .section-title { color: var(--bone); }
.section-prose {
  font-family: var(--font-body);
  font-size: var(--type-body);
  color: var(--slate);
  line-height: 1.6;
  max-width: 720px;
}
.section-prose + .section-prose { margin-top: var(--space-m); }
.section--ink .section-prose { color: var(--mist); }

/* ============================================================
   CHAPTER MARK
   ============================================================ */
.chapter {
  display: grid;
  grid-template-columns: minmax(140px, 1fr) minmax(0, 7fr);
  gap: var(--space-l);
  align-items: start;
}
.chapter-mark {
  font-family: var(--font-display);
  font-weight: 500;
  font-style: italic;
  font-size: var(--type-chapter);
  font-variation-settings: "opsz" 144;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--clay);
  user-select: none;
}
.section--ink .chapter-mark { color: var(--clay); }
.chapter-body { min-width: 0; }
.chapter-body .eyebrow { margin-bottom: var(--space-m); }
.chapter-body .section-title { margin-bottom: var(--space-m); }

/* ============================================================
   CAPABILITY TILES
   ============================================================ */
.capabilities-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--clay);
  border-bottom: 1px solid var(--clay);
  margin-top: var(--space-l);
}
.capabilities-grid--four { grid-template-columns: repeat(2, 1fr); }

.capability-tile {
  display: flex;
  flex-direction: column;
  gap: var(--space-m);
  padding: var(--space-l);
  position: relative;
  color: inherit;
  transition: background var(--duration-base) var(--ease);
  min-height: 280px;
}
.capability-tile + .capability-tile { border-left: 1px solid var(--clay); }
.capability-tile:first-child { padding-left: 0; }
.capability-tile:last-child { padding-right: 0; }
.capability-tile:hover { background: rgba(168, 111, 88, 0.04); }

.capabilities-grid--four .capability-tile:nth-child(3),
.capabilities-grid--four .capability-tile:nth-child(4) { border-top: 1px solid var(--clay); }
.capabilities-grid--four .capability-tile:nth-child(odd) { border-left: none; padding-left: 0; }
.capabilities-grid--four .capability-tile:nth-child(even) { padding-right: 0; }

.tile-marker {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: var(--type-tile-marker);
  font-variation-settings: "opsz" 48;
  letter-spacing: 0;
  line-height: 1;
  color: var(--clay);
  margin-bottom: var(--space-xs);
}
.capability-tile-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--type-h3);
  font-variation-settings: "opsz" 48;
  letter-spacing: -0.01em;
  line-height: 1.25;
  color: var(--ink);
}
.capability-tile-body {
  font-size: var(--type-body-sm);
  color: var(--slate);
  line-height: 1.55;
  flex: 1;
}

/* ============================================================
   METRICS STRIP - Quietude §5.iv translated to web
   ============================================================ */
.metrics-head { margin-bottom: var(--space-l); }
.metrics-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-l);
  border-top: 1px solid var(--clay);
  border-bottom: 1px solid var(--clay);
  padding: var(--space-l) 0;
}
.metric { display: flex; flex-direction: column; gap: var(--space-s); }
.metric__numeral {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--type-metric);
  font-variation-settings: "opsz" 144;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--ink);
}
.section--ink .metric__numeral { color: var(--bone); }
.metric__label {
  font-family: var(--font-body);
  font-size: var(--type-eyebrow);
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--slate);
  line-height: 1.4;
}
.section--ink .metric__label { color: var(--mist); }
.metrics-footnote {
  font-family: var(--font-body);
  font-size: var(--type-caption);
  letter-spacing: 0.04em;
  color: var(--slate);
  margin-top: var(--space-m);
}

/* ============================================================
   ACCOLADE - type-led recognition lockup (brand §8)
   ============================================================ */
.accolade {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-l);
  align-items: center;
  max-width: 640px;
  border-top: 1px solid var(--clay);
  border-bottom: 1px solid var(--clay);
  padding: var(--space-m) 0;
}
.accolade__figure {
  font-family: var(--font-display);
  font-weight: 500; font-style: italic;
  font-size: var(--type-metric);
  font-variation-settings: "opsz" 144;
  letter-spacing: -0.02em; line-height: 0.9;
  color: var(--clay);
}
.accolade__text { display: flex; flex-direction: column; gap: 6px; }
.accolade__label {
  font-family: var(--font-body); font-size: var(--type-body-sm);
  font-weight: 500; color: var(--ink); line-height: 1.3;
}
.accolade__detail {
  font-family: var(--font-body); font-size: var(--type-caption);
  letter-spacing: 0.04em; color: var(--slate); line-height: 1.4;
}

/* ---- Footer additions (June 2026 audit): contact column + two-column pages list ---- */
.site-footer__contact-line { margin-top: var(--space-s); }
.site-footer__sitemap--cols { display: block; columns: 2; column-gap: var(--space-l); }
.site-footer__sitemap--cols li { break-inside: avoid; margin-bottom: var(--space-xs); }
.footer-email { white-space: nowrap; }
@media (max-width: 640px) {
  .site-footer__sitemap--cols { columns: 1; }
}

/* ---- Legal pages (Legal Notice / Privacy Policy) ---- */
.legal-prose { max-width: 720px; }
.legal-prose h2 {
  font-family: var(--font-display);
  font-variation-settings: 'opsz' 40;
  font-size: 24px;
  color: var(--ink);
  margin: var(--space-xl) 0 var(--space-s);
}
.legal-prose h2:first-child { margin-top: 0; }
.legal-prose p, .legal-prose li {
  font-family: var(--font-body);
  font-size: var(--type-body-sm);
  color: var(--slate);
  line-height: 1.65;
}
.legal-prose p + p { margin-top: var(--space-s); }
.legal-prose ul { list-style: disc; padding-left: 1.3em; margin: var(--space-s) 0; }
.legal-prose li + li { margin-top: var(--space-xs); }
.legal-prose a { text-decoration: underline; text-underline-offset: 2px; }
.legal-updated {
  font-family: var(--font-body);
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--slate);
  margin-bottom: var(--space-l);
}

/* ============================================================
   LEADERSHIP - pure-type grid (brand book §5 alternative)
   ============================================================ */
.leadership-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-xl) var(--space-l);
  border-top: 1px solid var(--clay);
  padding-top: var(--space-xl);
}
.leader {
  display: flex;
  flex-direction: column;
  gap: var(--space-s);
  padding: 0;
}
.leader__role {
  font-family: var(--font-body);
  font-size: var(--type-eyebrow);
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--clay);
  line-height: 1.4;
}
.leader__name {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--type-h3);
  font-variation-settings: "opsz" 48;
  letter-spacing: -0.01em;
  line-height: 1.2;
  color: var(--ink);
}
.leader__bio {
  font-family: var(--font-body);
  font-size: var(--type-body-sm);
  color: var(--slate);
  line-height: 1.55;
  margin-top: var(--space-xs);
}

.leader__portrait {
  width: 100%;
  max-width: 220px;
  aspect-ratio: 1 / 1;
  background: var(--bone-press);
  border: 1px solid rgba(168, 111, 88, 0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-m);
  overflow: hidden;
}
.leader__portrait img { width: 100%; height: 100%; object-fit: cover; display: block; }
.leader__monogram {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 64px;
  font-variation-settings: "opsz" 144;
  letter-spacing: -0.01em;
  color: var(--clay);
  line-height: 1;
  user-select: none;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn-secondary {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--ink);
  position: relative;
  padding-bottom: 12px;
  transition: color var(--duration-fast) var(--ease);
  line-height: 1.4;
}
.btn-secondary::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  height: 1px;
  width: 24px;
  background: var(--clay);
  transition: width 200ms var(--ease);
}
.btn-secondary:hover { color: var(--clay); }
.btn-secondary:hover::after, .btn-secondary:focus-visible::after { width: 40px; }
.section--ink .btn-secondary { color: var(--bone); }
.section--ink .btn-secondary:hover { color: var(--clay-lift); }

.btn-primary {
  display: inline-block;
  background: var(--ink);
  color: var(--bone);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.04em;
  padding: 14px 28px;
  border-radius: 2px;
  border: none;
  transition: background var(--duration-fast) var(--ease);
  line-height: 1.4;
}
.btn-primary:hover { background: var(--ink-lift); }
.section--ink .btn-primary { background: var(--bone); color: var(--ink); }
.section--ink .btn-primary:hover { background: var(--bone-press); }

/* ============================================================
   CTA FOOTER
   ============================================================ */
.cta-footer { padding: 80px 0; }
.cta-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-2xl); }
.cta-block .eyebrow { margin-bottom: var(--space-m); }
.cta-block__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--type-h3);
  font-variation-settings: "opsz" 48;
  letter-spacing: -0.01em;
  line-height: 1.2;
  color: var(--ink);
  margin-bottom: var(--space-m);
}
.cta-block__body {
  font-family: var(--font-body);
  font-size: var(--type-body-sm);
  color: var(--slate);
  line-height: 1.55;
  margin-bottom: var(--space-l);
  max-width: 480px;
}

/* ============================================================
   SITE FOOTER
   ============================================================ */
.site-footer {
  background: var(--ink);
  color: var(--mist);
  padding-top: var(--space-xl);
  padding-bottom: var(--space-l);
}
.site-footer__inner { max-width: var(--content-max); margin: 0 auto; padding: 0 var(--margin-desktop); }
.site-footer__top-rule { height: 1px; background: var(--clay); margin-bottom: var(--space-xl); }
.site-footer__grid { display: grid; grid-template-columns: 1fr 1.5fr 1.5fr 1fr; gap: var(--space-l); margin-bottom: var(--space-xl); }
.site-footer__label {
  font-family: var(--font-body);
  font-size: var(--type-eyebrow);
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--clay);
  margin-bottom: var(--space-s);
}
.site-footer p, .site-footer a {
  font-family: var(--font-body);
  font-size: var(--type-body-sm);
  color: var(--mist);
  line-height: 1.55;
}
.site-footer a { transition: color var(--duration-fast) var(--ease); }
.site-footer a:hover { color: var(--clay-lift); }
.site-footer__sitemap { display: flex; flex-direction: column; gap: var(--space-xs); }
.site-footer__sitemap a { font-family: var(--font-body); font-size: var(--type-body-sm); color: var(--mist); line-height: 1.55; }
.site-footer__sitemap a:hover { color: var(--clay-lift); }
.site-footer__social-link { display: inline-flex; color: var(--clay); transition: color var(--duration-fast) var(--ease); margin-top: var(--space-xs); }
.site-footer__social-link:hover { color: var(--clay-lift); }
.site-footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: var(--space-l);
  padding-top: var(--space-l);
  border-top: 1px solid rgba(214, 217, 220, 0.15);
}
.site-footer__legal a + a { margin-left: var(--space-s); }
.site-footer__copy { font-size: var(--type-body-sm); }
.site-footer__disclaimer {
  margin-top: var(--space-l);
  font-size: var(--type-body-sm);
  line-height: 1.6;
  color: var(--mist);
  opacity: 0.75;
  max-width: 880px;
}

/* ============================================================
   MOTION
   ============================================================ */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity 400ms var(--ease), transform 400ms var(--ease); }
.reveal.is-visible { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  .reveal { opacity: 1; transform: none; }
  html { scroll-behavior: auto; }
}

/* ============================================================
   TABLET (640 - 1023px)
   ============================================================ */
@media (max-width: 1023px) {
  :root {
    --type-display: 52px;
    --type-h1: 40px;
    --type-h2: 28px;
    --type-h3: 20px;
    --type-lead: 20px;
    --type-metric: 44px;
    --type-chapter: 64px;
  }
  .container { padding-left: var(--margin-tablet); padding-right: var(--margin-tablet); }
  .pulled-phrase__inner { padding-left: var(--margin-tablet); padding-right: var(--margin-tablet); }
  .section { padding: 60px 0; }
  .hero-visual { display: none; }
  .chapter { grid-template-columns: 80px 1fr; gap: var(--space-m); }
  .capabilities-grid { grid-template-columns: 1fr; }
  .capabilities-grid .capability-tile + .capability-tile { border-left: none; border-top: 1px solid var(--clay); padding-left: 0; padding-right: 0; }
  .capabilities-grid--four .capability-tile:nth-child(odd),
  .capabilities-grid--four .capability-tile:nth-child(even) { border-left: none; padding-left: 0; padding-right: 0; }
  .capabilities-grid--four .capability-tile:nth-child(3),
  .capabilities-grid--four .capability-tile:nth-child(4) { border-top: 1px solid var(--clay); }
  .hub-grid { grid-template-columns: 1fr; }
  .hub-card:nth-child(even) { border-left: none; padding-left: 0; border-top: 1px solid var(--clay); }
  .hub-card:nth-child(odd) { padding-right: 0; }
  .metrics-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-l) var(--space-xl); }
  .plan-smart-panel { grid-template-columns: 1fr; gap: var(--space-m); }
  .leadership-grid { grid-template-columns: repeat(2, 1fr); }
  .credentials-list { grid-template-columns: repeat(2, 1fr); }
  .contact-routes { grid-template-columns: repeat(2, 1fr); }
  .contact-route:nth-child(3n+1) { border-left: 1px solid var(--clay); padding-left: var(--space-l); }
  .contact-route:nth-child(3n) { padding-right: var(--space-l); }
  .contact-route:nth-child(2n+1) { border-left: none; padding-left: 0; }
  .contact-route:nth-child(2n) { padding-right: 0; }
  .contact-route:nth-child(n+3) { border-top-color: var(--clay); }
  .cta-grid { grid-template-columns: 1fr; gap: var(--space-xl); }
  .site-footer__grid { grid-template-columns: 1fr 1fr; }
}

/* ============================================================
   MOBILE (<640px)
   ============================================================ */
@media (max-width: 639px) {
  :root {
    --type-display: 36px;
    --type-h1: 30px;
    --type-h2: 24px;
    --type-h3: 18px;
    --type-lead: 18px;
    --type-body: 17px;
    --type-body-sm: 15px;
    --type-eyebrow: 11px;
    --type-caption: 12px;
    --type-metric: 36px;
    --type-chapter: 48px;
    --masthead-h: 64px;
  }
  .container { padding-left: var(--margin-mobile); padding-right: var(--margin-mobile); }
  .pulled-phrase__inner { padding-left: var(--margin-mobile); padding-right: var(--margin-mobile); }
  .section { padding: 60px 0; }
  .chapter { grid-template-columns: 1fr; }
  .chapter-mark { font-size: var(--type-chapter); margin-bottom: var(--space-s); }

  .nav-primary ul { display: none; }
  .nav-toggle { display: flex; flex-direction: column; gap: 5px; padding: 10px; margin-right: -10px; }
  .nav-toggle span { display: block; width: 22px; height: 1px; background: var(--bone); transition: transform var(--duration-base) var(--ease), opacity var(--duration-base) var(--ease); transform-origin: center; }
  .nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
  .nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
  .nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

  .mobile-nav {
    display: block; position: fixed; top: var(--masthead-h); left: 0; right: 0; bottom: 0;
    background: var(--ink); padding: var(--space-l) var(--margin-mobile); z-index: 99;
    opacity: 0; visibility: hidden;
    transition: opacity var(--duration-base) var(--ease), visibility var(--duration-base) var(--ease);
  }
  .mobile-nav.is-open { opacity: 1; visibility: visible; }
  .mobile-nav ul { display: flex; flex-direction: column; gap: var(--space-m); }
  .mobile-nav a { font-family: var(--font-display); font-weight: 500; font-size: 28px; letter-spacing: -0.015em; color: var(--bone); }

  .hero { min-height: auto; padding: var(--space-xl) 0 var(--space-2xl); }
  .hero-eyebrow { margin-bottom: var(--space-l); }

  .metrics-grid { grid-template-columns: 1fr 1fr; padding: var(--space-m) 0; gap: var(--space-m) var(--space-l); }
  .leadership-grid { grid-template-columns: 1fr; }
  .credentials-list { grid-template-columns: 1fr; }
  .contact-routes { grid-template-columns: 1fr; }
  .contact-route { border-left: none !important; padding-left: 0 !important; padding-right: 0 !important; }
  .contact-route + .contact-route { border-top: 1px solid var(--clay); }
  .capability-area { grid-template-columns: 1fr; gap: var(--space-xs); }

  .site-footer__grid { grid-template-columns: 1fr; gap: var(--space-m); }
  .site-footer__bottom { flex-direction: column; align-items: flex-start; gap: var(--space-s); }
}

/* Optional warm surface - gentle rhythm between Bone sections. */
.section--warm { background: var(--bone-press); }

/* ============================================================
   ELEMENTOR HOST ADJUSTMENTS (build-specific, not from mockups)
   ============================================================ */
.e-flexbox-base { display: block; }
.elementor .elementor-widget-html { width: 100%; max-width: none; }
.elementor-widget-html .elementor-widget-container { width: 100%; }
.elementor-widget-html p:last-child { margin-bottom: 0; }/* End custom CSS */