@font-face {
  font-family: PP-NeueBit;
  src: url('../fonts/PPNeueBit-Bold.woff') format("woff"), url('../fonts/PPNeueBit-Bold.ttf') format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: PPFraktionMono;
  src: url('../fonts/PPFraktionMono-Light.woff') format("woff"), url('../fonts/PPFraktionMono-Light.ttf') format("truetype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Helvetica Narrow;
  src: url('../fonts/helr47w.ttf') format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --black: #000;
  --helv-narrow: "Helvetica Narrow", sans-serif;
  --light-grey: #b3b3b3;
  --dark-grey: #333;
  --blue: #3c3cff;
  --mid-grey: #666;
  --white: white;
  --black-2: black;
}

img {
  max-width: 100%;
  display: inline-block;
}

.home-section {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100vw;
  height: 100svh;
  display: flex;
  overflow: clip;
}

.bg-div {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.navbar {
  z-index: 999;
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  aspect-ratio: auto;
  background-color: var(--black);
  flex-flow: row;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: space-between;
  align-items: stretch;
  width: 100vw;
  height: 22px;
  display: flex;
  position: sticky;
  top: 0;
}

.navbar.wrapper {
  width: auto;
  height: auto;
  display: block;
}

.nav-div {
  -webkit-text-fill-color: inherit;
  background-clip: border-box;
  height: 100%;
}

.nav-div.mid {
  grid-column-gap: 10vw;
  grid-row-gap: 10vw;
  order: 0;
  justify-content: center;
  padding-left: 10px;
  padding-right: 10px;
  display: flex;
}

.nav-div.left {
  order: -1;
  width: 96px;
  padding-left: 10px;
  padding-right: 10px;
  display: flex;
}

.nav-div.right {
  cursor: default;
  flex-flow: column;
  order: 1;
  justify-content: center;
  align-items: stretch;
  width: 96px;
  padding-left: 10px;
  padding-right: 10px;
  display: flex;
}

.nav-link {
  color: var(--black);
  flex-flow: column;
  justify-content: center;
  align-items: stretch;
  height: 100%;
  text-decoration: none;
  display: flex;
}

.text-block {
  font-family: var(--helv-narrow);
  color: var(--light-grey);
  text-transform: uppercase;
  white-space: normal;
  font-size: 2svh;
  line-height: 100%;
  text-decoration: none;
}

.text-block.nav {
  text-align: center;
  margin-top: 2px;
  padding-top: 0;
  padding-bottom: 0;
  font-size: 16px;
}

.text-block._2024 {
  color: var(--light-grey);
  text-align: center;
  margin-top: 2px;
  font-size: 16px;
  display: none;
}

.image {
  height: 100%;
  padding-top: 2px;
  padding-bottom: 2px;
  display: block;
}

.image.nav-logo {
  display: block;
}

.image.home-logo {
  padding-top: 0;
  padding-bottom: 0;
}

.heading {
  font-family: var(--helv-narrow);
  color: var(--light-grey);
  text-align: center;
  text-transform: uppercase;
  margin-top: 2px;
  margin-bottom: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 100%;
  display: block;
}

.logo-div {
  z-index: 99999;
  background-color: var(--dark-grey);
  width: 100px;
  height: 100px;
  margin: auto;
  position: fixed;
  inset: 0%;
}

.contact-div {
  z-index: 99999;
  max-width: 160px;
  height: auto;
  margin-left: auto;
  margin-right: auto;
  display: block;
  position: fixed;
  inset: auto 0% 0%;
}

.contact-link {
  flex-flow: column;
  justify-content: center;
  align-items: stretch;
  width: 100%;
  height: 100%;
  text-decoration: none;
  display: flex;
}

.contact-text {
  z-index: 99999;
  font-family: var(--helv-narrow);
  color: var(--dark-grey);
  text-align: center;
  object-fit: fill;
  padding-top: 5px;
  padding-bottom: 5px;
  font-size: 18px;
  line-height: 100%;
}

.body.home, .body.work-index, .body.misc, .body.about, .body.attnw, .body.fr, .body.gfls, .body.e400, .body.ltc, .body.ans {
  background-color: var(--black);
}

.body.imprint {
  background-color: var(--black);
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.home-image {
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: block;
  position: fixed;
}

.about-section {
  background-color: var(--black);
  cursor: ns-resize;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100vw;
  height: 300rem;
  display: flex;
}

.lottie-animation {
  flex-flow: column;
  flex: 0 auto;
  align-self: center;
  align-items: center;
  width: 100vw;
  height: 106svh;
  margin-top: -6svh;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  position: fixed;
}

.misc-section {
  background-image: url('../images/bg-tile.jpg');
  background-position: 50% 0;
  background-size: 4vw;
  width: 100vw;
  height: 251vw;
  display: block;
  overflow: visible;
}

.mtpp-div {
  width: 42vw;
  height: 30vw;
  position: absolute;
  top: 7vw;
  left: 5vw;
  overflow: clip;
}

.mtpp-img {
  width: 100%;
  display: none;
}

.mtpp-img._1 {
  display: block;
}

.misc-info-div {
  z-index: 99999;
  pointer-events: none;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: none;
  height: auto;
  max-height: none;
  margin: auto;
  display: flex;
  position: fixed;
  inset: 0%;
}

.mtpp-text {
  z-index: 99999;
  font-family: var(--helv-narrow);
  color: var(--blue);
  text-align: center;
  object-fit: fill;
  background-color: #d9d9d9;
  font-size: 24px;
  line-height: 100%;
  display: none;
}

.lunya-fc-div {
  width: 30vw;
  height: 30vw;
  position: absolute;
  top: 21vw;
  left: 57vw;
  overflow: clip;
}

.fc-img._1 {
  width: 100%;
}

.fc-img._2, .fc-img._3, .fc-img._4, .fc-img._5, .fc-img._6, .fc-img._7, .fc-img._8 {
  width: 100%;
  display: none;
}

.lunya-fc-text {
  z-index: 99999;
  font-family: var(--helv-narrow);
  color: var(--blue);
  text-align: center;
  object-fit: fill;
  background-color: #d9d9d9;
  font-size: 24px;
  line-height: 100%;
  display: none;
}

.cf-logo-div {
  width: 16vw;
  height: 16vw;
  position: absolute;
  top: 53vw;
  left: 31vw;
  overflow: clip;
}

.cf-logo-img._1 {
  width: 100%;
}

.cf-logo-img._2 {
  width: 100%;
  display: none;
}

.cf-logo-text {
  z-index: 99999;
  font-family: var(--helv-narrow);
  color: var(--blue);
  text-align: center;
  object-fit: fill;
  background-color: #d9d9d9;
  font-size: 24px;
  line-height: 100%;
  display: none;
}

.endwars-div {
  justify-content: center;
  align-items: flex-start;
  width: 28vw;
  height: 40vw;
  display: flex;
  position: absolute;
  top: 85vw;
  left: 19vw;
  overflow: visible;
}

.endwars-img {
  max-width: none;
  height: 100%;
  margin-left: auto;
  margin-right: auto;
  display: none;
}

.endwars-img._1 {
  display: block;
}

.endwars-img._2, .endwars-img._4, .endwars-img._7, .endwars-img._8 {
  display: none;
}

.endwars-text {
  z-index: 99999;
  font-family: var(--helv-narrow);
  color: var(--blue);
  text-align: center;
  object-fit: fill;
  background-color: #d9d9d9;
  font-size: 24px;
  line-height: 100%;
  display: none;
}

.richie-ikab-div {
  cursor: alias;
  justify-content: center;
  align-items: center;
  width: 38vw;
  height: 22vw;
  display: flex;
  position: absolute;
  top: 59vw;
  left: 57vw;
  overflow: clip;
}

.richie-ikab-img {
  max-width: none;
  height: 100%;
  display: block;
}

.richie-ikab-vid {
  z-index: 99;
  background-color: var(--light-grey);
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: none;
  overflow: hidden;
}

.richie-ikab-text {
  z-index: 99999;
  font-family: var(--helv-narrow);
  color: var(--blue);
  text-align: center;
  object-fit: fill;
  background-color: #d9d9d9;
  font-size: 24px;
  line-height: 100%;
  display: none;
}

.poster-div {
  width: 30vw;
  height: 42vw;
  position: absolute;
  top: 105vw;
  left: 65vw;
  overflow: clip;
}

.poster-img {
  max-width: none;
  height: 100%;
  display: none;
}

.poster-img._1 {
  display: block;
}

.poster-text {
  z-index: 99999;
  font-family: var(--helv-narrow);
  color: var(--blue);
  text-align: center;
  object-fit: fill;
  background-color: #d9d9d9;
  font-size: 24px;
  line-height: 100%;
  display: none;
}

.lunya-iwhb-div {
  cursor: alias;
  justify-content: center;
  align-items: center;
  width: 22vw;
  height: 38vw;
  display: flex;
  position: absolute;
  top: 135vw;
  left: 5vw;
  overflow: clip;
}

.lunya-iwhb-img {
  max-width: none;
  height: 100%;
  display: block;
}

.lunya-iwhb-vid {
  z-index: 99;
  background-color: var(--light-grey);
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: none;
  overflow: hidden;
}

.lunya-iwhb-text {
  z-index: 99999;
  font-family: var(--helv-narrow);
  color: var(--blue);
  text-align: center;
  object-fit: fill;
  background-color: #d9d9d9;
  font-size: 24px;
  line-height: 100%;
  display: none;
}

.analogue-div {
  justify-content: center;
  align-items: flex-start;
  width: 30vw;
  height: 40vw;
  display: flex;
  position: absolute;
  top: 157vw;
  left: 50vw;
  overflow: visible;
}

.analogue-img {
  max-width: none;
  height: 100%;
  margin-left: auto;
  margin-right: auto;
  display: none;
}

.analogue-img._1 {
  display: block;
}

.analogue-img._2, .analogue-img._3, .analogue-img._4, .analogue-img._7, .analogue-img._8 {
  display: none;
}

.analogue-text {
  z-index: 99999;
  font-family: var(--helv-narrow);
  color: var(--blue);
  text-align: center;
  object-fit: fill;
  background-color: #d9d9d9;
  font-size: 24px;
  line-height: 100%;
  display: none;
}

.echochamber-div {
  width: 30vw;
  height: 42vw;
  position: absolute;
  top: 203vw;
  left: 11vw;
  overflow: clip;
}

.echochamber-img {
  max-width: none;
  height: 100%;
  display: none;
}

.echochamber-img._1 {
  display: block;
}

.echochamber-text {
  z-index: 99999;
  font-family: var(--helv-narrow);
  color: var(--blue);
  text-align: center;
  object-fit: fill;
  background-color: #d9d9d9;
  font-size: 24px;
  line-height: 100%;
  display: none;
}

.richie-witl-div {
  cursor: alias;
  justify-content: center;
  align-items: center;
  width: 38vw;
  height: 22vw;
  display: flex;
  position: absolute;
  top: 219vw;
  left: 57vw;
  overflow: clip;
}

.richie-witl-img {
  max-width: none;
  height: 100%;
  display: block;
}

.richie-witl-vid {
  z-index: 99;
  background-color: var(--light-grey);
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: none;
  overflow: hidden;
}

.richie-witl-text {
  z-index: 99999;
  font-family: var(--helv-narrow);
  color: var(--blue);
  text-align: center;
  object-fit: fill;
  background-color: #d9d9d9;
  font-size: 24px;
  line-height: 100%;
  display: none;
}

.work-index-section {
  grid-column-gap: 5svh;
  grid-row-gap: 5svh;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  padding-top: 20svh;
  padding-bottom: 35svh;
  display: flex;
}

.project-header {
  color: var(--light-grey);
  text-align: center;
  text-transform: uppercase;
  mix-blend-mode: difference;
  font-family: PP-NeueBit, sans-serif;
  font-size: 10vw;
  font-weight: 700;
  line-height: 65%;
}

.project-div-line {
  border: .35vw solid var(--light-grey);
  mix-blend-mode: difference;
  height: 18vw;
}

.cover-img-div {
  z-index: -5;
  pointer-events: none;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100vw;
  height: 100svh;
  display: flex;
  position: fixed;
  inset: 0%;
}

.cover-img {
  height: 70svh;
  margin: auto;
  display: none;
  position: absolute;
}

.project-link {
  text-decoration: none;
}

.project-section {
  justify-content: space-between;
  margin-top: 22px;
  display: flex;
}

.project-section.attnw, .project-section.fr, .project-section.gfls, .project-section.e400, .project-section.ltc {
  position: fixed;
  inset: 0%;
}

.project-section.ans {
  flex-flow: row;
  justify-content: space-between;
  align-items: stretch;
  height: auto;
  margin-top: 22px;
  display: flex;
  position: fixed;
  inset: 0%;
}

.project-text-div {
  background-color: var(--light-grey);
  cursor: ns-resize;
  width: 50%;
  height: 100%;
  overflow: scroll;
}

.project-img-div {
  grid-column-gap: 1vw;
  grid-row-gap: 1vw;
  background-color: var(--black);
  cursor: ns-resize;
  flex-flow: column;
  justify-content: flex-start;
  align-items: stretch;
  width: 50%;
  padding: .5vw 1vw 1vw;
  display: flex;
  overflow: scroll;
}

.project-img._1 {
  aspect-ratio: auto;
}

.project-img._4 {
  object-fit: cover;
  flex: 1;
}

.row-div {
  grid-column-gap: 1vw;
  grid-row-gap: 1vw;
  justify-content: space-between;
  align-items: flex-start;
  display: flex;
}

.row-div._1, .row-div._4 {
  justify-content: space-between;
  align-items: center;
}

.row-div._5 {
  grid-template-rows: auto;
  grid-template-columns: 1fr 1.2fr;
  grid-auto-columns: 1fr;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  display: grid;
}

.row-div._7 {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 25vw;
  display: flex;
}

.row-div.fr-1 {
  justify-content: space-between;
  align-items: center;
}

.row-div.fr-4 {
  grid-template-rows: auto;
  grid-template-columns: 1fr 1.8fr;
  grid-auto-columns: 1fr;
}

.row-div.fr-6 {
  grid-template-rows: auto;
  grid-template-columns: 2.1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.row-div.e400-1 {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 29vw;
}

.row-div.e400-3 {
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.row-div.e400-4 {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 29vw;
}

.row-div.ltc-4 {
  justify-content: space-between;
  align-items: center;
}

.row-div.ltc-3 {
  grid-template-rows: auto;
  grid-template-columns: 1fr 3.8fr;
  grid-auto-columns: 1fr;
  display: flex;
}

.row-div.ltc-2 {
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.row-div.ans-3 {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 29vw;
}

.row-div.ans-6 {
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.row-div.ans-7 {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 29vw;
}

.project-lb {
  cursor: zoom-in;
  flex-flow: column;
  flex: 1;
  height: 100%;
  display: flex;
}

.background-video {
  z-index: 9;
  width: 100%;
  height: 100%;
}

.background-video-2 {
  z-index: 9;
  height: 100%;
}

.background-video-3, .background-video-5 {
  z-index: 99;
  width: 100%;
}

.marquee-div {
  grid-column-gap: 2vw;
  grid-row-gap: 2vw;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding-top: .5vw;
  padding-left: 1vw;
  padding-right: 1vw;
  display: flex;
}

.header-div {
  padding: 1vw 1vw 0;
}

.description-div {
  padding: 1vw;
}

.project-heading {
  color: var(--black);
  text-transform: uppercase;
  width: 100%;
  margin-top: 0;
  margin-bottom: 0;
  font-family: PP-NeueBit, sans-serif;
  font-size: 8vw;
  font-weight: 700;
  line-height: 65%;
}

.project-description {
  color: var(--black);
  width: 100%;
  margin-bottom: 0;
  font-family: PPFraktionMono, sans-serif;
  font-size: 1.2vw;
  font-weight: 300;
  line-height: 150%;
}

.year-div {
  flex: 0 auto;
  justify-content: center;
  align-items: center;
  height: 100%;
  padding-top: 1vw;
  padding-bottom: 1vw;
  display: flex;
}

.marquee-container {
  flex: 0 auto;
  justify-content: flex-start;
  align-items: center;
  max-width: 76%;
  height: 100%;
  display: flex;
  overflow: hidden;
}

.year-text, .category-text {
  color: var(--black);
  font-family: PPFraktionMono, sans-serif;
  font-size: 1.2vw;
  font-weight: 300;
  line-height: 100%;
}

.category-container {
  justify-content: space-around;
  align-items: center;
  min-width: 100%;
  padding: 1vw 0;
  display: flex;
}

.footer-div {
  z-index: 9999;
  justify-content: space-between;
  align-items: flex-start;
  width: 100vw;
  display: flex;
  position: relative;
  inset: auto 0% 0%;
}

.footer-link {
  flex-flow: column;
  justify-content: center;
  align-items: stretch;
  text-decoration: none;
  display: flex;
}

.footer-text {
  z-index: 99999;
  font-family: var(--helv-narrow);
  color: var(--dark-grey);
  text-align: center;
  object-fit: fill;
  padding: 5px;
  font-size: 18px;
  line-height: 100%;
}

.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;
}

.addinfo-div {
  justify-content: space-between;
  align-items: flex-start;
  padding: 2vw 1vw 3vw;
  display: flex;
}

.addinfo-text {
  color: var(--black);
  overflow-wrap: anywhere;
  width: 100%;
  margin-bottom: 0;
  font-family: PPFraktionMono, sans-serif;
  font-size: 1.2vw;
  font-weight: 300;
  line-height: 150%;
}

.addinfo-wrapper {
  grid-column-gap: 1vw;
  grid-row-gap: 1vw;
  flex-flow: column;
  flex: 0 auto;
  width: 100%;
  display: flex;
}

.addinfo-header {
  color: var(--black);
  width: 100%;
  margin-top: 0;
  margin-bottom: 0;
  font-family: PPFraktionMono, sans-serif;
  font-size: 1.2vw;
  font-weight: 300;
  line-height: 150%;
  text-decoration: underline;
}

.addinfo-link {
  text-decoration: none;
}

.imprint-div {
  grid-column-gap: 2vw;
  grid-row-gap: 2vw;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 50vw;
  margin-top: 10vw;
  margin-bottom: 10vw;
  display: flex;
}

.imprint-header {
  color: var(--mid-grey);
  width: 100%;
  margin-top: 0;
  margin-bottom: 0;
  font-family: PPFraktionMono, sans-serif;
  font-size: 1vw;
  font-weight: 300;
  line-height: 150%;
  text-decoration: underline;
}

.imprint-text {
  color: var(--mid-grey);
  width: 100%;
  margin-bottom: 0;
  font-family: PPFraktionMono, sans-serif;
  font-size: 1vw;
  font-weight: 300;
  line-height: 150%;
}

.projectnav-div {
  justify-content: space-between;
  align-items: flex-start;
  padding: 1vw;
  display: flex;
}

.projectnav-text {
  color: var(--black);
  font-family: PPFraktionMono, sans-serif;
  font-size: 1.2vw;
  font-weight: 300;
  line-height: 100%;
}

.projectnav-link {
  flex-flow: column;
  justify-content: center;
  align-items: stretch;
  text-decoration: none;
  display: flex;
}

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

.nav-menu {
  grid-column-gap: 10vw;
  grid-row-gap: 10vw;
  justify-content: center;
  padding-left: 10px;
  padding-right: 10px;
  display: flex;
}

.footer-bg {
  background-color: var(--light-grey);
}

.about-div {
  width: 100%;
  height: 100%;
}

.project-section-mobile {
  margin-top: 28px;
  display: none;
  position: fixed;
  inset: 0%;
}

.project-section-mobile.attnw {
  flex-flow: row;
  justify-content: space-between;
  align-items: stretch;
  height: auto;
  display: none;
}

.project-section-mobile.fr {
  flex-flow: row;
  justify-content: space-between;
  align-items: stretch;
}

.project-section-mobile.gfls, .project-section-mobile.e400 {
  flex-flow: row;
  justify-content: space-between;
  align-items: stretch;
  position: fixed;
  inset: 0%;
}

.project-section-mobile.ltc, .project-section-mobile.ans {
  flex-flow: row;
  justify-content: space-between;
  align-items: stretch;
}

.misc-section-mobile {
  background-image: url('../images/bg-tile.jpg');
  background-position: 50% 0;
  background-size: 4vw;
  width: 100vw;
  height: 251vw;
  display: none;
  overflow: visible;
}

@media screen and (min-width: 1920px) {
  .project-text-div {
    flex-flow: column;
  }

  .project-img-div {
    grid-column-gap: .5vw;
    grid-row-gap: .5vw;
    padding-bottom: .5vw;
    padding-left: .5vw;
    padding-right: .5vw;
  }

  .row-div._5 {
    grid-column-gap: .5vw;
    grid-row-gap: .5vw;
  }

  .marquee-div {
    padding-top: .2vw;
    padding-left: .5vw;
    padding-right: .5vw;
  }

  .header-div {
    padding-top: .5vw;
    padding-left: .5vw;
    padding-right: .5vw;
  }

  .description-div {
    padding: .5vw;
  }

  .project-description, .year-text, .category-text {
    font-size: .9vw;
  }

  .addinfo-div {
    padding: 1vw .5vw 1.5vw;
  }

  .addinfo-text, .addinfo-header {
    font-size: .9vw;
  }

  .imprint-header, .imprint-text {
    font-size: .8vw;
  }

  .projectnav-div {
    padding: .5vw;
  }

  .projectnav-text {
    font-size: .9vw;
  }
}

@media screen and (max-width: 991px) {
  .navbar {
    display: flex;
  }

  .nav-div.left {
    width: 96px;
    display: flex;
  }

  .text-block.nav {
    padding-top: .5vw;
    padding-bottom: .5vw;
  }

  .menu-button {
    background-color: var(--black);
    color: var(--light-grey);
    padding: 0;
    position: static;
    overflow: hidden;
  }

  .menu-button.w--open {
    color: var(--mid-grey);
    overflow: hidden;
  }

  .nav-menu, .icon {
    background-color: var(--black);
  }
}

@media screen and (max-width: 479px) {
  .navbar {
    height: 28px;
  }

  .nav-div.left {
    width: 8rem;
    padding: 1px 2vw;
  }

  .nav-div.right {
    flex-flow: row;
    justify-content: flex-end;
    align-items: stretch;
    width: 8rem;
    padding-top: 2px;
    padding-left: 2vw;
    padding-right: 2vw;
  }

  .text-block.nav, .text-block._2024, .heading {
    font-size: 20px;
  }

  .contact-div {
    justify-content: center;
    align-items: center;
    max-width: 200px;
    display: flex;
  }

  .contact-link {
    align-items: center;
  }

  .contact-text {
    text-align: left;
    font-size: 20px;
  }

  .about-section {
    height: 150rem;
  }

  .lottie-animation {
    justify-content: flex-start;
    align-items: center;
    width: 400%;
    height: auto;
    margin-top: auto;
    display: block;
    position: absolute;
  }

  .misc-section {
    display: none;
  }

  .mtpp-div {
    width: 90vw;
    height: auto;
    position: static;
  }

  .misc-info-div {
    justify-content: center;
    align-items: flex-end;
    padding-bottom: 10vw;
    padding-left: 5vw;
    padding-right: 5vw;
  }

  .mtpp-text {
    font-size: 22px;
  }

  .lunya-fc-div {
    width: 70vw;
    height: auto;
    position: static;
  }

  .lunya-fc-text {
    font-size: 22px;
  }

  .cf-logo-div {
    width: 50vw;
    height: auto;
    position: static;
  }

  .cf-logo-text {
    font-size: 22px;
  }

  .endwars-div {
    width: auto;
    height: 65vw;
    position: static;
  }

  .endwars-text {
    font-size: 22px;
  }

  .richie-ikab-div {
    width: 90vw;
    height: 52vw;
    position: static;
  }

  .richie-ikab-text {
    font-size: 22px;
  }

  .poster-div {
    width: auto;
    height: 90vw;
    position: static;
  }

  .poster-text {
    font-size: 22px;
  }

  .lunya-iwhb-div {
    width: 55vw;
    height: 95vw;
    position: static;
  }

  .lunya-iwhb-text {
    font-size: 22px;
  }

  .analogue-div {
    width: auto;
    height: 60vw;
    position: static;
  }

  .analogue-text {
    font-size: 22px;
  }

  .echochamber-div {
    width: auto;
    height: 80vw;
    position: static;
  }

  .echochamber-text {
    font-size: 22px;
  }

  .richie-witl-div {
    width: 90vw;
    height: 52vw;
    position: static;
  }

  .richie-witl-text {
    font-size: 22px;
  }

  .work-index-section {
    padding-top: 25svh;
    padding-bottom: 25svh;
  }

  .project-header.attnw, .project-header.fr, .project-header.gfls, .project-header.e400, .project-header.ltc, .project-header.ans {
    font-size: 20vw;
  }

  .project-div-line {
    border-width: .9vw;
    height: 36vw;
  }

  .project-section.attnw {
    flex-flow: column;
    margin-top: 28px;
    display: none;
  }

  .project-section.fr, .project-section.gfls {
    display: none;
  }

  .project-section.e400 {
    margin-top: 28px;
    display: none;
  }

  .project-section.ltc, .project-section.ans {
    display: none;
  }

  .project-text-div {
    background-color: var(--black);
    width: 100%;
    height: auto;
  }

  .project-img-div {
    grid-column-gap: 2vw;
    grid-row-gap: 2vw;
    width: 100%;
    padding: 2vw;
  }

  .row-div._5 {
    grid-column-gap: 2vw;
    grid-row-gap: 2vw;
    grid-auto-flow: row;
    place-items: stretch stretch;
  }

  .row-div._7 {
    height: 40vw;
  }

  .row-div.fr-6 {
    grid-column-gap: 2vw;
    grid-row-gap: 2vw;
    align-items: stretch;
  }

  .row-div.e400-1 {
    height: 60vw;
  }

  .row-div.e400-3 {
    grid-column-gap: 2vw;
    grid-row-gap: 2vw;
    align-items: stretch;
  }

  .row-div.e400-4 {
    height: 60vw;
  }

  .row-div.ltc-2 {
    grid-column-gap: 2vw;
    grid-row-gap: 2vw;
  }

  .row-div.ans-3 {
    height: 55vw;
  }

  .row-div.ans-6 {
    grid-column-gap: 2vw;
    grid-row-gap: 2vw;
  }

  .row-div.ans-7 {
    height: 55vw;
  }

  .project-lb, .background-video-2 {
    height: auto;
  }

  .marquee-div {
    margin-top: 4vw;
    margin-bottom: 4vw;
    padding-left: 2vw;
    padding-right: 2vw;
  }

  .header-div {
    margin-top: 2vw;
    padding: 0 2vw;
  }

  .description-div {
    padding: 3vw 2vw;
  }

  .project-heading {
    color: var(--light-grey);
    font-size: 20vw;
  }

  .project-description, .year-text, .category-text {
    color: var(--light-grey);
    font-size: 3vw;
  }

  .footer-link {
    align-items: center;
  }

  .footer-text {
    font-size: 20px;
  }

  .addinfo-div {
    grid-column-gap: 2vw;
    grid-row-gap: 2vw;
    padding-top: 3vw;
    padding-left: 2vw;
    padding-right: 2vw;
  }

  .addinfo-text, .addinfo-header {
    color: var(--light-grey);
    font-size: 3vw;
  }

  .imprint-div {
    width: 80vw;
  }

  .imprint-header, .imprint-text {
    font-size: 3vw;
  }

  .projectnav-div {
    grid-column-gap: 2vw;
    grid-row-gap: 2vw;
    margin-bottom: 30px;
    padding-left: 2vw;
    padding-right: 2vw;
  }

  .projectnav-text {
    color: var(--light-grey);
    font-size: 3vw;
  }

  .menu-button {
    box-sizing: border-box;
    flex-flow: row;
    flex: 0 auto;
    justify-content: center;
    align-items: center;
    height: 100%;
    display: flex;
    overflow: hidden;
  }

  .icon {
    height: 100%;
    font-size: 30px;
    text-decoration: none;
  }

  .div-block {
    justify-content: center;
    align-items: center;
    width: 50vw;
    height: 50vw;
    display: flex;
  }

  .about-lottie-container {
    z-index: 1;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width: 70vw;
    height: 100vw;
    display: flex;
    position: fixed;
    overflow: hidden;
  }

  .about-div {
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width: 100vw;
    height: 95svh;
    display: flex;
    position: fixed;
  }

  .project-section-mobile {
    justify-content: space-between;
    align-items: stretch;
    display: flex;
  }

  .project-section-mobile.attnw, .project-section-mobile.fr, .project-section-mobile.gfls, .project-section-mobile.e400 {
    display: flex;
  }

  .misc-section-mobile {
    grid-column-gap: 30vw;
    grid-row-gap: 30vw;
    background-size: 8vw;
    flex-flow: column;
    align-items: center;
    height: auto;
    padding-top: 30vw;
    padding-bottom: 30vw;
    display: flex;
  }
}


@font-face {
  font-family: 'PP-NeueBit';
  src: url('../fonts/PPNeueBit-Bold.woff') format('woff'), url('../fonts/PPNeueBit-Bold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'PPFraktionMono';
  src: url('../fonts/PPFraktionMono-Light.woff') format('woff'), url('../fonts/PPFraktionMono-Light.ttf') format('truetype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Helvetica Narrow';
  src: url('../fonts/helr47w.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}