@font-face {
  font-family: "Helvetica Neue 5";
  src: url("font/helvetica-neue-5/HelveticaNeueUltraLight.otf") format("opentype");
  font-weight: 200;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Helvetica Neue 5";
  src: url("font/helvetica-neue-5/HelveticaNeueUltraLightItalic.otf") format("opentype");
  font-weight: 200;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Helvetica Neue 5";
  src: url("font/helvetica-neue-5/HelveticaNeueLight.otf") format("opentype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Helvetica Neue 5";
  src: url("font/helvetica-neue-5/HelveticaNeueLightItalic.otf") format("opentype");
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Helvetica Neue 5";
  src: url("font/helvetica-neue-5/HelveticaNeueRoman.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Helvetica Neue 5";
  src: url("font/helvetica-neue-5/HelveticaNeueItalic.ttf") format("truetype");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Helvetica Neue 5";
  src: url("font/helvetica-neue-5/HelveticaNeueMedium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Helvetica Neue 5";
  src: url("font/helvetica-neue-5/HelveticaNeueMediumItalic.otf") format("opentype");
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Helvetica Neue 5";
  src: url("font/helvetica-neue-5/HelveticaNeueBold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Helvetica Neue 5";
  src: url("font/helvetica-neue-5/HelveticaNeueBoldItalic.otf") format("opentype");
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Helvetica Neue 5";
  src: url("font/helvetica-neue-5/HelveticaNeueHeavy.otf") format("opentype");
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Helvetica Neue 5";
  src: url("font/helvetica-neue-5/HelveticaNeueHeavyItalic.otf") format("opentype");
  font-weight: 800;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Helvetica Neue 5";
  src: url("font/helvetica-neue-5/HelveticaNeueBlack.otf") format("opentype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Helvetica Neue 5";
  src: url("font/helvetica-neue-5/HelveticaNeueBlackItalic.otf") format("opentype");
  font-weight: 900;
  font-style: italic;
  font-display: swap;
}

:root {
  --bg: #ffffff;
  --surface: #ffffff;
  --surface-strong: #ffffff;
  --line: rgba(0, 0, 0, 0.12);
  --line-strong: rgba(0, 0, 0, 0.78);
  --text: #050505;
  --muted: rgba(0, 0, 0, 0.5);
  --shadow: none;
  --radius: 0;
  --max-width: 1200px;
  --content-width: 960px;
  --feature-width: 1280px;
  --font-sans: "Helvetica Neue 5", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --page-gutter: clamp(0.85rem, 2vw, 1.5rem);
  --page-gutter-tight: clamp(0.82rem, 1.8vw, 1.3rem);
  --safe-top: env(safe-area-inset-top);
  --safe-right: env(safe-area-inset-right);
  --safe-bottom: env(safe-area-inset-bottom);
  --safe-left: env(safe-area-inset-left);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: auto;
  background: var(--bg);
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  margin: 0;
  min-width: 320px;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-sans);
  overflow-x: hidden;
  overflow-x: clip;
}

html.from-intro .page-home .site-header,
html.from-intro .page-home main {
  opacity: 0;
  transform: translateY(28px) scale(0.992);
  filter: blur(10px);
}

html.from-intro.from-intro-ready .page-home .site-header,
html.from-intro.from-intro-ready .page-home main {
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
  transition:
    opacity 820ms cubic-bezier(0.2, 0.72, 0.2, 1),
    transform 820ms cubic-bezier(0.2, 0.72, 0.2, 1),
    filter 820ms cubic-bezier(0.2, 0.72, 0.2, 1);
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

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

button,
a {
  -webkit-tap-highlight-color: transparent;
}

img,
video,
iframe {
  max-width: 100%;
}

img,
video {
  display: block;
  height: auto;
}

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(0.65rem, 1.5vw, 1.25rem);
  width: 100%;
  padding:
    calc(1rem + var(--safe-top))
    calc(var(--page-gutter) + var(--safe-right))
    0.9rem
    calc(var(--page-gutter) + var(--safe-left));
  border-bottom: 1px solid transparent;
  border-radius: 0;
  background: #ffffff;
  --nav-pill-bg: rgba(0, 0, 0, 0.06);
  --nav-pill-border: rgba(0, 0, 0, 0.16);
  --nav-pill-fill: #06080f;
  --nav-pill-text: rgba(0, 0, 0, 0.8);
  --nav-pill-hover-text: #f8fbff;
  transform: translateY(0);
  transform-origin: top center;
  transition:
    transform 280ms ease,
    padding 280ms ease,
    border-radius 280ms ease,
    border-bottom-color 280ms ease,
    background-color 280ms ease,
    box-shadow 280ms ease,
    backdrop-filter 280ms ease,
    opacity 220ms ease;
}

.site-header__brand {
  display: inline-block;
  flex: 0 1 auto;
  min-width: 0;
  font-family: var(--font-sans);
  font-size: clamp(1.28rem, 2.45vw, 2.15rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 0.92;
  word-spacing: -0.04em;
  text-transform: uppercase;
  white-space: nowrap;
  transition: transform 280ms ease, letter-spacing 280ms ease, font-size 280ms ease;
}

.site-nav {
  display: flex;
  flex: 0 1 auto;
  min-width: 0;
  margin-left: auto;
  gap: clamp(0.55rem, 1.2vw, 1rem);
  align-items: center;
  justify-content: flex-end;
  margin-top: 0;
  padding: 0;
  border: 0;
  background: transparent;
  transition: gap 280ms ease, transform 280ms ease;
}

.site-header__section-title {
  margin: 0;
  pointer-events: none;
}

.site-nav a {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.38rem clamp(0.6rem, 1.2vw, 0.88rem);
  border-radius: 999px;
  border: 1px solid var(--nav-pill-border);
  background: var(--nav-pill-bg);
  color: var(--nav-pill-text);
  line-height: 1;
  isolation: isolate;
  overflow: hidden;
  font-size: clamp(0.62rem, 0.54rem + 0.22vw, 0.8rem);
  font-weight: 600;
  letter-spacing: clamp(0.08em, 0.18vw, 0.13em);
  text-transform: uppercase;
  white-space: nowrap;
  box-shadow: inset 0 0 0 0 rgba(0, 0, 0, 0);
  transition:
    color 240ms ease,
    border-color 240ms ease,
    transform 220ms ease,
    font-size 220ms ease,
    letter-spacing 220ms ease,
    box-shadow 260ms ease;
}

.site-nav a::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -155%;
  width: 230%;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: var(--nav-pill-fill);
  transform: translateX(-50%) scale(0);
  transition: transform 460ms cubic-bezier(0.2, 0.9, 0.2, 1);
  pointer-events: none;
  z-index: 0;
}

.site-nav a::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, rgba(255, 255, 255, 0) 15%, rgba(255, 255, 255, 0.42) 48%, rgba(255, 255, 255, 0) 78%);
  transform: translateX(-140%);
  pointer-events: none;
  z-index: 0;
}

.site-nav__label {
  position: relative;
  z-index: 1;
  display: inline-block;
  line-height: 1;
  transition: transform 240ms ease;
}

.site-nav a:hover,
.site-nav a:focus-visible,
.site-nav a[aria-current="page"] {
  color: var(--nav-pill-hover-text);
  transform: translateY(-1px);
  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.12);
}

.site-nav a:hover .site-nav__label,
.site-nav a:focus-visible .site-nav__label,
.site-nav a[aria-current="page"] .site-nav__label {
  transform: translateY(-1px);
}

.site-nav a:hover::before,
.site-nav a:focus-visible::before,
.site-nav a[aria-current="page"]::before {
  transform: translateX(-50%) scale(1);
}

.site-nav a:hover::after,
.site-nav a:focus-visible::after {
  animation: site-nav-sheen 560ms cubic-bezier(0.22, 1, 0.36, 1);
}

.site-nav a:focus-visible {
  outline: none;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.42);
}

@keyframes site-nav-sheen {
  0% {
    transform: translateX(-140%);
  }

  100% {
    transform: translateX(140%);
  }
}

body.is-scrolled .site-header {
  padding:
    calc(0.82rem + var(--safe-top))
    calc(var(--page-gutter-tight) + var(--safe-right))
    0.78rem
    calc(var(--page-gutter-tight) + var(--safe-left));
  border-bottom-color: rgba(0, 0, 0, 0.08);
  border-radius: 0 0 1rem 1rem;
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(18px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.06);
}

body.is-scrolled .site-header__brand {
  transform: translateY(-1px);
  font-size: clamp(1.18rem, 2.05vw, 1.72rem);
  letter-spacing: -0.035em;
}

body.is-scrolled .site-nav {
  gap: clamp(0.48rem, 1vw, 0.9rem);
  transform: translateY(-1px);
}

body.is-scrolled .site-nav a {
  transform: translateY(-1px);
  font-size: clamp(0.6rem, 0.52rem + 0.18vw, 0.74rem);
  letter-spacing: clamp(0.08em, 0.15vw, 0.12em);
}

.site-header--staggered-menu {
  z-index: 70;
}

.site-header--staggered-menu .site-nav {
  display: none !important;
}

.site-menu-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.36rem;
  margin-left: auto;
  padding: 0.14rem 0;
  border: 0;
  background: transparent;
  color: #000000;
  font-family: var(--font-sans);
  font-size: clamp(0.62rem, 0.54rem + 0.2vw, 0.8rem);
  font-weight: 600;
  letter-spacing: clamp(0.11em, 0.2vw, 0.16em);
  line-height: 1;
  text-transform: uppercase;
  cursor: pointer;
}

.site-header--staggered-menu .site-menu-toggle {
  color: #000000;
}

.site-menu-toggle:focus-visible {
  outline: 1px solid rgba(0, 0, 0, 0.62);
  outline-offset: 0.28rem;
}

.site-menu-toggle__text {
  display: block;
  min-width: 5.2ch;
  text-align: right;
}

.site-menu-toggle__icon {
  position: relative;
  width: 13px;
  height: 13px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

.site-menu-toggle__line {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 100%;
  height: 1.5px;
  border-radius: 2px;
  background: currentColor;
  transform: translate(-50%, -50%);
  transform-origin: center;
}

.site-menu-toggle__line--vertical {
  transform: translate(-50%, -50%) rotate(90deg);
}

.site-menu-toggle.is-open .site-menu-toggle__icon {
  transform: rotate(225deg);
}

.site-staggered-menu {
  position: fixed;
  inset: 0;
  z-index: 60;
  pointer-events: none;
}

.site-staggered-menu.is-open {
  pointer-events: auto;
}

.site-staggered-menu__scrim {
  position: absolute;
  inset: 0;
  background: rgba(2, 4, 10, 0.34);
  opacity: 0;
  transition: opacity 300ms ease;
}

.site-staggered-menu.is-open .site-staggered-menu__scrim {
  opacity: 1;
}

.site-staggered-menu__layers,
.site-staggered-menu__panel {
  position: absolute;
  top: 0;
  right: 0;
  width: clamp(260px, 40vw, 460px);
  height: 100%;
}

.site-staggered-menu__layers {
  pointer-events: none;
}

.site-staggered-menu__layer {
  position: absolute;
  inset: 0;
  transform: translateX(108%);
}

.site-staggered-menu__layer--one {
  background: #cfd5e8;
  transition: transform 520ms cubic-bezier(0.22, 1, 0.36, 1);
}

.site-staggered-menu__layer--two {
  background: #8ea0dc;
  transition: transform 560ms cubic-bezier(0.22, 1, 0.36, 1) 60ms;
}

.site-staggered-menu__panel {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  padding: clamp(5.9rem, 8vw, 6.6rem) clamp(1.2rem, 3vw, 2rem) clamp(1.2rem, 3vw, 1.8rem);
  background: #ffffff;
  color: #040509;
  transform: translateX(112%);
  transition: transform 620ms cubic-bezier(0.22, 1, 0.36, 1) 90ms;
  overflow-y: auto;
  pointer-events: auto;
}

.site-staggered-menu.is-open .site-staggered-menu__layer,
.site-staggered-menu.is-open .site-staggered-menu__panel {
  transform: translateX(0);
}

.site-staggered-menu__nav {
  width: 100%;
}

.site-staggered-menu__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: clamp(0.42rem, 1.3vw, 0.78rem);
}

.site-staggered-menu__item {
  position: relative;
  overflow: hidden;
}

.site-staggered-menu__item-link {
  position: relative;
  display: inline-flex;
  align-items: flex-start;
  justify-content: space-between;
  width: 100%;
  padding: 0.08rem 2.6rem 0.08rem 0.12rem;
  padding-right: 2.6rem;
  border-radius: 0.42rem;
  color: inherit;
  text-decoration: none;
  overflow: hidden;
  transition: color 220ms ease, transform 260ms cubic-bezier(0.22, 1, 0.36, 1);
}

.site-staggered-menu__item-link::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.03));
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 240ms ease;
  z-index: 0;
}

.site-staggered-menu__item-link::after {
  content: "";
  position: absolute;
  left: 0.2rem;
  right: 2.8rem;
  bottom: 0.02rem;
  height: 1px;
  background: rgba(0, 0, 0, 0.42);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 260ms ease;
  z-index: 0;
}

.site-staggered-menu__item-label {
  position: relative;
  z-index: 1;
  display: block;
  font-size: clamp(2rem, 6vw, 3.6rem);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 0.95;
  text-transform: uppercase;
  transform: translateY(124%) rotate(8deg);
  transform-origin: 50% 100%;
  transition: transform 620ms cubic-bezier(0.22, 1, 0.36, 1), letter-spacing 260ms ease;
  transition-delay: calc(220ms + var(--menu-item-delay, 0ms));
}

.site-staggered-menu__item-number {
  z-index: 1;
  position: absolute;
  right: 0;
  top: 0.25rem;
  font-size: 0.74rem;
  letter-spacing: 0.08em;
  color: #000000;
  opacity: 0;
  transition: opacity 380ms ease;
  transition-delay: calc(300ms + var(--menu-item-delay, 0ms));
}

.site-staggered-menu.is-open .site-staggered-menu__item-label {
  transform: translateY(0) rotate(0);
}

.site-staggered-menu.is-open .site-staggered-menu__item-number {
  opacity: 1;
}

.site-staggered-menu__item-link:hover,
.site-staggered-menu__item-link:focus-visible {
  color: #000000;
  transform: translateX(8px);
}

.site-staggered-menu__item-link:hover::before,
.site-staggered-menu__item-link:focus-visible::before,
.site-staggered-menu__item-link:hover::after,
.site-staggered-menu__item-link:focus-visible::after {
  transform: scaleX(1);
}

.site-staggered-menu__item-link:hover .site-staggered-menu__item-label,
.site-staggered-menu__item-link:focus-visible .site-staggered-menu__item-label {
  letter-spacing: -0.024em;
}

.site-staggered-menu__item-link:focus-visible {
  outline: none;
}

.site-staggered-menu__socials {
  margin-top: auto;
  padding-top: 1.65rem;
  display: grid;
  gap: 0.62rem;
}

.site-staggered-menu__social-title {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #000000;
}

.site-staggered-menu__social-links {
  display: flex;
  align-items: center;
  gap: 0.78rem;
}

.site-staggered-menu__social-link {
  width: 2.48rem;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  border: 1px solid rgba(0, 0, 0, 0.28);
  color: #000000;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: color 220ms ease, border-color 220ms ease, transform 220ms ease;
}

.site-staggered-menu__social-link:hover,
.site-staggered-menu__social-link:focus-visible {
  color: #000000;
  border-color: rgba(0, 0, 0, 0.52);
  transform: translateY(-1px);
}

.site-staggered-menu__icon {
  width: 1.36rem;
  height: 1.36rem;
}

.site-staggered-menu__icon--instagram {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.7;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.site-staggered-menu__icon--youtube {
  fill: currentColor;
  stroke: none;
}

body.is-site-menu-open {
  overflow: hidden;
}

.page-interactive-archive .site-header__section-title,
.page-graphic-design-archive .site-header__section-title,
.page-photo-archive .site-header__section-title,
.page-product-archive .site-header__section-title,
.page-my-work .site-header__section-title {
  position: absolute;
  left: 50%;
  top: calc(50% + (var(--safe-top) * 0.08));
  transform: translate(-50%, -50%);
  z-index: 1;
  font-family: var(--font-sans);
  font-size: clamp(0.92rem, 0.74rem + 0.92vw, 1.42rem);
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.78);
  white-space: nowrap;
}

/* Interactive Work: force menu effect accent to black */
.page-interactive-archive .site-staggered-menu__layer--one {
  background: #d2d2d2;
}

.page-interactive-archive .site-staggered-menu__layer--two {
  background: #8c8c8c;
}

.page-interactive-archive .site-staggered-menu__item-number,
.page-interactive-archive .site-staggered-menu__social-title {
  color: #000000;
}

.page-interactive-archive .site-staggered-menu__item-link:hover,
.page-interactive-archive .site-staggered-menu__item-link:focus-visible {
  color: #000000;
}

.page-interactive-archive .site-staggered-menu__social-link:hover,
.page-interactive-archive .site-staggered-menu__social-link:focus-visible {
  color: #000000;
  border-color: rgba(0, 0, 0, 0.42);
}

.page-graphic-design-archive .site-header__section-title {
  color: rgba(244, 244, 244, 0.9);
}

main {
  display: block;
  width: 100%;
  max-width: 100%;
}

.hero {
  position: relative;
  display: grid;
  align-items: center;
  min-height: 100svh;
  padding: clamp(7rem, 11vw, 8rem) var(--page-gutter) 2rem;
  overflow: clip;
  cursor: pointer;
  background: #ffffff;
}

.hero__canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background: #ffffff;
}

.hero__audio-controls {
  position: absolute;
  left: 50%;
  bottom: clamp(1rem, 3vw, 1.6rem);
  z-index: 2;
  display: grid;
  gap: 0.45rem;
  justify-items: center;
  width: fit-content;
  max-width: min(82vw, 320px);
  transform: translateX(-50%);
}

.hero__audio-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
}

.hero__audio-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.65rem;
  padding: 0.72rem 1rem;
  border: 1px solid rgba(0, 0, 0, 0.22);
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(18px);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  line-height: 1;
  text-transform: uppercase;
  cursor: pointer;
  transition:
    transform 220ms ease,
    background-color 220ms ease,
    border-color 220ms ease,
    color 220ms ease,
    opacity 220ms ease;
}

.hero__audio-button:hover,
.hero__audio-button:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(0, 0, 0, 0.5);
}

.hero__audio-button.is-active {
  background: rgba(5, 5, 5, 0.92);
  border-color: rgba(5, 5, 5, 0.92);
  color: #ffffff;
}

.hero__audio-button.is-error {
  border-color: rgba(160, 18, 18, 0.38);
}

.hero__audio-button:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.work-hub {
  min-height: 100svh;
  background: #ffffff;
}

.work-hub__scene {
  --work-center-width: min(88vw, 820px);
  --work-trigger-font-size: clamp(2.5rem, 8vw, 5.2rem);
  --work-center-inline-padding: clamp(0.75rem, 2.4vw, 1.9rem);
  position: relative;
  min-height: 100svh;
  overflow: hidden;
  background: #ffffff;
  isolation: isolate;
  cursor: pointer;
}

.work-hub__canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background: #ffffff;
  pointer-events: none;
}

.work-hub__center {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  display: grid;
  gap: 0.9rem;
  justify-items: center;
  width: min(var(--work-center-width), calc(100vw - (var(--work-center-inline-padding) * 2)));
  max-width: calc(100vw - (var(--work-center-inline-padding) * 2));
  padding-inline: var(--work-center-inline-padding);
  transform: translate(-50%, -50%);
}

.work-hub__trigger {
  width: auto;
  max-width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  font-family: var(--font-sans);
  font-size: min(var(--work-trigger-font-size), calc((100vw - 1.6rem) / 4.6));
  font-weight: 680;
  line-height: 0.92;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  color: rgba(5, 5, 5, 0.92);
  cursor: pointer;
  white-space: nowrap;
  text-align: center;
  user-select: none;
  transition:
    transform 760ms cubic-bezier(0.2, 0.86, 0.22, 1),
    letter-spacing 460ms ease,
    opacity 340ms ease,
    color 360ms ease,
    filter 360ms ease;
}

.work-hub__hint {
  margin: 0;
  font-size: 0.76rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  transition: opacity 220ms ease, transform 220ms ease;
}

.work-hub__hint:empty {
  display: none;
}

.work-hub__options {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  cursor: default;
}

.work-hub__option {
  --option-font-size: clamp(0.86rem, 1.34vw, 1.14rem);
  --option-scale: 0.56;
  --option-shift-x: 0px;
  --option-shift-y: 0px;
  --option-open-delay: 0ms;
  --option-ring-size: 152px;
  --option-ring-tilt: 0.78;
  --option-ring-rotation: 0deg;
  --option-ring-rotation-secondary: 12deg;
  --option-accent: rgba(30, 43, 94, 0.54);
  --option-accent-soft: rgba(88, 110, 172, 0.34);
  --option-accent-text: rgba(5, 5, 5, 0.94);
  --option-accent-glow: rgba(72, 103, 182, 0.12);
  position: absolute;
  top: 50%;
  left: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3.25rem;
  min-width: max-content;
  padding: 0.76rem 1.06rem;
  border: 0;
  background: transparent;
  font-family: var(--font-sans);
  font-size: var(--option-font-size);
  font-weight: 620;
  line-height: 1;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-align: center;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  isolation: isolate;
  transform-origin: center center;
  transform: translate3d(calc(-50% + var(--option-shift-x)), calc(-50% + var(--option-shift-y)), 0) scale(var(--option-scale));
  filter: blur(2px);
  cursor: pointer;
  touch-action: manipulation;
  backface-visibility: hidden;
  will-change: transform, opacity, font-size, filter;
  transition:
    transform 900ms cubic-bezier(0.2, 0.86, 0.22, 1),
    opacity 420ms ease,
    font-size 660ms cubic-bezier(0.2, 0.86, 0.22, 1),
    filter 420ms ease;
  transition-delay: 0ms;
}

.work-hub__option::before,
.work-hub__option::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  border-radius: 50%;
  pointer-events: none;
  opacity: 0;
  transition:
    transform 980ms cubic-bezier(0.2, 0.86, 0.22, 1),
    opacity 340ms ease,
    border-color 320ms ease,
    box-shadow 320ms ease;
}

.work-hub__option::before {
  width: var(--option-ring-size);
  height: calc(var(--option-ring-size) * var(--option-ring-tilt));
  border: 1.35px solid var(--option-accent);
  transform: translate(-50%, -50%) scale(0.18) rotate(var(--option-ring-rotation));
}

.work-hub__option::after {
  width: calc(var(--option-ring-size) * 0.78);
  height: calc(var(--option-ring-size) * var(--option-ring-tilt) * 0.82);
  border: 0.95px solid var(--option-accent-soft);
  transform: translate(-51%, -49%) scale(0.14) rotate(var(--option-ring-rotation-secondary));
}

.work-hub__option-text {
  display: inline-block;
  opacity: 1;
  font-family: inherit;
  font-weight: inherit;
  color: var(--option-accent-text);
  position: relative;
  z-index: 1;
  user-select: none;
  transition:
    color 360ms ease,
    text-shadow 360ms ease,
    opacity 260ms ease,
    transform 360ms ease;
}

.work-hub__option-effect {
  display: none;
}

.work-hub__option:nth-child(1) {
  --option-open-delay: 0ms;
}

.work-hub__option:nth-child(2) {
  --option-open-delay: 44ms;
}

.work-hub__option:nth-child(3) {
  --option-open-delay: 88ms;
}

.work-hub__option:nth-child(4) {
  --option-open-delay: 132ms;
}

.work-hub__option:nth-child(5) {
  --option-open-delay: 176ms;
}

.page-my-work.is-work-menu-open .work-hub__trigger {
  transform: scale(0.5);
  letter-spacing: -0.01em;
  opacity: 0.14;
  color: rgba(5, 5, 5, 0.34);
  filter: blur(0.2px);
}

.page-my-work.is-work-menu-open .work-hub__hint {
  opacity: 0;
  transform: translateY(10px);
}

.page-my-work.is-work-menu-open .work-hub__center {
  pointer-events: none;
}

.page-my-work.is-work-menu-open .work-hub__option {
  --option-scale: 1;
  --option-shift-x: var(--option-x, 0px);
  --option-shift-y: var(--option-y, 0px);
  opacity: 1;
  filter: blur(0);
  pointer-events: auto;
  transition-delay: var(--option-open-delay);
}

.page-my-work.is-work-menu-open .work-hub__option::before {
  opacity: 0.72;
  transform: translate(-50%, -50%) scale(1) rotate(var(--option-ring-rotation));
}

.page-my-work.is-work-menu-open .work-hub__option::after {
  opacity: 0.44;
  transform: translate(-51%, -49%) scale(1.08) rotate(var(--option-ring-rotation-secondary));
}

.page-my-work.is-work-menu-open .work-hub__option-text {
  color: var(--option-accent-text);
}

.work-hub__option:hover,
.work-hub__option:focus-visible,
.work-hub__option.is-hovered {
  z-index: 4;
}

.work-hub__option:hover::before,
.work-hub__option:focus-visible::before,
.work-hub__option.is-hovered::before {
  border-color: var(--option-accent);
  box-shadow: 0 0 22px var(--option-accent-glow);
}

.work-hub__option:hover::after,
.work-hub__option:focus-visible::after,
.work-hub__option.is-hovered::after {
  border-color: var(--option-accent-soft);
}

.work-hub__option:hover .work-hub__option-text,
.work-hub__option:focus-visible .work-hub__option-text,
.work-hub__option.is-hovered .work-hub__option-text {
  transform: scale(1.03);
  color: var(--option-accent-text);
  text-shadow: 0 0 14px var(--option-accent-glow);
}

.feature-project {
  padding: 1rem var(--page-gutter) 4.2rem;
  background: #ffffff;
}

.feature-project__inner {
  width: min(100%, 1260px);
  margin: 0 auto;
  display: grid;
  gap: clamp(0.95rem, 2.2vw, 1.4rem);
  justify-items: center;
}

.feature-project__media {
  width: min(100%, 1040px);
}

.feature-project__video {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  background: #ffffff;
  border: 0;
  outline: 0;
  box-shadow: none;
}

.feature-project__logo {
  display: block;
  width: clamp(220px, 34vw, 540px);
  max-width: 100%;
  height: auto;
  margin: 0 auto;
}

.feature-project__text-block {
  display: grid;
  gap: 0.42rem;
  justify-items: center;
  margin: 0 auto;
}

.feature-project__text-block--about {
  width: min(100%, 760px);
  justify-self: center;
  text-align: center;
}

.feature-project__text-block--prototype {
  width: min(100%, 620px);
  justify-self: center;
  text-align: center;
}

.feature-project__heading {
  margin: 0;
  font-size: 0.88rem;
  font-weight: 600;
  letter-spacing: 0;
}

.feature-project__copy {
  margin: 0;
  max-width: 64ch;
  font-size: 0.86rem;
  line-height: 1.58;
  color: var(--text);
  text-align: center;
}

.feature-project__actions {
  width: min(100%, 520px);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.72rem;
}

.feature-project__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 236px;
  min-width: 236px;
  min-height: 58px;
  padding: 0.82rem 1.2rem;
  border: 1px solid var(--line-strong);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 0 auto;
}

.feature-project__button:hover,
.feature-project__button:focus-visible {
  background: #050505;
  color: #ffffff;
}

.home-work-network {
  padding: clamp(2.9rem, 4.4vw, 4.2rem) var(--page-gutter) clamp(3.2rem, 4.6vw, 5rem);
  background: #ffffff;
}

.home-work-network__inner {
  width: min(100%, clamp(320px, 88vw, 1200px));
  margin: 0 auto;
  display: grid;
  gap: 0;
  justify-items: center;
}

.home-work-network__title {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 2;
  width: min(40%, 7ch);
  margin: 0;
  padding: 0.18em 0.28em;
  font-size: clamp(1.26rem, 0.88rem + 1.72vw, 2.9rem);
  font-weight: 400;
  letter-spacing: 0.14em;
  line-height: 0.92;
  text-align: center;
  text-transform: uppercase;
  color: rgba(5, 5, 5, 0.58);
  text-shadow:
    0 0 0 rgba(255, 110, 110, 0),
    0 0 0 rgba(255, 142, 142, 0),
    0 0 0 rgba(255, 188, 188, 0);
  transform: translate(-50%, -50%);
  transform-origin: center;
  isolation: isolate;
  animation: home-work-network-heartbeat 2.6s ease-in-out infinite;
  pointer-events: auto;
  cursor: pointer;
}

.home-work-network__title-link {
  display: block;
  color: inherit;
  text-decoration: none;
}

.home-work-network__title-link:focus-visible {
  outline: none;
}

.home-work-network__title::before,
.home-work-network__title::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  border-radius: 50%;
  pointer-events: none;
  opacity: 0;
  transform: translate(-50%, -50%) scale(0.76);
}

.home-work-network__title::before {
  z-index: -2;
  width: clamp(96px, 15vw, 210px);
  aspect-ratio: 1;
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0) 28%, rgba(255, 255, 255, 0) 40%, rgba(255, 255, 255, 0.04) 54%, rgba(255, 255, 255, 0) 70%),
    radial-gradient(circle, rgba(255, 168, 168, 0.12), rgba(255, 122, 122, 0.08) 42%, rgba(255, 98, 98, 0.02) 68%, rgba(255, 255, 255, 0) 82%);
  filter: blur(14px);
  animation: home-work-network-heartbeat-aura 2.6s ease-in-out infinite;
}

.home-work-network__title::after {
  z-index: -1;
  width: clamp(108px, 17vw, 232px);
  aspect-ratio: 1;
  border: 1px solid rgba(255, 122, 122, 0.12);
  box-shadow:
    0 0 0 1px rgba(255, 182, 182, 0.08) inset,
    0 0 18px rgba(255, 122, 122, 0.08);
  animation: home-work-network-heartbeat-ring 2.6s ease-in-out infinite;
}

@keyframes home-work-network-heartbeat {
  0%,
  34%,
  100% {
    transform: translate(-50%, -50%) scale(1);
    color: rgba(5, 5, 5, 0.58);
    text-shadow:
      0 0 0 rgba(255, 110, 110, 0),
      0 0 0 rgba(255, 142, 142, 0),
      0 0 0 rgba(255, 188, 188, 0);
  }

  10% {
    transform: translate(-50%, -50%) scale(1.045);
    text-shadow:
      0 0 8px rgba(255, 118, 118, 0.14),
      0 0 7px rgba(255, 148, 148, 0.1),
      0 0 6px rgba(255, 194, 194, 0.08);
  }

  18% {
    transform: translate(-50%, -50%) scale(0.985);
  }

  24% {
    transform: translate(-50%, -50%) scale(1.08);
    text-shadow:
      0 0 12px rgba(255, 106, 106, 0.22),
      0 0 12px rgba(255, 138, 138, 0.16),
      0 0 10px rgba(255, 186, 186, 0.12);
  }

  29% {
    transform: translate(-50%, -50%) scale(1.015);
  }
}

@keyframes home-work-network-heartbeat-aura {
  0%,
  34%,
  100% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.72);
  }

  10% {
    opacity: 0.18;
    transform: translate(-50%, -50%) scale(0.9);
  }

  24% {
    opacity: 0.34;
    transform: translate(-50%, -50%) scale(1.04);
  }

  32% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(1.24);
  }
}

@keyframes home-work-network-heartbeat-ring {
  0%,
  34%,
  100% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.76);
  }

  12% {
    opacity: 0.18;
    transform: translate(-50%, -50%) scale(0.94);
  }

  24% {
    opacity: 0.3;
    transform: translate(-50%, -50%) scale(1.08);
  }

  32% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(1.28);
  }
}

.home-work-network__stage {
  position: relative;
  width: min(100%, clamp(300px, 66vw, 980px));
  aspect-ratio: 20 / 10;
  isolation: isolate;
}

.home-work-network__stage::before {
  content: "";
  position: absolute;
  inset: 18%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(233, 46, 148, 0.1), rgba(255, 255, 255, 0) 68%);
  filter: blur(22px);
  opacity: 0.78;
  pointer-events: none;
}

.home-work-network__stage::after {
  content: "";
  position: absolute;
  inset: 9%;
  border-radius: 50%;
  border: 1px solid rgba(233, 46, 148, 0.08);
  pointer-events: none;
}

.home-work-network__canvas,
.home-work-network__links {
  position: absolute;
  inset: 0;
}

.home-work-network__canvas {
  display: block;
  width: 100%;
  height: 100%;
}

.home-work-network__link {
  --network-link-x: 50%;
  --network-link-y: 50%;
  --network-link-rotate: 0deg;
  --network-link-scale: 1;
  --network-hue: 330;
  position: absolute;
  left: var(--network-link-x);
  top: var(--network-link-y);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  max-width: clamp(4.1rem, 8.1vw, 7.6rem);
  min-height: 1.2rem;
  padding: clamp(0.12rem, 0.24vw, 0.2rem) clamp(0.2rem, 0.34vw, 0.3rem);
  font-size: clamp(0.62rem, 0.24rem + 0.76vw, 1.2rem);
  font-weight: 600;
  letter-spacing: -0.05em;
  line-height: 0.92;
  text-align: center;
  text-transform: uppercase;
  color: #050505;
  border-radius: 999px;
  text-shadow: 0 0 18px rgba(255, 255, 255, 0.98), 0 0 32px rgba(255, 255, 255, 0.92);
  background: rgba(255, 255, 255, 0);
  box-shadow: 0 0 0 rgba(233, 46, 148, 0);
  filter: drop-shadow(0 0 0 rgba(233, 46, 148, 0));
  transform: translate(-50%, -50%) rotate(var(--network-link-rotate)) scale(var(--network-link-scale));
  transform-origin: center;
  transition:
    color 220ms ease,
    text-shadow 220ms ease,
    transform 220ms ease,
    background-color 220ms ease,
    box-shadow 220ms ease,
    filter 220ms ease;
}

.home-work-network__link:hover,
.home-work-network__link:focus-visible,
.home-work-network__link.is-active {
  --network-link-scale: 1.12;
  color: hsl(var(--network-hue) 84% 48%);
  text-shadow: 0 0 28px rgba(255, 255, 255, 1), 0 0 52px rgba(255, 255, 255, 1);
  background: hsla(var(--network-hue) 82% 96% / 0.92);
  box-shadow: 0 0 0 1px hsla(var(--network-hue) 78% 46% / 0.18), 0 10px 28px hsla(var(--network-hue) 78% 46% / 0.14);
  filter: drop-shadow(0 10px 22px hsla(var(--network-hue) 78% 46% / 0.2));
}

.home-work-network__link:focus-visible {
  outline: none;
}

.home-work-network__link-label {
  display: block;
  text-wrap: balance;
}

.home-work-showcase {
  --showcase-hue: 214;
  --showcase-side-pad: clamp(0.85rem, 2.2vw, 1.9rem);
  position: relative;
  min-height: clamp(20rem, 58svh, 32rem);
  padding: clamp(1.5rem, 3.7svh, 2.9rem) var(--showcase-side-pad);
  display: grid;
  align-items: center;
  background: #020202;
  color: #f0f0f0;
  font-family: var(--font-sans);
  overflow: hidden;
  isolation: isolate;
}

.home-work-showcase__backdrop {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.home-work-showcase__backdrop::before,
.home-work-showcase__backdrop::after {
  content: none;
}

.home-work-showcase__line-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0.98;
}

.home-work-showcase__inner {
  position: relative;
  z-index: 1;
  width: min(100%, 1280px);
  min-height: min(50svh, 27rem);
  margin: 0 auto;
  display: grid;
  align-content: center;
  gap: clamp(0.44rem, 1.1vw, 0.82rem);
}

.home-work-showcase--graphic-slider {
  min-height: clamp(29rem, 72svh, 45rem);
  background: #ffffff;
  color: #050505;
}

.home-work-showcase--graphic-slider .home-work-showcase__line-canvas {
  opacity: 1;
  mix-blend-mode: normal;
}

.home-work-showcase--graphic-slider .home-work-showcase__inner {
  width: min(100%, 1320px);
  min-height: min(68svh, 42rem);
}

.home-graphic-slider {
  gap: clamp(0.86rem, 1.8vw, 1.24rem);
}

.home-graphic-slider__head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
}

.home-graphic-slider__title {
  margin: 0;
  font-family: var(--font-sans);
  font-size: clamp(1.52rem, 1.08rem + 2.38vw, 3.5rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 0.9;
  text-transform: uppercase;
  color: #050505;
  text-shadow: none;
  transition: color 260ms ease, text-shadow 260ms ease;
}

.home-graphic-slider__more {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0.56rem 0.84rem;
  border: 1px solid rgba(5, 5, 5, 0.24);
  background: rgba(5, 5, 5, 0.04);
  color: #050505;
  font-size: clamp(0.62rem, 0.56rem + 0.14vw, 0.72rem);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  transition: background-color 220ms ease, border-color 220ms ease, transform 220ms ease;
}

.home-graphic-slider__more:hover,
.home-graphic-slider__more:focus-visible {
  transform: translateY(-1px);
  background: rgba(5, 5, 5, 0.1);
  border-color: rgba(5, 5, 5, 0.36);
}

.home-graphic-slider__stage {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: clamp(0.6rem, 1.6vw, 1.16rem);
}

.home-graphic-slider__viewport {
  position: relative;
  height: clamp(24rem, 54vw, 42rem);
  overflow: visible;
  padding-bottom: clamp(2.4rem, 4.6vw, 3.8rem);
}

.home-graphic-slider__nav {
  appearance: none;
  border: 1px solid rgba(5, 5, 5, 0.28);
  background: rgba(5, 5, 5, 0.04);
  color: #050505;
  font-family: var(--font-sans);
  font-size: clamp(0.66rem, 0.56rem + 0.14vw, 0.76rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  min-width: clamp(3rem, 4.8vw, 3.9rem);
  min-height: clamp(2.7rem, 4vw, 3.3rem);
  padding: 0.4rem 0.6rem;
  cursor: pointer;
  transition: transform 220ms ease, background-color 220ms ease, border-color 220ms ease;
}

.home-graphic-slider__nav:hover,
.home-graphic-slider__nav:focus-visible {
  transform: translateY(-1px) scale(1.02);
  background: rgba(5, 5, 5, 0.1);
  border-color: rgba(5, 5, 5, 0.4);
}

.home-graphic-slider__item {
  position: absolute;
  top: 46%;
  left: 50%;
  width: min(100%, clamp(240px, 30vw, 440px));
  display: grid;
  gap: clamp(0.48rem, 0.92vw, 0.76rem);
  color: #050505;
  text-decoration: none;
  transform: translate(-50%, -50%);
  transform-origin: center;
  opacity: 0;
  pointer-events: none;
  z-index: 1;
  transition:
    transform 520ms cubic-bezier(0.2, 0.78, 0.2, 1),
    opacity 360ms ease,
    filter 360ms ease;
}

.home-graphic-slider__item.is-current,
.home-graphic-slider__item.is-prev,
.home-graphic-slider__item.is-next {
  pointer-events: auto;
}

.home-graphic-slider__item.is-current {
  transform: translate(-50%, -50%) scale(1);
  opacity: 1;
  z-index: 4;
  filter: none;
}

.home-graphic-slider__item.is-prev {
  transform: translate(-128%, -50%) scale(0.82);
  opacity: 0.58;
  z-index: 3;
  filter: saturate(0.74) brightness(0.88);
}

.home-graphic-slider__item.is-next {
  transform: translate(24%, -50%) scale(0.82);
  opacity: 0.58;
  z-index: 3;
  filter: saturate(0.74) brightness(0.88);
}

.home-graphic-slider__item.is-far-left {
  transform: translate(-208%, -50%) scale(0.66);
  opacity: 0;
  z-index: 1;
  filter: blur(1.1px);
}

.home-graphic-slider__item.is-far-right {
  transform: translate(122%, -50%) scale(0.66);
  opacity: 0;
  z-index: 1;
  filter: blur(1.1px);
}

.home-graphic-slider__media {
  position: relative;
  display: block;
  overflow: visible;
  width: 100%;
  border: none;
  background: transparent;
  box-shadow: 0 16px 42px rgba(0, 0, 0, 0.16);
}

.home-graphic-slider__meta {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 240ms ease, transform 260ms ease;
  overflow: visible;
}

.home-graphic-slider__item:not(.is-current) .home-graphic-slider__meta {
  opacity: 0;
  transform: translateY(8px);
}

.home-graphic-slider__media::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.74), rgba(0, 0, 0, 0.08) 52%, rgba(0, 0, 0, 0));
  opacity: 0;
  transition: opacity 240ms ease;
  pointer-events: none;
  z-index: 1;
}

.home-graphic-slider__media::after {
  content: attr(data-graphic-title);
  position: absolute;
  left: 0.7rem;
  right: 0.7rem;
  bottom: 0.62rem;
  z-index: 2;
  color: #ffffff;
  font-family: var(--font-sans);
  font-size: clamp(0.72rem, 0.62rem + 0.28vw, 0.96rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.08;
  text-transform: uppercase;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.64);
  opacity: 0;
  transform: translateY(18px) scale(0.96);
  filter: blur(7px);
  transition: opacity 240ms ease, transform 260ms ease, filter 260ms ease;
  pointer-events: none;
}

.home-graphic-slider__media img {
  display: block;
  width: 100%;
  height: auto;
  max-height: clamp(19rem, 37vw, 31rem);
  object-fit: contain;
  object-position: center;
  background: transparent;
  transform: scale(1);
  transition: transform 220ms ease;
}

.home-graphic-slider__item.is-current:hover .home-graphic-slider__media img,
.home-graphic-slider__item.is-current:focus-visible .home-graphic-slider__media img {
  transform: scale(1.01);
}

.home-graphic-slider__item:hover .home-graphic-slider__media::before,
.home-graphic-slider__item:focus-visible .home-graphic-slider__media::before {
  opacity: 1;
}

.home-graphic-slider__item:hover .home-graphic-slider__media::after,
.home-graphic-slider__item:focus-visible .home-graphic-slider__media::after {
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}

.home-work-showcase--light {
  background: #ffffff;
  color: #050505;
}

.home-work-showcase--light .home-work-showcase__line-canvas {
  opacity: 1;
  mix-blend-mode: normal;
}

.home-work-showcase--light .home-work-showcase__title {
  color: rgba(5, 5, 5, 0.86);
  text-shadow: none;
}

.home-work-showcase--light .home-work-showcase__title-link {
  color: inherit;
}

.home-work-showcase--light .home-work-showcase__label {
  color: rgba(5, 5, 5, 0.9);
  text-shadow: none;
}

.home-graphic-slider__meta {
  display: grid;
  gap: 0.32rem;
}

.home-graphic-slider__item-title {
  display: block;
  margin: 0;
  font-size: clamp(1.12rem, 0.9rem + 0.82vw, 1.72rem);
  font-weight: 700;
  letter-spacing: 0.01em;
  line-height: 1.02;
  text-transform: uppercase;
  color: #050505;
  text-wrap: balance;
}

.home-graphic-slider__item-desc {
  display: block;
  margin: 0;
  max-width: 60ch;
  font-size: clamp(0.82rem, 0.7rem + 0.28vw, 1rem);
  font-weight: 500;
  letter-spacing: 0.015em;
  line-height: 1.5;
  color: rgba(5, 5, 5, 0.82);
  white-space: normal;
  word-break: normal;
  overflow-wrap: anywhere;
  text-wrap: pretty;
}

.home-work-showcase__title {
  margin: 0;
  font-size: clamp(1.15rem, 0.8rem + 1.8vw, 2.35rem);
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 0.96;
  text-transform: uppercase;
  color: hsl(var(--showcase-hue) 94% 90%);
  text-shadow: 0 0 16px hsla(var(--showcase-hue) 90% 62% / 0.2);
  transition: color 220ms ease, text-shadow 280ms ease;
}

.home-work-showcase__title-link {
  display: inline-block;
  color: inherit;
  font-family: var(--font-sans);
  text-decoration: none;
}

.home-work-showcase__topics {
  display: grid;
  gap: clamp(0.12rem, 0.28vw, 0.38rem);
}

.home-work-showcase__topic {
  --topic-hue: 214;
  display: block;
  font-family: var(--font-sans);
  text-decoration: none;
  color: inherit;
  transition: color 220ms ease;
}

.home-work-showcase__topic:hover,
.home-work-showcase__topic:focus-visible,
.home-work-showcase__topic.is-active {
  transform: none;
}

.home-work-showcase__topic:focus-visible {
  outline: none;
}

.home-work-showcase__label {
  display: block;
  margin: 0;
  font-family: var(--font-sans);
  font-size: clamp(1.52rem, 5.2vw, 4.3rem);
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 0.88;
  text-transform: uppercase;
  white-space: nowrap;
  color: rgba(242, 242, 242, 0.9);
  text-shadow: 0 0 0 rgba(0, 0, 0, 0);
  transition:
    color 220ms ease,
    text-shadow 280ms ease,
    transform 220ms ease;
}

.home-work-showcase__topic:hover .home-work-showcase__label,
.home-work-showcase__topic:focus-visible .home-work-showcase__label,
.home-work-showcase__topic.is-active .home-work-showcase__label {
  color: hsl(var(--topic-hue) 94% 72%);
  text-shadow:
    0 0 20px hsla(var(--topic-hue) 92% 64% / 0.5),
    0 0 36px hsla(var(--topic-hue) 90% 56% / 0.28);
  transform: none;
}

@keyframes home-work-showcase-aura {
  0% {
    transform: translate3d(-2.5%, -1%, 0) scale(1);
  }

  100% {
    transform: translate3d(2.5%, 1%, 0) scale(1.08);
  }
}

@media (max-width: 960px) {
  .home-work-showcase {
    min-height: clamp(18rem, 54svh, 27rem);
    padding: clamp(1.35rem, 4.8vw, 2.2rem) 0.85rem;
  }

  .home-work-showcase__inner {
    min-height: min(48svh, 22rem);
    gap: clamp(0.4rem, 1.6vw, 0.76rem);
  }

  .home-work-showcase--graphic-slider .home-work-showcase__inner {
    min-height: min(70svh, 36rem);
  }

  .home-work-showcase__title {
    font-size: clamp(1rem, 4.4vw, 1.55rem);
    line-height: 0.94;
  }

  .home-work-showcase__label {
    font-size: clamp(1.34rem, 8.1vw, 3.1rem);
    line-height: 0.9;
    white-space: normal;
  }

  .home-graphic-slider__head {
    align-items: center;
  }

  .home-graphic-slider__title {
    font-size: clamp(1.2rem, 5.5vw, 2rem);
  }

  .home-graphic-slider__more {
    min-height: 38px;
    font-size: 0.58rem;
    letter-spacing: 0.08em;
    padding: 0.42rem 0.6rem;
  }

  .home-graphic-slider__stage {
    grid-template-columns: 1fr;
    gap: 0.66rem;
  }

  .home-graphic-slider__viewport {
    height: clamp(24rem, 108vw, 42rem);
    order: 1;
    overflow: visible;
    padding-bottom: clamp(2.2rem, 7vw, 4rem);
  }

  .home-graphic-slider__nav {
    min-width: 0;
    width: 100%;
    min-height: 42px;
  }

  .home-graphic-slider__nav--prev {
    order: 2;
  }

  .home-graphic-slider__nav--next {
    order: 3;
  }

  .home-graphic-slider__item {
    width: min(100%, 520px);
    top: 44%;
  }

  .home-graphic-slider__item.is-prev {
    transform: translate(-112%, -50%) scale(0.84);
    opacity: 0.34;
  }

  .home-graphic-slider__item.is-next {
    transform: translate(18%, -50%) scale(0.76);
    opacity: 0.28;
  }
}

.photography-feature {
  padding: 1.2rem var(--page-gutter) 7rem;
  background: #ffffff;
  overflow: clip;
}

.photography-feature__sheet {
  width: 100%;
  margin: 0 auto;
  display: grid;
  justify-items: center;
  gap: 0.7rem;
}

.photography-feature__kicker {
  margin: 0;
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}

.photography-feature__title {
  margin: 0;
  font-size: clamp(1.9rem, 1.12rem + 2.7vw, 4.2rem);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.photography-feature__scene {
  position: relative;
  width: 100%;
  min-height: clamp(520px, 54vw, 1080px);
  perspective: 1760px;
  perspective-origin: 50% 44%;
  overflow: hidden;
  isolation: isolate;
}

.photography-feature__scene::before {
  content: "";
  position: absolute;
  inset: clamp(2.3rem, 6vw, 4.8rem) clamp(0.25rem, 2.8vw, 1.75rem) clamp(3.3rem, 6vw, 5.1rem);
  border-radius: 50% / 38%;
  background:
    radial-gradient(ellipse at center, rgba(244, 244, 244, 0.9) 0%, rgba(255, 255, 255, 0.97) 50%, rgba(255, 255, 255, 0) 76%);
  z-index: 0;
  pointer-events: none;
}

.photography-feature__scene::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 8%;
  width: 88%;
  height: clamp(44px, 7vw, 140px);
  transform: translateX(-50%);
  background: radial-gradient(ellipse at center, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0) 72%);
  filter: blur(22px);
  opacity: 0.18;
  z-index: 0;
  pointer-events: none;
}

.photography-feature__network {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
}

.photography-feature__item {
  --item-width: clamp(36px, 2.8vw, 88px);
  --item-size-level: 1;
  --card-ratio: 2 / 3;
  --item-hover-scale: 1;
  position: absolute;
  top: 50%;
  left: 50%;
  width: var(--item-width);
  padding: 0;
  border: 0;
  background: transparent;
  appearance: none;
  cursor: zoom-in;
  z-index: 2;
  opacity: var(--sphere-opacity, 1);
  filter: blur(calc(var(--sphere-blur, 0) * 1px));
  transform-style: preserve-3d;
  will-change: transform, opacity, filter;
  transform:
    translate3d(calc(var(--sphere-x, 0) * 1px), calc(var(--sphere-y, 0) * 1px), calc(var(--sphere-z, 0) * 1px))
    translate(-50%, -50%)
    rotateY(calc(var(--sphere-rotate-y, 0) * 1deg))
    rotateX(calc(var(--sphere-rotate-x, 0) * 1deg))
    scale(calc(var(--sphere-scale, 1) * var(--item-size-level, 1) * var(--item-hover-scale, 1)));
  transition: filter 220ms ease, opacity 220ms ease;
}

.photography-feature__item:hover,
.photography-feature__item:focus-visible {
  --item-hover-scale: 1.16;
  filter: blur(0);
}

.photography-feature__item:focus-visible {
  outline: none;
}

.photography-feature__item[data-sphere-size="narrow"] {
  --item-width: clamp(22px, 1.6vw, 38px);
  --card-ratio: 5 / 13;
}

.photography-feature__item[data-sphere-size="tall"] {
  --item-width: clamp(34px, 2.4vw, 70px);
  --card-ratio: 2 / 3;
}

.photography-feature__item[data-sphere-size="square"] {
  --item-width: clamp(34px, 2.8vw, 74px);
  --card-ratio: 1;
}

.photography-feature__item[data-sphere-size="wide"] {
  --item-width: clamp(52px, 4vw, 124px);
  --card-ratio: 5 / 4;
}

.photography-feature__item[data-sphere-level="xs"] {
  --item-size-level: 0.72;
}

.photography-feature__item[data-sphere-level="sm"] {
  --item-size-level: 0.9;
}

.photography-feature__item[data-sphere-level="md"] {
  --item-size-level: 1.04;
}

.photography-feature__item[data-sphere-level="lg"] {
  --item-size-level: 1.22;
}

.photography-feature__card {
  display: block;
  width: 100%;
  aspect-ratio: var(--card-ratio);
  overflow: hidden;
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.09);
  transform: translateZ(0);
  transition: transform 260ms ease, box-shadow 260ms ease;
}

.photography-feature__item:hover .photography-feature__card,
.photography-feature__item:focus-visible .photography-feature__card {
  box-shadow: 0 18px 30px rgba(0, 0, 0, 0.16);
  transform: translateZ(0) scale(1.04);
}

.photography-feature__image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.04);
  transition: transform 260ms ease, filter 260ms ease;
}

.photography-feature__item:hover .photography-feature__image,
.photography-feature__item:focus-visible .photography-feature__image {
  transform: scale(1.1);
  filter: saturate(1.04) contrast(1.02);
}

.photography-feature__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.42rem;
  margin-top: 0.55rem;
}

.photography-feature__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 96px;
  min-height: 42px;
  padding: 0.64rem 1.12rem;
  border: 1px solid rgba(5, 5, 5, 0.22);
  background: transparent;
  color: #050505;
  font-size: 0.72rem;
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  transition: background-color 220ms ease, border-color 220ms ease, color 220ms ease;
}

.photography-feature__button:hover,
.photography-feature__button:focus-visible {
  background: rgba(5, 5, 5, 0.04);
  border-color: rgba(5, 5, 5, 0.42);
  color: #050505;
}

.page-main {
  min-height: 100svh;
  padding: clamp(7.6rem, 11vw, 8.75rem) var(--page-gutter) clamp(2.4rem, 5vw, 3rem);
  background: #ffffff;
}

.page-main--graphic-editorial {
  padding: clamp(6.9rem, 9.8vw, 7.9rem) clamp(0.5rem, 1.2vw, 1rem) 1rem;
  background: #ffffff;
}

.page-shell {
  width: min(100%, var(--content-width));
  margin: 0 auto;
  background: #ffffff;
}

.page-shell--wide {
  width: min(100%, 1320px);
}

.page-back,
.project-detail__back {
  --back-arrow-size: clamp(3rem, 3.4vw, 3.8rem);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: var(--back-arrow-size);
  height: var(--back-arrow-size);
  min-height: 0;
  padding: 0;
  margin-bottom: 1.6rem;
  border: 0;
  background: transparent;
  color: transparent;
  font-size: 0;
  line-height: 0;
  letter-spacing: 0;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  transition: transform 220ms ease, filter 220ms ease, opacity 220ms ease;
}

.page-back::before,
.project-detail__back::before {
  content: "";
  display: block;
  width: calc(var(--back-arrow-size) * 0.82);
  height: calc(var(--back-arrow-size) * 0.82);
  background: currentColor;
  color: #050505;
  clip-path: polygon(
    0% 50%,
    34% 16%,
    34% 34%,
    100% 34%,
    100% 66%,
    34% 66%,
    34% 84%
  );
}

.page-back:hover,
.page-back:focus-visible,
.project-detail__back:hover,
.project-detail__back:focus-visible {
  transform: translateX(-1px) scale(1.02);
  filter: drop-shadow(0 8px 14px rgba(0, 0, 0, 0.06));
}

.page-heading {
  margin: 0;
  font-family: var(--font-sans);
  font-size: clamp(2rem, 7vw, 5.6rem);
  font-weight: 700;
  letter-spacing: clamp(0.08em, 0.28vw, 0.18em);
  text-align: center;
  text-transform: uppercase;
}

.page-subtitle {
  margin: 1rem auto 0;
  max-width: 540px;
  font-size: clamp(0.78rem, 0.72rem + 0.2vw, 0.92rem);
  line-height: 1.8;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
}

.page-main--archive-rail {
  min-height: 100svh;
  padding: clamp(7rem, 10vw, 8rem) clamp(0.8rem, 1.8vw, 1.5rem) clamp(1rem, 2vw, 1.6rem);
  background: #f7f3ea;
}

.page-main--archive-rail-photo {
  background: #ffffff;
}

.page-main--photo-poster {
  min-height: 100svh;
  padding: clamp(7rem, 9vw, 8rem) clamp(0.65rem, 1.5vw, 1.2rem) clamp(0.35rem, 1vw, 0.9rem);
  background: #ffffff;
}

.photo-poster {
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: clamp(1.1rem, 2vw, 1.8rem);
  min-height: calc(100svh - clamp(7.6rem, 10vw, 9rem));
}

.page-interactive-archive .photo-poster {
  grid-template-rows: auto;
  min-height: auto;
}

.page-interactive-archive .photo-poster__hero {
  display: none;
}

.photo-poster--interactive {
  position: relative;
  overflow: visible;
  isolation: isolate;
}

.photo-poster--interactive .interactive-live-media {
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100svh;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
  background: transparent;
  opacity: 0;
  visibility: hidden;
  transition: opacity 520ms ease, visibility 520ms ease;
}

.page-interactive-archive.is-interactive-work-open .photo-poster--interactive .interactive-live-media {
  opacity: 1;
  visibility: visible;
}

.photo-poster--interactive .interactive-live-media::after {
  content: none;
}

.photo-poster--interactive .interactive-live-media__video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transform: scale(1.04);
  filter: saturate(1.06) contrast(1.02);
  transition: opacity 280ms ease, transform 1200ms ease;
}

.photo-poster--interactive .interactive-live-media__video.is-ready {
  opacity: 1;
  transform: scale(1.01);
}

.photo-poster--interactive .interactive-live-bg {
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100svh;
  display: block;
  z-index: 1;
  pointer-events: none;
  mix-blend-mode: multiply;
  opacity: 0.95;
}

.photo-poster--interactive .interactive-live-face-layer {
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100svh;
  display: block;
  z-index: 1;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  mix-blend-mode: normal;
  transition: opacity 220ms ease, visibility 220ms ease;
}

.photo-poster--interactive .interactive-live-face-layer.is-active {
  opacity: 1;
  visibility: visible;
}

.photo-poster--interactive .interactive-face-mode__video {
  position: fixed;
  left: -9999px;
  top: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.photo-poster--interactive .photo-poster__top,
.photo-poster--interactive .photo-poster__hero {
  position: relative;
  z-index: 2;
}

.page-interactive-archive .interactive-work-gate {
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100svh;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  pointer-events: auto;
  opacity: 1;
  cursor: pointer;
  transition: opacity 260ms ease;
}

.page-interactive-archive .interactive-work-gate__camera-preview {
  position: absolute;
  left: calc(clamp(0.9rem, 1.2vw, 1.3rem) + 84px);
  bottom: clamp(0.9rem, 1.2vw, 1.3rem);
  z-index: 2;
  width: clamp(92px, 10.8vw, 138px);
  aspect-ratio: 4 / 5;
  display: block;
  object-fit: cover;
  border: 1px solid rgba(0, 0, 0, 0.56);
  border-radius: 6px;
  background: #050505;
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.22);
  opacity: 0;
  transform: translateY(4px) scale(0.98) scaleX(-1);
  pointer-events: none;
  transition: opacity 220ms ease, transform 220ms ease, border-color 220ms ease;
}

.page-interactive-archive .interactive-work-gate__camera-preview.is-active {
  opacity: 0.96;
  transform: translateY(0) scale(1) scaleX(-1);
  border-color: rgba(0, 0, 0, 0.72);
}

.page-interactive-archive .interactive-work-gate__audio-toggle {
  position: absolute;
  left: clamp(0.9rem, 1.2vw, 1.3rem);
  bottom: clamp(0.9rem, 1.2vw, 1.3rem);
  z-index: 2;
  min-width: 68px;
  min-height: 34px;
  padding: 0.38rem 0.6rem;
  border: 1px solid rgba(0, 0, 0, 0.34);
  background: rgba(255, 255, 255, 0.9);
  color: #050505;
  font-family: var(--font-sans);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
  cursor: pointer;
  transition: background-color 180ms ease, border-color 180ms ease, transform 180ms ease, box-shadow 180ms ease;
}

.page-interactive-archive .interactive-work-gate__audio-toggle:hover,
.page-interactive-archive .interactive-work-gate__audio-toggle:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(0, 0, 0, 0.56);
  background: #ffffff;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.16);
}

.page-interactive-archive .interactive-work-gate__audio-toggle.is-playing,
.page-interactive-archive .interactive-work-gate__audio-toggle.is-active {
  background: #050505;
  color: #ffffff;
  border-color: rgba(0, 0, 0, 0.9);
}

.page-interactive-archive .interactive-work-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.85rem;
  flex-wrap: wrap;
}

.page-interactive-archive .interactive-work-face-toggle {
  min-width: 92px;
  min-height: 34px;
  padding: 0.38rem 0.72rem;
  border: 1px solid rgba(0, 0, 0, 0.34);
  background: rgba(255, 255, 255, 0.9);
  color: #050505;
  font-family: var(--font-sans);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
  cursor: pointer;
  transition: background-color 180ms ease, border-color 180ms ease, transform 180ms ease, box-shadow 180ms ease, opacity 180ms ease;
}

.page-interactive-archive .interactive-work-face-toggle:hover,
.page-interactive-archive .interactive-work-face-toggle:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(0, 0, 0, 0.56);
  background: #ffffff;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.16);
}

.page-interactive-archive .interactive-work-face-toggle.is-active {
  background: #050505;
  color: #ffffff;
  border-color: rgba(0, 0, 0, 0.9);
}

.page-interactive-archive .interactive-work-face-toggle:disabled {
  cursor: default;
  opacity: 0.48;
  box-shadow: none;
  transform: none;
}

.page-interactive-archive .interactive-work-gate::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 52%;
  width: clamp(220px, 34vw, 520px);
  aspect-ratio: 1;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0.88) 0%, rgba(255, 255, 255, 0.58) 34%, rgba(255, 255, 255, 0.08) 68%, rgba(255, 255, 255, 0) 100%);
  filter: blur(10px);
  opacity: 0.96;
  pointer-events: none;
  animation: interactive-work-gate-glow 2.8s ease-in-out infinite;
}

.page-interactive-archive .interactive-work-gate__beacon {
  position: relative;
  z-index: 1;
  display: block;
  width: clamp(26px, 2.5vw, 52px);
  aspect-ratio: 1;
  pointer-events: none;
  clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
  background: radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.98) 0%, rgba(230, 239, 255, 0.92) 34%, rgba(130, 170, 255, 0.74) 72%, rgba(130, 170, 255, 0) 100%);
  box-shadow:
    0 0 20px rgba(108, 152, 255, 0.72),
    0 0 44px rgba(108, 152, 255, 0.54),
    0 0 92px rgba(108, 152, 255, 0.36);
  animation: interactive-work-gate-beacon 2.2s ease-in-out infinite;
}

.page-interactive-archive .interactive-work-gate__beacon::before,
.page-interactive-archive .interactive-work-gate__beacon::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.page-interactive-archive .interactive-work-gate__beacon::before {
  width: clamp(96px, 11vw, 170px);
  aspect-ratio: 1;
  clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
  border: 1px solid rgba(40, 60, 110, 0.34);
  opacity: 0.88;
  animation: interactive-work-gate-rotate 4.6s linear infinite;
}

.page-interactive-archive .interactive-work-gate__beacon::after {
  width: clamp(138px, 16vw, 240px);
  height: 1px;
  background: linear-gradient(90deg, rgba(40, 60, 110, 0), rgba(40, 60, 110, 0.56), rgba(40, 60, 110, 0));
  box-shadow: 0 0 16px rgba(40, 60, 110, 0.26);
  animation: interactive-work-gate-scan 3.1s ease-in-out infinite;
}

@keyframes interactive-work-gate-glow {
  0%,
  100% {
    opacity: 0.72;
    transform: translate(-50%, -50%) scale(0.92);
  }

  50% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.1);
  }
}

@keyframes interactive-work-gate-beacon {
  0%,
  100% {
    transform: scale(0.9);
    opacity: 0.84;
  }

  50% {
    transform: scale(1.2);
    opacity: 1;
  }
}

@keyframes interactive-work-gate-rotate {
  0% {
    transform: translate(-50%, -50%) rotate(0deg) scale(0.92);
  }

  50% {
    transform: translate(-50%, -50%) rotate(180deg) scale(1.08);
  }

  100% {
    transform: translate(-50%, -50%) rotate(360deg) scale(0.92);
  }
}

@keyframes interactive-work-gate-scan {
  0%,
  100% {
    transform: translate(-50%, -50%) rotate(0deg);
    opacity: 0.4;
  }

  50% {
    transform: translate(-50%, -50%) rotate(90deg);
    opacity: 0.86;
  }
}

.page-interactive-archive .photo-poster__top {
  opacity: 0;
  transform: translateY(20px) scale(0.98);
  pointer-events: none;
  transition: opacity 300ms ease, transform 360ms ease;
}

.page-interactive-archive.is-interactive-work-open .photo-poster__top {
  opacity: 1;
  transform: none;
  pointer-events: auto;
}

.page-interactive-archive .photo-poster--interactive .photo-poster__item {
  opacity: 0;
  transform: translateY(24px) scale(0.92);
  transition:
    opacity 280ms ease,
    transform 360ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.page-interactive-archive.is-interactive-work-open .photo-poster--interactive .photo-poster__item {
  opacity: 1;
  transform: none;
}

.page-interactive-archive.is-interactive-work-open .photo-poster--interactive .photo-poster__item:nth-child(1) {
  transition-delay: 40ms;
}

.page-interactive-archive.is-interactive-work-open .photo-poster--interactive .photo-poster__item:nth-child(2) {
  transition-delay: 110ms;
}

.page-interactive-archive.is-interactive-work-open .photo-poster--interactive .photo-poster__item:nth-child(3) {
  transition-delay: 180ms;
}

.page-interactive-archive.is-interactive-work-open .interactive-work-gate {
  opacity: 0;
  pointer-events: none;
}

.photo-poster__top {
  display: grid;
  gap: 0.75rem;
}

.photo-poster__strip {
  display: flex;
  justify-content: center;
  gap: clamp(0.9rem, 1.5vw, 1.2rem);
  align-items: start;
}

.photo-poster__item {
  flex: 0 0 clamp(170px, 15vw, 220px);
  display: grid;
  gap: 0.38rem;
  color: inherit;
}

.photo-poster--interactive .photo-poster__item {
  --interactive-item-hue: 214;
  transition: transform 220ms ease;
}

.photo-poster--interactive .photo-poster__item-media {
  transition: box-shadow 240ms ease, transform 240ms ease;
}

.photo-poster--interactive .photo-poster__item.is-live-active .photo-poster__item-media {
  box-shadow:
    0 0 0 1px hsl(var(--interactive-item-hue) 86% 58% / 0.34),
    0 14px 30px hsl(var(--interactive-item-hue) 90% 48% / 0.26);
  transform: translateY(-1px);
}

.photo-poster--interactive .photo-poster__item.is-live-active .photo-poster__item-index,
.photo-poster--interactive .photo-poster__item.is-live-active .photo-poster__item-label {
  color: #000000;
}

.photo-poster--interactive .photo-poster__item:hover .photo-poster__item-index,
.photo-poster--interactive .photo-poster__item:hover .photo-poster__item-label,
.photo-poster--interactive .photo-poster__item:focus-visible .photo-poster__item-index,
.photo-poster--interactive .photo-poster__item:focus-visible .photo-poster__item-label {
  color: #000000;
}

.photo-poster__item-media {
  overflow: hidden;
  width: 100%;
  aspect-ratio: 4 / 3;
  background: #efefef;
}

.photo-poster--graphic .photo-poster__item {
  flex-basis: clamp(148px, 13vw, 190px);
}

.photo-poster--graphic .photo-poster__item-media {
  aspect-ratio: 3 / 4.2;
}

.photo-poster__item-media--placeholder {
  display: grid;
  place-items: end start;
  padding: 0.8rem;
  background: #050505;
  color: #ffffff;
}

.photo-poster__item-media--placeholder span {
  max-width: 8ch;
  font-size: clamp(0.92rem, 1.5vw, 1.2rem);
  line-height: 0.94;
  letter-spacing: -0.04em;
  text-transform: uppercase;
}

.photo-poster__item-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.photo-poster__item-media video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.photo-poster__item-media--circle {
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: #050505;
}

.photo-poster__item-media--circle img,
.photo-poster__item-media--circle video {
  border-radius: 50%;
  object-fit: cover;
}

.photo-poster__item-meta {
  display: flex;
  gap: 0.4rem;
  align-items: baseline;
}

.photo-poster__item-index,
.photo-poster__item-label,
.photo-poster__stamp,
.photo-poster__cta {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.7);
}

.photo-poster__copy {
  display: grid;
  align-content: center;
}

.photo-poster__editorial {
  display: grid;
  gap: 0.08rem;
  width: min(100%, 260px);
}

.photo-poster__editorial p {
  margin: 0;
  font-family: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;
  font-size: clamp(1.9rem, 3.2vw, 3rem);
  line-height: 0.9;
  letter-spacing: -0.05em;
  color: #111111;
}

.photo-poster__editorial-line--accent {
  padding-left: clamp(1.8rem, 4vw, 3.6rem);
  font-style: italic;
}

.photo-poster__hero {
  position: relative;
  display: grid;
  align-items: end;
  justify-items: center;
  padding-top: clamp(1.6rem, 4vw, 4.2rem);
  min-height: clamp(320px, 47vh, 720px);
}

.photo-poster__stamp {
  position: absolute;
  left: 0;
  top: 0.4rem;
}

.photo-poster__cta {
  position: absolute;
  right: 0;
  top: 0.4rem;
  text-decoration: underline;
  text-underline-offset: 0.16em;
}

.photo-poster__title {
  margin: 0;
  font-size: clamp(7rem, 34vw, 31rem);
  line-height: 0.72;
  letter-spacing: -0.14em;
  text-transform: uppercase;
  text-align: center;
  color: #050505;
}

.photo-poster__title--photo {
  width: 100%;
  font-size: clamp(4.8rem, 24vw, 18rem);
  line-height: 0.76;
  letter-spacing: -0.11em;
}

.photo-poster__title--graphic {
  font-size: clamp(5.8rem, 20vw, 19rem);
  line-height: 0.78;
  letter-spacing: -0.11em;
  max-width: 8.4ch;
}

.photo-poster__title--interactive {
  width: min(100%, 8.8ch);
  margin-inline: auto;
  font-size: clamp(4.1rem, 14vw, 11.5rem);
  line-height: 0.8;
  letter-spacing: -0.085em;
  text-wrap: balance;
}

.photo-poster__title--product {
  font-size: clamp(5rem, 21vw, 17rem);
  line-height: 0.78;
  letter-spacing: -0.1em;
  max-width: 8ch;
}

.photo-poster__title--drawing {
  width: 100%;
  font-size: clamp(5.6rem, 28vw, 20rem);
  line-height: 0.75;
  letter-spacing: -0.12em;
}

.archive-rail-page {
  display: grid;
  gap: clamp(1rem, 2vw, 1.6rem);
  width: 100%;
  min-height: calc(100svh - clamp(8rem, 11vw, 9.6rem));
  align-content: center;
}

.archive-rail-page--photo-centered {
  justify-items: center;
}

.archive-rail-page__header {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: start;
  gap: 1rem clamp(1rem, 2.4vw, 1.8rem);
}

.archive-rail-page__copy {
  display: grid;
  gap: 0.42rem;
  align-content: start;
  max-width: 32rem;
}

.archive-rail-page__eyebrow,
.archive-rail-page__hint,
.archive-rail__index,
.archive-rail__caption-index {
  margin: 0;
  font-size: 0.64rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.52);
}

.archive-rail-page__title {
  margin: 0;
  font-size: clamp(1.7rem, 3.8vw, 3.1rem);
  line-height: 0.92;
  letter-spacing: -0.06em;
  text-transform: uppercase;
}

.archive-rail-page__subtitle {
  margin: 0;
  max-width: 38ch;
  font-size: 0.84rem;
  line-height: 1.75;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.58);
}

.archive-rail-page__hint {
  align-self: end;
  justify-self: end;
}

.archive-rail {
  width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  padding-block: clamp(0.6rem, 1.5vw, 1rem);
  scrollbar-width: none;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
}

.archive-rail::-webkit-scrollbar {
  display: none;
}

.archive-rail--centered {
  overflow: visible;
  padding-block: 0;
}

.archive-rail:focus-visible {
  outline: 1px solid rgba(0, 0, 0, 0.18);
  outline-offset: 0.2rem;
}

.archive-rail__track {
  display: flex;
  align-items: flex-end;
  gap: clamp(0.8rem, 1.5vw, 1.15rem);
  min-width: max-content;
  padding: 0 clamp(1rem, 2vw, 1.6rem);
}

.archive-rail--centered .archive-rail__track {
  min-width: 0;
  justify-content: center;
}

.archive-rail__card {
  flex: 0 0 clamp(146px, 12vw, 194px);
  display: grid;
  gap: 0.65rem;
  align-self: end;
  color: inherit;
  scroll-snap-align: center;
}

.archive-rail__card--feature {
  flex-basis: clamp(270px, 22vw, 340px);
  gap: clamp(0.9rem, 1.8vw, 1.3rem);
  align-self: center;
}

.archive-rail__meta {
  display: grid;
  gap: 0.42rem;
  max-width: 21rem;
}

.archive-rail__title {
  margin: 0;
  max-width: 11ch;
  font-size: clamp(1.4rem, 2.8vw, 2.2rem);
  line-height: 0.9;
  letter-spacing: -0.05em;
  text-transform: uppercase;
}

.archive-rail__note {
  margin: 0;
  max-width: 26ch;
  font-size: 0.8rem;
  line-height: 1.7;
  color: rgba(0, 0, 0, 0.66);
}

.archive-rail__media {
  position: relative;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 4 / 5;
  background: #e6e2d9;
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.06);
}

.archive-rail__card--feature .archive-rail__media,
.archive-rail__media--feature {
  aspect-ratio: 4 / 6;
}

.archive-rail__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 260ms ease, filter 260ms ease;
}

.archive-rail__media--placeholder {
  display: grid;
  place-items: end start;
  padding: 1rem;
  background: #050505;
  color: #ffffff;
}

.archive-rail__media--placeholder span {
  max-width: 9ch;
  font-size: clamp(1rem, 1.8vw, 1.4rem);
  line-height: 0.94;
  letter-spacing: -0.03em;
  text-transform: uppercase;
}

.archive-rail__card:hover .archive-rail__media img,
.archive-rail__card:focus-visible .archive-rail__media img {
  transform: scale(1.02);
}

.archive-rail__caption {
  display: grid;
  gap: 0.18rem;
}

.archive-rail__caption-title {
  margin: 0;
  font-size: 0.74rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.76);
}

.archive-rail-page--photo-centered .archive-rail-page__header {
  width: min(100%, 980px);
  grid-template-columns: auto minmax(0, 1fr);
}

.archive-rail-page--photo-centered .archive-rail-page__copy {
  justify-items: center;
  max-width: 40rem;
  text-align: center;
}

.archive-rail-page--photo-centered .archive-rail {
  width: min(100%, 980px);
}

.archive-rail-page--photo-centered .archive-rail__card {
  flex-basis: clamp(220px, 20vw, 280px);
}

.archive-rail-page--photo-centered .archive-rail__card--feature {
  flex-basis: clamp(300px, 26vw, 360px);
}

.page-list {
  margin: 3.25rem 0 0;
  display: grid;
  gap: 1.4rem;
}

.page-item {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 1.2rem;
  align-items: baseline;
  padding: 0;
}

.page-item__index {
  margin: 0;
  font-size: 0.74rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}

.page-item__title {
  margin: 0;
  font-family: var(--font-sans);
  font-size: clamp(1.3rem, 4vw, 2rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.page-item__meta {
  margin: 0.45rem 0 0;
  font-size: 0.96rem;
  line-height: 1.7;
  color: var(--muted);
}

.page-copy {
  width: min(100%, 720px);
  margin: 3.25rem auto 0;
  padding-top: 0;
}

.page-copy p {
  margin: 0;
  font-size: 1rem;
  line-height: 1.9;
  text-align: center;
  color: var(--muted);
}

.page-about {
  background: #ffffff;
}

.about-spread {
  min-height: 100svh;
  padding: clamp(7rem, 10vw, 8.2rem) var(--page-gutter-tight) clamp(2.2rem, 4vw, 3.4rem);
  background: #ffffff;
}

.about-spread__stage {
  display: grid;
  grid-template-rows: auto 1fr auto;
  align-items: start;
  width: min(100%, 1520px);
  min-height: clamp(720px, 84vw, 980px);
  margin: 0 auto;
  gap: clamp(2.4rem, 7vw, 5rem);
}

.about-spread__rail {
  display: flex;
  justify-content: space-between;
  gap: clamp(0.18rem, 0.5vw, 0.46rem);
  width: 100%;
}

.about-spread__rail--top {
  align-items: flex-start;
}

.about-spread__rail--bottom {
  align-items: flex-end;
}

.about-spread__center {
  display: grid;
  align-self: center;
  justify-self: center;
  gap: 0.5rem;
  justify-items: center;
  width: min(100%, 760px);
  padding: 0 1rem;
  text-align: center;
  pointer-events: none;
}

.about-spread__headline {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(0.8rem, 2vw, 1.6rem);
  flex-wrap: wrap;
}

.about-spread__axis {
  font-size: 0.58rem;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}

.about-spread__title {
  margin: 0;
  font-size: clamp(1.16rem, 0.92rem + 1.3vw, 2.2rem);
  font-style: italic;
  font-weight: 200;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.7);
}

.about-spread__card {
  position: relative;
  display: grid;
  gap: 0.4rem;
  flex: 0 0 auto;
  width: var(--card-width, clamp(118px, 9vw, 170px));
  padding: 0;
  border: 0;
  background: transparent;
  text-align: left;
  cursor: zoom-in;
}

.about-spread__rail--top .about-spread__card:nth-child(2) {
  margin-top: clamp(0.3rem, 0.8vw, 0.72rem);
}

.about-spread__rail--top .about-spread__card:nth-child(4) {
  margin-top: clamp(0.18rem, 0.5vw, 0.44rem);
}

.about-spread__rail--bottom .about-spread__card:nth-child(2) {
  margin-bottom: clamp(0.4rem, 0.9vw, 0.82rem);
}

.about-spread__rail--bottom .about-spread__card:nth-child(4) {
  margin-bottom: clamp(0.28rem, 0.7vw, 0.58rem);
}

.about-spread__media {
  display: block;
  overflow: hidden;
  border: 1px solid rgba(5, 5, 5, 0.16);
  background: #f5f5f5;
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.08);
  transition: transform 260ms ease, box-shadow 260ms ease;
}

.about-spread__media img {
  display: block;
  width: 100%;
  height: auto;
  transition: transform 320ms ease, filter 320ms ease;
}

.about-spread__card:hover .about-spread__media,
.about-spread__card:focus-visible .about-spread__media {
  transform: translateY(-6px);
  box-shadow: 0 22px 38px rgba(0, 0, 0, 0.12);
}

.about-spread__card:hover .about-spread__media img,
.about-spread__card:focus-visible .about-spread__media img {
  transform: scale(1.035);
  filter: contrast(1.02) saturate(1.02);
}

.about-spread__meta {
  display: grid;
  gap: 0.05rem;
}

.about-spread__meta-primary,
.about-spread__meta-secondary {
  display: block;
}

.about-spread__meta-primary {
  font-size: 0.56rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #111111;
}

.about-spread__meta-secondary {
  font-size: 0.52rem;
  font-weight: 400;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.46);
}

.catalog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  gap: clamp(1rem, 2vw, 1.2rem);
  margin-top: 3rem;
}

.catalog-card {
  display: grid;
  gap: 0.95rem;
  min-height: clamp(210px, 26vw, 240px);
  padding: 1.35rem;
  border: 1px solid var(--line);
  background: #ffffff;
  transition: transform 220ms ease, box-shadow 220ms ease, background-color 220ms ease;
}

.catalog-card:hover,
.catalog-card:focus-visible {
  transform: translateY(-4px);
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.05);
}

.catalog-card__index {
  margin: 0;
  font-size: 0.74rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}

.catalog-card__title {
  margin: 0;
  font-family: var(--font-sans);
  font-size: clamp(1.4rem, 4vw, 2.2rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.catalog-card__meta {
  margin: 0;
  max-width: 36ch;
  font-size: 0.98rem;
  line-height: 1.7;
  color: var(--muted);
}

.photo-series {
  display: grid;
  gap: clamp(1rem, 2vw, 1.4rem);
  margin-top: 3rem;
}

.photo-series-card {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(260px, 0.9fr);
  gap: clamp(1rem, 2vw, 1.4rem);
  align-items: center;
  padding: clamp(1rem, 2.2vw, 1.35rem);
  border: 1px solid var(--line);
  background: #ffffff;
  transition: transform 220ms ease, box-shadow 220ms ease;
}

.photo-series-card:hover,
.photo-series-card:focus-visible {
  transform: translateY(-4px);
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.05);
}

.photo-series-card__media {
  overflow: hidden;
  background: #f4f4f4;
  aspect-ratio: 4 / 3;
}

.photo-series-card__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 320ms ease;
}

.photo-series-card:hover .photo-series-card__media img,
.photo-series-card:focus-visible .photo-series-card__media img {
  transform: scale(1.02);
}

.photo-series-card__body {
  display: grid;
  gap: 0.9rem;
}

.photo-gallery {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.35rem);
  margin-top: 3rem;
}

.photo-gallery__item {
  padding: 0;
  border: 0;
  background: transparent;
  cursor: zoom-in;
}

.photo-gallery__item:hover .photo-gallery__image,
.photo-gallery__item:focus-visible .photo-gallery__image {
  transform: scale(1.02);
}

.photo-gallery__image {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  background: #f4f4f4;
  transition: transform 260ms ease;
}

.photo-lightbox {
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  padding: 0;
  border: 0;
  background: transparent;
}

.photo-lightbox::backdrop {
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(8px);
}

.photo-lightbox__surface {
  position: relative;
  display: grid;
  align-content: center;
  justify-items: center;
  min-height: 100svh;
  min-height: 100dvh;
  padding: clamp(1rem, 3vw, 2rem);
}

.photo-lightbox__close {
  position: absolute;
  top: clamp(0.9rem, 2vw, 1.2rem);
  right: clamp(0.9rem, 2vw, 1.2rem);
  padding: 0;
  border: 0;
  background: transparent;
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
}

.photo-lightbox__nav {
  position: absolute;
  top: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(2.8rem, 4vw, 3.5rem);
  height: clamp(2.8rem, 4vw, 3.5rem);
  padding: 0;
  border: 1px solid rgba(0, 0, 0, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.84);
  color: #050505;
  font-size: clamp(1rem, 1.6vw, 1.35rem);
  line-height: 1;
  cursor: pointer;
  transform: translateY(-50%);
  backdrop-filter: blur(8px);
}

.photo-lightbox__nav--prev {
  left: clamp(0.8rem, 2vw, 1.2rem);
}

.photo-lightbox__nav--next {
  right: clamp(0.8rem, 2vw, 1.2rem);
}

.photo-lightbox__nav:hover,
.photo-lightbox__nav:focus-visible {
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(0, 0, 0, 0.24);
}

.photo-lightbox__nav:disabled,
.photo-lightbox__nav[hidden] {
  display: none;
}

.photo-lightbox__image {
  display: block;
  max-width: min(94vw, 1600px);
  max-height: 84vh;
  width: auto;
  height: auto;
  object-fit: contain;
}

.photo-lightbox__caption {
  margin: 0.85rem 0 0;
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}

.photo-lightbox__thumb-strip {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: clamp(4.2rem, 9vw, 7rem);
  gap: clamp(0.34rem, 0.8vw, 0.62rem);
  width: min(94vw, 1180px);
  margin: clamp(0.72rem, 1.6vw, 1rem) 0 0;
  padding: 0.22rem 0.12rem 0.24rem;
  overflow-x: auto;
  overflow-y: hidden;
  overscroll-behavior-x: contain;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.46) rgba(255, 255, 255, 0.08);
}

.photo-lightbox__thumb {
  position: relative;
  margin: 0;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.06);
  cursor: pointer;
  opacity: 0.72;
  transform: translateY(0) scale(1);
  transition: transform 220ms ease, border-color 220ms ease, opacity 220ms ease;
}

.photo-lightbox__thumb:hover,
.photo-lightbox__thumb:focus-visible {
  opacity: 0.96;
  border-color: rgba(255, 255, 255, 0.62);
  transform: translateY(-2px) scale(1.01);
}

.photo-lightbox__thumb.is-active {
  opacity: 1;
  border-color: rgba(255, 255, 255, 0.94);
}

.photo-lightbox__thumb-image {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  background: #111111;
}

body.is-lightbox-open {
  overflow: hidden;
}

.photo-archive {
  min-height: 100svh;
  padding: clamp(5.9rem, 7vw, 6.8rem) var(--page-gutter-tight) clamp(2.6rem, 4vw, 3.4rem);
  background: #ffffff;
}

.photo-archive__shell {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.photo-archive__shell::before,
.photo-archive__shell::after {
  content: none;
}

.photo-archive__masthead {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: clamp(2.3rem, 4vw, 3.2rem);
}

.photo-archive__chips {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.45rem;
}

.photo-archive__chip {
  display: inline-flex;
  align-items: center;
  min-height: 2.85rem;
  padding: 0.72rem 1rem;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.74);
  color: rgba(0, 0, 0, 0.56);
  font-size: 0.7rem;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  backdrop-filter: blur(5px);
}

.photo-archive__chip--active {
  color: #050505;
}

.page-photo-archive .page-back {
  --back-arrow-size: clamp(2.35rem, 2.55vw, 2.8rem);
  margin-bottom: 0;
  flex: 0 0 auto;
}

.photo-gallery.photo-gallery--research {
  counter-reset: photo-index;
  grid-template-columns: repeat(14, minmax(0, 1fr));
  gap: clamp(1.5rem, 2.4vw, 2.5rem);
  align-items: start;
  margin-top: 0;
  padding: 0;
}

.photo-gallery.photo-gallery--research .photo-gallery__item {
  counter-increment: photo-index;
  position: relative;
  grid-column: span 3;
  width: min(100%, 90%);
  justify-self: center;
  transform: none;
  transition: transform 220ms ease;
}

.photo-gallery.photo-gallery--research .photo-gallery__item::before {
  content: counter(photo-index, decimal-leading-zero);
  position: absolute;
  left: -1rem;
  bottom: 0.2rem;
  font-size: clamp(0.68rem, 0.78vw, 0.8rem);
  font-weight: 500;
  letter-spacing: 0.06em;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  color: rgba(0, 0, 0, 0.88);
  font-variant-numeric: tabular-nums;
}

.photo-gallery.photo-gallery--research .photo-gallery__item[data-photo-orientation="landscape"] {
  grid-column: span 4;
}

.photo-gallery.photo-gallery--research .photo-gallery__item[data-photo-orientation="portrait"],
.photo-gallery.photo-gallery--research .photo-gallery__item[data-photo-orientation="square"] {
  grid-column: span 3;
}

.photo-gallery.photo-gallery--research .photo-gallery__image {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  background: #f6f6f6;
  border: 1px solid rgba(0, 0, 0, 0.05);
  box-shadow: 0 12px 22px rgba(0, 0, 0, 0.06);
}

.photo-gallery.photo-gallery--research .photo-gallery__item[data-photo-orientation="landscape"] .photo-gallery__image {
  aspect-ratio: 4 / 3;
}

.photo-gallery.photo-gallery--research .photo-gallery__item[data-photo-orientation="square"] .photo-gallery__image {
  aspect-ratio: 1 / 1;
}

.photo-gallery.photo-gallery--research .photo-gallery__item:hover .photo-gallery__image,
.photo-gallery.photo-gallery--research .photo-gallery__item:focus-visible .photo-gallery__image {
  transform: scale(1.02);
  box-shadow: 0 18px 28px rgba(0, 0, 0, 0.1);
}

.photo-gallery.photo-gallery--research .photo-gallery__item:hover,
.photo-gallery.photo-gallery--research .photo-gallery__item:focus-visible {
  transform: translateY(-0.22rem);
}

.photo-gallery.photo-gallery--research .photo-gallery__item:focus-visible {
  outline: none;
}

.photo-gallery.photo-gallery--research .photo-gallery__item:focus-visible .photo-gallery__image {
  outline: 1px solid rgba(0, 0, 0, 0.48);
  outline-offset: 0.28rem;
}

.project-detail {
  width: min(100%, var(--content-width));
  margin: 0 auto;
  display: grid;
  gap: 1.5rem;
}

.project-detail--editorial {
  width: min(100%, 1540px);
  gap: clamp(1.4rem, 2vw, 2.3rem);
}

.project-detail__back {
  margin-bottom: 0.2rem;
  justify-self: start;
}

.project-detail__title {
  margin: 0;
  font-family: var(--font-sans);
  font-size: clamp(1.9rem, 6vw, 5rem);
  font-weight: 700;
  letter-spacing: clamp(0.06em, 0.24vw, 0.12em);
  text-transform: uppercase;
}

.project-detail__meta {
  margin: 0;
  font-size: 0.94rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}

.project-detail__body {
  width: min(100%, 760px);
  display: grid;
  gap: 1rem;
}

.project-detail__body p {
  margin: 0;
  font-size: clamp(1.02rem, 0.94rem + 0.26vw, 1.14rem);
  line-height: 1.92;
  color: var(--muted);
}

.project-detail__placeholder {
  display: grid;
  place-items: center;
  min-height: 320px;
  border: 1px dashed rgba(0, 0, 0, 0.18);
  font-size: 0.88rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.graphic-project-intro {
  display: grid;
  gap: 1rem;
  width: min(100%, 1180px);
  padding: clamp(1.4rem, 2.4vw, 2.2rem);
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 24px 54px rgba(0, 0, 0, 0.12);
}

.graphic-project-intro .project-detail__body {
  width: min(100%, 1020px);
}

.graphic-spreadbook {
  width: 100%;
  margin: 0 auto;
  display: grid;
  gap: clamp(0.55rem, 1.1vw, 0.9rem);
}

.graphic-project-top {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 0.75rem 1rem;
}

.graphic-project-top .project-detail__back {
  margin-bottom: 0;
}

.graphic-project-top .project-detail__meta {
  justify-self: end;
  text-align: right;
}

.graphic-spreadbook__sheet {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  width: 100%;
  min-height: max(680px, calc(100svh - clamp(8.6rem, 11vw, 10rem)));
  background: transparent;
  box-shadow: none;
}

.graphic-spreadbook__sheet::before {
  display: none;
}

.graphic-spreadbook__page {
  position: relative;
  display: grid;
  min-height: 100%;
  padding: clamp(1rem, 1.8vw, 1.8rem);
}

.graphic-spreadbook__page--intro {
  grid-template-rows: auto auto 1fr auto;
  gap: clamp(1rem, 1.9vw, 1.6rem);
  background: #ffffff;
}

.graphic-spreadbook__page--gallery {
  grid-template-rows: auto 1fr auto;
  gap: clamp(1rem, 1.9vw, 1.5rem);
  background: #050505;
}

.graphic-spreadbook__masthead {
  display: grid;
  gap: 0.8rem;
}

.graphic-spreadbook__kicker,
.graphic-spreadbook__eyebrow,
.graphic-spreadbook__gallery-label {
  margin: 0;
  font-size: 0.58rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.54);
}

.graphic-spreadbook__headline {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: clamp(0.9rem, 1.8vw, 1.6rem);
  align-items: start;
}

.graphic-spreadbook__number {
  margin: 0;
  font-size: clamp(2.8rem, 4.8vw, 5.4rem);
  line-height: 0.82;
  letter-spacing: -0.06em;
  color: #111111;
}

.graphic-spreadbook__headline-copy {
  display: grid;
  gap: 0.45rem;
}

.graphic-spreadbook__title {
  margin: 0;
  max-width: 10ch;
  font-size: clamp(2.2rem, 3.8vw, 4.4rem);
  line-height: 0.9;
  letter-spacing: -0.06em;
  text-transform: uppercase;
}

.graphic-spreadbook__facts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem 1.1rem;
  align-content: start;
}

.graphic-spreadbook__fact {
  padding-top: 0.62rem;
  border-top: 1px solid rgba(0, 0, 0, 0.14);
}

.graphic-spreadbook__fact-label,
.graphic-spreadbook__fact-value {
  margin: 0;
}

.graphic-spreadbook__fact-label {
  font-size: 0.54rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.48);
}

.graphic-spreadbook__fact-value {
  margin-top: 0.32rem;
  font-size: clamp(0.88rem, 0.82rem + 0.28vw, 1rem);
  line-height: 1.62;
  color: rgba(0, 0, 0, 0.76);
}

.graphic-spreadbook__body {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.95rem 1.2rem;
  align-content: end;
}

.graphic-spreadbook__body p {
  margin: 0;
  font-size: clamp(0.9rem, 0.84rem + 0.3vw, 1.02rem);
  line-height: 1.78;
  color: rgba(0, 0, 0, 0.72);
}

.graphic-spreadbook__topic-block {
  display: grid;
  gap: 0.44rem;
  align-content: start;
}

.graphic-spreadbook__topic-title {
  margin: 0;
  font-size: clamp(0.95rem, 1.35vw, 1.5rem);
  line-height: 1.05;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.92);
}

.graphic-spreadbook__topic-title--compact {
  font-size: clamp(0.82rem, 1.05vw, 1.08rem);
  letter-spacing: 0.08em;
}

.graphic-spreadbook__footer {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem 1.1rem;
  align-items: flex-end;
  padding-top: 0.72rem;
  border-top: 1px solid rgba(0, 0, 0, 0.14);
  font-size: 0.54rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.56);
}

.graphic-spreadbook__footer span {
  display: inline-block;
}

.graphic-spreadbook__footer--right {
  justify-content: space-between;
}

.graphic-spreadbook__gallery-head {
  display: flex;
  justify-content: space-between;
  gap: 0.8rem 1rem;
  align-items: baseline;
}

.graphic-spreadbook__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(0.72rem, 1.35vw, 1rem);
  align-content: start;
}

.graphic-spreadbook__item {
  padding: 0;
  border: 0;
  background: transparent;
  cursor: zoom-in;
}

.graphic-spreadbook__image {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: auto;
}

.graphic-spreadbook__image {
  object-fit: contain;
  background: transparent;
  border: 0;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.34);
  filter: none;
  transition: transform 220ms ease, box-shadow 220ms ease, filter 220ms ease;
}

.graphic-spreadbook__item:hover .graphic-spreadbook__image,
.graphic-spreadbook__item:focus-visible .graphic-spreadbook__image {
  transform: translateY(-2px);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.42);
  filter: none;
}

.graphic-spreadbook__item:focus-visible {
  outline: none;
}

.graphic-spreadbook__statement {
  display: grid;
  width: 100%;
  aspect-ratio: 4 / 5;
  place-items: end start;
  padding: 0.8rem;
  background: #f4f4f4;
  color: #111111;
  border: 0;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.28);
}

.graphic-spreadbook__statement span {
  font-size: 0.62rem;
  line-height: 1.35;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.graphic-spreadbook__page--gallery .graphic-spreadbook__gallery-label,
.graphic-spreadbook__page--gallery .graphic-spreadbook__footer {
  color: rgba(255, 255, 255, 0.7);
}

.graphic-spreadbook__page--gallery .graphic-spreadbook__footer {
  border-top-color: rgba(255, 255, 255, 0.16);
}

.page-graphic-project .photo-lightbox__image {
  filter: none;
}

.graphic-gallery-bar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: 1rem;
  font-size: 0.58rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.graphic-gallery-bar__link,
.graphic-gallery-bar__label {
  margin: 0;
  color: rgba(0, 0, 0, 0.82);
}

.graphic-gallery-bar__link--menu {
  justify-self: start;
}

.graphic-gallery-bar__label {
  justify-self: center;
}

.graphic-gallery-bar__link--action {
  justify-self: end;
}

.graphic-gallery-board {
  display: grid;
  grid-template-columns: minmax(120px, 170px) minmax(0, 1fr);
  grid-template-rows: auto 1fr auto;
  gap: clamp(1rem, 2vw, 1.8rem) clamp(1.6rem, 4vw, 4.5rem);
  min-height: clamp(640px, 86svh, 900px);
  padding: clamp(1rem, 1.9vw, 1.5rem);
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.04);
}

.graphic-gallery-index {
  grid-column: 1;
  grid-row: 1 / span 2;
  align-self: start;
  display: grid;
  gap: 0.3rem;
  padding-top: clamp(2.2rem, 7vw, 5rem);
}

.graphic-gallery-index a {
  font-size: 0.56rem;
  letter-spacing: 0.06em;
  color: rgba(0, 0, 0, 0.82);
}

.graphic-gallery-grid {
  grid-column: 2;
  grid-row: 1 / span 2;
  justify-self: end;
  align-self: start;
  display: grid;
  grid-template-columns: repeat(5, minmax(68px, 1fr));
  gap: 0.72rem;
  width: min(100%, 620px);
}

.graphic-gallery-item {
  padding: 0;
  border: 0;
  background: transparent;
  cursor: zoom-in;
}

.graphic-gallery-item__image {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  background: #e8e8e8;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.07);
  transition: transform 220ms ease, box-shadow 220ms ease;
}

.graphic-gallery-item[data-gallery-format="portrait"] .graphic-gallery-item__image {
  aspect-ratio: 3 / 4;
}

.graphic-gallery-item:hover .graphic-gallery-item__image,
.graphic-gallery-item:focus-visible .graphic-gallery-item__image {
  transform: translateY(-2px);
  box-shadow: 0 12px 22px rgba(0, 0, 0, 0.1);
}

.graphic-gallery-item:focus-visible {
  outline: none;
}

.graphic-gallery-title-block {
  grid-column: 1;
  grid-row: 3;
  align-self: end;
}

.graphic-gallery-title-block__project {
  margin: 0 0 0.28rem;
  font-size: 0.64rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.5);
}

.graphic-gallery-title {
  margin: 0;
  font-size: clamp(3rem, 5vw, 4.8rem);
  line-height: 0.92;
  letter-spacing: -0.04em;
}

.graphic-gallery-arrow {
  grid-column: 2;
  grid-row: 3;
  justify-self: end;
  align-self: end;
  margin: 0;
  font-size: 1rem;
  color: rgba(0, 0, 0, 0.58);
}

.graphic-project-notes {
  display: grid;
  gap: 1.1rem;
  padding: clamp(1rem, 1.8vw, 1.4rem);
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.04);
}

.graphic-project-notes__intro {
  display: grid;
  gap: 0.28rem;
}

.graphic-project-notes__eyebrow {
  margin: 0;
  font-size: 0.62rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.48);
}

.graphic-project-notes__title {
  margin: 0;
  font-size: clamp(1.2rem, 2vw, 1.8rem);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.graphic-project-notes__body {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem 1.2rem;
}

.graphic-project-notes__body p {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.8;
  color: rgba(0, 0, 0, 0.66);
}

.graphic-project-facts {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
}

.graphic-project-fact {
  padding-top: 0.6rem;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.graphic-project-fact__label,
.graphic-project-fact__value {
  margin: 0;
}

.graphic-project-fact__label {
  font-size: 0.58rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.48);
}

.graphic-project-fact__value {
  margin-top: 0.32rem;
  font-size: 0.86rem;
  line-height: 1.6;
  color: rgba(0, 0, 0, 0.72);
}

.graphic-editorial-wall {
  display: grid;
  gap: clamp(1.8rem, 2.6vw, 2.8rem);
}

.graphic-spread {
  width: 100%;
}

.graphic-spread__sheet {
  position: relative;
  display: grid;
  grid-template-columns: repeat(14, minmax(0, 1fr));
  grid-template-rows: repeat(10, minmax(0, 1fr));
  gap: clamp(0.85rem, 1.35vw, 1.25rem);
  min-height: clamp(540px, 48vw, 760px);
  padding: clamp(1.2rem, 2.2vw, 1.8rem);
  background: #fcfcfb;
  box-shadow: 0 28px 62px rgba(0, 0, 0, 0.14);
}

.graphic-spread__item {
  padding: 0;
  border: 0;
  background: transparent;
  cursor: zoom-in;
}

.graphic-spread__item:focus-visible {
  outline: 1px solid rgba(0, 0, 0, 0.42);
  outline-offset: 4px;
}

.graphic-spread__item--cover {
  z-index: 2;
}

.graphic-spread__frame {
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: #efefef;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.08);
}

.graphic-spread__item--cover .graphic-spread__frame {
  padding: clamp(0.45rem, 0.7vw, 0.65rem);
  background: #ffffff;
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.18);
}

.graphic-spread__item--cover .graphic-spread__image {
  object-position: center 28%;
}

.graphic-spread__image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 260ms ease, filter 260ms ease;
}

.graphic-spread__item:hover .graphic-spread__image,
.graphic-spread__item:focus-visible .graphic-spread__image {
  transform: scale(1.02);
  filter: contrast(1.02);
}

.graphic-spread__text {
  display: grid;
  align-content: start;
  gap: 0.75rem;
}

.graphic-spread__eyebrow {
  margin: 0;
  font-size: 0.62rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.58);
}

.graphic-spread__heading {
  margin: 0;
  font-size: clamp(1rem, 1.5vw, 1.4rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.graphic-spread__note {
  margin: 0;
  font-size: 0.78rem;
  line-height: 1.75;
  color: rgba(0, 0, 0, 0.64);
}

.graphic-spread__folio {
  position: absolute;
  bottom: clamp(0.85rem, 1.25vw, 1rem);
  margin: 0;
  font-size: 0.58rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.56);
}

.graphic-spread__folio--left {
  left: clamp(1.2rem, 2.2vw, 1.8rem);
}

.graphic-spread__folio--right {
  right: clamp(1.2rem, 2.2vw, 1.8rem);
}

.graphic-spread--chapter-a .graphic-spread__item--a-cover {
  grid-column: 1 / span 6;
  grid-row: 1 / span 8;
}

.graphic-spread--chapter-a .graphic-spread__item--a-window {
  grid-column: 7 / span 4;
  grid-row: 1 / span 3;
}

.graphic-spread--chapter-a .graphic-spread__item--a-passage {
  grid-column: 11 / span 4;
  grid-row: 1 / span 3;
}

.graphic-spread--chapter-a .graphic-spread__item--a-anchor {
  grid-column: 7 / span 8;
  grid-row: 9 / span 2;
}

.graphic-spread--chapter-a .graphic-spread__item--a-detail {
  grid-column: 11 / span 4;
  grid-row: 4 / span 3;
}

.graphic-spread--chapter-a .graphic-spread__item--a-rest {
  grid-column: 11 / span 4;
  grid-row: 7 / span 2;
}

.graphic-spread--chapter-a .graphic-spread__text--a {
  grid-column: 7 / span 4;
  grid-row: 4 / span 5;
}

.graphic-spread--chapter-b .graphic-spread__item--b-opener {
  grid-column: 1 / span 4;
  grid-row: 1 / span 3;
}

.graphic-spread--chapter-b .graphic-spread__item--b-horizon {
  grid-column: 5 / span 6;
  grid-row: 1 / span 4;
}

.graphic-spread--chapter-b .graphic-spread__item--b-echo {
  grid-column: 11 / span 4;
  grid-row: 1 / span 3;
}

.graphic-spread--chapter-b .graphic-spread__item--b-ground {
  grid-column: 1 / span 7;
  grid-row: 5 / span 4;
}

.graphic-spread--chapter-b .graphic-spread__item--b-pause {
  grid-column: 8 / span 4;
  grid-row: 5 / span 3;
}

.graphic-spread--chapter-b .graphic-spread__text--b {
  grid-column: 12 / span 3;
  grid-row: 5 / span 4;
}

.graphic-spread--chapter-c .graphic-spread__item--c-shelter {
  grid-column: 1 / span 7;
  grid-row: 1 / span 4;
}

.graphic-spread--chapter-c .graphic-spread__item--c-side {
  grid-column: 12 / span 3;
  grid-row: 1 / span 3;
}

.graphic-spread--chapter-c .graphic-spread__item--c-drift {
  grid-column: 1 / span 5;
  grid-row: 5 / span 3;
}

.graphic-spread--chapter-c .graphic-spread__item--c-release {
  grid-column: 6 / span 9;
  grid-row: 5 / span 4;
}

.graphic-spread--chapter-c .graphic-spread__text--c {
  grid-column: 8 / span 4;
  grid-row: 1 / span 4;
}

@media (max-width: 900px) {
  .about-spread {
    padding-inline: 1rem;
  }

  .about-spread__stage {
    min-height: 780px;
    gap: 2.5rem;
  }

  .about-spread__rail {
    gap: 0.3rem;
  }

  .about-spread__title {
    font-size: clamp(1.1rem, 0.96rem + 1vw, 1.8rem);
  }

  .about-spread__meta-primary {
    font-size: 0.52rem;
  }

  .about-spread__meta-secondary {
    font-size: 0.48rem;
  }

  .photography-feature {
    padding-bottom: 5.2rem;
  }

  .photography-feature__sheet {
    gap: 0.6rem;
  }

  .photography-feature__scene {
    min-height: clamp(500px, 66vw, 860px);
    perspective: 1440px;
  }

  .photography-feature__scene::before {
    inset: 1.8rem 0 3.6rem;
  }

  .photography-feature__scene::after {
    width: 90%;
    bottom: 8%;
  }

  .photography-feature__button {
    min-width: 92px;
    min-height: 40px;
    padding: 0.6rem 0.98rem;
    font-size: 0.66rem;
  }

  .photography-feature__title {
    font-size: clamp(1.52rem, 1.14rem + 1.8vw, 2.5rem);
  }

  .photo-archive__masthead {
    flex-direction: column;
    align-items: flex-start;
  }

  .photo-archive__chips {
    justify-content: flex-start;
  }

  .photo-archive__shell {
    padding: 0;
  }

  .photo-gallery.photo-gallery--research {
    grid-template-columns: repeat(8, minmax(0, 1fr));
    gap: 1.3rem;
  }

  .photo-gallery.photo-gallery--research .photo-gallery__item[data-photo-orientation="landscape"] {
    grid-column: span 3;
  }

  .photo-gallery.photo-gallery--research .photo-gallery__item[data-photo-orientation="portrait"],
  .photo-gallery.photo-gallery--research .photo-gallery__item[data-photo-orientation="square"] {
    grid-column: span 2;
  }

  .photo-gallery.photo-gallery--research .photo-gallery__item::before {
    left: -0.92rem;
    font-size: 0.72rem;
  }

  .photo-gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .page-main--archive-rail {
    padding: 6.9rem 0.7rem 0.9rem;
  }

  .page-main--photo-poster {
    padding: 6.8rem 0.7rem 0.7rem;
  }

  .photo-poster {
    min-height: auto;
  }

  .photo-poster__strip {
    justify-content: flex-start;
  }

  .photo-poster__item {
    flex-basis: clamp(158px, 28vw, 236px);
  }

  .photo-poster--graphic .photo-poster__item {
    flex-basis: clamp(138px, 22vw, 184px);
  }

  .photo-poster__editorial p {
    font-size: clamp(1.7rem, 4.6vw, 2.6rem);
  }

  .photo-poster__hero {
    padding-top: clamp(1.3rem, 3.6vw, 2.8rem);
    min-height: clamp(240px, 38vh, 460px);
  }

  .photo-poster__title {
    font-size: clamp(5.4rem, 30vw, 15rem);
    line-height: 0.74;
  }

  .photo-poster__title--photo {
    font-size: clamp(4.4rem, 25vw, 11.8rem);
  }

  .photo-poster__title--graphic {
    font-size: clamp(4.6rem, 18vw, 10.8rem);
  }

  .photo-poster__title--interactive {
    width: min(100%, 8.6ch);
    font-size: clamp(3.7rem, 14vw, 8.8rem);
  }

  .photo-poster__title--product {
    font-size: clamp(4.2rem, 18vw, 10.2rem);
  }

  .photo-poster__title--drawing {
    font-size: clamp(4.8rem, 25vw, 12.8rem);
  }

  .archive-rail-page {
    min-height: auto;
    align-content: start;
  }

  .archive-rail-page__header {
    grid-template-columns: 1fr;
  }

  .archive-rail-page__hint {
    justify-self: start;
  }

  .archive-rail__card {
    flex-basis: clamp(144px, 20vw, 190px);
  }

  .archive-rail__card--feature {
    flex-basis: clamp(250px, 34vw, 310px);
  }

  .page-main--graphic-editorial {
    padding: 6.8rem 0.55rem 0.75rem;
  }

  .graphic-project-top {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .graphic-project-top .project-detail__meta {
    justify-self: start;
    text-align: left;
  }

  .graphic-spreadbook__sheet {
    grid-template-columns: 1fr;
    background: #ffffff;
    min-height: auto;
  }

  .graphic-spreadbook__sheet::before {
    display: none;
  }

  .graphic-spreadbook__page--gallery {
    background: #050505;
    border-top: 0;
  }

  .graphic-spreadbook__facts,
  .graphic-spreadbook__body {
    grid-template-columns: 1fr;
  }

  .graphic-spreadbook__title {
    max-width: 12ch;
  }

  .graphic-gallery-board {
    width: 100%;
    grid-template-columns: 140px minmax(0, 1fr);
    gap: 1.1rem 1.4rem;
  }

  .graphic-gallery-grid {
    grid-template-columns: repeat(4, minmax(70px, 1fr));
    width: min(100%, 470px);
  }

  .graphic-project-notes__body {
    grid-template-columns: 1fr;
  }

  .graphic-project-facts {
    grid-template-columns: 1fr;
  }

  .graphic-gallery-title {
    font-size: clamp(2.6rem, 6vw, 4rem);
  }

  .home-work-network {
    padding: clamp(2.5rem, 4.2vw, 3.4rem) 0.95rem clamp(2.8rem, 4.2vw, 3.8rem);
  }

  .home-work-network__inner {
    width: min(100%, clamp(320px, 88vw, 900px));
  }

  .home-work-network__stage {
    width: min(100%, clamp(280px, 74vw, 760px));
    aspect-ratio: 18 / 10;
  }

  .home-work-network__title {
    width: min(42%, 7ch);
  }

  .home-work-network__link {
    max-width: clamp(4rem, 9.4vw, 6.8rem);
    font-size: clamp(0.62rem, 0.4rem + 0.72vw, 1.04rem);
  }
}

@media (max-width: 640px) {
  .site-header {
    padding:
      calc(0.9rem + var(--safe-top))
      calc(0.85rem + var(--safe-right))
      0.82rem
      calc(0.85rem + var(--safe-left));
    border-radius: 0;
  }

  .site-header__brand {
    font-size: clamp(1rem, 5.4vw, 1.38rem);
    letter-spacing: -0.035em;
  }

  .site-nav {
    gap: 0.45rem;
  }

  .site-nav a {
    font-size: 0.54rem;
    letter-spacing: 0.08em;
    padding: 0.34rem 0.58rem;
  }

  .site-menu-toggle {
    font-size: 0.56rem;
    letter-spacing: 0.1em;
  }

  .page-interactive-archive .site-header__section-title,
  .page-graphic-design-archive .site-header__section-title,
  .page-photo-archive .site-header__section-title,
  .page-product-archive .site-header__section-title,
  .page-my-work .site-header__section-title {
    font-size: 0.74rem;
    letter-spacing: 0.06em;
  }

  body.is-scrolled .site-header {
    padding:
      calc(0.74rem + var(--safe-top))
      calc(0.82rem + var(--safe-right))
      0.68rem
      calc(0.82rem + var(--safe-left));
    border-radius: 0 0 0.82rem 0.82rem;
  }

  body.is-scrolled .site-header__brand {
    font-size: clamp(0.96rem, 5vw, 1.22rem);
    letter-spacing: -0.03em;
  }

  body.is-scrolled .site-nav a {
    font-size: 0.52rem;
    letter-spacing: 0.08em;
    padding: 0.32rem 0.56rem;
  }

  .hero {
    padding-top: 6.6rem;
  }

  .about-spread {
    padding: 6.9rem 0.9rem 2.4rem;
  }

  .about-spread__stage {
    min-height: auto;
    gap: 1.8rem;
  }

  .about-spread__center {
    width: min(100%, 320px);
    gap: 0.42rem;
  }

  .about-spread__headline {
    gap: 0.5rem 1rem;
  }

  .about-spread__axis {
    font-size: 0.5rem;
  }

  .about-spread__title {
    font-size: clamp(0.94rem, 0.82rem + 1vw, 1.3rem);
    letter-spacing: 0.12em;
  }

  .about-spread__card {
    gap: 0.3rem;
  }

  .about-spread__rail {
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.46rem;
  }

  .about-spread__rail--top .about-spread__card:nth-child(2),
  .about-spread__rail--top .about-spread__card:nth-child(4),
  .about-spread__rail--bottom .about-spread__card:nth-child(2),
  .about-spread__rail--bottom .about-spread__card:nth-child(4) {
    margin-top: 0;
    margin-bottom: 0;
  }

  .about-spread__meta-primary {
    font-size: 0.46rem;
  }

  .about-spread__meta-secondary {
    font-size: 0.43rem;
  }

  .work-hub__center {
    top: 50%;
  }

  .work-hub__trigger {
    letter-spacing: -0.035em;
  }

  .page-my-work.is-work-menu-open .work-hub__trigger {
    transform: scale(0.5);
  }

  .work-hub__option {
    --option-ring-size: clamp(118px, 30vw, 160px);
    min-width: 0;
    max-width: min(45vw, 182px);
    padding: 0.68rem 0.76rem;
    line-height: 1.12;
    white-space: normal;
  }

  .work-hub__option-text {
    display: block;
    text-wrap: balance;
  }

  .feature-project {
    padding: 1rem 0.9rem 3.25rem;
  }

  .home-work-network {
    padding: 2.35rem 0.95rem clamp(2.6rem, 7vw, 3.3rem);
  }

  .home-work-network__inner {
    width: min(100%, 100%);
    gap: 0;
  }

  .home-work-network__title {
    width: min(46%, 6.8ch);
    padding: 0.26em 0.4em;
    font-size: clamp(1rem, 0.82rem + 0.92vw, 1.38rem);
  }

  .home-work-network__stage {
    width: min(100%, clamp(250px, 86vw, 420px));
    aspect-ratio: 16 / 10;
  }

  .home-work-network__link {
    max-width: clamp(3.6rem, 10.8vw, 4.9rem);
    font-size: clamp(0.54rem, 0.34rem + 0.86vw, 0.76rem);
    line-height: 0.94;
  }

  .photography-feature {
    padding: 0 0.95rem 4rem;
  }

  .photography-feature__sheet {
    gap: 0.52rem;
  }

  .photography-feature__kicker {
    font-size: 0.62rem;
  }

  .photography-feature__scene {
    min-height: clamp(440px, 100vw, 680px);
    perspective: 1040px;
  }

  .photography-feature__scene::before {
    inset: 1.2rem 0 2.4rem;
  }

  .photography-feature__scene::after {
    width: 94%;
    bottom: 9%;
  }

  .photography-feature__actions {
    gap: 0.38rem;
  }

  .photography-feature__button {
    min-width: 84px;
    min-height: 38px;
    padding: 0.56rem 0.88rem;
    font-size: 0.62rem;
    letter-spacing: 0.1em;
  }

  .photography-feature__title {
    font-size: clamp(1.28rem, 0.98rem + 1.6vw, 1.96rem);
  }

  .feature-project__logo {
    width: min(100%, 420px);
  }

  .feature-project__media {
    width: 100%;
  }

  .feature-project__copy {
    font-size: 0.94rem;
    line-height: 1.7;
  }

  .feature-project__button {
    width: min(100%, 280px);
    min-width: 0;
    min-height: 64px;
  }

  .feature-project__actions {
    width: min(100%, 280px);
    gap: 0.56rem;
  }

  .feature-project__actions .feature-project__button {
    width: 100%;
  }

  .page-main {
    padding: 6.8rem 0.95rem 2.4rem;
  }

  .page-main--archive-rail {
    padding: 6.45rem 0.35rem 0.45rem;
  }

  .page-main--photo-poster {
    padding: 6.35rem 0.35rem 0.35rem;
  }

  .page-main--graphic-editorial {
    padding: 6.45rem 0.35rem 0.5rem;
  }

  .page-back,
  .project-detail__back {
    --back-arrow-size: 2.82rem;
  }

  .page-back {
    margin-bottom: 1.25rem;
  }

  .project-detail__back {
    margin-bottom: 0.35rem;
  }

  .photo-poster {
    gap: 1rem;
  }

  .photo-poster__strip {
    gap: 0.55rem;
  }

  .photo-poster__item {
    flex-basis: calc(50vw - 0.55rem);
  }

  .photo-poster--graphic .photo-poster__item {
    flex-basis: calc(50vw - 0.75rem);
  }

  .photo-poster__item-index,
  .photo-poster__item-label,
  .photo-poster__stamp,
  .photo-poster__cta {
    font-size: 0.62rem;
  }

  .photo-poster__editorial {
    width: 100%;
  }

  .photo-poster__editorial p {
    font-size: clamp(1.45rem, 8.5vw, 2.1rem);
  }

  .photo-poster__editorial-line--accent {
    padding-left: 1.6rem;
  }

  .photo-poster__hero {
    padding-top: 1.2rem;
    min-height: 220px;
  }

  .photo-poster__title {
    font-size: clamp(4.9rem, 32vw, 9.8rem);
    line-height: 0.74;
  }

  .photo-poster__title--photo {
    font-size: clamp(3.7rem, 23vw, 7.4rem);
    letter-spacing: -0.1em;
  }

  .photo-poster__title--graphic {
    font-size: clamp(4rem, 18vw, 7.2rem);
  }

  .photo-poster__title--interactive {
    width: min(100%, 8.2ch);
    font-size: clamp(2.95rem, 14vw, 5.4rem);
    letter-spacing: -0.075em;
  }

  .photo-poster__title--product {
    font-size: clamp(3.4rem, 18vw, 6.2rem);
  }

  .photo-poster__title--drawing {
    font-size: clamp(3.8rem, 24vw, 7rem);
  }

  .archive-rail-page {
    gap: 0.85rem;
  }

  .archive-rail-page__title {
    font-size: clamp(1.45rem, 8.2vw, 2.2rem);
  }

  .archive-rail-page__subtitle {
    font-size: 0.74rem;
    line-height: 1.7;
  }

  .archive-rail__track {
    padding-inline: 0.7rem;
    gap: 0.72rem;
  }

  .archive-rail__card {
    flex-basis: 41vw;
  }

  .archive-rail__card--feature {
    flex-basis: min(72vw, 300px);
  }

  .archive-rail__caption-title {
    font-size: 0.66rem;
  }

  .graphic-spreadbook__page {
    padding: 0.9rem;
  }

  .graphic-spreadbook__headline {
    grid-template-columns: 1fr;
    gap: 0.55rem;
  }

  .graphic-spreadbook__number {
    font-size: clamp(2.2rem, 10vw, 3rem);
  }

  .graphic-spreadbook__title {
    font-size: clamp(1.8rem, 8vw, 2.6rem);
  }

  .graphic-spreadbook__gallery-head,
  .graphic-spreadbook__footer {
    flex-direction: column;
    align-items: flex-start;
  }

  .graphic-spreadbook__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.68rem;
  }

  .page-item {
    grid-template-columns: 1fr;
    gap: 0.5rem;
    padding: 1.1rem 0;
  }

  .page-subtitle {
    font-size: 0.78rem;
  }

  .catalog-card {
    min-height: 210px;
  }

  .photo-archive {
    padding-top: 5.4rem;
  }

  .photo-archive__shell {
    padding: 0;
  }

  .photo-archive__chip {
    min-height: 2.7rem;
    padding: 0.68rem 0.82rem;
    font-size: 0.6rem;
    letter-spacing: 0.1em;
  }

  .photo-gallery.photo-gallery--research {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.1rem;
  }

  .photo-gallery.photo-gallery--research .photo-gallery__item {
    width: min(100%, 94%);
    justify-self: center;
    grid-column: span 1;
  }

  .photo-gallery.photo-gallery--research .photo-gallery__item[data-photo-orientation="landscape"] {
    grid-column: span 2;
  }

  .photo-gallery.photo-gallery--research .photo-gallery__item::before {
    left: -0.82rem;
    bottom: 0.08rem;
    font-size: 0.62rem;
  }

  .photo-gallery {
    grid-template-columns: 1fr;
  }

  .graphic-gallery-bar {
    grid-template-columns: 1fr;
    justify-items: start;
    gap: 0.45rem;
  }

  .graphic-gallery-bar__label,
  .graphic-gallery-bar__link--action {
    justify-self: start;
  }

  .graphic-gallery-board {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto;
    min-height: auto;
    gap: 1rem;
  }

  .graphic-gallery-index {
    grid-column: 1;
    grid-row: 1;
    padding-top: 0;
    gap: 0.22rem;
  }

  .graphic-gallery-grid {
    grid-column: 1;
    grid-row: 2;
    justify-self: start;
    grid-template-columns: repeat(3, minmax(64px, 1fr));
    width: min(100%, 320px);
  }

  .graphic-gallery-title-block {
    grid-column: 1;
    grid-row: 3;
  }

  .graphic-gallery-arrow {
    grid-column: 1;
    grid-row: 4;
    justify-self: start;
  }

  .graphic-project-notes {
    padding: 1rem;
  }

  .photo-series-card {
    grid-template-columns: 1fr;
  }

  .photo-lightbox__image {
    max-width: 92vw;
    max-height: 78vh;
  }

  .photo-lightbox__nav {
    width: 2.5rem;
    height: 2.5rem;
    font-size: 1rem;
  }

  .photo-lightbox__nav--prev {
    left: 0.55rem;
  }

  .photo-lightbox__nav--next {
    right: 0.55rem;
  }
}

@media (max-width: 560px) {
  .site-header {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 0.34rem;
    padding-bottom: 0.64rem;
  }

  .site-nav {
    margin-left: 0;
    justify-content: center;
    flex-wrap: wrap;
    width: 100%;
    gap: 0.3rem 0.58rem;
  }

  .site-header.site-header--staggered-menu {
    display: flex;
    justify-content: space-between;
    justify-items: normal;
    gap: 0.42rem;
    width: 100%;
  }

  .site-header.site-header--staggered-menu .site-header__section-title {
    display: none;
  }

  .site-staggered-menu__layers,
  .site-staggered-menu__panel {
    width: 100%;
  }

  .site-nav a {
    font-size: clamp(0.5rem, 2.25vw, 0.62rem);
    letter-spacing: 0.07em;
    padding: 0.3rem 0.54rem;
  }

  body.is-scrolled .site-header {
    padding-bottom: 0.56rem;
  }

  body.is-scrolled .site-nav {
    transform: none;
  }

  body.is-scrolled .site-nav a {
    transform: none;
  }
}

@media (max-width: 420px) {
  .work-hub__option {
    --option-ring-size: clamp(96px, 31vw, 136px);
    max-width: min(44vw, 156px);
    padding: 0.58rem 0.62rem;
    font-size: clamp(0.7rem, 2.6vw, 0.86rem);
    letter-spacing: 0.1em;
  }

  .work-hub__trigger {
    font-size: min(var(--work-trigger-font-size), clamp(2rem, 11.2vw, 2.8rem));
    letter-spacing: -0.03em;
  }

  .site-footnote__inner {
    gap: 0.32rem 0.58rem;
  }

  .site-footnote__brand {
    width: 100%;
  }

  .photo-gallery.photo-gallery--research {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.92rem;
  }

  .photo-gallery.photo-gallery--research .photo-gallery__item::before {
    left: -0.74rem;
  }
}

@media (max-width: 380px) {
  .site-header {
    padding:
      calc(0.82rem + var(--safe-top))
      calc(0.72rem + var(--safe-right))
      0.76rem
      calc(0.72rem + var(--safe-left));
  }

  .site-header__brand {
    font-size: 0.92rem;
    letter-spacing: -0.028em;
  }

  .site-nav {
    gap: 0.34rem;
  }

  .site-nav a {
    font-size: 0.5rem;
    letter-spacing: 0.06em;
    padding: 0.28rem 0.48rem;
  }

  .site-menu-toggle {
    font-size: 0.52rem;
    letter-spacing: 0.1em;
  }

  body.is-scrolled .site-header {
    padding: 0.68rem 0.7rem 0.64rem;
  }

  body.is-scrolled .site-header__brand {
    font-size: 0.88rem;
    letter-spacing: -0.024em;
  }

  body.is-scrolled .site-nav a {
    font-size: 0.48rem;
    letter-spacing: 0.06em;
    padding: 0.26rem 0.46rem;
  }

  .page-heading {
    letter-spacing: 0.06em;
  }

  .about-spread__stage {
    gap: 2rem;
  }
}

.site-footnote {
  position: relative;
  z-index: 20;
  width: 100%;
  padding:
    0.96rem
    calc(var(--page-gutter) + var(--safe-right))
    calc(0.88rem + var(--safe-bottom))
    calc(var(--page-gutter) + var(--safe-left));
  border-top: 1px solid rgba(0, 0, 0, 0.08);
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(16px);
  box-shadow: 0 -12px 32px rgba(0, 0, 0, 0.05);
  opacity: 0;
  transform: translate3d(0, 14px, 0);
  animation: site-footnote-enter 620ms cubic-bezier(0.22, 1, 0.36, 1) 80ms forwards;
}

.site-footnote__inner {
  width: min(100%, 1200px);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: clamp(0.65rem, 1.4vw, 1.2rem);
  font-family: var(--font-sans);
  min-height: 1.12rem;
}

.site-footnote__brand {
  display: inline-block;
  flex: 0 0 auto;
  min-width: 0;
  font-size: clamp(0.84rem, 1.28vw, 1.06rem);
  font-weight: 620;
  letter-spacing: clamp(0.08em, 0.16vw, 0.14em);
  text-transform: none;
  white-space: nowrap;
  color: rgba(8, 8, 8, 0.88);
}

.site-footnote__nav {
  display: flex;
  flex: 0 0 auto;
  min-width: 0;
  align-items: center;
  justify-content: center;
  gap: clamp(0.52rem, 1.2vw, 0.88rem);
}

.site-footnote__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(1.75rem, 2.8vw, 2rem);
  height: clamp(1.75rem, 2.8vw, 2rem);
  padding: 0;
  border-radius: 0;
  color: rgba(10, 10, 10, 0.76);
  text-decoration: none;
  transition: opacity 220ms ease, transform 220ms ease, color 220ms ease, filter 220ms ease;
}

.site-footnote__icon {
  width: clamp(0.98rem, 1.42vw, 1.16rem);
  height: clamp(0.98rem, 1.42vw, 1.16rem);
  stroke: currentColor;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.8;
}

.site-footnote__link:hover,
.site-footnote__link:focus-visible {
  color: rgba(0, 0, 0, 0.96);
  opacity: 1;
  transform: translate3d(0, -1px, 0);
  filter: drop-shadow(0 4px 10px rgba(0, 0, 0, 0.14));
}

.site-footnote__link:focus-visible {
  outline: none;
}

@keyframes site-footnote-enter {
  from {
    opacity: 0;
    transform: translate3d(0, 14px, 0);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@media (max-width: 640px) {
  .site-footnote {
    padding:
      0.82rem
      calc(var(--page-gutter-tight) + var(--safe-right))
      calc(0.78rem + var(--safe-bottom))
      calc(var(--page-gutter-tight) + var(--safe-left));
  }

  .site-footnote__inner {
    gap: 0.42rem;
  }

  .site-footnote__brand {
    font-size: clamp(0.72rem, 3.2vw, 0.84rem);
    letter-spacing: clamp(0.06em, 0.12vw, 0.1em);
    white-space: normal;
    text-align: center;
  }

  .site-footnote__nav {
    gap: clamp(0.38rem, 2.2vw, 0.58rem);
  }

  .site-footnote__link {
    width: clamp(1.6rem, 7vw, 1.76rem);
    height: clamp(1.6rem, 7vw, 1.76rem);
  }

  .site-footnote__icon {
    width: clamp(0.88rem, 4vw, 1rem);
    height: clamp(0.88rem, 4vw, 1rem);
  }
}

/* Graphic Design direction */
.page-graphic-project {
  background: #020202;
  color: #f2f2f2;
}

.page-graphic-design-archive {
  background: #020202;
  color: #f2f2f2;
}

.page-graphic-project .site-header {
  background: #020202;
  --nav-pill-bg: rgba(236, 244, 255, 0.08);
  --nav-pill-border: rgba(201, 222, 255, 0.36);
  --nav-pill-fill: rgba(236, 244, 255, 0.94);
  --nav-pill-text: rgba(236, 244, 255, 0.9);
  --nav-pill-hover-text: #060d1b;
}

.page-graphic-project .site-header__brand {
  color: rgba(244, 244, 244, 0.9);
}

.page-graphic-project.is-scrolled .site-header {
  border-bottom-color: rgba(255, 255, 255, 0.16);
  background: rgba(2, 2, 2, 0.82);
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.52);
}

.page-graphic-design-archive .site-header {
  background: #020202;
  --nav-pill-bg: rgba(236, 244, 255, 0.08);
  --nav-pill-border: rgba(201, 222, 255, 0.36);
  --nav-pill-fill: rgba(236, 244, 255, 0.94);
  --nav-pill-text: rgba(236, 244, 255, 0.9);
  --nav-pill-hover-text: #060d1b;
  gap: clamp(0.65rem, 1.5vw, 1.25rem);
  padding:
    calc(1rem + var(--safe-top))
    calc(var(--page-gutter) + var(--safe-right))
    0.9rem
    calc(var(--page-gutter) + var(--safe-left));
}

.page-graphic-design-archive .site-header__brand {
  font-size: clamp(1.28rem, 2.45vw, 2.15rem);
  letter-spacing: -0.04em;
}

.page-graphic-design-archive .site-nav {
  gap: clamp(0.55rem, 1.2vw, 1rem);
}

.page-graphic-design-archive .site-header__brand {
  color: rgba(244, 244, 244, 0.9);
}

.page-graphic-design-archive .site-nav a {
  font-size: clamp(0.62rem, 0.54rem + 0.22vw, 0.8rem);
  letter-spacing: clamp(0.08em, 0.18vw, 0.13em);
}

.page-graphic-design-archive.is-scrolled .site-header {
  border-bottom-color: rgba(255, 255, 255, 0.16);
  background: rgba(2, 2, 2, 0.82);
  padding:
    calc(0.82rem + var(--safe-top))
    calc(var(--page-gutter-tight) + var(--safe-right))
    0.78rem
    calc(var(--page-gutter-tight) + var(--safe-left));
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.52);
}

.page-photo-archive.page-photo-tunnel-lite .site-header,
.page-photo-archive.page-photo-cinema .site-header,
.page-photo-archive.page-photo-tunnel .site-header {
  --nav-pill-bg: rgba(236, 244, 255, 0.08);
  --nav-pill-border: rgba(201, 222, 255, 0.36);
  --nav-pill-fill: rgba(236, 244, 255, 0.94);
  --nav-pill-text: rgba(236, 244, 255, 0.92);
  --nav-pill-hover-text: #060d1b;
}

.page-graphic-design-archive .page-main--photo-poster {
  position: relative;
  isolation: isolate;
  min-height: 100svh;
  height: auto;
  overflow-x: clip;
  overflow-y: visible;
  padding: clamp(7.2rem, 10.8vw, 8.8rem) clamp(0.4rem, 0.9vw, 0.82rem) clamp(10rem, 24vh, 18rem);
  background: #020202;
}

.page-graphic-design-archive .page-main--photo-poster::before,
.page-graphic-design-archive .page-main--photo-poster::after {
  content: "";
  position: absolute;
  inset: -14% -12%;
  pointer-events: none;
  z-index: 0;
}

.page-graphic-design-archive .page-main--photo-poster::before {
  background:
    repeating-linear-gradient(
      116deg,
      rgba(134, 185, 255, 0.2) 0 1px,
      rgba(134, 185, 255, 0) 1px 40px
    ),
    repeating-linear-gradient(
      -116deg,
      rgba(129, 229, 255, 0.14) 0 1px,
      rgba(129, 229, 255, 0) 1px 56px
    );
  opacity: 0.55;
  transform-origin: center;
  animation: graphic-archive-line-flow 19s linear infinite;
}

.page-graphic-design-archive .page-main--photo-poster::after {
  background:
    radial-gradient(120% 58% at 28% 20%, rgba(129, 176, 255, 0.22), rgba(129, 176, 255, 0)),
    radial-gradient(110% 64% at 70% 82%, rgba(109, 255, 235, 0.18), rgba(109, 255, 235, 0));
  opacity: 0.48;
  filter: blur(22px);
  animation: graphic-archive-aura-drift 14s ease-in-out infinite alternate;
}

.page-graphic-design-archive .photo-poster--graphic {
  position: relative;
  min-height: calc(100svh - clamp(5.6rem, 7.8vw, 6.4rem));
  height: auto;
  grid-template-rows: auto auto;
  gap: clamp(0.5rem, 0.9vw, 0.88rem);
  padding: clamp(0.64rem, 1.1vw, 0.98rem);
  border: 0;
  overflow: visible;
  background: transparent;
}

.page-graphic-design-archive .photo-poster--graphic::before,
.page-graphic-design-archive .photo-poster--graphic::after {
  position: absolute;
  font-family: var(--font-sans);
  font-style: normal;
  font-weight: 700;
  line-height: 0.84;
  letter-spacing: -0.08em;
  text-transform: uppercase;
  color: rgba(230, 232, 238, 0.18);
  pointer-events: none;
  user-select: none;
  z-index: 0;
  will-change: transform, opacity;
}

.page-graphic-design-archive .photo-poster--graphic::before {
  content: "Pongsant";
  top: clamp(-1.4rem, -2vw, -0.6rem);
  left: clamp(-0.6rem, -1vw, -0.2rem);
  font-size: clamp(4.8rem, 15vw, 13rem);
  animation: graphic-archive-word-float-a 12s ease-in-out infinite;
}

.page-graphic-design-archive .photo-poster--graphic::after {
  content: "Portfolio";
  right: clamp(-0.5rem, -0.7vw, -0.1rem);
  bottom: clamp(-1.2rem, -1.6vw, -0.4rem);
  font-size: clamp(4.4rem, 14vw, 12rem);
  animation: graphic-archive-word-float-b 14s ease-in-out infinite;
}

.page-graphic-design-archive .photo-poster--graphic > * {
  position: relative;
  z-index: 2;
}

.page-graphic-design-archive .photo-poster--graphic .photo-poster__top {
  gap: 0.45rem;
}

.page-graphic-design-archive .photo-poster--graphic .page-back::before {
  color: rgba(245, 245, 245, 0.86);
}

.page-graphic-design-archive .photo-poster--graphic .photo-poster__strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(0.45rem, 0.9vw, 0.72rem);
  align-items: start;
}

.page-graphic-design-archive .photo-poster--graphic .photo-poster__item {
  --poster-letter-ratio: 8.5 / 11;
  width: 100%;
  min-width: 0;
  gap: 0.32rem;
  flex: initial;
  justify-items: center;
  transition: transform 520ms cubic-bezier(0.2, 0.82, 0.22, 1), opacity 520ms ease;
  will-change: transform, opacity;
}

.page-graphic-design-archive .photo-poster--graphic .photo-poster__item[data-poster-orientation="landscape"] {
  --poster-letter-ratio: 11 / 8.5;
}

.page-graphic-design-archive .photo-poster--graphic .photo-poster__item:hover,
.page-graphic-design-archive .photo-poster--graphic .photo-poster__item:focus-visible {
  transform: translateY(-4px);
}

.page-graphic-design-archive .photo-poster--graphic .photo-poster__item.is-scroll-reveal {
  opacity: 0;
  transform: translate3d(0, 20px, 0) scale(0.97);
  transition-delay: var(--reveal-delay, 0ms);
}

.page-graphic-design-archive .photo-poster--graphic .photo-poster__item.is-scroll-reveal.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

.page-graphic-design-archive .photo-poster--graphic .photo-poster__item-media {
  width: min(100%, clamp(92px, 11vw, 176px));
  aspect-ratio: var(--poster-letter-ratio, 8.5 / 11);
  height: auto;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 0;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: #080808;
  box-shadow: 0 16px 26px rgba(0, 0, 0, 0.45);
}

.page-graphic-design-archive .photo-poster--graphic .photo-poster__item[data-poster-orientation="landscape"] .photo-poster__item-media {
  width: min(100%, clamp(98px, 12.4vw, 214px));
}

.page-graphic-design-archive .photo-poster--graphic .photo-poster__item-media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  border-radius: 0;
  filter: none;
  transition: transform 260ms ease, filter 260ms ease;
}

.page-graphic-design-archive .photo-poster--graphic .photo-poster__item:hover .photo-poster__item-media img,
.page-graphic-design-archive .photo-poster--graphic .photo-poster__item:focus-visible .photo-poster__item-media img {
  transform: scale(1.04);
  filter: saturate(1.08) contrast(1.04);
}

.page-graphic-design-archive .photo-poster--graphic .photo-poster__item-index,
.page-graphic-design-archive .photo-poster--graphic .photo-poster__item-label {
  color: rgba(240, 240, 240, 0.82);
}

.page-graphic-design-archive .photo-poster--graphic .photo-poster__hero {
  min-height: clamp(88px, 15vh, 164px);
  padding-top: clamp(0.08rem, 0.35vw, 0.24rem);
}

.page-graphic-design-archive .photo-poster--graphic .photo-poster__title--graphic {
  max-width: none;
  font-family: var(--font-sans);
  font-size: clamp(2.6rem, 8.8vw, 6.6rem);
  font-weight: 700;
  color: rgba(236, 238, 242, 0.2);
  letter-spacing: -0.085em;
  animation: graphic-archive-title-pulse 9s ease-in-out infinite;
}

@keyframes graphic-archive-word-float-a {
  0% {
    transform: translate3d(0, 0, 0) rotate(-1deg);
    opacity: 0.2;
  }

  50% {
    transform: translate3d(14px, -10px, 0) rotate(-2.2deg);
    opacity: 0.3;
  }

  100% {
    transform: translate3d(-8px, 8px, 0) rotate(-0.6deg);
    opacity: 0.22;
  }
}

@keyframes graphic-archive-word-float-b {
  0% {
    transform: translate3d(0, 0, 0) rotate(0.6deg);
    opacity: 0.2;
  }

  50% {
    transform: translate3d(-12px, 8px, 0) rotate(1.8deg);
    opacity: 0.28;
  }

  100% {
    transform: translate3d(10px, -10px, 0) rotate(0.2deg);
    opacity: 0.22;
  }
}

@keyframes graphic-archive-line-flow {
  0% {
    transform: translate3d(0, 0, 0) rotate(0deg) scale(1.02);
  }

  50% {
    transform: translate3d(-2.5%, 2.2%, 0) rotate(0.35deg) scale(1.04);
  }

  100% {
    transform: translate3d(2.8%, -2.4%, 0) rotate(-0.35deg) scale(1.02);
  }
}

@keyframes graphic-archive-aura-drift {
  0% {
    transform: translate3d(-1.8%, -1%, 0) scale(1);
  }

  100% {
    transform: translate3d(2.2%, 1.8%, 0) scale(1.06);
  }
}

@keyframes graphic-archive-card-in {
  from {
    opacity: 0;
    transform: translate3d(0, 20px, 0) scale(0.96);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@keyframes graphic-archive-title-pulse {
  0%,
  100% {
    opacity: 0.72;
    letter-spacing: -0.085em;
  }

  50% {
    opacity: 1;
    letter-spacing: -0.078em;
  }
}

.page-graphic-project .page-main--graphic-editorial {
  min-height: 100svh;
  height: auto;
  overflow: visible;
  padding: clamp(6.2rem, 8.8vw, 7.1rem) clamp(0.45rem, 0.9vw, 0.85rem) clamp(2rem, 5.2vw, 3.2rem);
  background: #020202;
}

.page-graphic-project .project-detail__back::before {
  color: rgba(245, 245, 245, 0.86);
}

.page-graphic-project .graphic-spreadbook {
  height: auto;
  min-height: 0;
  grid-template-rows: auto auto;
  gap: clamp(0.32rem, 0.8vw, 0.62rem);
  position: relative;
  isolation: isolate;
}

.page-graphic-project .graphic-spreadbook::before,
.page-graphic-project .graphic-spreadbook::after {
  position: absolute;
  font-weight: 700;
  line-height: 0.84;
  letter-spacing: -0.08em;
  text-transform: uppercase;
  color: rgba(228, 232, 238, 0.12);
  pointer-events: none;
  user-select: none;
  z-index: 0;
}

.page-graphic-project .graphic-spreadbook::before {
  content: "Pongsant";
  top: clamp(-1.2rem, -2vw, -0.4rem);
  left: clamp(-0.8rem, -0.9vw, -0.2rem);
  font-size: clamp(5rem, 14vw, 13.5rem);
}

.page-graphic-project .graphic-spreadbook::after {
  content: "Portfolio";
  right: clamp(-0.6rem, -0.7vw, -0.1rem);
  bottom: clamp(-1.3rem, -1.8vw, -0.6rem);
  font-size: clamp(4.8rem, 13.5vw, 12.5rem);
}

.page-graphic-project .graphic-project-top,
.page-graphic-project .graphic-spreadbook__sheet {
  position: relative;
  z-index: 1;
}

.page-graphic-project .graphic-project-top {
  gap: 0.35rem 0.8rem;
}

.page-graphic-project .graphic-project-top .project-detail__meta {
  color: rgba(255, 255, 255, 0.62);
}

.page-graphic-project .graphic-spreadbook__sheet {
  height: auto;
  min-height: max(760px, calc(100svh - clamp(8.6rem, 11vw, 10rem)));
  border: 1px solid rgba(255, 255, 255, 0.14);
  overflow: visible;
  background:
    linear-gradient(118deg, rgba(255, 255, 255, 0.05) 0%, rgba(255, 255, 255, 0.01) 34%, rgba(255, 255, 255, 0) 58%),
    #050505;
}

.page-graphic-project .graphic-spreadbook__page {
  min-height: 0;
  padding: clamp(0.68rem, 1.15vw, 1rem);
}

.page-graphic-project .graphic-spreadbook__page--intro {
  gap: clamp(0.55rem, 1vw, 0.9rem);
  background: #0f1013;
}

.page-graphic-project .graphic-spreadbook__page--gallery {
  grid-template-rows: auto auto auto;
  align-content: start;
  gap: clamp(0.55rem, 1vw, 0.9rem);
  background: #030303;
  border-left: 1px solid rgba(255, 255, 255, 0.1);
}

.page-graphic-project .graphic-spreadbook__kicker,
.page-graphic-project .graphic-spreadbook__eyebrow,
.page-graphic-project .graphic-spreadbook__gallery-label {
  color: rgba(255, 255, 255, 0.52);
}

.page-graphic-project .graphic-spreadbook__number,
.page-graphic-project .graphic-spreadbook__title {
  color: rgba(245, 245, 245, 0.92);
}

.page-graphic-project .graphic-spreadbook__fact {
  border-top-color: rgba(255, 255, 255, 0.22);
}

.page-graphic-project .graphic-spreadbook__fact-label {
  color: rgba(255, 255, 255, 0.56);
}

.page-graphic-project .graphic-spreadbook__fact-value,
.page-graphic-project .graphic-spreadbook__body p {
  color: rgba(245, 245, 245, 0.8);
  font-size: clamp(0.88rem, 0.82rem + 0.32vw, 1rem);
  line-height: 1.64;
}

.page-graphic-project .graphic-spreadbook__topic-title {
  color: rgba(250, 252, 255, 0.95);
}

.page-graphic-project .graphic-spreadbook__facts,
.page-graphic-project .graphic-spreadbook__body {
  gap: clamp(0.44rem, 0.75vw, 0.66rem);
}

.page-graphic-project .graphic-spreadbook__footer {
  border-top-color: rgba(255, 255, 255, 0.22);
  color: rgba(255, 255, 255, 0.62);
}

.page-graphic-project .graphic-spreadbook__footer--right span:first-child {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: clamp(0.72rem, 0.64rem + 0.42vw, 0.96rem);
  font-weight: 700;
  letter-spacing: 0.2em;
  color: rgba(236, 246, 255, 0.95);
  text-shadow:
    0 0 0 rgba(150, 212, 255, 0),
    0 0 0 rgba(255, 255, 255, 0);
  animation: graphic-click-photo-glow 2.4s ease-in-out infinite;
}

@keyframes graphic-click-photo-glow {
  0%,
  100% {
    opacity: 0.72;
    transform: translateY(0) scale(1);
    text-shadow:
      0 0 0 rgba(150, 212, 255, 0),
      0 0 0 rgba(255, 255, 255, 0);
  }

  50% {
    opacity: 1;
    transform: translateY(-1px) scale(1.05);
    text-shadow:
      0 0 12px rgba(150, 212, 255, 0.34),
      0 0 5px rgba(255, 255, 255, 0.42);
  }
}

.page-graphic-project .graphic-spreadbook__grid {
  grid-template-columns: repeat(6, minmax(0, 1fr));
  grid-auto-rows: minmax(72px, 1fr);
  gap: clamp(0.65rem, 1.1vw, 0.92rem);
}

.page-graphic-project .graphic-spreadbook__grid > * {
  min-width: 0;
}

.page-graphic-project .graphic-spreadbook__item {
  display: block;
  height: 100%;
  min-height: 140px;
}

.page-graphic-project .graphic-spreadbook__item--pdf {
  cursor: pointer;
  text-decoration: none;
}

.page-graphic-project .graphic-spreadbook__pdf {
  display: block;
  width: 100%;
  height: 100%;
  min-height: clamp(340px, 56vh, 760px);
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: #ffffff;
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.55);
}

.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-split {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: minmax(220px, 1fr);
  gap: clamp(0.62rem, 1.05vw, 0.88rem);
}

.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-split .graphic-spreadbook__item {
  grid-column: auto;
  grid-row: auto;
  min-height: 0;
  display: grid;
  gap: 0.44rem;
  padding: 0.42rem;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.03);
  text-decoration: none;
}

.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-split .graphic-spreadbook__item:nth-child(1),
.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-split .graphic-spreadbook__item:nth-child(2),
.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-split .graphic-spreadbook__item:nth-child(3),
.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-split .graphic-spreadbook__item:nth-child(4),
.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-split .graphic-spreadbook__item:nth-child(5),
.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-split .graphic-spreadbook__item:nth-child(6) {
  grid-column: auto;
  grid-row: auto;
}

.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-split .graphic-spreadbook__pdf,
.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-split .graphic-spreadbook__image {
  width: 100%;
  height: 100%;
  min-height: clamp(320px, 54vh, 720px);
  object-fit: contain;
  background: #ffffff;
  border: 1px solid rgba(255, 255, 255, 0.24);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.56);
  filter: none;
}

.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-split .graphic-spreadbook__item:hover .graphic-spreadbook__image,
.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-split .graphic-spreadbook__item:focus-visible .graphic-spreadbook__image {
  filter: none;
}

.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-topics {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: auto;
  gap: clamp(0.72rem, 1.2vw, 1rem);
}

.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-topics .graphic-spreadbook__item {
  grid-column: auto;
  grid-row: auto;
}

.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-topics .graphic-spreadbook__item--branding-topic {
  position: relative;
  min-height: clamp(260px, 48vh, 620px);
  padding: 0.45rem;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.04);
}

.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-topics .graphic-spreadbook__item--branding-topic .graphic-spreadbook__image {
  width: 100%;
  height: 100%;
  min-height: clamp(240px, 44vh, 560px);
  object-fit: contain;
  background: #0a0b0d;
  filter: none;
}

.page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-topics .graphic-spreadbook__item--hidden-trigger {
  display: none !important;
}

.page-graphic-project .graphic-spreadbook__body--branding-topics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(0.5rem, 1vw, 0.8rem);
}

.page-graphic-project .graphic-spreadbook__branding-caption {
  font-size: 0.74rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: rgba(246, 248, 252, 0.9);
}

@media (max-width: 900px) {
  .page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-split {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
  }

  .page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-split .graphic-spreadbook__pdf,
  .page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-split .graphic-spreadbook__image {
    min-height: clamp(260px, 52vh, 560px);
  }

  .page-graphic-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-topics {
    grid-template-columns: 1fr;
  }

  .page-graphic-project .graphic-spreadbook__body--branding-topics {
    grid-template-columns: 1fr;
  }
}

.page-graphic-project .graphic-spreadbook__item:nth-child(1) {
  grid-column: span 3;
  grid-row: span 4;
}

.page-graphic-project .graphic-spreadbook__item:nth-child(2) {
  grid-column: span 2;
  grid-row: span 2;
}

.page-graphic-project .graphic-spreadbook__item:nth-child(3) {
  grid-column: span 1;
  grid-row: span 2;
}

.page-graphic-project .graphic-spreadbook__item:nth-child(4) {
  grid-column: span 2;
  grid-row: span 3;
}

.page-graphic-project .graphic-spreadbook__item:nth-child(5) {
  grid-column: span 2;
  grid-row: span 2;
}

.page-graphic-project .graphic-spreadbook__item:nth-child(6) {
  grid-column: span 1;
  grid-row: span 3;
}

.page-graphic-project .graphic-spreadbook__image {
  height: 100%;
  object-fit: cover;
  border-radius: 0;
  border: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.55);
  filter: grayscale(100%) contrast(1.08);
}

.page-graphic-project .graphic-spreadbook__item:hover .graphic-spreadbook__image,
.page-graphic-project .graphic-spreadbook__item:focus-visible .graphic-spreadbook__image {
  filter: grayscale(24%) contrast(1.1);
}

.page-graphic-project .graphic-spreadbook__statement {
  grid-column: span 3;
  grid-row: span 2;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: linear-gradient(150deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02)), #0f1012;
  color: rgba(250, 250, 250, 0.84);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.5);
}

.page-graphic-project .graphic-spreadbook__grid--spotlight {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(0.72rem, 1.2vw, 1rem);
  align-items: stretch;
  min-height: 0;
}

.page-graphic-project .graphic-spreadbook__grid--spotlight .graphic-spreadbook__item {
  grid-column: auto;
  grid-row: auto;
}

.page-graphic-project .graphic-spreadbook__grid--spotlight .graphic-spreadbook__statement {
  display: none;
}

.page-graphic-project .graphic-spreadbook__spotlight-main {
  min-width: 0;
  min-height: 0;
}

.page-graphic-project .graphic-spreadbook__spotlight-main .graphic-spreadbook__item {
  width: 100%;
  min-height: clamp(420px, 72vh, 980px);
  height: clamp(420px, 72vh, 980px);
}

.page-graphic-project .graphic-spreadbook__spotlight-main .graphic-spreadbook__image {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  border-radius: 0;
  background: #0a0b0d;
  border: 1px solid rgba(255, 255, 255, 0.24);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.64);
  filter: none;
}

.page-graphic-project .graphic-spreadbook__spotlight-thumbs {
  display: none;
}

.page-graphic-project .graphic-spreadbook__spotlight-thumbs .graphic-spreadbook__item {
  width: 100%;
  min-height: 0;
  height: 100%;
  opacity: 0;
  transform: translateY(18px) scale(0.94);
  transform-origin: center;
  transition:
    opacity 360ms ease,
    transform 460ms cubic-bezier(0.2, 0.86, 0.22, 1),
    filter 260ms ease;
  transition-delay: var(--spotlight-delay, 0ms);
}

.page-graphic-project .graphic-spreadbook__spotlight-thumbs .graphic-spreadbook__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0;
  background: #101217;
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.5);
  filter: grayscale(28%) contrast(1.05);
}

.page-graphic-project .graphic-spreadbook__spotlight-thumbs .graphic-spreadbook__item:hover .graphic-spreadbook__image,
.page-graphic-project .graphic-spreadbook__spotlight-thumbs .graphic-spreadbook__item:focus-visible .graphic-spreadbook__image {
  filter: grayscale(0%) contrast(1.08);
}

.page-graphic-project .graphic-spreadbook__grid--spotlight.is-single {
  grid-template-columns: 1fr;
}

.page-graphic-project .graphic-spreadbook__grid--spotlight.is-single .graphic-spreadbook__spotlight-thumbs {
  display: none;
}

.page-graphic-project .photo-lightbox::backdrop {
  background: rgba(0, 0, 0, 0.9);
  backdrop-filter: blur(6px);
}

.page-graphic-project .photo-lightbox__close,
.page-graphic-project .photo-lightbox__caption {
  color: rgba(245, 245, 245, 0.84);
}

.page-graphic-project .photo-lightbox__thumb {
  border-color: rgba(255, 255, 255, 0.24);
  background: rgba(255, 255, 255, 0.04);
}

.page-graphic-project .photo-lightbox__thumb.is-active {
  border-color: rgba(255, 255, 255, 0.9);
}

.page-graphic-project .photo-lightbox__thumb-image {
  background: #050505;
}

/* Product project white direction */
.page-graphic-project.page-product-project {
  background: #ffffff;
  color: #050505;
}

.page-graphic-project.page-product-project .site-header {
  background: #ffffff;
  --nav-pill-bg: rgba(5, 5, 5, 0.06);
  --nav-pill-border: rgba(5, 5, 5, 0.18);
  --nav-pill-fill: #06080f;
  --nav-pill-text: rgba(5, 5, 5, 0.9);
  --nav-pill-hover-text: #f7fbff;
}

.page-graphic-project.page-product-project .site-header__brand {
  color: rgba(5, 5, 5, 0.9);
}

.page-graphic-project.page-product-project.is-scrolled .site-header {
  border-bottom-color: rgba(0, 0, 0, 0.1);
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.08);
}

.page-graphic-project.page-product-project .page-main--graphic-editorial {
  background: #ffffff;
}

.page-graphic-project.page-product-project .project-detail__back::before {
  color: rgba(5, 5, 5, 0.9);
}

.page-graphic-project.page-product-project .graphic-spreadbook::before,
.page-graphic-project.page-product-project .graphic-spreadbook::after {
  color: rgba(5, 5, 5, 0.08);
}

.page-graphic-project.page-product-project .graphic-project-top .project-detail__meta {
  color: rgba(5, 5, 5, 0.46);
}

.page-graphic-project.page-product-project .graphic-spreadbook__sheet {
  border: 1px solid rgba(0, 0, 0, 0.14);
  background: #ffffff;
}

.page-graphic-project.page-product-project .graphic-spreadbook__page--intro,
.page-graphic-project.page-product-project .graphic-spreadbook__page--gallery {
  background: #ffffff;
}

.page-graphic-project.page-product-project .graphic-spreadbook__page--gallery {
  border-left: 1px solid rgba(0, 0, 0, 0.1);
}

.page-graphic-project.page-product-project .graphic-spreadbook__kicker,
.page-graphic-project.page-product-project .graphic-spreadbook__eyebrow,
.page-graphic-project.page-product-project .graphic-spreadbook__gallery-label {
  color: rgba(0, 0, 0, 0.54);
}

.page-graphic-project.page-product-project .graphic-spreadbook__number,
.page-graphic-project.page-product-project .graphic-spreadbook__title,
.page-graphic-project.page-product-project .graphic-spreadbook__topic-title {
  color: rgba(5, 5, 5, 0.94);
}

.page-graphic-project.page-product-project .graphic-spreadbook__fact {
  border-top-color: rgba(0, 0, 0, 0.14);
}

.page-graphic-project.page-product-project .graphic-spreadbook__fact-label {
  color: rgba(0, 0, 0, 0.52);
}

.page-graphic-project.page-product-project .graphic-spreadbook__fact-value,
.page-graphic-project.page-product-project .graphic-spreadbook__body p {
  color: rgba(5, 5, 5, 0.78);
}

.page-graphic-project.page-product-project .graphic-spreadbook__footer {
  border-top-color: rgba(0, 0, 0, 0.14);
  color: rgba(0, 0, 0, 0.58);
}

.page-graphic-project.page-product-project .graphic-spreadbook__footer--right span:first-child {
  color: rgba(5, 5, 5, 0.88);
  text-shadow: none;
  animation: none;
}

.page-graphic-project.page-product-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-topics .graphic-spreadbook__item--branding-topic {
  border: 1px solid rgba(0, 0, 0, 0.14);
  background: #ffffff;
}

.page-graphic-project.page-product-project .graphic-spreadbook__grid.graphic-spreadbook__grid--branding-topics .graphic-spreadbook__item--branding-topic .graphic-spreadbook__image {
  background: #ffffff;
}

.page-graphic-project.page-product-project .graphic-spreadbook__branding-caption {
  color: rgba(5, 5, 5, 0.82);
}

.page-graphic-project.page-product-project .graphic-spreadbook__image,
.page-graphic-project.page-product-project .graphic-spreadbook__spotlight-main .graphic-spreadbook__image,
.page-graphic-project.page-product-project .graphic-spreadbook__spotlight-thumbs .graphic-spreadbook__image {
  border: 1px solid rgba(0, 0, 0, 0.16);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.15);
  filter: none;
}

.page-graphic-project.page-product-project .graphic-spreadbook__item:hover .graphic-spreadbook__image,
.page-graphic-project.page-product-project .graphic-spreadbook__item:focus-visible .graphic-spreadbook__image,
.page-graphic-project.page-product-project .graphic-spreadbook__spotlight-thumbs .graphic-spreadbook__item:hover .graphic-spreadbook__image,
.page-graphic-project.page-product-project .graphic-spreadbook__spotlight-thumbs .graphic-spreadbook__item:focus-visible .graphic-spreadbook__image {
  filter: none;
}

.interactive-work-showcase {
  display: grid;
  gap: clamp(0.72rem, 1.2vw, 1rem);
  align-content: start;
}

.interactive-work-showcase__video {
  width: 100%;
  min-height: clamp(300px, 50vh, 680px);
  border: 1px solid rgba(0, 0, 0, 0.16);
  background: #ffffff;
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.15);
}

.interactive-work-showcase__image {
  width: 100%;
  height: clamp(300px, 50vh, 680px);
  border: 1px solid rgba(0, 0, 0, 0.16);
  background: #ffffff;
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.15);
  object-fit: contain;
}

.interactive-work-showcase__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.6rem;
  width: fit-content;
  padding: 0.65rem 1rem;
  border: 1px solid rgba(0, 0, 0, 0.2);
  font-family: var(--font-sans);
  font-size: clamp(0.72rem, 0.66rem + 0.22vw, 0.84rem);
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: rgba(5, 5, 5, 0.9);
  background: #ffffff;
  transition: transform 220ms ease, background-color 220ms ease, color 220ms ease;
}

.interactive-work-showcase__link:hover,
.interactive-work-showcase__link:focus-visible {
  transform: translateY(-1px);
  background: #050505;
  color: #ffffff;
}

@media (max-width: 1080px) {
  .page-graphic-design-archive .photo-poster--graphic .photo-poster__strip {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .page-graphic-project .graphic-spreadbook__grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    grid-auto-rows: minmax(94px, 1fr);
  }

  .page-graphic-project .graphic-spreadbook__item:nth-child(1) {
    grid-column: span 2;
    grid-row: span 3;
  }

  .page-graphic-project .graphic-spreadbook__item:nth-child(2),
  .page-graphic-project .graphic-spreadbook__item:nth-child(3),
  .page-graphic-project .graphic-spreadbook__item:nth-child(4),
  .page-graphic-project .graphic-spreadbook__item:nth-child(5),
  .page-graphic-project .graphic-spreadbook__item:nth-child(6) {
    grid-column: span 2;
    grid-row: span 2;
  }

  .page-graphic-project .graphic-spreadbook__statement {
    grid-column: span 2;
    grid-row: span 2;
  }

  .page-graphic-project .graphic-spreadbook__spotlight-main .graphic-spreadbook__item {
    min-height: clamp(340px, 64vh, 760px);
    height: clamp(340px, 64vh, 760px);
  }
}

@media (max-width: 760px) {
  .page-graphic-design-archive .photo-poster--graphic .photo-poster__strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .page-graphic-design-archive .page-main--photo-poster {
    height: auto;
    overflow: visible;
  }

  .page-graphic-project .page-main--graphic-editorial {
    height: auto;
    overflow: visible;
  }

  .page-graphic-design-archive .photo-poster--graphic {
    padding: 0.7rem;
  }

  .page-graphic-project .graphic-spreadbook::before,
  .page-graphic-project .graphic-spreadbook::after,
  .page-graphic-design-archive .photo-poster--graphic::before,
  .page-graphic-design-archive .photo-poster--graphic::after {
    font-size: clamp(3.7rem, 24vw, 6.6rem);
  }

  .page-graphic-project .graphic-spreadbook__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-auto-rows: minmax(96px, 1fr);
  }

  .page-graphic-project .graphic-spreadbook__item:nth-child(1) {
    grid-column: span 2;
    grid-row: span 3;
  }

  .page-graphic-project .graphic-spreadbook__item:nth-child(2),
  .page-graphic-project .graphic-spreadbook__item:nth-child(3),
  .page-graphic-project .graphic-spreadbook__item:nth-child(4),
  .page-graphic-project .graphic-spreadbook__item:nth-child(5),
  .page-graphic-project .graphic-spreadbook__item:nth-child(6) {
    grid-column: span 1;
    grid-row: span 2;
  }

  .page-graphic-project .graphic-spreadbook__statement {
    grid-column: span 3;
    grid-row: span 1;
    aspect-ratio: auto;
    min-height: 84px;
  }

  .photo-lightbox__thumb-strip {
    grid-auto-columns: clamp(3.8rem, 19vw, 5.4rem);
  }

  .page-graphic-project .graphic-spreadbook__spotlight-main .graphic-spreadbook__item {
    min-height: clamp(280px, 56vh, 620px);
    height: clamp(280px, 56vh, 620px);
  }
}

body.page-graphic-design-archive.is-graphic-archive-popup-open {
  overflow-x: hidden;
}

.page-graphic-design-archive {
  background: #000000;
  overflow-x: hidden;
}

.page-graphic-design-archive .page-main--photo-poster {
  background: #000000;
  overflow-x: visible;
}

.page-graphic-design-archive .graphic-archive-particle-canvas {
  position: absolute;
  left: 0;
  top: 0;
  width: 0;
  height: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 1;
  mix-blend-mode: screen;
}

.page-graphic-design-archive .page-main--photo-poster > :not(.graphic-archive-particle-canvas) {
  position: relative;
  z-index: 1;
}

.page-graphic-design-archive .page-main--photo-poster::before,
.page-graphic-design-archive .page-main--photo-poster::after {
  content: none;
}

.page-graphic-design-archive .photo-poster--graphic.photo-poster--graphic-board {
  width: min(98vw, 1140px);
  margin-inline: auto;
  min-height: calc(100svh - clamp(6.1rem, 8.6vw, 7rem));
  height: auto;
  grid-template-rows: auto auto minmax(0, 1fr);
  align-content: center;
  justify-items: center;
  gap: clamp(0.3rem, 1.2vh, 0.9rem);
  padding: clamp(0.24rem, 0.9vw, 0.6rem);
  position: relative;
  margin-top: clamp(0.8rem, 1.8vh, 1.5rem);
}

.page-graphic-design-archive .photo-poster--graphic.photo-poster--graphic-board::before,
.page-graphic-design-archive .photo-poster--graphic.photo-poster--graphic-board::after {
  content: none;
}

.page-graphic-design-archive .photo-poster--graphic.photo-poster--graphic-board .photo-poster__top {
  position: absolute;
  top: clamp(0.08rem, 0.45vh, 0.32rem);
  left: clamp(0.16rem, 0.65vw, 0.46rem);
  width: auto;
  z-index: 6;
  gap: 0;
}

.page-graphic-design-archive .photo-poster--graphic.photo-poster--graphic-board .photo-poster__top .page-back {
  margin: 0;
}

.page-graphic-design-archive .graphic-archive-board {
  order: 3;
  position: relative;
  align-self: center;
  justify-self: center;
  width: min(84vw, 74svh, 730px);
  max-width: 100%;
  aspect-ratio: 1 / 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-template-rows: repeat(3, minmax(0, 1fr));
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: #000000;
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.46);
}

.page-graphic-design-archive .graphic-archive-board__tile {
  position: relative;
  margin: 0;
  padding: 0;
  border: 0;
  border-right: 1px solid rgba(255, 255, 255, 0.16);
  border-bottom: 1px solid rgba(255, 255, 255, 0.16);
  background: #000000;
  color: #f2f4f8;
  overflow: hidden;
  text-align: left;
  cursor: pointer;
  transition: transform 250ms ease, box-shadow 250ms ease, filter 250ms ease;
}

.page-graphic-design-archive .graphic-archive-board__tile:nth-child(3n) {
  border-right: 0;
}

.page-graphic-design-archive .graphic-archive-board__tile:nth-last-child(-n+3) {
  border-bottom: 0;
}

.page-graphic-design-archive .graphic-archive-board__tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.02) contrast(1.05);
  transition: transform 280ms ease, filter 280ms ease;
}

.page-graphic-design-archive .graphic-archive-board__tile::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(4, 7, 16, 0.84) 0%,
    rgba(4, 7, 16, 0.42) 28%,
    rgba(4, 7, 16, 0) 64%
  );
}

.page-graphic-design-archive .graphic-archive-board__label {
  position: absolute;
  left: 0.55rem;
  right: 0.55rem;
  bottom: 0.5rem;
  z-index: 2;
  font-size: clamp(0.55rem, 0.8vw, 0.72rem);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  line-height: 1.2;
}

.page-graphic-design-archive .graphic-archive-board__tile:hover,
.page-graphic-design-archive .graphic-archive-board__tile:focus-visible {
  transform: scale(1.02);
  z-index: 2;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.36);
}

.page-graphic-design-archive .graphic-archive-board__tile:hover img,
.page-graphic-design-archive .graphic-archive-board__tile:focus-visible img {
  transform: scale(1.05);
  filter: saturate(1.1) contrast(1.08);
}

.page-graphic-design-archive .photo-poster--graphic.photo-poster--graphic-board .photo-poster__hero {
  order: 2;
  width: 100%;
  min-height: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0;
  margin-bottom: clamp(0.14rem, 0.54vh, 0.44rem);
  text-align: center;
}

.page-graphic-design-archive .photo-poster--graphic.photo-poster--graphic-board .photo-poster__title--graphic {
  color: rgba(246, 248, 252, 0.92);
  font-size: clamp(1.7rem, 4.4vw, 3.3rem);
  font-weight: 800;
  letter-spacing: -0.05em;
  line-height: 0.9;
  animation: none;
}

.page-graphic-design-archive .graphic-archive-popup {
  position: fixed;
  inset: 0;
  margin: auto;
  width: min(96vw, 1120px);
  max-height: 88svh;
  border: 0;
  padding: 0;
  background: transparent;
  color: #f2f4f8;
}

.page-graphic-design-archive .graphic-archive-popup::backdrop {
  background: rgba(0, 0, 0, 0.74);
  backdrop-filter: blur(5px);
}

.page-graphic-design-archive .graphic-archive-popup__panel {
  border: 1px solid rgba(255, 255, 255, 0.24);
  background: #000000;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.58);
  padding: clamp(0.7rem, 1.2vw, 1rem);
  animation: graphic-archive-popup-in 320ms cubic-bezier(0.2, 0.82, 0.22, 1) both;
}

.page-graphic-design-archive .graphic-archive-popup__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
  margin-bottom: 0.72rem;
}

.page-graphic-design-archive .graphic-archive-popup__title {
  margin: 0;
  font-size: clamp(0.85rem, 1.15vw, 1rem);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(245, 247, 252, 0.92);
}

.page-graphic-design-archive .graphic-archive-popup__close {
  width: 2rem;
  height: 2rem;
  border: 1px solid rgba(255, 255, 255, 0.24);
  background: rgba(255, 255, 255, 0.06);
  color: rgba(246, 248, 252, 0.92);
  cursor: pointer;
  font-size: 1.05rem;
  line-height: 1;
}

.page-graphic-design-archive .graphic-archive-popup__close:hover,
.page-graphic-design-archive .graphic-archive-popup__close:focus-visible {
  background: rgba(255, 255, 255, 0.14);
}

.page-graphic-design-archive .graphic-archive-popup__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
  gap: 0.56rem;
  max-height: calc(88svh - 5.6rem);
  overflow-y: auto;
  padding-right: 0.1rem;
}

.page-graphic-design-archive .graphic-archive-popup__item {
  display: grid;
  gap: 0.28rem;
  text-decoration: none;
  color: rgba(244, 246, 252, 0.92);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.16);
  padding: 0.35rem;
  opacity: 0;
  transform: translateY(14px) scale(0.97);
  animation: graphic-archive-popup-item-in 340ms ease-out both;
  animation-delay: calc(var(--item-order, 0) * 34ms + 90ms);
}

.page-graphic-design-archive .graphic-archive-popup__item:hover,
.page-graphic-design-archive .graphic-archive-popup__item:focus-visible {
  transform: translateY(-4px);
  border-color: rgba(255, 255, 255, 0.34);
  background: rgba(255, 255, 255, 0.09);
}

.page-graphic-design-archive .graphic-archive-popup__item-index {
  font-size: 0.65rem;
  letter-spacing: 0.08em;
  opacity: 0.7;
}

.page-graphic-design-archive .graphic-archive-popup__thumb {
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #050608;
}

.page-graphic-design-archive .graphic-archive-popup__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.page-graphic-design-archive .graphic-archive-popup__item-label {
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

@keyframes graphic-archive-popup-in {
  from {
    opacity: 0;
    transform: translateY(-30px) scale(0.96);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes graphic-archive-popup-item-in {
  from {
    opacity: 0;
    transform: translateY(-14px) scale(0.97);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@media (max-width: 900px) {
  .page-graphic-design-archive .graphic-archive-board {
    width: min(88vw, 72svh, 640px);
  }

  .page-graphic-design-archive .photo-poster--graphic.photo-poster--graphic-board .photo-poster__title--graphic {
    font-size: clamp(1.38rem, 4.6vw, 2.5rem);
  }
}

@media (max-width: 640px) {
  .page-graphic-design-archive .photo-poster--graphic.photo-poster--graphic-board {
    min-height: calc(100svh - clamp(7.2rem, 14vw, 8.3rem));
    grid-template-rows: auto auto minmax(0, 1fr);
    gap: clamp(0.16rem, 0.76vh, 0.4rem);
    padding: 0.34rem;
  }

  .page-graphic-design-archive .graphic-archive-board {
    width: min(94vw, 72svh, 560px);
  }

  .page-graphic-design-archive .graphic-archive-board__label {
    font-size: 0.53rem;
    bottom: 0.38rem;
  }

  .page-graphic-design-archive .photo-poster--graphic.photo-poster--graphic-board .photo-poster__title--graphic {
    font-size: clamp(1.2rem, 5.8vw, 1.9rem);
    letter-spacing: -0.04em;
  }

  .page-graphic-design-archive .graphic-archive-popup__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

:root {
  --heading-font-family: var(--font-sans);
  --heading-display-weight: 800;
  --heading-display-letter-spacing: -0.05em;
  --heading-display-line-height: 0.86;
  --heading-compact-weight: 700;
  --heading-compact-letter-spacing: 0.03em;
  --heading-compact-line-height: 1.02;
}

:is(
  .page-heading,
  .home-work-network__title,
  .home-work-showcase__title,
  .home-work-showcase__label,
  .photography-feature__title,
  .photo-poster__title,
  .archive-rail-page__title,
  .archive-rail__title,
  .about-spread__headline,
  .about-spread__title,
  .project-detail__title,
  .graphic-spreadbook__title,
  .graphic-gallery-title
) {
  font-family: var(--heading-font-family);
  font-weight: var(--heading-display-weight);
  letter-spacing: var(--heading-display-letter-spacing);
  line-height: var(--heading-display-line-height);
  word-spacing: -0.03em;
  font-kerning: normal;
}

:is(
  .feature-project__heading,
  .archive-rail__caption-title,
  .page-item__title,
  .catalog-card__title,
  .graphic-spreadbook__topic-title,
  .graphic-spreadbook__topic-title--compact,
  .graphic-gallery-title-block__project,
  .graphic-project-notes__title,
  .graphic-archive-popup__title
) {
  font-family: var(--heading-font-family);
  font-weight: var(--heading-compact-weight);
  letter-spacing: var(--heading-compact-letter-spacing);
  line-height: var(--heading-compact-line-height);
  font-kerning: normal;
}

.page-main :is(h1, h2, h3):not(.sr-only) {
  font-family: var(--heading-font-family);
  font-kerning: normal;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
