@font-face {
  font-family: "Inter";
  src: url("./fonts/Inter-VariableFont_opsz,wght.ttf") format("truetype");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Tilt Warp";
  src: url("./fonts/TiltWarp-Regular-VariableFont_XROT,YROT.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  width: 100%;
  min-height: 100%;
}

body {
  background: #1e1e1e;
  overflow-x: hidden;
  font-family: Inter, system-ui, sans-serif;
}

img {
  display: block;
}

.poster {
  position: absolute;
  left: 0px;
  top: 1375px;
  width: 985px;
  height: 1407px;
  object-fit: cover;
}

.type-analysis {
  position: relative;
  width: 1440px;
  height: 7173px;
  margin: 0 auto;
  background: #1e1e1e;
  overflow: hidden;
  transform: scale(min(1, calc(100vw / 1440)));
  transform-origin: top center;
}

.top-meta {
  position: absolute;
  left: 0;
  top: 0;
  width: 1440px;
  height: 275px;
}

.top-meta__dot {
  position: absolute;
  width: 24px;
  height: 50px;
  border-radius: 0 24px 24px 0;
  background: #fff;
}

.top-meta__dot--left {
  left: 10px;
  top: 27px;
}

.top-meta__dot--right {
  left: 42px;
  top: 27px;
}

.top-meta__home-link {
  position: absolute;
  left: 6px;
  top: 21px;
  width: 72px;
  height: 62px;
  z-index: 5;
  cursor: pointer;
}

.top-meta__home-link:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 3px;
}

.top-meta__line,
.top-meta__divider {
  position: absolute;
  background: #bcbcbc;
}

.top-meta__line {
  top: 101px;
  height: 1px;
}

.top-meta__line--left {
  left: 0;
  width: 455px;
}

.top-meta__line--middle {
  left: 470px;
  width: 499px;
}

.top-meta__line--right {
  left: 985px;
  width: 455px;
}

.top-meta__divider {
  top: -18px;
  width: 1px;
  height: 107px;
}

.top-meta__divider--one {
  left: 457px;
}

.top-meta__divider--two {
  left: 971px;
}

.top-meta__label,
.top-meta__credit {
  position: absolute;
  margin: 0;
  color: #fff;
  font: 400 12px/1.2 Inter, sans-serif;
}

.top-meta__label {
  left: 478px;
  top: 74px;
}

.top-meta__credit {
  left: 992px;
  top: 62px;
}

.hero {
  position: absolute;
  left: 0;
  top: 205px;
  width: 1440px;
  height: 1034px;
}

.hero__stripes {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    repeating-linear-gradient(
      to bottom,
      #00e4ff 0 3px,
      #1e1e1e 3px 21px
    );
  background-size: 100% 44px;
  animation: hero-stripes-loop 26s linear infinite;
}

.hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  opacity: 0;
}

.hero--video-ready .hero__video {
  opacity: 1;
}

@keyframes hero-stripes-loop {
  from {
    background-position: 0 0;
  }
  to {
    background-position: 0 176px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero__stripes {
    animation: none;
  }
}

.hero__title {
  position: absolute;
  left: 0;
  margin: 0;
  color: #fff;
  font: 700 85px/1 Inter, sans-serif;
  letter-spacing: -1px;
  z-index: 2;
}

.hero__title--line1 {
  top: 517px;
}

.hero__title--line2 {
  top: 672px;
}

.hero__title--line2 span {
  color: #ff6928;
}

.text-block {
  position: absolute;
  margin: 0;
  color: #fff;
  font: 400 24px/normal Inter, sans-serif;
  white-space: pre-wrap;
}

.text-block p {
  margin: 0 0 0.5em;
}

.text-block--top-right {
  left: 1000px;
  top: 1415px;
  width: 420px;
  z-index: 1;
  line-height: 0;
}

.text-block--top-right p {
  margin: 0;
  line-height: normal;
}

.vertical-title {
  position: absolute;
  left: 16px;
  top: 2816px;
  width: 350px;
  height: 1742px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.vertical-title p {
  margin: 0;
  width: 1742px;
  height: 350px;
  color: #fff;
  font: 400 105px/normal "Tilt Warp", cursive;
  white-space: nowrap;
  transform: rotate(-90deg);
  transform-origin: center;
}

.rule {
  position: absolute;
  display: block;
  pointer-events: none;
}

.rule--vertical {
  left: 209px;
  top: 2811px;
  width: 1747px;
  height: 1px;
  transform: rotate(90deg);
  transform-origin: top left;
}

.rule--horizontal {
  left: 200px;
  top: 4573px;
  width: 200px;
  height: 1px;
}

.art {
  position: absolute;
  width: 376px;
  height: 395px;
  object-fit: cover;
}

/* Row 1 - Top images */
.art--a {
  left: 230px;
  top: 2816px;
}

.art--b {
  left: 636px;
  top: 2816px;
}

.art--c {
  left: 1053px;
  top: 2816px;
}

/* Row 2 - Middle images */
.art--d {
  left: 230px;
  top: 3682px;
}

.art--e {
  left: 1053px;
  top: 3682px;
}

.art--f {
  left: 631px;
  top: 4152px;
}

/* Row 3 - Bottom images */
.art--g {
  left: 225px;
  top: 4152px;
}

.art--h {
  left: 1048px;
  top: 4152px;
}

.text-block--left-gap {
  left: 230px;
  top: 3215px;
  width: 376px;
  z-index: 1;
}

.text-block--middle-left {
  left: 626px;
  top: 3215px;
  width: 397px;
  z-index: 1;
}

.text-block--middle-right {
  left: 1043px;
  top: 3215px;
  width: 386px;
  z-index: 1;
}
