@font-face {
  font-family: "Montserrat";
  src: url("../fonts/Montserrat-Light.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src: url("../fonts/Montserrat-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src: url("../fonts/Montserrat-Medium.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src: url("../fonts/Montserrat-SemiBold.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

:root {
  color-scheme: light;
  --ink: #111111;
  --paper: #e9e9e7;
  --white: #ffffff;
  --black: #000000;
  --dark: #141017;
  --work-card: #161616;
  --card: #f7f7f6;
  --brand-green: #01644c;
  --line: rgba(17, 17, 17, 0.16);
  --line-dark: rgba(255, 255, 255, 0.18);
  --copy-muted: rgba(17, 17, 17, 0.66);
  --copy-muted-dark: rgba(233, 233, 231, 0.72);
  --loader-ring: rgba(17, 17, 17, 0.22);
  --menu-control: rgba(255, 255, 255, 0.22);
  --menu-control-hover: rgba(255, 255, 255, 0.28);
  --menu-link-muted: rgba(233, 233, 231, 0.58);
  --menu-copy: rgba(255, 255, 255, 0.72);
  --hero-title-color: rgba(17, 17, 17, 0.84);
  --hero-copy-color: rgba(17, 17, 17, 0.72);
  --card-border: rgba(17, 17, 17, 0.08);
  --about-text-muted: rgba(17, 17, 17, 0.2);
  --pad: clamp(24px, 2.25vw, 46px);
  --edge-x: clamp(42px, 2.55vw, 92px);
  --edge-y: clamp(28px, 3.35vh, 62px);
  --logo-size: clamp(24px, 1.35vw, 48px);
  --menu-line-width: clamp(32px, 1.9vw, 68px);
  --menu-line-height: clamp(2px, 0.112vw, 4px);
  --menu-line-gap: clamp(8px, 0.45vw, 16px);
  --ease-out: cubic-bezier(0.19, 1, 0.22, 1);
  --menu-ease: cubic-bezier(0.575, 0.015, 0, 0.995);
}

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

html {
  background: var(--paper);
  scroll-behavior: smooth;
  text-size-adjust: 100%;
}

body {
  margin: 0;
  overflow-x: hidden;
  background: var(--paper);
  color: var(--ink);
  font-family: "Montserrat", Arial, sans-serif;
  font-size: clamp(16px, 0.8vw, 22px);
  line-height: 1.4;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}

@supports (overflow: clip) {
  body {
    overflow-x: clip;
  }
}

body.menu-open,
body.menu-closing {
  overflow: hidden;
}

img,
picture {
  display: block;
}

img {
  max-width: 100%;
  height: auto;
}

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

button {
  border: 0;
  margin: 0;
  padding: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  cursor: pointer;
}

main {
  background: var(--dark);
}

.section-light {
  background: var(--paper);
  color: var(--ink);
}

.section-dark {
  background: var(--dark);
  color: var(--paper);
}

.page-loader {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  background: var(--paper);
  transition: opacity 0.6s ease, visibility 0.6s ease;
}

.page-loader span {
  width: 44px;
  height: 44px;
  border: 1px solid var(--loader-ring);
  border-top-color: var(--ink);
  border-radius: 50%;
  animation: spin 0.9s linear infinite;
}

body.is-loaded .page-loader {
  opacity: 0;
  visibility: hidden;
}

.site-header {
  position: fixed;
  inset: 0;
  z-index: 80;
  pointer-events: none;
}

.site-logo {
  position: fixed;
  top: calc(var(--edge-y) + env(safe-area-inset-top));
  left: calc((var(--edge-x) - clamp(5px, 0.28vw, 10px)) + env(safe-area-inset-left));
  z-index: 90;
  width: var(--logo-size);
  color: var(--black);
  pointer-events: auto;
  transition: color 260ms ease, opacity 180ms ease, transform 260ms ease;
}

.site-logo svg {
  width: 100%;
  height: auto;
}

.site-header.is-over-dark .site-logo {
  color: var(--white);
}

body.menu-open .site-logo,
body.menu-closing .site-logo {
  opacity: 0;
  pointer-events: none;
}

.menu-toggle {
  position: fixed;
  top: calc((var(--edge-y) + clamp(3px, 0.16vw, 6px)) + env(safe-area-inset-top));
  right: calc((var(--edge-x) - clamp(1.5px, 0.08vw, 3px)) + env(safe-area-inset-right));
  z-index: 100;
  display: flex;
  align-items: center;
  width: var(--menu-line-width);
  height: calc((var(--menu-line-height) * 3) + (var(--menu-line-gap) * 2));
  color: var(--black);
  pointer-events: auto;
  transition:
    top 360ms ease,
    right 360ms ease,
    width 360ms ease,
    height 360ms ease,
    color 260ms ease;
}

.site-header.is-over-dark .menu-toggle,
body.menu-open .menu-toggle,
body.menu-closing .menu-toggle {
  color: var(--white);
}

.menu-toggle__icon {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  transition:
    background-color 260ms ease,
    border-radius 360ms ease,
    opacity 220ms ease,
    transform 220ms ease;
}

.menu-toggle__icon svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: visible;
}

.menu-toggle__burger {
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.menu-toggle__icon .menu-toggle__close {
  inset: auto;
  top: 50%;
  right: auto;
  bottom: auto;
  left: 50%;
  width: 38%;
  height: 38%;
  opacity: 0;
  transform: translate(-50%, -50%) rotate(90deg) scale(0.8);
  transition: opacity 0.45s ease, transform 0.45s ease;
}

.menu-toggle:hover .menu-toggle__icon {
  opacity: 0.62;
  transform: scale(1.03);
}

body.menu-open .menu-toggle,
body.menu-closing .menu-toggle {
  top: calc(clamp(12px, 1vw, 18px) + env(safe-area-inset-top));
  right: calc(clamp(10px, 1vw, 18px) + env(safe-area-inset-right));
  width: clamp(58px, 5.6vw, 80px);
  height: clamp(58px, 5.6vw, 80px);
}

body.menu-open .menu-toggle__icon,
body.menu-closing .menu-toggle__icon {
  border-radius: 50%;
  background: var(--menu-control);
  opacity: 1;
  transform: none;
}

body.menu-open .menu-toggle:hover .menu-toggle__icon,
body.menu-closing .menu-toggle:hover .menu-toggle__icon {
  background: var(--menu-control-hover);
}

body.menu-open .menu-toggle__burger,
body.menu-closing .menu-toggle__burger {
  opacity: 0;
}

body.menu-open .menu-toggle__close,
body.menu-closing .menu-toggle__close {
  opacity: 1;
  transform: translate(-50%, -50%) rotate(90deg) scale(1);
}

.site-logo:focus-visible,
.menu-toggle:focus-visible,
.site-menu a:focus-visible,
.work-card:focus-visible,
.connect-heading:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 5px;
}

.site-menu {
  position: fixed;
  inset: 0;
  z-index: 60;
  display: flex;
  width: 100%;
  height: 100vh;
  height: 100dvh;
  overflow: auto;
  overscroll-behavior-y: contain;
  background: var(--black);
  color: var(--white);
  pointer-events: none;
  visibility: hidden;
  clip-path: polygon(0 0, 100% 0, 130% 0, 0 0);
  transform: rotate(7deg) scale(1.3);
  transform-origin: top right;
  transition:
    visibility 1s var(--menu-ease),
    clip-path 1s var(--menu-ease),
    transform 1s var(--menu-ease);
}

.site-menu.is-visible,
body.menu-closing .site-menu {
  visibility: visible;
}

.site-menu.is-visible {
  pointer-events: auto;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  transform: rotate(0) scale(1);
}

.site-menu__panel {
  display: flex;
  width: 100%;
  min-height: 100%;
}

.site-menu__container {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: start;
  width: 100%;
  max-width: min(calc(100vw - 200px), 1240px);
  min-height: 600px;
  margin: auto;
  padding: 60px 0;
}

.site-menu__nav {
  padding-left: 8px;
  clip-path: inset(-100vw 0 -100vw 0);
}

.site-menu__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.site-menu__item {
  display: flex;
  overflow: hidden;
  margin-top: 10px;
  padding: 15px 0;
  line-height: 26px;
}

.site-menu__item:first-child {
  padding-top: 6px;
}

.site-menu__item a {
  display: flex;
  color: var(--paper);
  font-size: 36px;
  font-weight: 600;
  line-height: 26px;
  text-transform: uppercase;
  transition: color 0.3s ease, opacity 0.2s ease-out;
}

.site-menu__list:hover .site-menu__item a {
  color: var(--menu-link-muted);
}

.site-menu__list .site-menu__item a:hover {
  color: var(--white);
}

.site-menu__contact {
  display: grid;
  align-content: start;
  gap: 35px;
  padding-left: 8px;
  color: var(--menu-copy);
  font-size: 16px;
  line-height: 1.7;
}

.site-menu__contact p {
  max-width: 36ch;
  margin: 0;
}

.site-menu__contact a {
  transition: color 0.3s ease;
}

.site-menu__contact a:hover {
  color: var(--white);
}

.hero {
  position: relative;
  display: grid;
  align-items: end;
  min-height: 100svh;
  padding: 210px var(--pad) 120px;
  overflow: hidden;
}

.hero__content {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1280px;
}

.hero-title {
  max-width: 1260px;
  margin: 0 0 24px;
  color: var(--hero-title-color);
  font-size: clamp(70px, 3vw, 90px);
  font-weight: 300;
  line-height: 1.2;
  letter-spacing: 0;
}

.hero-title__line {
  display: inline-flex;
  align-items: baseline;
  white-space: nowrap;
}

.word-rotator {
  display: inline-block;
  width: 10.5ch;
  min-width: 10.5ch;
  margin-left: 0.2em;
  color: var(--ink);
  white-space: nowrap;
  will-change: transform, opacity;
}

.word-rotator.is-changing {
  animation: word-swap 0.55s ease;
}

.hero-copy {
  max-width: min(720px, 100%);
  margin: 0;
  color: var(--hero-copy-color);
  font-size: clamp(20px, 0.9vw, 28px);
  font-weight: 400;
  line-height: 1.3;
}

.section-kicker {
  font-size: clamp(16px, 0.8vw, 22px);
  font-weight: 500;
  line-height: 1.2;
}

.work-capabilities-stack {
  position: relative;
  isolation: isolate;
  background: var(--dark);
}

.work {
  display: flex;
  align-items: center;
  height: 100vh;
  min-height: 640px;
  padding: 0 0 0 var(--pad);
  overflow: hidden;
  scroll-margin-top: 112px;
}

.work-carousel {
  position: relative;
  width: 100%;
}

.work-track {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: calc((100vw - var(--pad) - 60px) / 2.3);
  gap: 30px;
  overflow-x: auto;
  overflow-y: hidden;
  padding-right: var(--pad);
  scrollbar-width: none;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
}

.work-track::-webkit-scrollbar {
  display: none;
}

.work-card {
  position: relative;
  display: block;
  height: 82vh;
  min-height: 520px;
  overflow: hidden;
  background: var(--work-card);
  isolation: isolate;
  scroll-snap-align: start;
}

.work-card::after {
  position: absolute;
  inset: auto 0 0;
  z-index: 1;
  height: 42%;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.62), rgba(0, 0, 0, 0));
  content: "";
  pointer-events: none;
}

.work-card picture,
.work-card img {
  width: 100%;
  height: 100%;
}

.work-card img {
  object-fit: cover;
  transition: transform 0.9s var(--ease-out), filter 0.9s ease;
}

.work-card:hover img {
  filter: saturate(1.06) contrast(1.03);
  transform: scale(1.04);
}

.work-card__meta {
  position: absolute;
  right: clamp(18px, 2vw, 34px);
  bottom: clamp(18px, 2vw, 34px);
  left: clamp(18px, 2vw, 34px);
  z-index: 2;
  display: grid;
  gap: 6px;
  max-width: 38ch;
  color: var(--white);
  pointer-events: none;
}

.work-card__meta strong {
  font-size: clamp(20px, 1.2vw, 30px);
  font-weight: 500;
  line-height: 1.1;
}

.work-card__meta span {
  color: rgba(255, 255, 255, 0.78);
  font-size: clamp(13px, 0.72vw, 17px);
  line-height: 1.35;
}

.work-carousel.is-cursor-active .work-track {
  cursor: none;
}

.work-carousel.is-dragging .work-track {
  scroll-snap-type: none;
  user-select: none;
}

.carousel-cursor {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 70;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--paper);
  opacity: 0;
  pointer-events: none;
  transform: translate3d(-50%, -50%, 0) scale(0.6);
  transition: opacity 0.2s ease, transform 0.25s var(--ease-out);
  will-change: transform, opacity;
}

.carousel-cursor.is-visible {
  opacity: 1;
  transform: translate3d(-50%, -50%, 0) scale(1);
}

.carousel-cursor.is-grabbing {
  transform: translate3d(-50%, -50%, 0) scale(0.92);
}

.carousel-cursor__icon {
  font-size: 22px;
  font-weight: 400;
  line-height: 1;
}

.capabilities {
  --capabilities-pad-top: clamp(64px, 6vw, 110px);
  --capabilities-pad-bottom: clamp(96px, 9vw, 170px);
  --capabilities-kicker-stack: calc((clamp(16px, 0.8vw, 22px) * 1.2) + clamp(28px, 3vw, 60px));
  padding: var(--capabilities-pad-top) var(--pad) var(--capabilities-pad-bottom);
  overflow: hidden;
}

.capabilities__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(28px, 3vw, 60px);
  transform: translate3d(0, var(--capabilities-shift, 0), 0);
  will-change: transform;
}

.capability-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 30px;
}

.capability-card {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 22px;
  min-height: clamp(340px, 29vw, 520px);
  padding: clamp(30px, 2.55vw, 58px);
  overflow: hidden;
  border: 1px solid var(--card-border);
  border-radius: 6px;
  background: var(--card);
  color: var(--ink);
  transition:
    transform 0.35s ease,
    background 0.35s ease,
    border-color 0.35s ease,
    box-shadow 0.35s ease;
}

.capability-card:hover {
  transform: translateY(-6px);
}

.capability-card__icon {
  position: relative;
  z-index: 2;
  display: block;
  align-self: flex-start;
  width: clamp(148px, 13vw, 220px);
  height: clamp(130px, 10.5vw, 176px);
  margin-bottom: auto;
  transition: transform 0.35s ease;
}

.capability-card__icon picture,
.capability-card__icon img {
  width: 100%;
  height: 100%;
}

.capability-card__icon img {
  object-fit: contain;
  object-position: left top;
  transform-origin: left top;
}

.capability-card h3 {
  position: relative;
  z-index: 2;
  max-width: 560px;
  margin: 0 0 24px;
  font-size: clamp(32px, 1.5vw, 50px);
  font-weight: 400;
  line-height: 1.3;
}

.capability-card p {
  position: relative;
  z-index: 2;
  max-width: 590px;
  margin: 0;
  font-size: clamp(16px, 0.8vw, 22px);
  font-weight: 400;
  line-height: 1.4;
}

.stats {
  display: grid;
  grid-template-rows: 1fr auto;
  gap: 70px;
  min-height: 92svh;
  padding: 110px var(--pad) 125px;
  border-bottom: 1px solid var(--line-dark);
}

.stats__intro {
  max-width: 1100px;
  align-self: center;
  justify-self: center;
  text-align: center;
}

.stats__intro h2 {
  margin: 0;
  font-size: clamp(48px, 4.4vw, 110px);
  font-weight: 300;
  line-height: 1.1;
  letter-spacing: 0;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  border-top: 1px solid var(--line-dark);
}

.stat {
  padding: 38px 30px 0 0;
}

.stat h3 {
  margin: 0 0 18px;
  font-size: clamp(28px, 1.9vw, 44px);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 0;
}

.stat p {
  max-width: 32ch;
  margin: 0;
  color: var(--copy-muted-dark);
  font-size: clamp(18px, 1vw, 24px);
  font-weight: 400;
  line-height: 1.45;
  text-wrap: pretty;
}

@media (min-width: 861px) {
  .stat p {
    max-width: 29ch;
  }
}

.about-contact-stack {
  position: relative;
  isolation: isolate;
  background: var(--paper);
}

.about {
  position: relative;
  z-index: 9;
  display: grid;
  grid-template-columns: minmax(160px, 25%) minmax(0, 75%);
  gap: 0;
  padding: clamp(90px, 10vw, 210px) var(--pad);
  border-radius: 40px 40px 0 0;
}

.about-text {
  max-width: 1220px;
  margin: 0 0 52px;
  color: var(--ink);
  font-size: clamp(40px, 2.9vw, 56px);
  font-weight: 300;
  line-height: 1.22;
  letter-spacing: 0;
}

.about-text .text-word {
  display: inline-block;
  color: var(--ink);
  opacity: var(--word-opacity, 0.1);
  transition: opacity 0.18s linear;
}

.site-footer.connect-footer {
  position: relative;
  z-index: 10;
  min-height: 50svh;
  padding: 0 var(--pad) 26px;
  overflow: hidden;
  border-radius: 60px 60px 0 0;
  background: var(--white);
  color: var(--ink);
}

.connect-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-items: start;
  min-height: 50svh;
  padding: clamp(42px, 4vw, 72px) 0 clamp(28px, 3vw, 54px);
}

.connect-hero__content {
  display: grid;
  width: 100%;
  justify-items: start;
}

.connect-brand,
.connect-role,
.connect-bottom p {
  margin: 0;
}

.connect-brand {
  color: var(--ink);
  font-size: 16px;
  font-weight: 600;
  line-height: 1.4;
}

.connect-role {
  max-width: 440px;
  margin-top: 5px;
  color: var(--copy-muted);
  font-size: clamp(16px, 0.9vw, 22px);
}

.connect-heading {
  display: grid;
  width: max-content;
  max-width: 100%;
  margin-top: clamp(32px, 5vh, 68px);
  justify-self: start;
  color: var(--ink);
  font-size: clamp(58px, 6.2vw, 118px);
  font-weight: 300;
  line-height: 0.88;
  letter-spacing: 0;
  transition: color 0.25s ease, transform 0.25s ease;
}

.connect-heading:hover,
.connect-heading:focus-visible {
  color: var(--brand-green);
  transform: translateX(10px);
}

.connect-heading span {
  display: block;
}

.connect-bottom {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 1fr) minmax(130px, 0.6fr);
  gap: 26px;
  align-items: end;
  padding-top: clamp(18px, 2vw, 30px);
  border-top: 1px solid var(--line);
  color: var(--copy-muted);
}

.connect-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 22px;
  justify-content: center;
  text-align: center;
}

.connect-links a,
.connect-bottom a {
  transition: color 0.25s ease;
}

.connect-links a:hover,
.connect-links a:focus-visible,
.connect-bottom a:hover,
.connect-bottom a:focus-visible {
  color: var(--brand-green);
}

.connect-bottom > p:last-child {
  text-align: right;
}

.js .reveal {
  opacity: 0;
  transform: translateY(34px);
  transition: opacity 0.8s ease, transform 0.8s var(--ease-out);
}

.js .reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (min-width: 861px) {
  .work-capabilities-stack .work {
    position: sticky;
    top: 0;
    z-index: 1;
  }

  .work-capabilities-stack .capabilities {
    position: relative;
    z-index: 2;
    display: grid;
    align-items: center;
    min-height: 100svh;
  }

  .work-capabilities-stack .capabilities__inner {
    --capabilities-center-offset: calc((var(--capabilities-pad-bottom) - var(--capabilities-pad-top) - var(--capabilities-kicker-stack)) / 2);
    transform: translate3d(0, var(--capabilities-center-offset), 0);
    will-change: auto;
  }

  .about-contact-stack .about {
    position: sticky;
    top: 0;
    z-index: 1;
    min-height: 100svh;
  }

  .about-contact-stack .site-footer.connect-footer {
    z-index: 2;
  }
}

@media (max-width: 1180px) {
  .work-track {
    grid-auto-columns: calc((100vw - var(--pad) - 40px) / 1.7);
    gap: 24px;
  }

  .work-card {
    height: 78vh;
    min-height: 460px;
  }

  .connect-bottom {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .connect-links {
    justify-content: start;
    text-align: left;
  }

  .connect-bottom > p:last-child {
    text-align: left;
  }
}

@media (max-width: 980px) {
  .hero-title {
    font-size: 46px;
    line-height: 1;
  }

  .about-text {
    font-size: 34px;
    line-height: 1.2;
  }

  .stats__intro h2,
  .capability-card h3 {
    font-size: 30px;
    line-height: 1.2;
  }

  .stat h3 {
    font-size: 26px;
    line-height: 1.2;
  }

  .about {
    border-radius: 34px 34px 0 0;
  }
}

@media (max-width: 860px) {
  .hero {
    min-height: 92svh;
    padding-top: 145px;
    padding-bottom: 76px;
  }

  .work {
    display: block;
    height: auto;
    min-height: 0;
    padding: 60px 0 88px var(--pad);
  }

  .work-track {
    grid-auto-columns: minmax(300px, calc(100vw - 48px));
    gap: 20px;
  }

  .work-card {
    height: auto;
    min-height: 0;
    aspect-ratio: 4 / 3;
  }

  .work-card__meta {
    max-width: 32ch;
  }

  .about,
  .capabilities {
    grid-template-columns: 1fr;
  }

  .about {
    row-gap: clamp(36px, 8vw, 54px);
  }

  .about-text {
    color: var(--about-text-muted);
  }

  .capability-grid,
  .stats-grid {
    grid-template-columns: 1fr;
  }

  .capability-card {
    min-height: 300px;
  }

  .stats {
    min-height: auto;
  }

  .site-footer.connect-footer {
    min-height: auto;
    margin-top: -42px;
    border-radius: 42px 42px 0 0;
  }

  .connect-hero {
    min-height: auto;
    padding-top: clamp(46px, 7vw, 68px);
  }

  .connect-heading {
    font-size: clamp(46px, 8vw, 72px);
  }
}

@media (max-width: 760px) {
  :root {
    --edge-x: clamp(18px, 6vw, 32px);
    --edge-y: clamp(16px, 4vh, 28px);
    --logo-size: clamp(26px, 8vw, 36px);
    --menu-line-width: clamp(32px, 11vw, 42px);
    --menu-line-height: 2px;
    --menu-line-gap: clamp(7px, 2.5vw, 9px);
  }

  .site-menu__container {
    grid-template-columns: 1fr;
    justify-items: center;
    max-width: min(100vw, 1240px);
    min-height: min(520px, calc(100dvh - 120px));
    padding: 60px 0 0;
  }

  .site-menu__nav {
    padding-left: 0;
  }

  .site-menu__item {
    justify-content: center;
    padding: 10px 0;
  }

  .site-menu__item a {
    font-size: clamp(26px, 7.7vw, 34px);
    text-align: center;
  }

  .site-menu__contact {
    display: none;
  }
}

@media (max-width: 620px) {
  :root {
    --pad: 20px;
  }

  body {
    font-size: 16px;
    line-height: 1.5;
  }

  .section-kicker {
    font-size: 16px;
  }

  .hero-title {
    font-size: clamp(31px, 8.25vw, 36px);
    line-height: 1.2;
  }

  .hero-title__line {
    display: inline;
    white-space: normal;
  }

  .word-rotator {
    width: auto;
    min-width: 0;
    margin-left: 0;
  }

  .hero-copy {
    max-width: 330px;
    font-size: 18px;
  }

  .about,
  .capabilities,
  .stats {
    padding-left: var(--pad);
    padding-right: var(--pad);
  }

  .about-text {
    font-size: 27px;
    line-height: 1.22;
  }

  .capability-grid {
    gap: 18px;
  }

  .capability-card {
    padding: 28px;
  }

  .capability-card__icon {
    width: 136px;
    height: 116px;
  }

  .stats__intro h2,
  .capability-card h3 {
    font-size: 24px;
    line-height: 1.2;
  }

  .stat p {
    font-size: 20px;
    line-height: 1.3;
  }

  .site-footer.connect-footer {
    padding: 0 var(--pad) 24px;
    border-radius: 36px 36px 0 0;
  }

  .connect-hero {
    justify-items: center;
    padding-top: 46px;
    padding-bottom: 34px;
    text-align: center;
  }

  .connect-hero__content {
    justify-items: center;
  }

  .connect-heading {
    width: auto;
    justify-self: start;
    justify-content: start;
    margin-top: 30px;
    font-size: clamp(36px, 10vw, 48px);
    text-align: left;
  }

  .connect-heading:hover,
  .connect-heading:focus-visible {
    transform: translateY(-4px);
  }

  .connect-bottom {
    justify-items: center;
    text-align: center;
  }

  .connect-links {
    justify-content: center;
    text-align: center;
  }

  .connect-bottom > p:last-child {
    text-align: center;
  }
}

@media (max-height: 640px) and (orientation: landscape) {
  :root {
    --edge-y: 16px;
    --logo-size: clamp(24px, 7vh, 32px);
    --menu-line-width: clamp(32px, 11vh, 42px);
    --menu-line-height: 2px;
    --menu-line-gap: 7px;
  }

  .site-menu__container {
    min-height: calc(100dvh - 64px);
    padding-top: 54px;
    padding-bottom: 36px;
  }

  .site-menu__item {
    padding: clamp(5px, 2vh, 10px) 0;
  }

  .site-menu__item a {
    font-size: clamp(24px, 8vh, 34px);
  }
}

@media (min-width: 761px) and (max-width: 1024px) {
  .site-menu__container {
    max-width: min(calc(100vw - 100px), 1240px);
    padding: 60px 0 0;
  }
}

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

  .capabilities__inner {
    transform: none;
    will-change: auto;
  }
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes word-swap {
  0% {
    opacity: 1;
    transform: translateY(0);
  }

  45% {
    opacity: 0;
    transform: translateY(18px);
  }

  55% {
    opacity: 0;
    transform: translateY(-18px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
