:root {
  --_tokens---background: var(--_primitives---neutral--100);
  --font-family: IBM Plex Mono, Noto Serif TC, monospace;
  --_tokens---on-background: var(--_primitives---neutral--800);
  --font-size: calc(var(--width-current) / var(--width-basis) * var(--font-basis));
  --outline-width: 1px;
  --_tokens---outline: var(--_primitives---black--50);
  --_responsive---site-header--height: 4em;
  --_tokens---header: var(--_primitives---neutral--alpha--150-75);
  --blur-radius: 24px;
  --_tokens---on-header: var(--_primitives---neutral--800);
  --_tokens---button: transparent;
  --_tokens---button-hovered: var(--_primitives---neutral--800);
  --_tokens---on-button: var(--_primitives---neutral--800);
  --container-max: 1920px;
  --_responsive---tagline--regular: 5.5em;
  --_tokens---on-background-muted: var(--_primitives---neutral--600);
  --_responsive---body--regular: 1em;
  --_responsive---body--small: .75em;
  --_responsive---body--medium: 1.5em;
  --_tokens---accent: var(--_primitives---green--600);
  --_responsive---menu--width: 20em;
  --_tokens---surface: var(--_primitives---white--25);
  --_tokens---on-surface: var(--_primitives---neutral--800);
  --_tokens---gradient-1: var(--_primitives---neutral--125);
  --_tokens---gradient-2: var(--_primitives---neutral--150);
  --_responsive---label--regular: 1em;
  --_responsive---label--small: .75em;
  --_responsive---label--large: 2em;
  --_responsive---title--regular: 1.5em;
  --_responsive---title--small: 1em;
  --_responsive---title--large: 3em;
  --_responsive---title--medium: 2em;
  --spacing-work-item: 5em;
  --_tokens---accent-high-contrast: var(--_primitives---green--800);
  --_tokens---on-button-hovered: var(--_primitives---neutral--100);
  --_tokens---button-cta: var(--_tokens---primary);
  --_tokens---on-button-cta: var(--_tokens---on-primary);
  --_tokens---button-cta-hovered: color-mix(in hsl, var(--_tokens---primary), white 10%);
  --spacing-column-x: 2em;
  --_tokens---background-accent: color-mix(in hsl, var(--_primitives---yellow--600), transparent 50%);
  --_primitives---white--50: #ffffff80;
  --_primitives---white--100: #fff;
  --_primitives---neutral--alpha--150-75: #c2bfbcbf;
  --_primitives---white--25: #ffffff40;
  --_primitives---black--25: #00000040;
  --_primitives---black--50: #00000080;
  --width-basis: 1440;
  --width-current: clamp(var(--container-min), 100vw, var(--container-max));
  --_primitives---black--100: #000;
  --container-min: 992px;
  --font-basis: 16;
  --_tokens---primary: var(--_primitives---neutral--800);
  --_tokens---on-primary: var(--_primitives---neutral--100);
  --_primitives---green--800: #00996e;
  --_primitives---green--600: #00e5a4;
  --_primitives---yellow--300: #fffb8d;
  --_primitives---yellow--600: #fff700;
  --_primitives---yellow--800: #a7a32e;
  --_primitives---neutral--200: #b6b2af;
  --_primitives---neutral--600: #5f6266;
  --_primitives---neutral--800: #2f3133;
  --_primitives---neutral--900: #212224;
  --_primitives---neutral--950: #1c1e1f;
  --_primitives---neutral--125: #dbd8d7;
  --_primitives---neutral--150: #c2bfbc;
  --_primitives---neutral--100: #e7e5e4;
}

.w-layout-vflex {
  flex-direction: column;
  align-items: flex-start;
  display: flex;
}

.w-layout-hflex {
  flex-direction: row;
  align-items: flex-start;
  display: flex;
}

.w-pagination-wrapper {
  flex-wrap: wrap;
  justify-content: center;
  display: flex;
}

.w-pagination-previous {
  color: #333;
  background-color: #fafafa;
  border: 1px solid #ccc;
  border-radius: 2px;
  margin-left: 10px;
  margin-right: 10px;
  padding: 9px 20px;
  font-size: 14px;
  display: block;
}

.w-pagination-previous-icon {
  margin-right: 4px;
}

.w-pagination-next {
  color: #333;
  background-color: #fafafa;
  border: 1px solid #ccc;
  border-radius: 2px;
  margin-left: 10px;
  margin-right: 10px;
  padding: 9px 20px;
  font-size: 14px;
  display: block;
}

.w-pagination-next-icon {
  margin-left: 4px;
}

body {
  background-color: var(--_tokens---background);
  font-family: var(--font-family);
  color: var(--_tokens---on-background);
  font-size: var(--font-size);
  --_responsive---site-header--height: 4em;
  --_responsive---tagline--regular: 5.5em;
  --_responsive---body--regular: 1em;
  --_responsive---body--small: .75em;
  --_responsive---body--medium: 1.5em;
  --_responsive---menu--width: 20em;
  --_responsive---label--regular: 1em;
  --_responsive---label--small: .75em;
  --_responsive---label--large: 2em;
  --_responsive---title--regular: 1.5em;
  --_responsive---title--small: 1em;
  --_responsive---title--large: 3em;
  --_responsive---title--medium: 2em;
  --_tokens---background: var(--_primitives---neutral--100);
  --_tokens---on-background: var(--_primitives---neutral--800);
  --_tokens---outline: var(--_primitives---black--50);
  --_tokens---header: var(--_primitives---neutral--alpha--150-75);
  --_tokens---on-header: var(--_primitives---neutral--800);
  --_tokens---button: transparent;
  --_tokens---button-hovered: var(--_primitives---neutral--800);
  --_tokens---on-button: var(--_primitives---neutral--800);
  --_tokens---on-background-muted: var(--_primitives---neutral--600);
  --_tokens---accent: var(--_primitives---green--600);
  --_tokens---surface: var(--_primitives---white--25);
  --_tokens---on-surface: var(--_primitives---neutral--800);
  --_tokens---gradient-1: var(--_primitives---neutral--125);
  --_tokens---gradient-2: var(--_primitives---neutral--150);
  --_tokens---accent-high-contrast: var(--_primitives---green--800);
  --_tokens---on-button-hovered: var(--_primitives---neutral--100);
  --_tokens---button-cta: var(--_tokens---primary);
  --_tokens---on-button-cta: var(--_tokens---on-primary);
  --_tokens---button-cta-hovered: color-mix(in hsl, var(--_tokens---primary), white 10%);
  --_tokens---background-accent: color-mix(in hsl, var(--_primitives---yellow--600), transparent 50%);
  --_tokens---primary: var(--_primitives---neutral--800);
  --_tokens---on-primary: var(--_primitives---neutral--100);
  overflow-x: clip;
}

.navigation-group---h {
  grid-column-gap: 1.5em;
  grid-row-gap: 1.5em;
  border-left: var(--outline-width) solid var(--_tokens---outline);
  justify-content: flex-end;
  align-items: center;
  height: 100%;
  margin: 0;
  padding: 0 2em;
  display: flex;
}

.navigation-group---h.grow {
  flex: 1;
}

.button---text {
  color: inherit;
  background-color: #0000;
  padding: .25em 0;
  text-decoration: none;
}

.button---home {
  height: 100%;
  color: inherit;
  padding: .5em;
}

.site-header {
  z-index: 999;
  height: var(--_responsive---site-header--height);
  border-top: var(--outline-width) solid var(--_tokens---outline);
  border-bottom: var(--outline-width) solid var(--_tokens---outline);
  background-color: var(--_tokens---header);
  -webkit-backdrop-filter: blur(var(--blur-radius));
  backdrop-filter: blur(var(--blur-radius));
  pointer-events: auto;
  color: var(--_tokens---on-header);
}

.svg {
  width: auto;
  height: 100%;
}

.navigation-item {
  justify-content: center;
  align-items: center;
  display: flex;
}

.site-navigation {
  flex: 1;
  justify-content: flex-end;
  align-items: stretch;
  height: 100%;
  display: flex;
}

.button---header {
  aspect-ratio: 1;
  border-left: var(--outline-width) solid var(--_tokens---outline);
  background-color: var(--_tokens---button);
  justify-content: center;
  align-items: center;
  transition: background-color .3s;
  display: flex;
}

.button---header:hover {
  background-color: var(--_tokens---button-hovered);
}

.icon-menu-line {
  background-color: var(--_tokens---on-button);
  width: 2.5em;
  height: 1px;
  transition: background-color .3s;
}

.icon-menu {
  grid-column-gap: .25em;
  grid-row-gap: .25em;
  flex-flow: column;
  justify-content: center;
  display: flex;
}

.container {
  height: 100%;
  max-width: var(--container-max);
  margin-left: auto;
  margin-right: auto;
  padding-left: 1em;
  padding-right: 1em;
}

.container.full-width {
  padding-left: 0;
  padding-right: 0;
}

.container.position-relative {
  position: relative;
}

.section-hero {
  height: calc(100svh - var(--_responsive---site-header--height));
}

.column {
  flex: 1;
}

.column.auto {
  flex: 0 auto;
}

.column.text-align-center {
  text-align: center;
}

.text---tagline {
  letter-spacing: -.1em;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: .125em;
  font-family: Instrument Sans, sans-serif;
  font-weight: 400;
  line-height: 100%;
}

.text---tagline.regular {
  font-size: var(--_responsive---tagline--regular);
}

.hero-inner {
  justify-content: flex-end;
  align-items: flex-start;
  height: 100%;
  padding-top: 2em;
  padding-bottom: 2em;
}

.text---body {
  font-family: var(--font-family);
  color: var(--_tokens---on-background-muted);
  letter-spacing: -.025em;
  margin-top: 0;
  margin-bottom: 1.5em;
  font-weight: 400;
  line-height: 150%;
}

.text---body.regular {
  font-size: var(--_responsive---body--regular);
}

.text---body.small {
  font-size: var(--_responsive---body--small);
}

.text---body.medium {
  font-size: var(--_responsive---body--medium);
}

.text---body.medium.highlighted {
  color: var(--_tokens---on-background);
}

.eyebrow {
  background-color: var(--_tokens---accent);
  width: 2.5em;
  height: .5em;
  margin-bottom: 1em;
}

.page-wrapper {
  width: 100%;
  min-height: 80vh;
  padding-bottom: 8em;
  padding-top: calc(8em + var(--_responsive---site-header--height));
  transition-property: right;
  transition-duration: .3s;
  transition-timing-function: ease;
  position: relative;
  right: 0;
  overflow: clip;
}

.page-wrapper.menu-opened {
  right: calc(.5 * var(--_responsive---menu--width));
}

.page-wrapper.page-wrapper-hero {
  padding-bottom: 0;
  padding-top: var(--_responsive---site-header--height);
}

.site-menu-drawer {
  height: calc(100% - var(--_responsive---site-header--height));
  justify-content: flex-end;
  align-items: flex-start;
  position: relative;
}

.header-wrapper {
  z-index: 999;
  pointer-events: none;
  width: 100%;
  position: fixed;
  inset: 0%;
  overflow: clip;
}

.site-menu {
  top: 0;
  right: calc(-1 * var(--_responsive---menu--width));
  width: var(--_responsive---menu--width);
  border-left-style: solid;
  border-left-width: var(--outline-width);
  border-left-color: var(--_tokens---outline);
  background-color: var(--_tokens---surface);
  height: 100%;
  -webkit-backdrop-filter: blur(var(--blur-radius));
  backdrop-filter: blur(var(--blur-radius));
  pointer-events: auto;
  color: var(--_tokens---on-surface);
  flex-flow: column;
  justify-content: space-between;
  padding-left: 1.5em;
  padding-right: 1.5em;
  transition-property: right;
  transition-duration: .3s;
  transition-timing-function: ease;
  display: flex;
  position: absolute;
}

.site-menu.menu-opened {
  right: 0;
}

.navigation-group---v {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  margin: 0;
  padding-top: 1em;
  padding-bottom: 1em;
  padding-left: 0;
  display: flex;
}

.navigation-group---v.grow {
  flex: 1;
}

.section-services {
  border-top: var(--outline-width) solid var(--_tokens---outline);
  border-bottom: var(--outline-width) solid var(--_tokens---outline);
  background-color: var(--_tokens---surface);
  -webkit-backdrop-filter: blur(var(--blur-radius));
  backdrop-filter: blur(var(--blur-radius));
  color: var(--_tokens---on-surface);
}

.block-row {
  border-bottom: var(--outline-width) solid var(--_tokens---outline);
  border-left: var(--outline-width) solid var(--_tokens---outline);
  align-items: stretch;
  display: flex;
}

.block-row.last {
  border-bottom-style: none;
}

.block {
  border-right-style: solid;
  border-right-width: var(--outline-width);
  border-right-color: var(--_tokens---outline);
  margin-left: calc(-1 * var(--outline-width));
  margin-right: calc(-1 * var(--outline-width));
  flex: 1;
  padding: .5em .75em 0;
}

.block:where(.w-variant-be9028db-cfe7-05db-b429-342896bfe603) {
  flex: none;
  min-width: 20%;
}

.block.service-item {
  align-items: flex-start;
  min-height: 8em;
  display: flex;
}

.block.service-item:where(.w-variant-be9028db-cfe7-05db-b429-342896bfe603), .block.service-item.empty {
  flex: 0 auto;
  width: 20%;
}

.block.auto {
  flex: 0 auto;
}

.half-circle-outter {
  z-index: -1;
  aspect-ratio: 1 / 2;
  background-color: var(--_tokens---gradient-1);
  border-top-right-radius: 9999px;
  border-bottom-right-radius: 9999px;
  justify-content: flex-start;
  align-items: center;
  height: 200%;
  display: flex;
  position: absolute;
  top: 0;
  right: 0;
}

.half-circle-inner {
  aspect-ratio: 1 / 2;
  background-color: var(--_tokens---gradient-2);
  border-top-right-radius: 9999px;
  border-bottom-right-radius: 9999px;
  height: 50%;
}

.text---label {
  letter-spacing: .05em;
  text-transform: uppercase;
  line-height: 100%;
}

.text---label.regular {
  font-size: var(--_responsive---label--regular);
}

.text---label.small {
  font-size: var(--_responsive---label--small);
}

.text---label.large {
  font-size: var(--_responsive---label--large);
}

.bullet {
  background-color: var(--_tokens---accent);
  border-radius: 999px;
  width: .75em;
  height: .75em;
  margin-right: .125em;
}

.text---title {
  letter-spacing: -.025em;
  margin-top: 0;
  margin-bottom: .75em;
  font-weight: 400;
  line-height: 100%;
}

.text---title.regular {
  font-size: var(--_responsive---title--regular);
}

.text---title.small {
  font-size: var(--_responsive---title--small);
}

.text---title.small.emphasized.recent-works-heading {
  text-align: right;
}

.text---title.large {
  font-size: var(--_responsive---title--large);
}

.text---title.medium {
  font-size: var(--_responsive---title--medium);
}

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

.section-recent-works {
  padding: 8em 7em;
}

.recent-works-wrapper {
  grid-column-gap: var(--spacing-work-item);
  grid-row-gap: var(--spacing-work-item);
  position: relative;
}

.work-image {
  aspect-ratio: 1;
  background-color: var(--_tokens---on-background-muted);
  background-image: url('https://d3e54v103j8qbb.cloudfront.net/img/background-image.svg');
  background-position: 0 0;
  background-repeat: no-repeat;
  background-size: cover;
  margin-bottom: 1em;
}

.work-image.work-image-1 {
  background-image: url('/images/Project-Thumbnail---P50B.png');
}

.work-image.work-image-2 {
  background-image: url('/images/Project-Thumbnail---WhizPad.png');
}

.work-image.work-image-3 {
  background-image: url('/images/Project-Thumbnail---5ENSLab.png');
}

.tag-item {
  border-top-style: solid;
  border-top-width: var(--outline-width);
  border-top-color: var(--_tokens---on-background);
  border-right-style: solid;
  border-right-width: var(--outline-width);
  border-right-color: var(--_tokens---on-background);
  border-bottom-style: solid;
  border-bottom-width: var(--outline-width);
  border-bottom-color: var(--_tokens---on-background);
  border-left-style: solid;
  border-left-width: var(--outline-width);
  border-left-color: var(--_tokens---on-background);
  border-radius: 999px;
  flex: none;
  width: fit-content;
  padding: .25em .75em;
}

.tag-item.text---label.small:where(.w-variant-20dc6c13-1411-8ef0-7b27-b2ceef1d3990) {
  border-color: var(--_tokens---accent-high-contrast);
  color: var(--_tokens---accent-high-contrast);
}

.tags {
  grid-column-gap: .5em;
  grid-row-gap: .5em;
  flex-flow: wrap;
  margin-bottom: .5em;
  display: flex;
}

.work-title {
  margin-bottom: .3125em;
}

.work-number {
  justify-content: flex-start;
  align-items: center;
  margin-bottom: .25em;
  display: flex;
}

.service-item-number {
  flex: none;
  justify-content: flex-start;
  align-items: center;
  padding-top: .25em;
  display: flex;
}

.service-item {
  align-items: flex-start;
  min-height: 8em;
  display: flex;
}

.button {
  border: var(--outline-width) solid var(--_tokens---on-button);
  background-color: var(--_tokens---button);
  color: var(--_tokens---on-button);
  padding: .6875em 1em .75em;
  transition: background-color .3s;
}

.button:hover {
  background-color: var(--_tokens---button-hovered);
  color: var(--_tokens---on-button-hovered);
}

.button.cta {
  background-color: var(--_tokens---button-cta);
  color: var(--_tokens---on-button-cta);
}

.button.cta:hover {
  background-color: var(--_tokens---button-cta-hovered);
}

.mode-light {
  --_tokens---background: var(--_primitives---neutral--100);
  --_tokens---on-background: var(--_primitives---neutral--800);
  --_tokens---outline: var(--_primitives---black--50);
  --_tokens---header: var(--_primitives---neutral--alpha--150-75);
  --_tokens---on-header: var(--_primitives---neutral--800);
  --_tokens---button: transparent;
  --_tokens---button-hovered: var(--_primitives---neutral--800);
  --_tokens---on-button: var(--_primitives---neutral--800);
  --_tokens---on-background-muted: var(--_primitives---neutral--600);
  --_tokens---accent: var(--_primitives---green--600);
  --_tokens---surface: var(--_primitives---white--25);
  --_tokens---on-surface: var(--_primitives---neutral--800);
  --_tokens---gradient-1: var(--_primitives---neutral--125);
  --_tokens---gradient-2: var(--_primitives---neutral--150);
  --_tokens---accent-high-contrast: var(--_primitives---green--800);
  --_tokens---on-button-hovered: var(--_primitives---neutral--100);
  --_tokens---button-cta: var(--_tokens---primary);
  --_tokens---on-button-cta: var(--_tokens---on-primary);
  --_tokens---button-cta-hovered: color-mix(in hsl, var(--_tokens---primary), white 10%);
  --_tokens---background-accent: color-mix(in hsl, var(--_primitives---yellow--600), transparent 50%);
  --_tokens---primary: var(--_primitives---neutral--800);
  --_tokens---on-primary: var(--_primitives---neutral--100);
}

.mode-dark {
  --_tokens---background: var(--_primitives---neutral--950);
  --_tokens---on-background: var(--_primitives---neutral--100);
  --_tokens---outline: var(--_primitives---white--50);
  --_tokens---header: var(--_primitives---black--25);
  --_tokens---on-header: var(--_primitives---neutral--100);
  --_tokens---button: transparent;
  --_tokens---button-hovered: var(--_primitives---neutral--100);
  --_tokens---on-button: var(--_primitives---neutral--100);
  --_tokens---on-background-muted: var(--_primitives---neutral--200);
  --_tokens---accent: var(--_primitives---green--600);
  --_tokens---surface: var(--_primitives---black--25);
  --_tokens---on-surface: var(--_primitives---neutral--100);
  --_tokens---gradient-1: var(--_primitives---neutral--800);
  --_tokens---gradient-2: var(--_primitives---neutral--900);
  --_tokens---accent-high-contrast: var(--_primitives---green--600);
  --_tokens---on-button-hovered: var(--_primitives---neutral--950);
  --_tokens---button-cta: var(--_tokens---primary);
  --_tokens---on-button-cta: var(--_tokens---on-primary);
  --_tokens---button-cta-hovered: color-mix(in hsl, var(--_tokens---primary), white 10%);
  --_tokens---background-accent: color-mix(in hsl, var(--_primitives---yellow--600), transparent 75%);
  --_tokens---primary: var(--_primitives---neutral--100);
  --_tokens---on-primary: var(--_primitives---neutral--950);
}

.site-footer {
  border-top-style: solid;
  border-top-width: var(--outline-width);
  border-top-color: var(--_tokens---outline);
  border-bottom-style: solid;
  border-bottom-width: var(--outline-width);
  border-bottom-color: var(--_tokens---outline);
  width: 100%;
  margin-right: calc(-1 * var(--outline-width));
  overflow: clip;
}

.footer-title {
  color: var(--_tokens---on-background-muted);
  margin-bottom: .25em;
}

.footer-links {
  margin-bottom: .5em;
  padding-left: 0;
  list-style: none;
}

.footer-link-item {
  padding-top: .25em;
  padding-bottom: .25em;
}

.footer-note {
  height: 100%;
  color: var(--_tokens---on-background-muted);
  justify-content: flex-start;
  align-items: center;
  padding-bottom: .5em;
}

.work-description {
  color: var(--_tokens---on-background-muted);
}

.button---back-to-top {
  cursor: pointer;
  transition: color .3s, background-color .3s;
}

.button---back-to-top:hover {
  background-color: var(--_tokens---button-hovered);
  color: var(--_tokens---on-button-hovered);
}

.icon---up {
  height: 3.5em;
}

.hero-wrapper {
  justify-content: flex-start;
  align-items: stretch;
  height: 100%;
  display: flex;
}

.work-item {
  margin-bottom: var(--spacing-work-item);
}

.work-item.indented {
  padding-right: 8em;
}

.work-item.margin-top {
  margin-top: 16em;
}

.the-work {
  padding-top: 8em;
  padding-bottom: 8em;
}

.row {
  grid-column-gap: var(--spacing-column-x);
  grid-row-gap: var(--spacing-column-x);
  display: flex;
}

.page-header {
  margin-bottom: 4em;
}

.image {
  width: 100%;
  margin-bottom: 2em;
}

.video-container {
  aspect-ratio: 16 / 9;
  width: 100%;
  margin-bottom: 2em;
}

.video {
  height: 100%;
}

.text-group {
  margin-bottom: 2em;
}

.text-group.centerd {
  text-align: center;
  max-width: 40em;
  margin: 2em auto 4em;
}

.list-item {
  margin-bottom: .125em;
}

.breadcrumb {
  margin-bottom: 2em;
}

.breadcrumb-item {
  text-decoration: none;
  display: inline-block;
}

.breadcrumb-item:hover {
  text-decoration: underline;
}

.utility-page-wrap {
  justify-content: center;
  align-items: center;
  width: 100vw;
  max-width: 100%;
  height: 100vh;
  max-height: 100%;
  display: flex;
}

.utility-page-content {
  text-align: center;
  flex-direction: column;
  width: 260px;
  display: flex;
}

.utility-page-form {
  flex-direction: column;
  align-items: stretch;
  display: flex;
}

.form-item {
  grid-column-gap: .5em;
  grid-row-gap: .5em;
  border-top-style: solid;
  border-top-width: var(--outline-width);
  border-top-color: var(--_tokens---on-background);
  border-right-style: solid;
  border-right-width: var(--outline-width);
  border-right-color: var(--_tokens---on-background);
  border-bottom-style: solid;
  border-bottom-width: var(--outline-width);
  border-bottom-color: var(--_tokens---on-background);
  border-left-style: solid;
  border-left-width: var(--outline-width);
  border-left-color: var(--_tokens---on-background);
  margin-bottom: calc(-1 * var(--outline-width));
  padding: .25em;
  display: flex;
}

.form-item-field {
  background-color: var(--_tokens---background-accent);
  appearance: none;
  border: 1px #000;
  border-radius: 0;
  flex: 1;
  margin-bottom: 0;
  padding: .25em 0;
}

.text---form-label {
  font-family: Instrument Sans, sans-serif;
  font-weight: 500;
  line-height: 100%;
}

.text---form-label.regular {
  font-size: var(--_responsive---label--regular);
}

.text---form-label.small {
  font-size: var(--_responsive---label--small);
}

.work-list-item-row {
  grid-column-gap: var(--spacing-column-x);
  grid-row-gap: var(--spacing-column-x);
  text-decoration: none;
  display: flex;
}

.work-list-item-row.outter {
  transition: transform .3s;
}

.work-list-item-row.outter:hover {
  transform: translate(1em);
}

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

.work-list-item-image {
  aspect-ratio: 1;
  object-fit: cover;
  max-width: 8em;
  height: 100%;
}

.work-list-item-title {
  margin-bottom: .25em;
}

.work-list-item-column {
  flex: 1;
}

.work-list-item-column.auto {
  flex: 0 auto;
}

.work-list-item-column.text-align-center {
  text-align: center;
}

.work-list-item-column.main {
  min-width: 40%;
}

.work-list-item {
  border-top-style: solid;
  border-top-width: var(--outline-width);
  border-top-color: var(--_tokens---outline);
  border-bottom-style: solid;
  border-bottom-width: var(--outline-width);
  border-bottom-color: var(--_tokens---outline);
  margin-bottom: calc(-1 * var(--outline-width));
  padding-top: 1em;
  padding-bottom: 1em;
}

.container-web-capture {
  text-align: center;
  max-width: 60em;
  margin-left: auto;
  margin-right: auto;
}

.shader-wrap {
  z-index: -1;
  width: 100%;
  height: 100vh;
  position: fixed;
  inset: 0%;
  overflow: hidden;
}

.us-scene {
  width: 100%;
  height: 100%;
}

.page-background {
  z-index: -1;
  width: 100%;
  height: 100lvh;
  position: fixed;
  inset: 0%;
}

.hero-background-fallback {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.loading-complete {
  overflow: auto;
}

@media screen and (max-width: 991px) {
  body {
    --_responsive---site-header--height: 4em;
    --_responsive---tagline--regular: 5.5em;
    --_responsive---body--regular: 1em;
    --_responsive---body--small: .75em;
    --_responsive---body--medium: 1.5em;
    --_responsive---menu--width: 20em;
    --_responsive---label--regular: 1em;
    --_responsive---label--small: .75em;
    --_responsive---label--large: 2em;
    --_responsive---title--regular: 1.5em;
    --_responsive---title--small: 1em;
    --_responsive---title--large: 3em;
    --_responsive---title--medium: 2em;
  }

  .half-circle-outter {
    width: 100%;
    height: auto;
    top: auto;
    bottom: -100vw;
  }

  .section-recent-works {
    padding-left: 5em;
    padding-right: 5em;
  }

  .footer-links {
    margin-top: .5em;
  }
}

@media screen and (max-width: 767px) {
  body {
    --_responsive---site-header--height: 4em;
    --_responsive---tagline--regular: 5.5em;
    --_responsive---body--regular: 1em;
    --_responsive---body--small: .75em;
    --_responsive---body--medium: 1.5em;
    --_responsive---menu--width: 20em;
    --_responsive---label--regular: 1em;
    --_responsive---label--small: .75em;
    --_responsive---label--large: 2em;
    --_responsive---title--regular: 1.5em;
    --_responsive---title--small: 1em;
    --_responsive---title--large: 3em;
    --_responsive---title--medium: 2em;
  }

  .section-recent-works {
    padding-left: 2em;
    padding-right: 2em;
  }
}

@media screen and (max-width: 479px) {
  body {
    --_responsive---site-header--height: 5em;
    --_responsive---tagline--regular: 5.5em;
    --_responsive---body--regular: 1.25em;
    --_responsive---body--small: .9375em;
    --_responsive---body--medium: 1.875em;
    --_responsive---menu--width: 70%;
    --_responsive---label--regular: 1.25em;
    --_responsive---label--small: .9375em;
    --_responsive---label--large: 2.5em;
    --_responsive---title--regular: 1.875em;
    --_responsive---title--small: 1.25em;
    --_responsive---title--large: 3.75em;
    --_responsive---title--medium: 2.5em;
  }

  .navigation-group---h {
    display: none;
  }

  .hero-inner.right {
    justify-content: center;
    align-items: flex-end;
  }

  .hero-inner.left {
    justify-content: flex-start;
    align-items: flex-start;
    padding-top: 5em;
  }

  .navigation-group---v {
    grid-column-gap: 1em;
    grid-row-gap: 1em;
  }

  .text---title.small.emphasized.recent-works-heading {
    margin-bottom: 2em;
  }

  .recent-works-wrapper {
    display: block;
  }

  .button {
    padding-top: 1em;
    padding-bottom: 1em;
  }

  .icon---up {
    height: 5em;
  }

  .hero-wrapper {
    flex-flow: column;
    display: flex;
  }

  .work-item.indented {
    padding-right: 0;
  }

  .work-item.margin-top {
    margin-top: 5em;
  }

  .row {
    display: block;
  }

  .form-item {
    min-height: 5em;
  }

  .work-list-item-row {
    grid-column-gap: .5em;
    grid-row-gap: .5em;
    flex-flow: column wrap;
  }

  .work-list-item-row.outter {
    grid-column-gap: 1.5em;
    grid-row-gap: 1.5em;
    flex-flow: row;
  }
}


