@font-face {
  font-family: "DM Mono";
  src: url("fonts/DMMono-Regular.woff2") format("woff2"), url("fonts/DMMono-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "DM Mono";
  src: url("fonts/DMMono-Medium.woff2") format("woff2"), url("fonts/DMMono-Medium.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
html, body {
  font-family: "DM Mono", monospace;
  font-size: 16px;
  scroll-behavior: smooth;
  background: #000;
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  -webkit-tap-highlight-color: transparent;
  text-size-adjust: none;
}

.labs.footer {
  padding: 1.5625rem 1.0625rem;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
}
@media screen and (min-width:768px) {
  .labs.footer {
    padding: 1.875rem 1.0625rem;
  }
}
@media screen and (min-width:992px) {
  .labs.footer ul {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.625rem;
  }
}
.labs.footer ul li {
  color: rgba(255, 255, 255, 0.4);
  text-transform: uppercase;
  line-height: normal;
  letter-spacing: 0.04rem;
}
@media (max-width: 767px) and (orientation: landscape) {
  .labs.footer ul li {
    font-size: 0.75rem;
  }
}
@media screen and (min-width:992px) {
  .labs.footer ul li {
    min-width: 16rem;
  }
}
@media screen and (min-width:1199px) {
  .labs.footer ul li {
    min-width: 16.875rem;
  }
}
.labs.footer ul li.is-light {
  color: #fff;
}
@media screen and (min-width:992px) {
  .labs.footer ul li.is-center {
    text-align: center;
  }
}
@media screen and (min-width:992px) {
  .labs.footer ul li.is-right {
    text-align: right;
  }
}

ul, ol {
  margin: 0;
  padding: 0;
}
ul li, ol li {
  list-style: none;
}

p {
  font-size: 1em;
  line-height: 1.125;
  margin: 0 0 1.25rem;
}
p:last-of-type {
  margin: 0;
}
p:empty {
  display: none;
}

h1, h2, h3, h4, h5, h6 {
  margin: 0 0 1.25rem;
}

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

.aspect-box {
  position: relative;
  height: 0;
  width: 100%;
  padding-top: calc(100% / (var(--aspect-ratio)));
}
.aspect-box img, .aspect-box video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.is-desktop {
  display: none;
}
@media screen and (min-width:992px) {
  .is-desktop {
    display: block;
  }
}

@media screen and (min-width:992px) {
  .is-mobile {
    display: none;
  }
}

.is-hide {
  display: none;
}

.container {
  max-width: 120rem;
  margin: 0 auto;
  padding: 0 0.9375rem;
}

.labs.intro {
  height: 100vh;
  max-height: calc(var(--vh, 1vh) * 100);
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
.labs.intro .intro__title {
  font-size: 1rem;
  line-height: normal;
  color: #fff;
  letter-spacing: 0.04rem;
  text-transform: uppercase;
  position: absolute;
  z-index: 1;
  top: 1.5rem;
  right: 2.3125rem;
  max-width: 12.875rem;
}
@media screen and (min-width:480px) {
  .labs.intro .intro__title {
    font-size: 1.25rem;
    max-width: 21.875rem;
  }
}
@media (max-width: 340px) {
  .labs.intro .intro__title {
    right: 1.25rem;
  }
}
@media screen and (min-width:992px) {
  .labs.intro .intro__media {
    position: relative;
  }
}
.labs.intro .intro__media figure {
  left: 17vw;
  width: 78vh;
}
@media screen and (max-width:991px) {
  .labs.intro .intro__media figure {
    transform: rotate(90deg);
    position: absolute;
    top: -0.5625rem;
    transform-origin: left center;
  }
}
@media screen and (min-width:768px) {
  .labs.intro .intro__media figure {
    width: 73vh;
  }
}
@media screen and (min-width:992px) {
  .labs.intro .intro__media figure {
    width: 56.458vw;
  }
}
@media (max-width: 767px) and (orientation: landscape) {
  .labs.intro .intro__media figure {
    top: 0;
    left: 6vw;
    width: 45vh;
  }
}
@media (max-width: 767px) {
  .labs.intro .intro__media figure {
    left: 19.6875rem;
    width: 31.25rem;
    top: 1.6875rem;
  }
}
@media (max-width: 481px) {
  .labs.intro .intro__media figure {
    width: 31.5rem;
    top: 1.5625rem;
    left: 19.75rem;
    right: auto;
    max-width: unset;
  }
}
@media (max-width: 340px) and (max-height: 620px) {
  .labs.intro .intro__media figure {
    width: 25rem;
    top: 1.5625rem;
    left: 15.75rem;
  }
}
@media (max-width: 900px) and (orientation: landscape) {
  .labs.intro .intro__media figure {
    left: 10rem;
    width: 14.375rem;
    top: 0.6875rem;
  }
}
@media (max-height: 370px) and (orientation: landscape) {
  .labs.intro .intro__media figure {
    left: 8.125rem;
    width: 11.25rem;
  }
}
.labs.intro .intro__media figure img {
  width: 100%;
}
.labs.intro .intro__media video {
  object-fit: cover;
  position: absolute;
  bottom: 0;
  mix-blend-mode: multiply;
  width: 83vh;
  top: -24vh;
  right: -84%;
}
@media (max-width: 767px) and (orientation: landscape) {
  .labs.intro .intro__media video {
    right: 50%;
    width: 70vh;
    top: -22vh;
  }
}
@media screen and (max-width:991px) {
  .labs.intro .intro__media video {
    transform: rotate(90deg);
    transform-origin: left center;
    left: 70%;
    max-width: calc(100% + 50px);
    top: 0;
  }
}
@media screen and (min-width:768px) {
  .labs.intro .intro__media video {
    top: -18.5vh;
    right: -32%;
  }
}
@media screen and (min-width:992px) {
  .labs.intro .intro__media video {
    top: auto;
    right: auto;
    left: 0;
    bottom: -3.125rem;
    width: 56.6vw;
  }
}
@media screen and (max-width:991px) {
  .labs.intro .intro__media video {
    left: 55vh;
    top: 1vh;
  }
}
@media (max-width: 767px) {
  .labs.intro .intro__media video {
    left: 60vh;
    top: 0;
    width: 500px;
    top: 27px;
    left: 372px;
  }
}
@media (max-width: 481px) {
  .labs.intro .intro__media video {
    max-width: unset;
    width: 31.5rem;
    top: 1.5625rem;
    left: 23.125rem;
  }
}
@media (max-width: 340px) and (max-height: 620px) {
  .labs.intro .intro__media video {
    width: 25rem;
    top: 1.5625rem;
    left: 18.125rem;
  }
}
@media (max-width: 900px) and (orientation: landscape) {
  .labs.intro .intro__media video {
    left: 12.5rem;
    width: 14.375rem;
    top: 0.6875rem;
  }
}
@media (max-height: 370px) and (orientation: landscape) {
  .labs.intro .intro__media video {
    left: 10rem;
    width: 11.25rem;
  }
}
@media screen and (max-width:991px) {
  .labs.intro .intro__media figure,
  .labs.intro .intro__media video {
    transform: translate(-50%, -50%) rotate(90deg);
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .labs.intro .intro__media figure,
  .labs.intro .intro__media video {
    top: 3%;
    left: 45vh;
    max-width: 100%;
    max-height: 100%;
  }
}