.site-header { background: rgba(0,0,0,.25); mix-blend-mode: normal; }
.site-header nav a { color: #fff; }
.brand span { font-size: 13px; color: #fff; }
.brand { align-items: center; }
.brand img { width: auto; height: 9px; object-fit: contain; align-self: center; }

.section-kicker, .proof-copy > span { font-size: 16px; font-weight: 700; letter-spacing: .2em; }
.section-kicker { border-top-width: 2px; gap: 22px; }
.section-kicker span { font-weight: 700; }
.proof-copy > span { color: #ddd; }

.tech-intro p {
  display: flex;
  align-items: baseline;
  gap: 12px;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: .06em;
  color: #fff;
}
.tech-intro p span {
  font-size: 9px;
  font-weight: 400;
  letter-spacing: .2em;
  color: #777;
}

.hero-lead { text-align: right; }

.product-view { position: relative; }
.product-view img {
  position: absolute;
  inset: 0;
  margin: auto;
  width: auto;
  height: auto;
  max-width: 70%;
  max-height: 92%;
  object-fit: contain;
}

.edition-gif {
  display: block;
  width: 100%;
  height: auto;
  margin-top: 28px;
}

@media (min-width: 901px) {
  .edition-gif-stack,
  .edition-grid article > .edition-gif {
    height: 780px;
    overflow: hidden;
  }
  .edition-grid article > .edition-gif {
    width: 100%;
    object-fit: contain;
  }
  .edition-gif-stack .edition-gif {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }
}

.feature-gif {
  display: block;
  width: 100%;
  height: auto;
  margin-top: 24px;
}

@media (min-width: 901px) {
  .feature-gif { max-width: 310px; }
}

.edition-gif-stack {
  position: relative;
  margin-top: 28px;
}
.edition-gif-stack .edition-gif {
  margin-top: 0;
  opacity: 0;
  transition: opacity .6s ease;
}
.edition-gif-stack .edition-gif:first-child {
  position: relative;
}
.edition-gif-stack .edition-gif:not(:first-child) {
  position: absolute;
  inset: 0;
}
.edition-gif-stack .edition-gif.active {
  opacity: 1;
}

.tech-video {
  display: block;
  width: 100%;
  height: auto;
  margin-top: 24px;
}

.menu-toggle { display: flex; align-items: center; gap: 10px; font-size: 9px; letter-spacing: .15em; z-index: 2; }
.menu-toggle i { width: 18px; height: 1px; background: #fff; display: block; position: relative; }
.menu-toggle i::after { content: ""; position: absolute; width: 18px; height: 1px; background: #fff; top: 5px; left: 0; }
.site-header nav {
  position: fixed;
  inset: 0 0 0 auto;
  left: auto;
  width: min(420px, 86vw);
  background: #0a0a0a;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: 64px 56px;
  gap: 30px;
  font-size: 16px;
  transform: translateX(100%);
  transition: transform .5s;
  mix-blend-mode: normal;
}
body.menu-open .site-header nav { transform: none; }

.nav-collab {
  align-self: stretch;
  width: 100%;
  height: auto;
  object-fit: contain;
  margin: 40px 0 0;
  filter: invert(1);
}

.style-break img { object-position: center 26%; }

@media (max-width: 900px) {
  .style-break { height: auto; min-height: 0; aspect-ratio: 658 / 842; }
}

.menu-toggle i, .menu-toggle i::after { transition: transform .3s ease, top .3s ease; }
.menu-toggle span { position: relative; }
.menu-toggle span::after { content: "CLOSE"; position: absolute; left: 0; top: 0; opacity: 0; transition: opacity .2s ease; white-space: nowrap; }
body.menu-open .menu-toggle span { opacity: 0; }
body.menu-open .menu-toggle span::after { opacity: 1; }
body.menu-open .menu-toggle i { transform: rotate(45deg); }
body.menu-open .menu-toggle i::after { top: 0; transform: rotate(-90deg); }

footer > div:last-child { text-align: right; }
.footer-collab { margin: 0 0 28px; }
.footer-collab img {
  display: block;
  width: 320px;
  height: auto;
  margin-left: auto;
  filter: invert(1);
}

@media (max-width: 900px) {
  .footer-collab { margin: 0 0 32px; }
  .footer-collab img { width: 260px; margin: 0 auto; }
}

.scroll { flex-direction: column; align-items: center; gap: 10px; }
.scroll i { width: 1px; height: 34px; background: #fff; }
.scroll i::after {
  right: auto;
  top: auto;
  left: -2px;
  bottom: -1px;
  transform: rotate(45deg);
}

@media (min-width: 901px) {
  .tech-image { inset: 6% 36% 0 6%; }
}

.wide-visual img { object-position: center 5%; }

.mosaic-row figure { width: 22vw; }
.mosaic-row figure:nth-child(2n) { width: 30vw; }

@keyframes driftA {
  from { transform: translateX(-5%); }
  to { transform: translateX(-30%); }
}

@keyframes driftB {
  from { transform: translateX(-25%); }
  to { transform: translateX(-2%); }
}

@media (max-width: 900px) {
  .mosaic-row figure { width: 33vw; }
  .mosaic-row figure:nth-child(2n) { width: 48vw; }

  .site-header nav { width: min(78vw, 360px); padding: 28vw 10vw; }
}

@media (max-width: 560px) {
  .tech-intro h2 { font-size: 8.5vw; }
  .detail-lead h2 { font-size: 10vw; }
  .brand img { height: 7px; }
  .brand span { display: inline; }
}
