/* Hallmark - pre-emit critique: P5 H5 E5 S5 R5 V5 - genre: editorial - mood: premium-established - macrostructure: Split Studio - anchor: green - contrast: pass (40-41) - nav: N2 - footer: Ft2 - slop: pass (42-49) - mobile: pass (34,49,50-57) - enrichment: E6 centered ASCII LSS canvas */
@import url("../tokens.css");

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  overflow-x: clip;
  color-scheme: light;
  scroll-behavior: smooth;
}

body {
  min-width: 20rem;
  margin: 0;
  overflow-x: clip;
  background: var(--color-paper);
  color: var(--color-ink);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.62;
  letter-spacing: 0;
  text-rendering: optimizeLegibility;
}

body.menu-open,
body.dialog-open {
  overflow: clip;
}

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

button,
input,
select,
textarea {
  font: inherit;
  color: inherit;
}

button {
  cursor: pointer;
}

a {
  color: inherit;
  text-decoration: none;
}

p,
h1,
h2,
h3,
h4,
figure {
  margin: 0;
}

ul,
ol {
  margin: 0;
  padding: 0;
}

li {
  list-style: none;
}

::selection {
  background: var(--color-success-paper);
  color: var(--color-ink);
}

:focus {
  outline: 2px solid var(--color-focus-idle);
  outline-offset: 3px;
}

:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 3px;
}

.skip-link {
  position: fixed;
  inset-block-start: var(--space-sm);
  inset-inline-start: var(--space-sm);
  z-index: var(--z-tooltip);
  transform: translateY(-160%);
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  padding-inline: var(--space-md);
  border: var(--rule-hair) solid var(--color-rule);
  background: var(--color-paper);
  color: var(--color-ink);
  font-weight: 700;
  transition: transform var(--dur-short) var(--ease-out);
}

.skip-link:focus-visible {
  transform: translateY(0);
}

.site-header {
  position: sticky;
  inset-block-start: 0;
  z-index: var(--z-sticky);
  background: var(--color-paper);
  border-block-end: var(--rule-hair) solid var(--color-rule);
}

body[data-page="home"] .site-header {
  position: fixed;
  inset-inline: 0;
  transition:
    background-color var(--dur-long) var(--ease-out),
    border-color var(--dur-long) var(--ease-out),
    color var(--dur-long) var(--ease-out);
}

body[data-page="home"] .site-header.is-home-at-top:not(.is-menu-open) {
  background: var(--color-hero-panel);
  border-block-end-color: var(--color-hero-panel-rule);
  color: var(--color-paper);
}

.mast-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  min-height: 36px;
  padding-inline: var(--space-md);
  border-block-end: var(--rule-hair) solid var(--color-rule-2);
  color: var(--color-muted);
  font-family: var(--font-body);
  font-size: var(--text-xs);
}

body[data-page="home"] .mast-meta,
body[data-page="home"] .brand img,
body[data-page="home"] .nav-list,
body[data-page="home"] .menu-toggle {
  transition:
    border-color var(--dur-long) var(--ease-out),
    color var(--dur-long) var(--ease-out),
    filter var(--dur-long) var(--ease-out),
    background-color var(--dur-long) var(--ease-out),
    opacity var(--dur-long) var(--ease-out);
}

body[data-page="home"] .site-header.is-home-at-top:not(.is-menu-open) .mast-meta {
  border-block-end-color: var(--color-hero-panel-rule);
  color: var(--color-hero-text-muted);
}

.mast-meta span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.meta-link,
.search-open,
.menu-toggle,
.nav-link,
.nav-cta,
.button,
.text-link,
.footer-link {
  white-space: nowrap;
}

.search-open {
  min-height: 36px;
  border: 0;
  background: none;
  color: var(--color-ink);
  font-weight: 700;
}

body[data-page="home"] .site-header.is-home-at-top:not(.is-menu-open) .search-open,
body[data-page="home"] .site-header.is-home-at-top:not(.is-menu-open) .meta-link {
  color: var(--color-paper);
}

.mast-brand-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
}

.brand {
  min-width: 0;
  display: inline-flex;
  align-items: center;
}

.brand img {
  width: min(20rem, 100%);
  height: auto;
}

body[data-page="home"] .site-header.is-home-at-top:not(.is-menu-open) .brand img {
  filter: brightness(0) invert(1);
  opacity: 0.96;
}

.brand-fallback {
  display: none;
  font-family: var(--font-body);
  font-weight: 700;
}

.brand img.is-missing {
  display: none;
}

.brand img.is-missing + .brand-fallback {
  display: inline-block;
}

.menu-toggle {
  min-height: 40px;
  min-width: 40px;
  display: inline-grid;
  place-items: center;
  border: var(--rule-hair) solid var(--color-rule);
  border-radius: var(--radius-sm);
  background: var(--color-paper);
  color: var(--color-ink);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 700;
  transition:
    background-color var(--dur-short) var(--ease-out),
    color var(--dur-short) var(--ease-out),
    transform var(--dur-micro) var(--ease-out);
}

.menu-toggle:active {
  transform: translateY(1px);
}

body[data-page="home"] .site-header.is-home-at-top:not(.is-menu-open) .menu-toggle {
  border-color: var(--color-hero-panel-rule);
  background: var(--color-hero-panel);
  color: var(--color-paper);
}

.site-nav {
  display: none;
  padding: 0 var(--space-md) var(--space-sm);
}

.site-header.is-menu-open .site-nav {
  display: block;
}

.nav-list {
  display: grid;
  gap: var(--space-2xs);
  border-block-start: var(--rule-hair) solid var(--color-rule-2);
  padding-block-start: var(--space-sm);
}

.nav-link,
.nav-cta {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  border-radius: var(--radius-sm);
  font-weight: 700;
  transition:
    background-color var(--dur-short) var(--ease-out),
    color var(--dur-short) var(--ease-out),
    transform var(--dur-micro) var(--ease-out);
}

.nav-link {
  padding-inline: var(--space-sm);
  color: var(--color-ink-2);
}

.nav-cta {
  width: fit-content;
  margin-block-start: var(--space-xs);
  padding-inline: var(--space-md);
  border: var(--rule-hair) solid var(--color-ink);
  color: var(--color-ink);
}

.nav-link[aria-current="page"],
.nav-link:hover,
.nav-link:focus-visible,
.nav-cta:hover,
.nav-cta:focus-visible {
  background: var(--color-ink);
  color: var(--color-paper);
}

.nav-link:active,
.nav-cta:active {
  transform: translateY(1px);
}

body[data-page="home"] .site-header.is-home-at-top:not(.is-menu-open) .nav-list {
  border-block-start-color: var(--color-hero-panel-rule);
}

body[data-page="home"] .site-header.is-home-at-top:not(.is-menu-open) .nav-link,
body[data-page="home"] .site-header.is-home-at-top:not(.is-menu-open) .nav-cta {
  color: var(--color-paper);
}

body[data-page="home"] .site-header.is-home-at-top:not(.is-menu-open) .nav-cta {
  border-color: var(--color-paper);
}

body[data-page="home"] .site-header.is-home-at-top:not(.is-menu-open) .nav-link[aria-current="page"],
body[data-page="home"] .site-header.is-home-at-top:not(.is-menu-open) .nav-link:hover,
body[data-page="home"] .site-header.is-home-at-top:not(.is-menu-open) .nav-link:focus-visible,
body[data-page="home"] .site-header.is-home-at-top:not(.is-menu-open) .nav-cta:hover,
body[data-page="home"] .site-header.is-home-at-top:not(.is-menu-open) .nav-cta:focus-visible {
  border-color: var(--color-paper);
  background: var(--color-paper);
  color: var(--color-ink);
}

.page-shell {
  width: min(72rem, calc(100% - 2rem));
  margin-inline: auto;
}

.narrow-shell {
  width: min(54rem, calc(100% - 2rem));
  margin-inline: auto;
}

.wide-shell {
  width: min(88rem, calc(100% - 2rem));
  margin-inline: auto;
}

.hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-2xl);
  padding-block: var(--space-2xl) var(--space-3xl);
}

.hero-home {
  padding-block-start: var(--space-xl);
}

.hero.hero-home-motion {
  position: relative;
  isolation: isolate;
  display: block;
  overflow: clip;
  min-height: 100svh;
  min-height: 100dvh;
  padding-block: 0;
  background: var(--color-hero-surface);
  color: var(--color-paper);
}

.hero-home-inner {
  position: relative;
  z-index: var(--z-base);
  display: grid;
  gap: var(--space-2xl);
  min-height: inherit;
  align-content: center;
  align-items: start;
  padding-block: calc(var(--space-3xl) + var(--space-lg)) var(--space-lg);
}

.ascii-hero-canvas,
.ascii-hero-overlay {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.ascii-hero-canvas {
  z-index: 0;
  opacity: 1;
}

.ascii-hero-overlay {
  z-index: 1;
  background:
    linear-gradient(
      90deg,
      var(--color-hero-overlay-strong),
      var(--color-hero-overlay-mid) 44%,
      var(--color-hero-overlay-clear) 76%
    ),
    linear-gradient(
      180deg,
      var(--color-hero-overlay-clear) 12%,
      var(--color-hero-overlay-strong)
    );
}

.hero-home-motion .hero-copy {
  max-width: 42rem;
  padding-inline-end: 0;
}

.hero.hero-home-motion h1 {
  font-size: var(--text-display-s);
}

.hero-home-motion .section-label,
.hero-home-motion .hero-copy > p,
.hero-motion-note p {
  color: var(--color-hero-text-muted);
}

.hero-home-motion .hero-copy > p {
  margin-block-start: var(--space-md);
}

.hero-home-motion .hero-actions {
  margin-block-start: var(--space-md);
}

.hero-home-motion .button {
  border-color: var(--color-paper);
  background: var(--color-paper);
  color: var(--color-ink);
}

.hero-home-motion .button:hover,
.hero-home-motion .button:focus-visible {
  border-color: var(--color-paper-2);
  background: var(--color-paper-2);
  color: var(--color-ink);
}

.hero-home-motion .text-link {
  color: var(--color-paper);
}

.hero-home-motion .text-link:hover,
.hero-home-motion .text-link:focus-visible {
  color: var(--color-accent-ink);
}

.hero-motion-note {
  display: none;
  gap: var(--space-sm);
  align-self: end;
  max-width: 31rem;
  padding: var(--space-lg);
  border: var(--rule-hair) solid var(--color-hero-panel-rule);
  border-radius: var(--radius-card);
  background: var(--color-hero-panel);
}

.hero-motion-note strong {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-style: normal;
  line-height: 1.15;
}

.hero-copy,
.section-copy,
.prose,
.contact-panel {
  min-width: 0;
}

.section-label,
.fine-label,
.meta-text {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-muted);
  line-height: 1.4;
}

.section-label {
  margin-block-end: var(--space-sm);
}

.hero h1,
.page-title,
.section-title,
.statement,
.footer-statement {
  font-family: var(--font-display);
  font-weight: 800;
  font-style: normal;
  line-height: 1.06;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

.hero h1,
.page-title {
  max-width: 11ch;
  font-size: var(--text-display);
}

.section-title {
  max-width: 13ch;
  font-size: var(--text-3xl);
}

.section-title.is-wide,
.page-title.is-wide {
  max-width: 16ch;
}

.lede,
.hero-copy > p,
.section-copy > p,
.prose p,
.contact-panel p {
  max-width: 65ch;
  color: var(--color-ink-2);
  font-size: var(--text-md);
}

.hero-copy > p,
.section-copy > p,
.prose p + p,
.contact-panel p {
  margin-block-start: var(--space-lg);
}

.hero-actions,
.section-actions,
.form-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-md);
  margin-block-start: var(--space-xl);
}

.button {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  border: var(--rule-hair) solid var(--color-ink);
  border-radius: var(--radius-sm);
  padding: var(--space-sm) var(--space-lg);
  background: var(--color-ink);
  color: var(--color-paper);
  font-weight: 700;
  line-height: 1;
  transition:
    background-color var(--dur-short) var(--ease-out),
    color var(--dur-short) var(--ease-out),
    border-color var(--dur-short) var(--ease-out),
    transform var(--dur-micro) var(--ease-out);
}

.button:hover,
.button:focus-visible {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-accent-ink);
}

.button:active {
  transform: translateY(1px);
}

.button:disabled,
.button[aria-disabled="true"] {
  cursor: not-allowed;
  opacity: 0.55;
}

.button-outline {
  background: var(--color-paper);
  color: var(--color-ink);
}

.button-outline:hover,
.button-outline:focus-visible {
  background: var(--color-ink);
  border-color: var(--color-ink);
  color: var(--color-paper);
}

.text-link {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  border-block-end: var(--rule-hair) solid currentColor;
  color: var(--color-accent);
  font-weight: 700;
  transition:
    color var(--dur-short) var(--ease-out),
    transform var(--dur-micro) var(--ease-out);
}

.text-link:hover,
.text-link:focus-visible {
  color: var(--color-ink);
}

.text-link:active {
  transform: translateY(1px);
}

.hero-media {
  display: grid;
  gap: var(--space-md);
  align-self: start;
}

.media-frame {
  overflow: clip;
  border: var(--rule-hair) solid var(--color-rule);
  border-radius: var(--radius-card);
  background: var(--color-ink);
  box-shadow: var(--shadow-soft);
}

.media-frame video {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}

.media-frame video.is-hidden {
  display: none;
}

.system-note {
  display: grid;
  gap: var(--space-sm);
  padding: var(--space-lg);
  border: var(--rule-hair) solid var(--color-rule);
  border-radius: var(--radius-card);
  background: var(--color-paper-2);
}

.system-note strong {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  line-height: 1.15;
}

.system-note p {
  color: var(--color-ink-2);
}

.section {
  padding-block: var(--space-3xl);
  border-block-start: var(--rule-hair) solid var(--color-rule);
}

.section-tight {
  padding-block: var(--space-2xl);
}

.section-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-xl);
}

.split-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-xl);
  padding-block: var(--space-2xl);
  border-block-start: var(--rule-hair) solid var(--color-rule-2);
}

.split-row:first-child {
  border-block-start: 0;
  padding-block-start: 0;
}

.split-proof {
  min-width: 0;
  display: grid;
  align-content: start;
  gap: var(--space-md);
  border-radius: var(--radius-card);
  padding: var(--space-lg);
  background: var(--color-paper-2);
}

.split-proof h3 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  line-height: 1.12;
  overflow-wrap: anywhere;
}

.split-proof p {
  color: var(--color-ink-2);
}

.trust-grid,
.reason-grid,
.industry-grid,
.capability-grid,
.service-list,
.engagement-grid {
  display: grid;
  gap: var(--space-md);
}

.trust-item,
.reason-item,
.industry-card,
.capability-card,
.engagement-card {
  min-width: 0;
  border: var(--rule-hair) solid var(--color-rule);
  border-radius: var(--radius-card);
  padding: var(--space-lg);
  background: var(--color-paper);
}

.trust-item h3,
.reason-item h3,
.industry-card h3,
.capability-card h3,
.engagement-card h3,
.service-row h2,
.principle h3 {
  font-family: var(--font-display);
  font-weight: 800;
  font-style: normal;
  font-size: var(--text-xl);
  line-height: 1.16;
}

.trust-item p,
.reason-item p,
.industry-card p,
.capability-card p,
.engagement-card p,
.service-row p,
.principle p {
  margin-block-start: var(--space-sm);
  color: var(--color-ink-2);
}

.service-list {
  gap: 0;
  border-block-start: var(--rule-hair) solid var(--color-rule);
}

.service-row {
  display: grid;
  gap: var(--space-md);
  padding-block: var(--space-xl);
  border-block-end: var(--rule-hair) solid var(--color-rule);
}

.service-meta {
  display: grid;
  gap: var(--space-xs);
  align-content: start;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-muted);
}

.service-value {
  color: var(--color-accent);
  font-weight: 700;
}

.process-timeline {
  counter-reset: stage;
  display: grid;
  gap: var(--space-md);
}

.process-stage {
  min-width: 0;
  counter-increment: stage;
  display: grid;
  gap: var(--space-md);
  padding: var(--space-lg);
  border: var(--rule-hair) solid var(--color-rule);
  border-radius: var(--radius-card);
  background: var(--color-paper);
}

.process-stage::before {
  content: counter(stage, decimal-leading-zero);
  font-family: var(--font-body);
  color: var(--color-accent);
  font-weight: 700;
}

.process-stage h2,
.process-stage h3 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  line-height: 1.12;
  overflow-wrap: anywhere;
}

.process-stage p {
  color: var(--color-ink-2);
}

.principle-list {
  display: grid;
  gap: var(--space-lg);
}

.principle {
  padding-block-start: var(--space-lg);
  border-block-start: var(--rule-hair) solid var(--color-rule);
}

.capability-grid {
  grid-auto-rows: auto;
}

.capability-card {
  display: grid;
  align-content: space-between;
  gap: var(--space-xl);
  min-height: 15rem;
}

.capability-card.is-featured {
  background: var(--color-ink);
  color: var(--color-paper);
}

.capability-card.is-featured p,
.capability-card.is-featured .meta-text {
  color: var(--color-paper-2);
}

.capability-card .meta-text {
  color: var(--color-muted);
}

.quote-panel {
  padding: var(--space-2xl);
  border-radius: var(--radius-card);
  background: var(--color-ink);
  color: var(--color-paper);
}

.quote-panel p {
  max-width: 58ch;
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 800;
  line-height: 1.18;
}

.quote-panel span {
  display: block;
  margin-block-start: var(--space-lg);
  color: var(--color-paper-3);
  font-family: var(--font-body);
  font-size: var(--text-xs);
}

.contact-layout {
  display: grid;
  gap: var(--space-2xl);
}

.contact-panel {
  display: grid;
  gap: var(--space-lg);
  align-content: start;
}

.contact-methods {
  display: grid;
  gap: var(--space-md);
  padding-block-start: var(--space-lg);
  border-block-start: var(--rule-hair) solid var(--color-rule);
}

.contact-methods a {
  width: fit-content;
  color: var(--color-accent);
  font-weight: 700;
  border-block-end: var(--rule-hair) solid currentColor;
}

.contact-form {
  display: grid;
  gap: var(--space-lg);
  padding: var(--space-lg);
  border: var(--rule-hair) solid var(--color-rule);
  border-radius: var(--radius-card);
  background: var(--color-paper-2);
}

.form-row {
  display: grid;
  gap: var(--space-xs);
}

.form-row label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-ink);
}

.form-row input,
.form-row select,
.form-row textarea,
.search-field {
  width: 100%;
  min-height: 48px;
  border: var(--rule-hair) solid var(--color-rule);
  border-radius: var(--radius-input);
  background: var(--color-paper);
  color: var(--color-ink);
  padding: var(--space-sm) var(--space-md);
  transition:
    background-color var(--dur-short) var(--ease-out),
    border-color var(--dur-short) var(--ease-out);
}

.form-row textarea {
  min-height: 9rem;
  resize: vertical;
}

.form-row input:hover,
.form-row select:hover,
.form-row textarea:hover,
.search-field:hover {
  background: var(--color-paper-3);
}

.form-row input:focus-visible,
.form-row select:focus-visible,
.form-row textarea:focus-visible,
.search-field:focus-visible {
  border-color: var(--color-ink-2);
}

.form-row input:disabled,
.form-row select:disabled,
.form-row textarea:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}

.form-row[data-state="error"] input,
.form-row[data-state="error"] select,
.form-row[data-state="error"] textarea {
  border-color: var(--color-error);
  background: var(--color-error-paper);
}

.form-row[data-state="success"] input,
.form-row[data-state="success"] select,
.form-row[data-state="success"] textarea {
  border-color: var(--color-accent);
  background: var(--color-success-paper);
}

.form-status {
  min-height: 1.5rem;
  color: var(--color-accent);
  font-weight: 700;
}

.search-dialog {
  width: min(42rem, calc(100% - 2rem));
  max-height: min(44rem, calc(100dvh - 2rem));
  margin: auto;
  overflow: auto;
  border: var(--rule-hair) solid var(--color-rule);
  border-radius: var(--radius-card);
  padding: 0;
  background: var(--color-paper);
  color: var(--color-ink);
  box-shadow: var(--shadow-soft);
}

.search-dialog::backdrop {
  background: var(--color-scrim);
}

.dialog-inner {
  display: grid;
  gap: var(--space-lg);
  padding: var(--space-lg);
}

.dialog-header {
  display: flex;
  justify-content: space-between;
  gap: var(--space-lg);
  align-items: start;
  padding-block-end: var(--space-lg);
  border-block-end: var(--rule-hair) solid var(--color-rule);
}

.dialog-header h2 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  line-height: 1.1;
}

.icon-button {
  min-width: 44px;
  min-height: 44px;
  border: var(--rule-hair) solid var(--color-rule);
  border-radius: var(--radius-sm);
  background: var(--color-paper);
  color: var(--color-ink);
  font-weight: 700;
  transition:
    background-color var(--dur-short) var(--ease-out),
    color var(--dur-short) var(--ease-out),
    transform var(--dur-micro) var(--ease-out);
}

.icon-button:hover,
.icon-button:focus-visible {
  background: var(--color-ink);
  color: var(--color-paper);
}

.icon-button:active {
  transform: translateY(1px);
}

.site-search-form {
  display: grid;
  gap: var(--space-sm);
}

.search-row {
  display: grid;
  gap: var(--space-sm);
}

.search-results {
  display: grid;
  gap: var(--space-md);
}

.search-result {
  display: grid;
  gap: var(--space-xs);
  padding-block: var(--space-md);
  border-block-start: var(--rule-hair) solid var(--color-rule-2);
}

.search-result span {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-muted);
}

.search-result a {
  width: fit-content;
  color: var(--color-accent);
  font-weight: 700;
}

.search-result p {
  color: var(--color-ink-2);
}

.site-footer {
  border-block-start: var(--rule-hair) solid var(--color-rule);
  padding-block: var(--space-2xl) var(--space-xl);
}

.footer-statement {
  max-width: 18ch;
  font-size: var(--text-3xl);
}

.footer-grid {
  display: grid;
  gap: var(--space-xl);
  margin-block-start: var(--space-xl);
  padding-block-start: var(--space-lg);
  border-block-start: var(--rule-hair) solid var(--color-rule);
}

.footer-logo {
  width: min(20rem, 100%);
  height: auto;
}

.footer-links {
  min-width: 0;
  display: grid;
  gap: var(--space-sm);
}

.footer-links h2,
.footer-links h3 {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-muted);
}

.footer-link,
.footer-email {
  width: fit-content;
  color: var(--color-ink-2);
  font-weight: 700;
  overflow-wrap: anywhere;
  transition: color var(--dur-short) var(--ease-out);
}

.footer-link:hover,
.footer-link:focus-visible,
.footer-email:hover,
.footer-email:focus-visible {
  color: var(--color-accent);
}

.footer-bottom {
  display: grid;
  gap: var(--space-sm);
  margin-block-start: var(--space-xl);
  color: var(--color-muted);
  font-family: var(--font-body);
  font-size: var(--text-xs);
}

@media (min-width: 40rem) {
  .page-shell,
  .narrow-shell,
  .wide-shell {
    width: min(100% - 3rem, var(--shell-width, 72rem));
  }

  .narrow-shell {
    --shell-width: 54rem;
  }

  .wide-shell {
    --shell-width: 88rem;
  }

  .hero h1,
  .page-title {
    font-size: var(--text-display);
  }

  .hero.hero-home-motion h1 {
    font-size: var(--text-display);
  }

  .hero-home-inner {
    padding-block: calc(var(--space-3xl) + var(--space-xl)) var(--space-2xl);
  }

  .hero-home-motion .hero-copy > p {
    margin-block-start: var(--space-lg);
  }

  .hero-home-motion .hero-actions {
    margin-block-start: var(--space-xl);
  }

  .section-title {
    font-size: var(--text-4xl);
  }

  .search-row {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .trust-grid,
  .reason-grid,
  .industry-grid,
  .engagement-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .process-stage {
    grid-template-columns: 5rem minmax(0, 1fr);
  }

  .process-stage::before {
    grid-row: span 2;
  }

  .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .footer-bottom {
    grid-template-columns: minmax(0, 1fr) auto;
  }
}

@media (min-width: 60rem) {
  .mast-meta,
  .mast-brand-row,
  .site-nav {
    padding-inline: var(--space-lg);
  }

  .mast-brand-row {
    grid-template-columns: 1fr;
    justify-items: center;
    padding-block: var(--space-sm);
  }

  .brand {
    justify-content: center;
  }

  .menu-toggle {
    display: none;
  }

  .site-nav,
  .site-header.is-menu-open .site-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-md);
    padding-block: 0 var(--space-sm);
  }

  .nav-list {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
    border-block-start: 0;
    padding-block-start: 0;
  }

  .nav-link {
    padding-inline: var(--space-sm);
  }

  .nav-cta {
    margin-block-start: 0;
  }

  .mast-meta {
    min-height: 32px;
  }

  .search-open {
    min-height: 32px;
  }

  .brand img {
    width: min(21rem, 100%);
  }

  .hero {
    grid-template-columns: minmax(0, 1fr) minmax(20rem, 0.72fr);
    align-items: center;
  }

  .hero-home-inner {
    grid-template-columns: minmax(0, 0.95fr) minmax(20rem, 0.62fr);
    padding-block: calc(var(--space-3xl) + var(--space-2xl)) var(--space-2xl);
  }

  .hero-motion-note {
    display: grid;
    justify-self: end;
    align-self: center;
    margin-block-end: 0;
  }

  .hero-copy {
    padding-inline-end: var(--space-xl);
  }

  .section-grid {
    grid-template-columns: minmax(0, 0.82fr) minmax(20rem, 1fr);
    align-items: start;
  }

  .split-row {
    grid-template-columns: minmax(0, 0.85fr) minmax(20rem, 1fr);
    align-items: center;
  }

  .split-row.is-reversed {
    grid-template-columns: minmax(20rem, 1fr) minmax(0, 0.85fr);
  }

  .split-row.is-reversed .section-copy {
    order: 2;
  }

  .trust-grid {
    grid-template-columns: 1.2fr 0.9fr 0.9fr;
  }

  .reason-grid {
    grid-template-columns: 1.1fr 0.9fr 1fr;
  }

  .service-row {
    grid-template-columns: minmax(10rem, 0.35fr) minmax(0, 0.75fr) minmax(18rem, 1fr);
    align-items: start;
  }

  .process-timeline {
    gap: var(--space-lg);
  }

  .capability-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }

  .capability-card {
    grid-column: span 2;
  }

  .capability-card.is-wide {
    grid-column: span 3;
  }

  .capability-card.is-featured {
    grid-column: span 4;
  }

  .industry-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .contact-layout {
    grid-template-columns: minmax(0, 0.82fr) minmax(22rem, 0.8fr);
    align-items: start;
  }

  .footer-grid {
    grid-template-columns: minmax(14rem, 1.1fr) repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 80rem) {
  .site-header {
    display: grid;
    grid-template-columns: minmax(15rem, 0.32fr) minmax(0, 1fr);
    grid-template-areas:
      "meta meta"
      "brand nav";
    align-items: center;
  }

  .mast-meta {
    grid-area: meta;
    padding-inline: var(--space-xl);
  }

  .mast-brand-row {
    grid-area: brand;
    grid-template-columns: minmax(0, 1fr);
    justify-items: start;
    padding: var(--space-sm) var(--space-md) var(--space-sm) var(--space-xl);
  }

  .brand {
    justify-content: flex-start;
  }

  .brand img {
    width: min(18rem, 100%);
  }

  .site-nav,
  .site-header.is-menu-open .site-nav {
    grid-area: nav;
    justify-content: flex-end;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-xl) var(--space-sm) 0;
  }

  .nav-list {
    gap: var(--space-2xs);
  }

  .hero-home {
    padding-block: var(--space-3xl) var(--space-4xl);
  }

  .hero.hero-home-motion {
    min-height: 100svh;
    min-height: 100dvh;
    padding-block: 0;
  }

  .hero-home-inner {
    padding-block: calc(var(--space-3xl) + var(--space-lg)) var(--space-2xl);
  }

  .hero h1,
  .page-title {
    font-size: var(--text-display);
  }
}

@media (prefers-reduced-motion: reduce) {
  .ascii-hero-canvas {
    opacity: 0.86;
  }
}

@media (hover: hover) and (pointer: fine) {
  .trust-item:hover,
  .reason-item:hover,
  .industry-card:hover,
  .capability-card:hover,
  .engagement-card:hover,
  .process-stage:hover {
    transform: translateY(-2px);
  }

  .trust-item,
  .reason-item,
  .industry-card,
  .capability-card,
  .engagement-card,
  .process-stage {
    transition:
      transform var(--dur-short) var(--ease-out),
      border-color var(--dur-short) var(--ease-out);
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    animation-duration: 150ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 150ms !important;
  }
}
