:root {
  --black: #000;
  --white: #fff;
  --cream: #eef3ed;
  --muted: rgba(255, 255, 255, 0.22);
  --soft: rgba(255, 255, 255, 0.62);
  --faint: rgba(255, 255, 255, 0.08);
  --grid-margin: 2.25rem;
  --grid-gap: 0.625rem;
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --orb-x: 50vw;
  --orb-y: 50vh;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  height: 100%;
  background: var(--black);
  scroll-behavior: auto;
  -webkit-tap-highlight-color: rgba(150, 150, 150, 0.24);
}

body {
  min-width: 320px;
  height: 100%;
  margin: 0;
  overflow: hidden;
  background: var(--black);
  color: var(--white);
  font-family: "Geist", Arial, Helvetica, sans-serif;
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
}

body.is-loading {
  cursor: progress;
}

body.about-open,
body.time-open {
  overflow: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: -20%;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(circle at var(--orb-x) var(--orb-y), rgba(255, 255, 255, 0.07), transparent 13rem),
    radial-gradient(circle at 70% 20%, rgba(238, 243, 237, 0.025), transparent 22rem);
  mix-blend-mode: screen;
  opacity: 0.58;
}

img,
canvas {
  display: block;
}

img {
  max-width: 100%;
}

button,
a {
  color: inherit;
  font: inherit;
  -webkit-tap-highlight-color: rgba(150, 150, 150, 0.24);
}

button {
  padding: 0;
  border: 0;
  background: transparent;
}

a {
  color: inherit;
  text-decoration: none;
}

a:visited,
a:hover,
a:active {
  color: inherit;
}

a:focus-visible,
button:focus-visible {
  outline: 1px solid rgba(170, 170, 170, 0.85);
  outline-offset: 0.3rem;
}

.intro-loader {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: #000;
  color: #fff;
}

.loader-wrapper {
  position: absolute;
  left: 50%;
  top: 54%;
  width: 350px;
  height: 240px;
  transform: translate(-50%, -50%) scale(1.15);
}

.floor {
  position: absolute;
  left: 50%;
  top: 70%;
  z-index: 2;
  width: 350px;
  height: 5px;
  background: #673c63;
  box-shadow: 0 2px 5px #111;
  transform: translate(-50%, -50%);
}

.candles {
  position: absolute;
  left: 50%;
  top: 70%;
  z-index: 1;
  width: 250px;
  height: 150px;
  transform: translate(-50%, -100%);
}

.candle1 {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 35px;
  height: 100px;
  background: #fff;
  border: 3px solid #673c63;
  border-bottom: 0;
  border-radius: 3px;
  box-shadow: -2px 0 0 #95c6f2 inset;
  transform: translate(60%, -25%);
  transform-origin: center right;
  animation: expand-body 3s infinite linear;
}

.candle1__stick,
.candle2__stick {
  position: absolute;
  left: 50%;
  top: 0;
  width: 3px;
  height: 15px;
  background: #673c63;
  border-radius: 8px;
  transform: translate(-50%, -100%);
}

.candle2__stick {
  height: 12px;
  transform-origin: bottom center;
  animation: stick-animation 3s infinite linear;
}

.candle1__eyes,
.candle2__eyes {
  position: absolute;
  left: 50%;
  top: 0;
  width: 35px;
  height: 30px;
  transform: translate(-50%, 0);
}

.candle1__eyes-one,
.candle1__eyes-two {
  position: absolute;
  top: 20%;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #673c63;
  transform: translate(-70%, 0);
  animation: blink-eyes 3s infinite linear;
}

.candle1__eyes-one {
  left: 30%;
}

.candle1__eyes-two {
  left: 70%;
}

.candle1__mouth {
  position: absolute;
  left: 40%;
  top: 20%;
  width: 0;
  height: 0;
  border-radius: 20px;
  background: #673c63;
  transform: translate(-50%, -50%);
  animation: uff 3s infinite linear;
}

.candle__smoke-one {
  position: absolute;
  left: 30%;
  top: 50%;
  width: 30px;
  height: 3px;
  background: #8b8b8b;
  transform: translate(-50%, -50%);
  animation: move-left 3s infinite linear;
}

.candle__smoke-two {
  position: absolute;
  left: 30%;
  top: 40%;
  width: 10px;
  height: 10px;
  border-radius: 10px;
  background: #8b8b8b;
  transform: translate(-50%, -50%);
  animation: move-top 3s infinite linear;
}

.candle2 {
  position: absolute;
  left: 20%;
  top: 65%;
  width: 42px;
  height: 60px;
  background: #fff;
  border: 3px solid #673c63;
  border-bottom: 0;
  border-radius: 3px;
  box-shadow: -2px 0 0 #95c6f2 inset;
  transform: translate(60%, -15%);
  transform-origin: center right;
  animation: shake-left 3s infinite linear;
}

.candle2__eyes-one,
.candle2__eyes-two {
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 5px;
  height: 5px;
  border: 0 solid #673c63;
  border-radius: 50%;
  background: #673c63;
  transform: translate(-80%, 0);
}

.candle2__eyes-one {
  left: 30%;
  animation: changeto-lower 3s infinite linear;
}

.candle2__eyes-two {
  left: 70%;
  animation: changeto-greater 3s infinite linear;
}

.light__wave {
  position: absolute;
  top: 35%;
  left: 35%;
  z-index: 0;
  width: 75px;
  height: 75px;
  border: 2px solid rgba(255, 255, 255, 0.2);
  border-radius: 50%;
  transform: translate(-25%, -50%) scale(2.5);
  animation: expand-light 3s infinite linear;
}

.candle2__fire {
  position: absolute;
  top: 50%;
  left: 40%;
  display: block;
  width: 16px;
  height: 20px;
  border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
  background: #ff9800;
  transform: translate(-50%, -50%);
  animation: dance-fire 3s infinite linear;
}

.sparkles-one,
.sparkles-two {
  position: absolute;
  z-index: 3;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #ffc107;
  opacity: 0;
  animation: sparkle 3s infinite linear;
}

.sparkles-one {
  left: 31%;
  top: 20%;
}

.sparkles-two {
  left: 48%;
  top: 24%;
  animation-delay: 0.35s;
}

.loader-text {
  position: absolute;
  left: 50%;
  top: calc(54% + 8rem);
  margin: 0;
  color: rgba(255, 255, 255, 0.58);
  font-family: "Geist Mono", Consolas, monospace;
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transform: translateX(-50%);
}

@keyframes blink-eyes {
  0%,
  35% {
    opacity: 1;
    transform: translate(-70%, 0);
  }

  36%,
  39% {
    opacity: 0;
    transform: translate(-70%, 0);
  }

  40% {
    opacity: 1;
    transform: translate(-70%, 0);
  }

  50%,
  65% {
    transform: translate(-140%, 0);
  }

  66% {
    transform: translate(-70%, 0);
  }
}

@keyframes expand-body {
  0%,
  40% {
    transform: scale(1) translate(60%, -25%);
  }

  45%,
  55% {
    transform: scale(1.1) translate(60%, -28%);
  }

  60% {
    transform: scale(0.89) translate(60%, -25%);
  }

  65% {
    transform: scale(1) translate(60%, -25%);
  }

  70% {
    transform: scale(0.95) translate(60%, -25%);
  }

  75% {
    transform: scale(1) translate(60%, -25%);
  }
}

@keyframes uff {
  0%,
  40% {
    width: 0;
    height: 0;
  }

  50%,
  54% {
    left: 30%;
    width: 15px;
    height: 15px;
  }

  59% {
    left: 20%;
    width: 5px;
    height: 5px;
  }

  62% {
    left: 20%;
    width: 2px;
    height: 2px;
  }

  67% {
    left: 30%;
    width: 0;
    height: 0;
  }
}

@keyframes move-left {
  0%,
  59%,
  100% {
    left: 40%;
    width: 0;
  }

  60% {
    left: 30%;
    width: 30px;
  }

  68% {
    left: 20%;
    width: 0;
  }
}

@keyframes move-top {
  0%,
  64%,
  100% {
    top: 0;
    width: 0;
    height: 0;
  }

  65% {
    left: 40%;
    top: 40%;
    width: 10px;
    height: 10px;
  }

  80% {
    top: 20%;
    width: 0;
    height: 0;
  }
}

@keyframes shake-left {
  0%,
  74% {
    left: 20%;
    transform: translate(60%, -15%);
  }

  75% {
    left: 20%;
    background: #fff;
    border-color: #673c63;
    transform: scale(1.15, 0.85) translate(60%, -15%);
  }

  91% {
    left: 20%;
    background: #f44336;
    border-color: #f44336;
    box-shadow: -2px 0 0 #f44336 inset;
    transform: scale(1.18, 0.82) translate(60%, -10%);
  }

  92% {
    left: 20%;
    transform: scale(0.85, 1.15) translate(60%, -15%);
  }

  95% {
    left: 20%;
    transform: scale(1.05, 0.95) translate(60%, -15%);
  }

  97%,
  100% {
    left: 20%;
    transform: scale(1) translate(60%, -15%);
  }
}

@keyframes stick-animation {
  0%,
  59% {
    left: 50%;
    top: 0;
    transform: translate(-50%, -100%);
  }

  62% {
    left: 50%;
    top: 0;
    transform: rotate(-15deg) translate(-50%, -100%);
  }

  65% {
    left: 50%;
    top: 0;
    transform: rotate(15deg) translate(-50%, -100%);
  }

  70% {
    left: 50%;
    top: 0;
    transform: rotate(-5deg) translate(-50%, -100%);
  }

  72% {
    left: 50%;
    top: 0;
    transform: rotate(5deg) translate(-50%, -100%);
  }

  74%,
  84% {
    left: 50%;
    top: 0;
    transform: rotate(0deg) translate(-50%, -100%);
  }

  85% {
    transform: rotate(180deg) translate(0, 120%);
  }

  92%,
  100% {
    left: 50%;
    top: 0;
    transform: translate(-50%, -100%);
  }
}

@keyframes expand-light {
  10%,
  29%,
  59%,
  89% {
    border-color: rgba(255, 255, 255, 0);
    transform: translate(-25%, -50%) scale(0);
  }

  90%,
  20%,
  50% {
    transform: translate(-25%, -50%) scale(1);
  }

  95%,
  96%,
  26%,
  27%,
  56%,
  57% {
    border-color: rgba(255, 255, 255, 0.5);
    transform: translate(-25%, -50%) scale(2);
  }

  0%,
  28%,
  58%,
  100% {
    border-color: rgba(255, 255, 255, 0.2);
    transform: translate(-25%, -50%) scale(2.5);
  }
}

@keyframes dance-fire {
  59%,
  89% {
    left: 40%;
    width: 0;
    height: 0;
  }

  90%,
  0%,
  7%,
  15%,
  23%,
  31%,
  39%,
  47%,
  55% {
    left: 40.8%;
    width: 16px;
    height: 20px;
    background: #ffc107;
  }

  94%,
  3%,
  11%,
  19%,
  27%,
  35%,
  43%,
  51%,
  58% {
    left: 41.2%;
    width: 16px;
    height: 20px;
    background: #ff9800;
  }
}

@keyframes changeto-lower {
  0%,
  70%,
  90% {
    border: 0 solid #673c63;
    border-radius: 50%;
    background: #673c63;
    transform: translate(-90%, 0);
  }

  71%,
  89% {
    padding: 1px;
    border: solid #673c63;
    border-width: 0 2px 2px 0;
    border-radius: 0;
    background: transparent;
    transform: rotate(-45deg) translate(-50%, -65%);
    transform-origin: bottom left;
  }
}

@keyframes changeto-greater {
  0%,
  70%,
  90% {
    top: 50%;
    border: 0 solid #673c63;
    border-radius: 50%;
    background: #673c63;
    transform: translate(-80%, 0);
  }

  71%,
  89% {
    top: 30%;
    padding: 1px;
    border: solid #673c63;
    border-width: 0 2px 2px 0;
    border-radius: 0;
    background: transparent;
    transform: rotate(135deg) translate(-80%, 20%);
    transform-origin: bottom left;
  }
}

@keyframes sparkle {
  0%,
  65%,
  100% {
    opacity: 0;
    transform: translateY(0) scale(0);
  }

  72% {
    opacity: 1;
    transform: translateY(-8px) scale(1);
  }

  82% {
    opacity: 0;
    transform: translateY(-18px) scale(0.4);
  }
}

.cursor-orb {
  position: fixed;
  z-index: 80;
  top: 0;
  left: 0;
  width: 9px;
  height: 9px;
  pointer-events: none;
  border-radius: 50%;
  background: #fff;
  opacity: 0;
  transform: translate3d(-100px, -100px, 0);
  mix-blend-mode: exclusion;
}

.site-header {
  position: fixed;
  z-index: 20;
  top: 1.875rem;
  left: 0;
  right: 0;
  height: 3rem;
  display: grid;
  grid-template-columns: auto 1fr auto;
  column-gap: var(--grid-gap);
  align-items: center;
  padding-inline: var(--grid-margin);
  pointer-events: none;
  color: #fff;
  mix-blend-mode: exclusion;
}

.brand,
.main-nav a,
.mobile-about-link {
  pointer-events: auto;
}

.brand,
.main-nav a,
.mobile-about-link {
  position: relative;
  display: inline-block;
  width: max-content;
  overflow: hidden;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.brand {
  width: 2.125rem;
  height: 2.3125rem;
  letter-spacing: 0.02em;
}

.brand img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.header-quote {
  grid-column: 2;
  justify-self: center;
  max-width: min(28rem, 48vw);
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  font-family: "Geist Mono", Consolas, monospace;
  font-size: 0.6875rem;
  font-weight: 500;
  line-height: 1.35;
  letter-spacing: 0.08em;
  text-align: center;
  text-transform: uppercase;
}

.brand-hover,
.nav-hover {
  position: absolute;
  inset: 0 auto auto 0;
  color: #fff;
  clip-path: inset(0 0 100% 0);
  transition: clip-path 420ms var(--ease);
}

.brand:hover .brand-hover,
.main-nav a:hover .nav-hover {
  clip-path: inset(0 0 0 0);
}

.main-nav {
  grid-column: 3;
  justify-self: end;
  display: flex;
  align-items: center;
  gap: 2.375rem;
  transition: opacity 240ms ease, visibility 240ms ease;
}

body.about-open .main-nav {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}

.mobile-about-link {
  display: none;
  justify-self: end;
  transition: opacity 240ms ease, visibility 240ms ease;
}

body.about-open .mobile-about-link {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}

.time-panel {
  position: fixed;
  inset: 0;
  z-index: 12;
  display: flex;
  align-items: end;
  overflow: hidden;
  padding: 0 var(--grid-margin) 0;
  background: #000;
  color: #fff;
  clip-path: inset(100% 0 0 0);
  pointer-events: none;
}

.time-panel p {
  position: absolute;
  right: var(--grid-margin);
  bottom: clamp(7.5rem, 17vw, 15rem);
  width: min(19.875rem, 34vw);
  margin: 0;
  color: rgba(255, 255, 255, 0.55);
  font-family: "Geist Mono", Consolas, monospace;
  font-size: 0.875rem;
  line-height: 1.5;
  letter-spacing: 0.08em;
}

.time-meta {
  position: absolute;
  left: var(--grid-margin);
  right: var(--grid-margin);
  bottom: clamp(7.5rem, 17vw, 15rem);
  display: grid;
  grid-template-columns: 6fr 3fr 3fr;
  gap: var(--grid-gap);
  color: rgba(255, 255, 255, 0.7);
  font-family: "Geist Mono", Consolas, monospace;
  font-size: 0.875rem;
  letter-spacing: 0.08em;
}

.big-time {
  display: flex;
  align-items: end;
  width: 100%;
  font-family: "Geist Mono", Consolas, monospace;
  font-size: 33.4vw;
  font-weight: 300;
  line-height: 0.78;
  letter-spacing: 0;
  white-space: nowrap;
}

.work-stage {
  position: fixed;
  inset: 0;
  z-index: 2;
  overflow: hidden;
  background: #000;
  color: #fff;
}

.work-stage::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 46%, transparent 0 24rem, rgba(0, 0, 0, 0.2) 38rem),
    linear-gradient(180deg, rgba(255, 255, 255, 0.018), transparent 26%, transparent 76%, rgba(255, 255, 255, 0.035));
  opacity: 0.62;
}

.hero-background-video {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.24;
  transform: scale(1.02);
  pointer-events: none;
}

.stage-canvas {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  opacity: 0.2;
}

.seo-copy {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.work-overview,
.list-container {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.work-overview {
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  touch-action: none;
}

.hidden-cases {
  display: none;
}

.list-container {
  z-index: 3;
  cursor: grab;
  user-select: none;
}

.list-container.is-dragging {
  cursor: grabbing;
}

.work-item {
  position: absolute;
  top: 50%;
  left: 50%;
  height: 62vh;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.04);
  color: #fff;
  cursor: pointer;
  opacity: 0;
  transform: translate3d(-50%, -50%, 0);
  transform-origin: center;
  backface-visibility: hidden;
  contain: layout paint size;
  transition: width 520ms var(--ease), opacity 160ms linear;
  will-change: transform, opacity;
}

.work-item img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: cover;
  opacity: 0;
  transform: none;
  filter: saturate(0.78) brightness(0.66);
  transition: opacity 460ms ease, transform 620ms var(--ease), filter 260ms var(--ease);
  will-change: transform;
  pointer-events: none;
  user-select: none;
  -webkit-user-drag: none;
}

.work-item.is-loaded img {
  opacity: 1;
}

.work-item.is-active img {
  object-fit: cover;
  filter: saturate(1.04) brightness(1);
}

.work-item:not(.is-active) img {
  filter: saturate(0.78) brightness(0.66);
}

.work-item.is-secondary img {
  filter: saturate(1.04) brightness(1);
}

.work-item::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  border: 1px solid rgba(255, 255, 255, 0.34);
  opacity: 0;
  pointer-events: none;
  transition: opacity 340ms var(--ease);
}

.work-item::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0.2)),
    radial-gradient(circle at 50% 45%, transparent 38%, rgba(0, 0, 0, 0.22));
  opacity: 0.48;
  pointer-events: none;
  transition: opacity 340ms var(--ease);
}

.work-item.is-active {
  cursor: default;
}

.work-item.is-secondary {
  display: none;
}

.work-item.is-active::before {
  opacity: 0.62;
}

.work-item.is-active::after {
  opacity: 0.18;
}

body.is-moving .work-item img,
.list-container.is-dragging .work-item img {
  filter: none;
  transition-duration: 120ms;
}

body.is-moving .work-item:not(.is-active)::after,
.list-container.is-dragging .work-item:not(.is-active)::after {
  opacity: 0.58;
}

body.is-moving .hero-background-video {
  opacity: 0.16;
}

@media (hover: hover) and (pointer: fine) {
  .work-item:not(.is-active):hover img {
    filter: saturate(1) brightness(0.92);
  }

  .work-item:not(.is-active):hover::before {
    opacity: 0.42;
  }

  .work-item:not(.is-active):hover::after {
    opacity: 0.26;
  }
}

.project-details {
  position: absolute;
  z-index: 8;
  left: var(--grid-margin);
  bottom: 1.72rem;
  display: flex;
  flex-direction: column;
  gap: 0.66rem;
  width: min(24rem, calc(100vw - 2 * var(--grid-margin)));
  pointer-events: none;
  mix-blend-mode: exclusion;
}

.project-details,
.project-counter {
  display: none;
}

.project-title-window,
.project-role-window {
  position: relative;
  overflow: hidden;
  width: 100%;
  max-width: min(32rem, calc(100vw - 2 * var(--grid-margin)));
  clip-path: inset(-10% 0% -10% 0%);
}

.project-title-list,
.project-role-list {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  will-change: transform;
}

.project-title-list a,
.project-role-list div,
.detail-ghost {
  display: block;
  white-space: nowrap;
}

.project-title-list a,
.project-title-window .detail-ghost {
  font-size: clamp(0.875rem, 0.72rem + 0.31vw, 1rem);
  line-height: 1;
  letter-spacing: 0.04em;
  font-weight: 400;
}

.project-role-list div,
.project-role-window .detail-ghost {
  color: rgba(255, 255, 255, 0.24);
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.detail-ghost {
  opacity: 0;
  pointer-events: none;
}

.project-counter {
  position: absolute;
  z-index: 8;
  right: calc(var(--grid-margin) + ((100vw - (2 * var(--grid-margin) + 11 * var(--grid-gap))) / 12) + 0.625rem);
  bottom: 1.75rem;
  display: flex;
  gap: calc(var(--grid-gap) * 1.35);
  min-width: 4.6rem;
  color: #fff;
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.1em;
  mix-blend-mode: exclusion;
}

.counter-window {
  position: relative;
  overflow: hidden;
  width: 1.2em;
  height: 1.2em;
}

.current-index {
  position: absolute;
  inset: 0;
  color: rgba(255, 255, 255, 0.24);
  will-change: transform;
}

.js-item-list,
.js-item-list-copy {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.counter-ghost {
  opacity: 0;
}

.current-length {
  width: 1.2em;
}

.project-counter .current-index {
  color: rgba(255, 255, 255, 0.24);
}

.view-toggle {
  position: absolute;
  z-index: 8;
  right: calc(var(--grid-margin) - 0.25rem);
  bottom: 1.6875rem;
  width: 2.5rem;
  height: 1.125rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  cursor: pointer;
  mix-blend-mode: exclusion;
}

.toggle-icon {
  position: relative;
  display: block;
  width: 2.5rem;
  height: 1.125rem;
}

.toggle-bar {
  position: absolute;
  top: 50%;
  width: 2px;
  height: 0.65rem;
  transform: translateY(-50%);
  will-change: transform;
}

.toggle-bar-inner {
  display: block;
  width: 100%;
  height: 100%;
  background: currentColor;
  will-change: transform;
}

.js-left {
  left: calc(50% - 0.625rem);
}

.js-middle-left {
  left: calc(50% - 0.125rem);
}

.js-middle-right {
  right: calc(50% - 0.125rem);
}

.js-right {
  right: calc(50% - 0.625rem);
}

.project-list {
  position: absolute;
  z-index: 7;
  inset: 0;
  display: grid;
  align-content: center;
  gap: 0;
  padding: 8rem var(--grid-margin) 6.75rem;
  background: rgba(0, 0, 0, 0.86);
  clip-path: inset(0 0 100% 0);
  pointer-events: none;
}

.project-list button {
  display: grid;
  grid-template-columns: 0.55fr 3.45fr 2.7fr 0.8fr;
  gap: var(--grid-gap);
  align-items: center;
  width: 100%;
  min-height: clamp(3.75rem, 8.5vh, 5.6rem);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  color: #fff;
  cursor: pointer;
  text-align: left;
  opacity: 0;
  transform: translateY(2rem);
}

.project-list button:last-child {
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.project-list span {
  color: rgba(255, 255, 255, 0.34);
  font-family: "Geist Mono", Consolas, monospace;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: color 260ms ease;
}

.project-list span:nth-child(2) {
  color: #fff;
  font-family: "Geist", Arial, Helvetica, sans-serif;
  font-size: clamp(2rem, 5vw, 5rem);
  line-height: 1.04;
  letter-spacing: 0;
  text-transform: none;
}

.project-list button:hover span,
.project-list button.is-selected span {
  color: #fff;
}

.shop-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
}

.shop-actions-main {
  position: absolute;
  z-index: 8;
  left: var(--grid-margin);
  bottom: 1.55rem;
  color: #fff;
  mix-blend-mode: exclusion;
}

.order-link,
.social-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.625rem;
  border: 1px solid currentColor;
  color: inherit;
  line-height: 1;
  transition: background 260ms var(--ease), color 260ms var(--ease), transform 260ms var(--ease), opacity 260ms var(--ease);
}

.order-link {
  gap: 0.625rem;
  padding: 0 1rem 0 0.625rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.order-link-icon,
.social-links span {
  font-family: "Geist Mono", Consolas, monospace;
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.order-link-icon {
  display: inline-grid;
  place-items: center;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  background: currentColor;
  color: #000;
}

.social-links {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
}

.social-links a {
  width: 2.625rem;
  border-radius: 50%;
}

.order-link:hover,
.social-links a:hover {
  background: #fff;
  color: #000;
  transform: translateY(-2px);
}

.order-link:hover .order-link-icon {
  background: #000;
  color: #fff;
}

.about-panel {
  position: fixed;
  inset: 0;
  z-index: 16;
  display: grid;
  grid-template-columns: 7fr 5fr;
  gap: var(--grid-gap);
  align-items: end;
  padding: 8rem var(--grid-margin) var(--grid-margin);
  overflow: hidden;
  background: #eef3ed;
  color: #000;
  clip-path: inset(0 0 100% 0);
  pointer-events: none;
}

.about-panel > div {
  opacity: 0;
  transform: translateY(2rem);
}

.about-close {
  position: absolute;
  top: 1.875rem;
  right: var(--grid-margin);
  z-index: 2;
  cursor: pointer;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.about-kicker {
  margin: 0 0 1.25rem;
  color: rgba(0, 0, 0, 0.42);
  font-family: "Geist Mono", Consolas, monospace;
  font-size: 0.75rem;
  line-height: 1.5;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.about-panel h2 {
  max-width: 58rem;
  margin: 0;
  font-size: clamp(3rem, 7vw, 8.333rem);
  font-weight: 400;
  line-height: 0.96;
  letter-spacing: 0;
}

.about-copy {
  display: grid;
  gap: 1.35rem;
  justify-items: start;
}

.about-copy p {
  max-width: 32rem;
  margin: 0 0 0.5rem;
  color: rgba(0, 0, 0, 0.58);
  font-family: "Geist Mono", Consolas, monospace;
  font-size: 0.875rem;
  line-height: 1.5;
  letter-spacing: 0.08em;
}

.shop-actions-about {
  color: #000;
}

.shop-actions-about .order-link:hover,
.shop-actions-about .social-links a:hover {
  background: #000;
  color: #eef3ed;
}

.shop-actions-about .order-link-icon {
  color: #eef3ed;
}

.shop-actions-about .order-link:hover .order-link-icon {
  background: #eef3ed;
  color: #000;
}

.js-reveal {
  transform: translateY(110%);
  clip-path: inset(0 0 100% 0);
}

@media (max-width: 999px) {
  :root {
    --grid-margin: 1.125rem;
  }

  .site-header {
    top: 1.25rem;
    grid-template-columns: auto minmax(0, 1fr) auto;
    height: 2.25rem;
  }

  .header-quote {
    max-width: min(13.5rem, 52vw);
    font-size: 0.56rem;
    line-height: 1.3;
  }

  .main-nav {
    display: none;
  }

  .mobile-about-link {
    position: relative;
    display: block;
  }

  .work-item {
    height: min(calc(((100vw - (2 * var(--grid-margin) + 5 * var(--grid-gap))) / 6) * 4.35 + 3 * var(--grid-gap)), calc(100dvh - 11rem));
  }

  .work-item.is-secondary {
    display: block;
  }

  .project-details {
    left: var(--grid-margin);
    right: var(--grid-margin);
    bottom: 1.6rem;
    align-items: center;
    width: auto;
    text-align: center;
  }

  .project-counter {
    left: var(--grid-margin);
    right: var(--grid-margin);
    bottom: 50%;
    justify-content: space-between;
    width: auto;
    min-width: 0;
    transform: translateY(50%);
  }

  .view-toggle {
    display: none;
  }

  .shop-actions-main {
    left: var(--grid-margin);
    right: var(--grid-margin);
    bottom: 1.35rem;
    justify-content: center;
  }

  .project-list {
    display: none;
  }

  .time-panel {
    padding-inline: var(--grid-margin);
  }

  .time-panel p {
    right: var(--grid-margin);
    bottom: 7.25rem;
    width: min(19rem, 52vw);
    font-size: 0.75rem;
  }

  .time-meta {
    bottom: 7.25rem;
    grid-template-columns: 1fr 1fr;
  }

  .big-time {
    font-size: 28vw;
  }

  .about-panel {
    grid-template-columns: 1fr;
    align-content: end;
    gap: 2rem;
    padding-top: 7rem;
  }

  .about-copy {
    gap: 1.2rem;
  }
}

@media (max-width: 620px) {
  body::before {
    opacity: 0.52;
  }

  .loader-wrapper {
    transform: translate(-50%, -50%) scale(0.85);
  }

  .loader-text {
    top: calc(54% + 6.75rem);
    width: calc(100vw - 2 * var(--grid-margin));
    text-align: center;
  }

  .work-item {
    height: min(86vw, calc(100dvh - 12rem), 31rem);
  }

  .project-title-window {
    max-width: calc(100vw - 2 * var(--grid-margin));
    overflow: hidden;
  }

  .project-role-list div,
  .project-role-window .detail-ghost {
    font-size: 0.68rem;
  }

  .time-panel p {
    position: static;
    align-self: end;
    width: calc(100vw - 2 * var(--grid-margin));
    margin-bottom: 1.5rem;
  }

  .time-meta {
    bottom: 6.5rem;
  }

  .big-time {
    position: absolute;
    left: var(--grid-margin);
    right: var(--grid-margin);
    bottom: 0.8rem;
    font-size: 25vw;
  }

  .about-panel h2 {
    font-size: clamp(2.4rem, 13vw, 4.5rem);
    line-height: 1;
  }

  .about-copy p {
    font-size: 0.75rem;
  }

  .shop-actions {
    gap: 0.5rem;
  }

  .order-link {
    min-height: 2.45rem;
    padding-right: 0.85rem;
  }

  .social-links a {
    width: 2.45rem;
    min-height: 2.45rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 1ms !important;
    transition-duration: 1ms !important;
    scroll-behavior: auto !important;
  }

  .cursor-orb,
  .stage-canvas,
  .hero-background-video {
    display: none;
  }
}
