@font-face {
  font-family: "Rounded Black";
  src: url("Rounded-Black.ttf") format("truetype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

:root {
  --compass-x: 50%;
  --compass-y: 50%;
  --compass-size: 7%;
  --compass-angle: 0deg;
  --compass-opacity: 1;
}

* {
  box-sizing: border-box;
}

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

body {
  margin: 0;
  min-height: 100vh;
  overflow: hidden;
  background: #ececec;
  color: #151515;
}

.scene {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  width: 100%;
  min-height: 100svh;
  padding: clamp(12px, 3vw, 36px);
}

.image-stack {
  position: relative;
  width: min(92vw, calc(86svh * 4919 / 3919), 1180px);
  line-height: 0;
  transition: opacity 480ms ease;
}

.lost-image {
  display: block;
  width: 100%;
  height: auto;
  user-select: none;
}

.compass-image {
  position: absolute;
  left: var(--compass-x);
  top: var(--compass-y);
  width: var(--compass-size);
  height: auto;
  opacity: var(--compass-opacity);
  transform: translate(-50%, -50%) rotate(var(--compass-angle));
  transform-origin: 50% 50%;
  transition: opacity 480ms ease;
  filter: drop-shadow(0 8px 12px rgb(0 0 0 / 0.34));
  pointer-events: none;
  user-select: none;
  will-change: opacity, transform;
}

.scroll-arrow {
  position: absolute;
  left: 50%;
  bottom: clamp(16px, 4vh, 42px);
  display: grid;
  grid-template-rows: repeat(2, 18px);
  place-items: center;
  width: 42px;
  height: 54px;
  padding: 0;
  border: 0;
  color: #c85624;
  background: transparent;
  cursor: pointer;
  opacity: 0.78;
  transform: translateX(-50%);
  transition: opacity 180ms ease, transform 180ms ease;
  animation: arrow-drift 1.45s ease-in-out infinite;
}

.scroll-arrow:hover,
.scroll-arrow:focus-visible {
  opacity: 1;
}

.scroll-arrow svg {
  display: block;
  width: 30px;
  height: 30px;
  fill: currentColor;
}

.scroll-arrow svg:first-child {
  color: #2b180e;
}

.scroll-arrow svg:last-child {
  color: #c85624;
}

.coming-soon {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  min-height: 100svh;
  padding: clamp(24px, 6vw, 72px);
  opacity: 0;
  pointer-events: none;
  text-align: center;
  transition: opacity 800ms ease;
}

.video-embed {
  width: min(90vw, 1120px);
  aspect-ratio: 16 / 9;
  background: #2b180e;
  box-shadow: 0 18px 40px rgb(43 24 14 / 0.22);
}

.video-embed iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
}

body.is-revealed .scroll-arrow {
  opacity: 0;
  pointer-events: none;
}

body.is-revealed .compass-image {
  opacity: 0;
}

body.is-revealed .image-stack {
  opacity: 0;
}

body.is-revealed .coming-soon {
  opacity: 1;
  pointer-events: auto;
}

@keyframes arrow-drift {
  0%,
  100% {
    transform: translate(-50%, 0);
  }

  50% {
    transform: translate(-50%, 8px);
  }
}
