/* ============================================================
   Unique work page — The Otherworld
   ============================================================ */

.unique-page main.wrap {
  padding-top: 0;
}

.unique-hero {
  display: grid;
  grid-template-columns: minmax(340px, 42%) minmax(0, 1fr);
  gap: clamp(36px, 6vw, 92px);
  align-items: start;
  padding-top: calc(118px + var(--nav-h, 72px));
  padding-bottom: clamp(64px, 8vw, 112px);
}

.unique-hero__media {
  position: sticky;
  top: 96px;
}

.unique-hero__image {
  background: transparent;
}

.unique-hero__image img,
.unique-hero__image video,
.unique-hero__image canvas {
  width: 100%;
  aspect-ratio: 2 / 3;
  object-fit: contain;
}

.unique-hero__image video {
  display: block;
  background: transparent;
}

.unique-masked-video {
  position: relative;
  aspect-ratio: 900 / 1312;
  overflow: hidden;
}

.unique-masked-video__alpha,
.unique-masked-video__canvas,
.unique-masked-video__fallback {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  aspect-ratio: auto;
  object-fit: contain;
}

.unique-masked-video__canvas {
  display: block;
  opacity: 0;
  transition: opacity 260ms var(--ease);
}

.unique-masked-video__canvas.is-ready {
  opacity: 1;
}

.unique-masked-video__alpha {
  display: block;
  opacity: 0;
  transition: opacity 260ms var(--ease);
}

.unique-masked-video__source,
.unique-masked-video__mask {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.unique-masked-video__fallback {
  opacity: 1;
  transition: opacity 180ms var(--ease);
}

.unique-masked-video.is-alpha-mode .unique-masked-video__alpha {
  opacity: 1;
}

.unique-masked-video.is-alpha-mode .unique-masked-video__fallback,
.unique-masked-video.is-canvas-mode .unique-masked-video__fallback {
  opacity: 0;
}

.unique-masked-video.is-canvas-mode .unique-masked-video__alpha {
  display: none;
}

.unique-hero__caption {
  margin-top: 14px;
  font-family: var(--font-sans);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-quiet);
  text-align: center;
}

.unique-hero__eyebrow,
.unique-story__kicker,
.home-unique-feature__eyebrow {
  font-family: var(--font-sans);
  font-size: 11px;
  line-height: 1.2;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-quiet);
  font-weight: 400;
}

.unique-hero__eyebrow {
  margin-bottom: 18px;
}

.unique-hero__title {
  margin-bottom: 24px;
  font-size: clamp(44px, 7vw, 92px);
  line-height: 0.95;
  letter-spacing: -0.045em;
  font-weight: 400;
}

.unique-hero__lead {
  max-width: 58ch;
  margin-bottom: 36px;
  font-size: clamp(17px, 1.55vw, 21px);
  line-height: 1.65;
  color: var(--ink-body);
  font-weight: 300;
}

.unique-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 42px;
}

.unique-facts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  border-top: 1px solid var(--rule);
  border-left: 1px solid var(--rule);
}

.unique-fact {
  min-height: 108px;
  padding: 18px;
  border-right: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}

.unique-fact__label {
  display: block;
  margin-bottom: 8px;
  font-family: var(--font-sans);
  font-size: 10px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink-quiet);
}

.unique-fact__value {
  display: block;
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink-body);
}

.unique-story {
  display: grid;
  grid-template-columns: minmax(260px, 0.52fr) minmax(0, 1fr);
  gap: clamp(28px, 5vw, 76px);
  padding: clamp(64px, 8vw, 112px) 0;
  border-top: 1px solid var(--rule);
  align-items: start;
}

.unique-story__kicker {
  margin: 0 0 18px;
}

.unique-story__media {
  margin: 0;
}

.unique-story__media img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  object-position: center 52%;
}

.unique-story__body {
  max-width: 760px;
}

.unique-story__body h2 {
  margin-bottom: 24px;
  font-size: clamp(28px, 4vw, 54px);
  line-height: 1.03;
  font-weight: 400;
}

.unique-story__body p {
  margin-bottom: 1.1em;
  font-size: clamp(16px, 1.35vw, 19px);
  line-height: 1.75;
  color: var(--ink-body);
  font-weight: 300;
}

.unique-story__body .unique-story__kicker {
  margin: 0 0 18px;
  font-family: var(--font-sans);
  font-size: 11px;
  line-height: 1.2;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-quiet);
  font-weight: 400;
}

.unique-gallery {
  display: grid;
  grid-template-columns: minmax(260px, 0.92fr) minmax(220px, 0.62fr);
  gap: clamp(22px, 4vw, 56px);
  max-width: 840px;
  margin: 0 auto;
  padding-bottom: clamp(64px, 8vw, 112px);
  align-items: start;
}

.unique-gallery figure {
  margin: 0;
  overflow: hidden;
}

.unique-gallery__hover {
  cursor: zoom-in;
}

.unique-gallery img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform-origin: var(--zoom-x, 50%) var(--zoom-y, 50%);
  transition: transform 0.45s var(--ease), filter 0.3s var(--ease);
}

.unique-gallery__main {
  grid-column: 1;
}

.unique-gallery__main img {
  height: auto;
  aspect-ratio: 2 / 3;
  object-fit: contain;
  background: transparent;
}

.unique-gallery__details {
  display: grid;
  grid-template-rows: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(16px, 2.6vw, 32px);
  height: var(--gallery-main-height, auto);
  align-self: start;
}

.unique-gallery__detail {
  width: 100%;
  min-height: 0;
  justify-self: stretch;
}

.unique-gallery__detail img {
  aspect-ratio: auto;
}

.unique-gallery__hover:hover img {
  transform: scale(1.75);
  filter: contrast(1.03);
}

.unique-contact {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(320px, 1fr);
  gap: clamp(36px, 6vw, 92px);
  align-items: start;
  padding: clamp(48px, 7vw, 92px) 0;
  border-top: 1px solid var(--rule);
}

.unique-contact__intro h2 {
  margin-bottom: 18px;
  font-size: clamp(28px, 4vw, 48px);
  line-height: 1.04;
  font-weight: 400;
}

.unique-contact__intro p {
  max-width: 48ch;
  font-size: 15px;
  line-height: 1.75;
  color: var(--ink-muted);
  font-weight: 300;
}

.unique-contact__intro .unique-hero__eyebrow {
  max-width: none;
  margin-bottom: 18px;
  font-family: var(--font-sans);
  font-size: 11px;
  line-height: 1.2;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-quiet);
  font-weight: 400;
}

.unique-contact .contact-form {
  width: 100%;
  flex: none;
}

.unique-contact .contact-form__field--grow textarea {
  min-height: 150px;
  resize: vertical;
}

.home-unique-feature {
  max-width: 1400px;
  margin: clamp(40px, 6vw, 80px) auto 0;
  padding: 0 clamp(32px, 6vw, 96px);
}

.home-unique-feature__inner {
  display: grid;
  grid-template-columns: minmax(92px, 150px) minmax(0, 1fr) auto;
  gap: clamp(20px, 4vw, 56px);
  align-items: center;
  padding: 28px 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}

.home-unique-feature__media {
  width: clamp(92px, 10vw, 140px);
  aspect-ratio: 800 / 1422;
  overflow: hidden;
  background: transparent;
  justify-self: start;
}

.home-unique-feature__media img,
.home-unique-feature__media video {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  transition: transform 0.55s var(--ease);
}

.home-unique-feature__inner:hover img,
.home-unique-feature__inner:hover video {
  transform: scale(1.035);
}

.home-unique-feature__eyebrow {
  margin-bottom: 8px;
}

.home-unique-feature__content {
  min-width: 0;
}

.home-unique-feature__title {
  margin-bottom: 8px;
  font-size: clamp(24px, 3vw, 40px);
  line-height: 1.02;
  font-weight: 400;
}

.home-unique-feature__text {
  max-width: 56ch;
  font-size: 14px;
  line-height: 1.65;
  color: var(--ink-muted);
  font-weight: 300;
}

.home-unique-feature--portfolio {
  margin-top: clamp(48px, 7vw, 92px);
  padding-bottom: 0;
}

.home-unique-feature:not(.home-unique-feature--portfolio) + .collections-section {
  padding-top: clamp(56px, 7vw, 88px);
}

@media (max-width: 900px) {
  .unique-hero,
  .unique-story,
  .unique-contact,
  .home-unique-feature__inner {
    grid-template-columns: 1fr;
  }

  .unique-hero__media {
    position: static;
    max-width: 560px;
    margin: 0 auto;
  }

  .unique-hero__content {
    display: contents;
  }

  .unique-hero__eyebrow {
    order: 1;
  }

  .unique-hero__title {
    order: 2;
  }

  .unique-hero__lead {
    order: 3;
  }

  .unique-hero__actions {
    order: 4;
  }

  .unique-hero__media {
    order: 5;
  }

  .unique-facts {
    order: 6;
  }

  .home-unique-feature {
    margin-top: 40px;
  }

  .home-unique-feature__inner {
    gap: 30px;
    padding: 34px 0;
  }

  .home-unique-feature__media {
    width: min(80%, 340px);
    max-width: none;
    justify-self: center;
  }

  .home-unique-feature__content {
    display: grid;
    gap: 12px;
    justify-items: start;
    max-width: 58ch;
  }

  .home-unique-feature__eyebrow,
  .home-unique-feature__title {
    margin-bottom: 0;
  }

  .home-unique-feature__text {
    font-size: 15px;
    line-height: 1.72;
  }

  .home-unique-feature .btn-ghost {
    margin-top: 4px;
    width: fit-content;
  }

  .home-unique-feature:not(.home-unique-feature--portfolio) + .collections-section {
    padding-top: 56px;
  }
}

@media (max-width: 640px) {
  .unique-hero {
    padding-top: calc(84px + var(--nav-h, 72px));
  }

  .unique-facts,
  .unique-gallery {
    grid-template-columns: 1fr;
    max-width: 560px;
  }

  .unique-gallery__main,
  .unique-gallery__details {
    grid-column: auto;
    grid-row: auto;
  }

  .unique-gallery__details {
    height: auto;
    grid-template-rows: auto auto;
  }

  .unique-gallery__detail img {
    height: auto;
    aspect-ratio: 4 / 3;
  }

  .unique-gallery__hover {
    cursor: auto;
  }

  .home-unique-feature {
    padding-left: 24px;
    padding-right: 24px;
  }

  .home-unique-feature__inner {
    gap: 34px;
    padding: 36px 0;
  }

  .home-unique-feature__media {
    width: min(80%, 300px);
  }

  .home-unique-feature__content {
    gap: 14px;
  }

  .home-unique-feature .btn-ghost {
    width: 100%;
    justify-content: center;
  }
}
