/* Homepage-only layout. */

.hero { position: relative; width: 100%; }

.hero__video {
  position: relative;
  width: calc(100% - 48px);
  margin: 6px 24px;
  aspect-ratio: 16 / 9;
  background: #0d0d0d;
  overflow: visible;
  cursor: pointer;
  --hero-cursor-x: 50%;
  --hero-cursor-y: 50%;
  animation: pageFadeIn 900ms var(--ease-out) 560ms both;
}

.hero__video.is-cursor-visible {
  cursor: none;
}

.hero__video::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(to bottom, transparent 0 var(--tear-y1, 8%), rgba(255,255,255,var(--tear-a1,0.32)) var(--tear-y1, 8%) calc(var(--tear-y1, 8%) + var(--tear-h1, 3px)), transparent calc(var(--tear-y1, 8%) + var(--tear-h1, 3px)) 100%),
    linear-gradient(to bottom, transparent 0 var(--tear-y2, 19%), rgba(255,255,255,var(--tear-a2,0.26)) var(--tear-y2, 19%) calc(var(--tear-y2, 19%) + var(--tear-h2, 2px)), transparent calc(var(--tear-y2, 19%) + var(--tear-h2, 2px)) 100%),
    linear-gradient(to bottom, transparent 0 var(--tear-y3, 33%), rgba(255,255,255,var(--tear-a3,0.2)) var(--tear-y3, 33%) calc(var(--tear-y3, 33%) + var(--tear-h3, 4px)), transparent calc(var(--tear-y3, 33%) + var(--tear-h3, 4px)) 100%);
  mix-blend-mode: overlay;
  z-index: 12;
  opacity: 0.4;
  transform: translateX(0);
  animation: vhsGlitchSlice 720ms steps(2, end) infinite;
  transition: inset var(--t-mid) var(--ease-out);
}

.hero__video__media {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: transparent;
  filter: contrast(1.02) saturate(0.96);
  transition:
    left var(--t-mid) var(--ease-out),
    top var(--t-mid) var(--ease-out),
    width var(--t-mid) var(--ease-out),
    height var(--t-mid) var(--ease-out),
    filter var(--t-mid) var(--ease-out);
}

.hero__video:hover::before,
.hero__video:hover .hero__scanline {
  inset: 5px;
}

.hero__video:hover .hero__video__media {
  left: 5px;
  top: 5px;
  width: calc(100% - 10px);
  height: calc(100% - 10px);
}

.hero__video-frame {
  position: absolute;
  inset: 0;
  z-index: 13;
  border: 0.5px solid var(--line-strong);
  pointer-events: none;
  transition: inset var(--t-mid) var(--ease-out);
}

.hero__video:hover .hero__video-frame {
  inset: 5px;
}

.hero__video.is-playing .hud--bl,
.hero__video.is-playing .hud--br {
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}

.hero__video__ch-h,
.hero__video__ch-v {
  position: absolute;
  display: none;
  background: rgba(255, 255, 255, 0.02);
  mix-blend-mode: difference;
  pointer-events: none;
  transition: background-color 180ms ease;
}

.hero__video__ch-h { left: 0; right: 0; top: var(--hero-cursor-y, 50%); height: 1px; }
.hero__video__ch-v { top: 0; bottom: 0; left: var(--hero-cursor-x, 50%); width: 1px; }

.hero__video.is-cursor-visible .hero__video__ch-h,
.hero__video.is-cursor-visible .hero__video__ch-v {
  background: rgba(255, 255, 255, 0.06);
}

.hero__video-corners {
  position: absolute;
  inset: 0;
  z-index: 11;
  pointer-events: none;
  transition: inset var(--t-mid) var(--ease-out);
}

.hero__video:hover .hero__video-corners {
  inset: -5px;
}

.hero__corner {
  position: absolute;
  width: 15px;
  height: 15px;
  border: 0 solid rgba(255, 255, 255, 0.3);
}

.hero__corner--tl {
  top: 0;
  left: 0;
  border-top-width: 0.5px;
  border-left-width: 0.5px;
}

.hero__corner--tr {
  top: 0;
  right: 0;
  border-top-width: 0.5px;
  border-right-width: 0.5px;
}

.hero__corner--bl {
  bottom: 0;
  left: 0;
  border-bottom-width: 0.5px;
  border-left-width: 0.5px;
}

.hero__corner--br {
  bottom: 0;
  right: 0;
  border-bottom-width: 0.5px;
  border-right-width: 0.5px;
}

.hud {
  position: absolute;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text-55);
  display: flex;
  align-items: center;
  gap: 16px;
  animation: pageFadeIn 650ms var(--ease-out) 840ms both;
}

.hud--tl { top: 30px; left: 30px; }
.hud--tr { top: 30px; right: 30px; }
.hud--bl { bottom: 34px; left: 30px; color: var(--text-55); }
.hud--br { bottom: 34px; right: 30px; color: var(--text-55); text-align: right; }

.hud__rec { display: inline-flex; align-items: center; gap: 8px; }

.hud__rec::before {
  content: "";
  width: 7px;
  height: 7px;
  background: var(--rec);
  border-radius: 50%;
  animation: pulseDot 1.6s ease-in-out infinite;
}

.hud__sep { color: var(--text-40); }

.hero__play {
  display: none;
}

.hero__video:hover .hero__play,
.hero__video.is-cursor-visible .hero__play {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.hero__video:active .hero__play {
  transform: translate(-50%, -50%) scale(0.9);
}

.hero__play-icon {
  font-family: "Material Symbols Outlined";
  font-size: 32px;
  font-weight: 200;
  font-variation-settings: "FILL" 1, "wght" 200, "GRAD" 0, "opsz" 24;
  line-height: 1;
  color: var(--bg);
  direction: ltr;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
  -webkit-font-feature-settings: "liga";
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "liga";
}

.hero__scanline {
  position: absolute;
  inset: 0;
  z-index: 8;
  overflow: hidden;
  pointer-events: none;
  transition: inset var(--t-mid) var(--ease-out);
}

.hero__scanline::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.035) 0,
    rgba(255, 255, 255, 0.035) 1px,
    transparent 1px,
    transparent 4px
  );
  mix-blend-mode: screen;
  opacity: 0.6;
}

.hero__scanline::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 2px;
  background: rgba(255, 255, 255, 0.035);
  animation: heroScan 9s linear infinite;
}

@media (hover: hover) and (pointer: fine) {
  .hero__video {
    cursor: none;
  }
}

.hero__slogan-block {
  min-height: 422px;
  padding: 48px 24px;
}

.hero__slogan {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(54px, 9.22vw, 118px);
  line-height: 1;
  letter-spacing: -1px;
  color: var(--text-display);
  width: 100%;
  max-width: 1200px;
}

.hero__intro {
  margin-top: 32px;
  max-width: 960px;
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 24px;
  line-height: 1.2;
  letter-spacing: 0;
  color: var(--text-55);
}

.hero__intro strong { color: inherit; font-weight: inherit; }

.hero__scroll {
  height: 162px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

#work {
  padding-top: 24px;
}

.hero__scroll-label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 1px;
  color: var(--text-55);
  text-transform: uppercase;
}

.hero__scroll-track {
  width: 1px;
  height: 96px;
  background: rgba(255, 255, 255, 0.12);
  position: relative;
  overflow: hidden;
}

.hero__scroll-track::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 28px;
  background: var(--text);
  animation: scrollDrop 1.8s ease-in-out infinite;
}

@keyframes vhsGlitchSlice {
  0% {
    transform: translateX(0);
  }
  8% {
    transform: translateX(5px) skewX(-0.8deg);
  }
  10% {
    transform: translateX(-3px) skewX(0.35deg);
  }
  46% {
    transform: translateX(0);
  }
  48% {
    transform: translateX(-6px) skewX(0.78deg);
  }
  50% {
    transform: translateX(3px) skewX(-0.32deg);
  }
  100% {
    transform: translateX(0);
  }
}

.work__split {
  display: grid;
  grid-template-columns: minmax(0, 0.4fr) minmax(0, 0.6fr);
  gap: 48px;
}

.work__hint {
  margin-bottom: 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 1px;
  color: var(--text-55);
  text-transform: uppercase;
}

.work__index { width: 100%; }

.work-row {
  position: relative;
  display: flex;
  gap: 8px;
  align-items: flex-start;
  min-height: 73px;
  padding: 24px 8px;
  border-bottom: 0.5px solid rgba(255, 255, 255, 0.05);
  cursor: pointer;
  background: transparent;
  overflow: hidden;
  transition: padding var(--t-mid) var(--ease-out), gap var(--t-mid) var(--ease-out);
}

.work-row::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: var(--text);
  opacity: 0;
  transform: scaleX(1);
  transform-origin: left center;
  transition: opacity 320ms ease;
}

.work-row:first-child { border-top: 0; }

.work-row__link {
  position: absolute;
  inset: 0;
  z-index: 5;
}

.work-row.is-active {
  min-height: 78px;
  padding: 24px 16px 24px 56px;
  gap: 16px;
  align-items: center;
}

.work-row.is-active::before,
.work-row:hover::before,
.work-row:focus-within::before {
  opacity: 1;
  animation: workRowFillIn 360ms var(--ease-out) both;
}

.work-row__caret {
  position: absolute;
  z-index: 2;
  left: 16px;
  top: 50%;
  width: 30px;
  font-family: "Material Symbols Outlined";
  font-size: 28px;
  font-weight: 200;
  font-variation-settings: "FILL" 0, "wght" 200, "GRAD" 0, "opsz" 24;
  line-height: 1;
  color: var(--text);
  opacity: 0;
  transform: translate(-14px, -50%);
  transition:
    opacity 120ms ease,
    transform 180ms var(--ease-out),
    color var(--t-fast);
}

.work-row.is-active .work-row__caret,
.work-row:hover .work-row__caret,
.work-row:focus-within .work-row__caret {
  color: var(--bg);
  opacity: 1;
  transform: translate(0, -50%);
  transition:
    opacity 280ms ease,
    transform 380ms var(--ease-out),
    color var(--t-fast);
}

.work-row__num {
  position: relative;
  z-index: 1;
  flex: 0 0 auto;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 400;
  color: var(--text-40);
  letter-spacing: 1px;
  transition: color var(--t-fast);
}

.work-row.is-active .work-row__num { color: var(--bg); opacity: 1; }

.work-row__title-wrap {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-start;
  gap: 16px;
  flex: 1 1 auto;
  min-width: 0;
}

.work-row__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 28px;
  line-height: 1;
  letter-spacing: 0;
  color: var(--text-55);
  position: relative;
  white-space: nowrap;
  transition: color var(--t-fast);
}

.work-row.is-active .work-row__title,
.work-row:hover .work-row__title,
.work-row:focus-within .work-row__title,
.work-row:hover .work-row__num,
.work-row:focus-within .work-row__num {
  color: var(--bg);
}

.work-row__year {
  position: relative;
  z-index: 1;
  flex: 0 0 auto;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 400;
  color: var(--text-40);
  letter-spacing: 1px;
  text-align: right;
  transition: color var(--t-fast);
}

.work-row.is-active .work-row__year,
.work-row:hover .work-row__year,
.work-row:focus-within .work-row__year {
  color: var(--bg);
}

@keyframes workRowFillIn {
  from { transform: scaleX(0); }
  to { transform: scaleX(1); }
}

.work__preview-wrap { position: relative; }

.work__preview {
  position: sticky;
  top: 74px;
  width: 100%;
  aspect-ratio: 16 / 9;
}

.work__preview .frame__inner,
.work-card__preview .frame__inner,
.about__portrait .frame__inner {
  background: #0d0d0d;
  border-color: rgba(255, 255, 255, 0.05);
}

.work__preview .frame__inner,
.work-card__preview .frame__inner,
.about__portrait .frame__inner {
  overflow: visible;
}

.work__preview .frame__ch-h,
.work__preview .frame__ch-v,
.work-card__preview .frame__ch-h,
.work-card__preview .frame__ch-v,
.about__portrait .frame__ch-h,
.about__portrait .frame__ch-v {
  display: none;
  background: rgba(255, 255, 255, 0.02);
  mix-blend-mode: difference;
  transition: background-color 180ms ease;
}

.work__preview .frame__ch-h,
.work-card__preview .frame__ch-h,
.about__portrait .frame__ch-h {
  top: var(--preview-cross-y, 50%);
}

.work__preview .frame__ch-v,
.work-card__preview .frame__ch-v,
.about__portrait .frame__ch-v {
  left: var(--preview-cross-x, 50%);
}

.work__preview .preview-slot.is-cursor-active .frame__ch-h,
.work__preview .preview-slot.is-cursor-active .frame__ch-v,
.work-card.is-cursor-active .frame__ch-h,
.work-card.is-cursor-active .frame__ch-v,
.about__portrait.is-cursor-active .frame__ch-h,
.about__portrait.is-cursor-active .frame__ch-v {
  background: rgba(255, 255, 255, 0.06);
}

.work__preview .frame__brackets > span,
.work-card__preview .frame__brackets > span,
.about__portrait .frame__brackets > span {
  border-color: rgba(255, 255, 255, 0.4);
}

.work__preview .frame__brackets,
.work-card__preview .frame__brackets,
.about__portrait .frame__brackets {
  inset: -10px;
  transition: inset 240ms cubic-bezier(0.45, 0, 0.15, 1);
}

.work__preview .frame__inner,
.work-card__preview .frame__inner,
.about__portrait .frame__inner {
  inset: 10px;
  transform-style: preserve-3d;
  transform:
    translate3d(
      calc(var(--preview-shift-x, 0px) * -0.35),
      calc(var(--preview-shift-y, 0px) * -0.35),
      0
    )
    rotateX(var(--preview-tilt-x, 0deg))
    rotateY(var(--preview-tilt-y, 0deg))
    skew(
      calc(var(--preview-skew-x, 0deg) * 0.45),
      calc(var(--preview-skew-y, 0deg) * 0.35)
    );
  transform-origin: center;
  transition:
    inset 240ms cubic-bezier(0.45, 0, 0.15, 1),
    transform 160ms ease-out;
}

.work__preview .preview-slot:hover .frame__brackets,
.work__preview .preview-slot:focus-visible .frame__brackets,
.work-card:hover .frame__brackets,
.work-card:focus-visible .frame__brackets,
.about__portrait:hover .frame__brackets,
.about__portrait:focus-visible .frame__brackets {
  inset: -10px;
}

.work__preview .preview-slot:hover .frame__inner,
.work__preview .preview-slot:focus-visible .frame__inner,
.work-card:hover .frame__inner,
.work-card:focus-visible .frame__inner,
.about__portrait:hover .frame__inner,
.about__portrait:focus-visible .frame__inner {
  inset: 10px;
}

.work__preview .frame__label,
.work-card__preview .frame__label,
.about__portrait .frame__label {
  opacity: 0;
  transform: translate3d(
    calc(var(--preview-shift-x, 0px) * 0.8),
    calc(var(--preview-shift-y, 0px) * 0.8),
    42px
  );
  transition:
    opacity 260ms ease,
    transform 420ms cubic-bezier(0.45, 0, 0.15, 1);
}

.work__preview .preview-slot,
.work-card,
.about__portrait {
  perspective: 680px;
  transform-style: preserve-3d;
  --preview-cursor-x: 50%;
  --preview-cursor-y: 50%;
  --preview-cross-x: 50%;
  --preview-cross-y: 50%;
}

.work__preview .preview-slot::after,
.work-card::after,
.about__portrait::after {
  content: "arrow_outward";
  position: absolute;
  left: var(--preview-cursor-x, 50%);
  top: var(--preview-cursor-y, 50%);
  z-index: 12;
  width: 32px;
  height: 32px;
  display: none;
  place-items: center;
  background: rgba(255, 255, 255, 0.92);
  border: 0.5px solid rgba(255, 255, 255, 0.18);
  color: var(--bg);
  mix-blend-mode: difference;
  font-family: "Material Symbols Outlined";
  font-size: 24px;
  font-weight: 200;
  font-variation-settings: "FILL" 1, "wght" 200, "GRAD" 0, "opsz" 24;
  line-height: 1;
  letter-spacing: 0;
  text-transform: none;
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, -50%) scale(0.82);
  transition:
    opacity 160ms ease,
    transform 220ms cubic-bezier(0.45, 0, 0.15, 1);
}

.about__portrait::after {
  content: "";
  width: 8px;
  height: 8px;
}

.work__preview .preview-slot.is-cursor-active,
.work-card.is-cursor-active,
.about__portrait.is-cursor-active {
  cursor: none;
}

.work__preview .preview-slot.is-cursor-active::after,
.work-card.is-cursor-active::after,
.about__portrait.is-cursor-active::after {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.work__preview .frame__brackets,
.work-card__preview .frame__brackets,
.about__portrait .frame__brackets {
  transform:
    translate3d(
      calc(var(--preview-shift-x, 0px) * 1.35),
      calc(var(--preview-shift-y, 0px) * 1.35),
      34px
    )
    rotateX(calc(var(--preview-tilt-x, 0deg) * -0.45))
    rotateY(calc(var(--preview-tilt-y, 0deg) * -0.45))
    skew(var(--preview-skew-x, 0deg), var(--preview-skew-y, 0deg));
  transform-origin: center;
  transition:
    inset 240ms cubic-bezier(0.45, 0, 0.15, 1),
    transform 120ms ease-out;
}

.work__preview .frame__label,
.work-card__preview .frame__label,
.about__portrait .frame__label {
  transform:
    translate3d(
      calc(var(--preview-shift-x, 0px) * 0.8),
      calc(var(--preview-shift-y, 0px) * 0.8),
      42px
    );
}

.work__preview .preview-slot:hover .frame__label,
.work__preview .preview-slot:focus-visible .frame__label,
.work-card:hover .frame__label,
.work-card:focus-visible .frame__label,
.about__portrait:hover .frame__label,
.about__portrait:focus-visible .frame__label {
  opacity: 0;
  transform:
    translate3d(
      calc(var(--preview-shift-x, 0px) * 0.8),
      calc(var(--preview-shift-y, 0px) * 0.8),
      42px
    );
}

.work__preview .preview-slot {
  position: absolute;
  inset: 0;
  display: block;
  opacity: 0;
  transition: opacity var(--t-slow) ease;
  pointer-events: none;
  color: inherit;
  text-decoration: none;
  cursor: pointer;
}

.work__preview .preview-slot.is-active { opacity: 1; pointer-events: auto; }

.work__cards {
  display: none;
}

.work__cards-head {
  display: none;
}

.work__cards-btn {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 0.5px solid rgba(255, 255, 255, 0.12);
  border-radius: 0;
  background: transparent;
  color: var(--text-55);
  cursor: pointer;
  transition: color var(--t-fast), background var(--t-fast), border-color var(--t-fast), opacity var(--t-fast);
}

.work__cards-btn .material-symbols-outlined {
  font-family: "Material Symbols Outlined";
  font-size: 24px;
  font-weight: 200;
  font-variation-settings: "FILL" 0, "wght" 200, "GRAD" 0, "opsz" 24;
  line-height: 1;
}

.work__cards-btn:disabled {
  cursor: default;
  opacity: 0.32;
}

@media (hover: hover) and (pointer: fine) {
  .work__cards-btn:not(:disabled):hover {
    background: var(--text);
    border-color: var(--text);
    color: var(--bg);
  }
}

.work-card {
  position: relative;
  display: flex;
  flex: 0 0 100%;
  flex-direction: column;
  gap: 16px;
  color: inherit;
  text-decoration: none;
  scroll-snap-align: start;
}

.work-card__preview {
  position: relative;
  aspect-ratio: 16 / 9;
  width: 100%;
  overflow: visible;
}

.work-card__mobile-cover {
  display: none;
}

.work-card__meta {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 8px;
  min-height: 46px;
  box-sizing: border-box;
  padding: 0 10px;
}

.work-card__title-group,
.work-card__arrow-group {
  display: flex;
  flex-direction: column;
}

.work-card__title-group {
  gap: 8px;
  min-width: 0;
}

.work-card__arrow-group {
  align-items: flex-end;
  flex: 0 0 28px;
}

.work-card__year {
  font-family: var(--font-mono);
  font-size: 10px;
  line-height: 1;
  letter-spacing: 1px;
  color: var(--text-40);
  transition: color var(--t-mid) var(--ease-out);
}

.work-card__title {
  overflow: hidden;
  font-family: var(--font-display);
  font-size: 28px;
  line-height: 1;
  letter-spacing: 0;
  color: var(--text-55);
  text-overflow: ellipsis;
  white-space: nowrap;
  transition: color var(--t-mid) var(--ease-out);
}

.work-card__icon {
  display: inline-block;
  font-family: "Material Symbols Outlined";
  font-size: 28px;
  font-weight: 200;
  font-variation-settings: "FILL" 0, "wght" 200, "GRAD" 0, "opsz" 24;
  line-height: 1;
  color: var(--text-40);
  transition: color var(--t-mid) var(--ease-out);
}

.work-card.is-active .work-card__year,
.work-card.is-active .work-card__title,
.work-card.is-active .work-card__icon {
  color: var(--text);
}

.work-card__arrow-group {
  overflow: hidden;
}

.work-card:hover .work-card__icon,
.work-card:focus-visible .work-card__icon {
  animation: workCardArrowLoop 640ms cubic-bezier(0.45, 0, 0.15, 1) 1;
}

.work__cards .work-card__preview .frame__brackets {
  inset: 10px;
  transform: none;
  transform-origin: center;
  transition:
    inset 240ms cubic-bezier(0.45, 0, 0.15, 1),
    transform 120ms ease-out;
}

.work__cards .work-card__preview .frame__brackets > span {
  border-color: rgba(255, 255, 255, 0.15);
}

.work__cards .work-card__preview .frame__brackets > .b--tl { border-top-width: 1px; border-left-width: 1px; }
.work__cards .work-card__preview .frame__brackets > .b--tr { border-top-width: 1px; border-right-width: 1px; }
.work__cards .work-card__preview .frame__brackets > .b--bl { border-bottom-width: 1px; border-left-width: 1px; }
.work__cards .work-card__preview .frame__brackets > .b--br { border-bottom-width: 1px; border-right-width: 1px; }

.work__cards .work-card__preview .frame__inner {
  inset: 0;
  transform: none;
  transform-style: preserve-3d;
  transform-origin: center;
  transition:
    inset 240ms cubic-bezier(0.45, 0, 0.15, 1),
    transform 160ms ease-out;
}

.work__cards .work-card:hover .frame__brackets,
.work__cards .work-card:focus-visible .frame__brackets {
  inset: -10px;
  transform:
    translate3d(
      calc(var(--preview-shift-x, 0px) * 1.35),
      calc(var(--preview-shift-y, 0px) * 1.35),
      34px
    )
    rotateX(calc(var(--preview-tilt-x, 0deg) * -0.45))
    rotateY(calc(var(--preview-tilt-y, 0deg) * -0.45))
    skew(var(--preview-skew-x, 0deg), var(--preview-skew-y, 0deg));
}

.work__cards .work-card:hover .frame__brackets > span,
.work__cards .work-card:focus-visible .frame__brackets > span {
  border-color: rgba(255, 255, 255, 0.4);
}

.work__cards .work-card:hover .frame__brackets > .b--tl,
.work__cards .work-card:focus-visible .frame__brackets > .b--tl { border-top-width: 1.5px; border-left-width: 1.5px; }
.work__cards .work-card:hover .frame__brackets > .b--tr,
.work__cards .work-card:focus-visible .frame__brackets > .b--tr { border-top-width: 1.5px; border-right-width: 1.5px; }
.work__cards .work-card:hover .frame__brackets > .b--bl,
.work__cards .work-card:focus-visible .frame__brackets > .b--bl { border-bottom-width: 1.5px; border-left-width: 1.5px; }
.work__cards .work-card:hover .frame__brackets > .b--br,
.work__cards .work-card:focus-visible .frame__brackets > .b--br { border-bottom-width: 1.5px; border-right-width: 1.5px; }

.work__cards .work-card:hover .frame__inner,
.work__cards .work-card:focus-visible .frame__inner {
  inset: 10px;
  transform:
    translate3d(
      calc(var(--preview-shift-x, 0px) * -0.35),
      calc(var(--preview-shift-y, 0px) * -0.35),
      0
    )
    rotateX(var(--preview-tilt-x, 0deg))
    rotateY(var(--preview-tilt-y, 0deg))
    skew(
      calc(var(--preview-skew-x, 0deg) * 0.45),
      calc(var(--preview-skew-y, 0deg) * 0.35)
    );
}

.work__cards .work-card__meta {
  transform: none;
  transform-origin: left top;
  transform-style: preserve-3d;
  transition: transform 160ms ease-out;
}

.work__cards .work-card:hover .work-card__meta,
.work__cards .work-card:focus-visible .work-card__meta {
  transform:
    translate3d(
      calc(var(--preview-shift-x, 0px) * 0.35),
      calc(var(--preview-shift-y, 0px) * 0.35),
      10px
    )
    rotateX(calc(var(--preview-tilt-x, 0deg) * 0.15))
    rotateY(calc(var(--preview-tilt-y, 0deg) * 0.15));
}

.work__cards .work-card__year,
.work__cards .work-card__title,
.work__cards .work-card__icon {
  transition: color 180ms ease, transform 160ms ease-out;
}

.work__cards .work-card__title,
.work__cards .work-card__year,
.work__cards .work-card__icon {
  transform: none;
}

.work__cards .work-card:hover .work-card__title,
.work__cards .work-card:focus-visible .work-card__title {
  transform: translateZ(10px);
}

.work__cards .work-card:hover .work-card__year,
.work__cards .work-card:hover .work-card__icon,
.work__cards .work-card:focus-visible .work-card__year,
.work__cards .work-card:focus-visible .work-card__icon {
  transform: translateZ(18px);
}

@keyframes workCardArrowLoop {
  0% {
    opacity: 1;
    transform: translate(0, 0);
  }
  38% {
    opacity: 0;
    transform: translate(12px, -12px);
  }
  39% {
    opacity: 0;
    transform: translate(-12px, 12px);
  }
  72%, 100% {
    opacity: 1;
    transform: translate(0, 0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .work-card:hover .work-card__icon,
  .work-card:focus-visible .work-card__icon {
    animation: none;
  }
}

.work__more {
  margin-top: 48px;
  display: flex;
  justify-content: center;
}

.work__more .btn {
  width: auto;
  min-width: 212px;
  white-space: nowrap;
}

.about__grid {
  display: grid;
  grid-template-columns: minmax(0, 480px) minmax(0, 1fr);
  gap: 48px;
  align-items: flex-start;
}

.about__portrait {
  position: relative;
  width: 100%;
  max-width: 480px;
  aspect-ratio: 3 / 4;
}

.about__content {
  width: 100%;
  max-width: 680px;
}

.about__lede {
  max-width: 960px;
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 32px;
  line-height: 1.25;
  letter-spacing: 0;
  color: var(--text);
  margin-top: 0;
  margin-bottom: 16px;
}

.about__body {
  max-width: 960px;
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.5;
  color: var(--text-55);
  margin-top: 0;
  margin-bottom: 32px;
}

.about__meta {
  display: flex;
  flex-direction: column;
  gap: 24px;
  max-width: 960px;
}

.about__meta > div {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 170px;
  padding-top: 0;
  border-top: 0;
}

.about__meta dt {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 400;
  color: var(--text-55);
  letter-spacing: 1px;
  text-transform: uppercase;
}

.about__meta dd {
  font-family: var(--font-body);
  font-size: 13px;
  line-height: 1.2;
  color: var(--text);
}

.exp__grid {
  display: grid;
  grid-template-columns: minmax(0, 0.4fr) minmax(0, 0.6fr);
  gap: 48px;
  align-items: flex-start;
}

.exp__left { position: sticky; top: 90px; }

.exp__lede {
  max-width: 680px;
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 32px;
  line-height: 1.2;
  letter-spacing: 0;
  color: var(--text);
  margin-bottom: 48px;
}

.exp__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  max-width: 640px;
  margin-bottom: 48px;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,0.05);
}

.exp__stats .stat__num {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 48px;
  letter-spacing: -1px;
  line-height: 1;
  color: var(--text);
}

.exp__stats > div {
  width: max-content;
  justify-self: start;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  text-align: center;
}

.exp__stats .stat__label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 400;
  color: var(--text-55);
  letter-spacing: 1px;
  line-height: 1;
  text-transform: uppercase;
  margin-top: 0;
}

.exp__cv { width: 221px; }

.exp__right {
  border-top: 0;
}

.exp__row {
  min-height: 137px;
  padding: 32px 0;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 32px;
  align-items: start;
}

/* Left group: logo → year → content, horizontal flex */
.exp__group {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 48px;
}

/* Right group: mark */
.exp__mark { grid-column: 2; justify-self: end; }

.exp__mark,
.exp__years {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 1px;
  color: var(--text-40);
}

.exp__logo { width: 100px; height: 30px; flex-shrink: 0; }
.exp__years { width: 72px; padding-top: 2px; font-size: 13px; line-height: 1; letter-spacing: 1px; color: var(--text-55); flex-shrink: 0; }
.exp__mark { width: 32px; padding-top: 2px; }

.exp__logo {
  width: 100px;
  height: 30px;
  display: block;
  opacity: 1;
  background-repeat: no-repeat;
  background-position: left center;
  background-size: contain;
}

.exp__logo--gm { background-image: url("../assets/GM%20Logo.svg"); }
.exp__logo--jidu { background-image: url("../assets/JIDU%20Logo.svg"); }
.exp__logo--avatr { background-image: url("../assets/Avatr%20Logo.svg"); }
.exp__logo--enovate { background-image: url("../assets/Enovate%20Logo.svg"); }

.exp__role {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 24px;
  line-height: 1.2;
  color: var(--text);
  margin-bottom: 16px;
}

.exp__co {
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1;
  letter-spacing: 1px;
  color: var(--text-55);
  margin-bottom: 4px;
}

.exp__scope {
  font-family: var(--font-body);
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: 0;
  color: var(--text-40);
  text-transform: none;
}

.exp__scope-short { display: none; }

@media (max-width: 719px) {
  .exp__scope-detail { display: none; }
  .exp__scope-short { display: block; }
}

.contact__grid {
  display: grid;
  grid-template-columns: minmax(0, 0.4fr) minmax(0, 0.6fr);
  gap: 48px;
  align-items: flex-start;
}

.contact__lede {
  max-width: 680px;
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 32px;
  line-height: 1.2;
  color: var(--text);
  margin-bottom: 48px;
}

.contact__button { min-width: 260px; }

.contact__meta .pair:nth-child(-n+2) dd {
  cursor: pointer;
}

.contact__side {
  display: grid;
  grid-template-columns: 176px minmax(0, 1fr);
  gap: 48px;
}

.wechat-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-self: stretch;
  padding: 8px 32px;
  border-bottom: 0.5px solid rgba(255,255,255,0.05);
}

.wechat-card__qr {
  width: 120px;
  height: 120px;
  background: transparent;
  padding: 0;
  background-image: url("../assets/wechat%20QR.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.wechat-card__label,
.wechat-card__caption {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 400;
  color: var(--text-55);
  letter-spacing: 1px;
}

.wechat-card__label {
  text-transform: uppercase;
}

.wechat-card__caption {
  max-width: 160px;
  font-size: 9px;
  line-height: 1;
  text-align: center;
  text-transform: none;
  letter-spacing: 0;
}

.contact__meta {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.contact__meta .pair {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 8px 0;
  border-top: 0;
  border-bottom: 0.5px solid rgba(255,255,255,0.05);
}

.contact__meta dt {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 400;
  color: var(--text-55);
  letter-spacing: 1px;
  text-transform: uppercase;
}

.contact__meta dd {
  font-family: var(--font-display);
  font-size: 18px;
  line-height: normal;
  color: var(--text);
}

@media (max-width: 1199px) {
  .hero__video {
    width: calc(100% - 32px);
    margin-right: 16px;
    margin-left: 16px;
  }

  .hero__slogan-block {
    padding-right: 16px;
    padding-left: 16px;
    min-height: auto;
  }

  .hero__scroll {
    padding-right: 16px;
    padding-left: 16px;
  }

  .hero__intro,
  .exp__lede,
  .contact__lede { font-size: 21px; }
  .contact__lede { margin-bottom: 0; }

  .work__split,
  .exp__grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }

  .contact__grid {
    grid-template-columns: 1fr auto 1fr;
    gap: 8px;
  }

  .contact__side {
    display: contents;
  }

  .work__split { display: none; }
  .work__cards-head {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    margin-bottom: 16px;
  }

  .work__cards {
    --work-card-gap: 8px;
    --work-card-peek: 36px;
    display: flex;
    gap: var(--work-card-gap);
    margin-right: -16px;
    margin-left: -16px;
    padding: 12px 16px 18px;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scroll-padding-left: 16px;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }

  .work-card {
    flex-basis: calc(100% - var(--work-card-gap) - var(--work-card-peek));
  }

  .work__cards::-webkit-scrollbar { display: none; }

  .work__preview { position: static; }
  .about__grid,
  .exp__left {
    display: grid;
    grid-template-columns: minmax(240px, 0.42fr) minmax(0, 0.58fr);
    gap: 32px;
    align-items: flex-start;
  }
  .about__portrait { max-width: none; }
  .exp__left { position: static; }
  .exp__lede,
  .exp__stats {
    margin-bottom: 0;
  }
  .exp__stats {
    padding-top: 0;
    border-top: 0;
  }
  .exp__stats > div {
    justify-self: start;
  }
  .exp__cv {
    grid-column: 1 / -1;
    justify-self: center;
  }
  .wechat-card {
    padding: 8px 16px;
    align-items: center;
    text-align: center;
    justify-self: center;
  }
}

@media (max-width: 719px) {
  .hero__video {
    width: calc(100% - 24px);
    margin-right: 12px;
    margin-left: 12px;
  }

  .hero__video { min-height: 220px; }
  .hud { font-size: 8.5px; gap: 8px; }
  .hud--tl, .hud--tr { top: 14px; }
  .hud--tl { left: 14px; }
  .hud--tr { right: 14px; }
  .hud--bl, .hud--br { bottom: 14px; }
  .hud--bl { left: 14px; }
  .hud--br { right: 14px; }
  .hud--bl, .hud--br { max-width: 44%; }
  .hero__play { display: none; }
  .hero__play-icon { font-size: 32px; }

  .hero__slogan-block { padding: 32px 12px; }
  .hero__intro { margin-top: 32px; font-size: 18px; line-height: 1.35; }
  .hero__scroll { height: 120px; padding: 0 12px; }

  .work__cards {
    --work-card-gap: 8px;
    --work-card-peek: 36px;
    gap: var(--work-card-gap);
    margin-right: -12px;
    margin-left: -12px;
    padding: 12px 12px 18px;
    scroll-padding-left: 12px;
  }

  .work-card {
    flex-basis: calc(100% - var(--work-card-gap) - var(--work-card-peek));
    gap: 14px;
  }

  .work-card__desktop-video {
    display: none;
  }

  .work-card__mobile-cover {
    display: block;
  }

  .work-card__title {
    font-size: 24px;
  }

  .work-row {
    grid-template-columns: 32px 1fr 44px;
    gap: 12px;
    padding: 14px 12px;
  }
  .work-row.is-active { min-height: 70px; padding: 14px 12px 14px 44px; gap: 12px; }
  .work-row__caret { left: 12px; }
  .work-row__caret { font-size: 22px; }
  .work-row__title { font-size: 21px; white-space: normal; }
  .work__more .btn { width: auto; }

  .about__lede { font-size: 24px; }
  .about__body { font-size: 15px; }
  .about__meta > div,
  .contact__meta .pair {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .exp__stats { gap: 24px; }
  .exp__stats > div { justify-self: center; }
  .exp__cv {
    justify-self: center;
    margin-left: auto;
    margin-right: auto;
  }
  .exp__row {
    gap: 16px;
  }
  .exp__brand { flex-basis: 120px; gap: 16px; }
  .exp__row > div:not(.exp__brand) { flex: 1 1 auto; }
  .exp__years { text-align: left; }
  .exp__logo { width: 80px; }
  .exp__role { font-size: 20px; }

  .contact__grid { grid-template-columns: 1fr; }
  .contact__side { display: grid; grid-template-columns: 1fr; gap: 32px; }
  .contact__lede { max-width: none; margin-bottom: 0; }
  .wechat-card {
    padding: 8px 16px;
    align-items: center;
    text-align: center;
  }
  .contact__meta .pair {
    align-items: center;
    text-align: center;
  }
}

@media (max-width: 719px) {
  .about__grid,
  .exp__left {
    grid-template-columns: 1fr;
    gap: 48px;
  }

  .about__grid .about__portrait {
    max-width: 360px;
    justify-self: start;
  }

  .exp__stats > div {
    justify-self: center;
  }
}
