body.page-photo-series .photoSeriesMain {
  max-width: none;
  width: 100%;
  padding: clamp(1rem, 2.4vw, 1.8rem) 0 clamp(4rem, 7vw, 6rem);
  background: #000;
}

body.page-photo-series .photoSeriesTitleBlock {
  width: min(100%, 1180px);
  margin: 0 auto;
  padding: clamp(0.85rem, 1.8vw, 1.35rem) clamp(1.2rem, 3.4vw, 2.8rem) clamp(1.8rem, 3.2vw, 2.8rem);
}

body.page-photo-series-structure .photoSeriesTitleBlock {
  text-align: center;
}

body.page-photo-series-traces .photoSeriesTitleBlock {
  text-align: center;
}

body.page-photo-series-nature .photoSeriesTitleBlock {
  text-align: center;
}

/* Nature Without Time — Section 01 centered vertical sequence */
body.page-photo-series-nature .sosSection01 {
  width: min(100%, 1240px);
  margin: 0 auto;
  padding: clamp(1.2rem, 2.4vw, 2rem) clamp(1rem, 3vw, 2rem) clamp(120px, 14vw, 180px);
  box-sizing: border-box;
}

body.page-photo-series-nature .sosComposition {
  position: static;
  min-height: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(38px, 5vw, 56px);
}

body.page-photo-series-nature .sosImage {
  position: static;
  margin: 0;
  transform: none !important;
}

body.page-photo-series-nature .sosImage--main,
body.page-photo-series-nature .sosImage--topRight,
body.page-photo-series-nature .sosImage--bottomRight {
  width: min(100%, 980px);
  left: auto;
  right: auto;
  top: auto;
  bottom: auto;
}

/* Keep narrative order as 01 -> 02 -> 03 */
body.page-photo-series-nature .sosImage--main {
  order: 1;
}
body.page-photo-series-nature .sosImage--topRight {
  order: 2;
}
body.page-photo-series-nature .sosImage--bottomRight {
  order: 3;
}

body.page-photo-series .photoSeriesTitle {
  margin: 0;
  font-family: "Inter", system-ui, sans-serif;
  font-size: clamp(1.08rem, 2.4vw, 1.8rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.94);
}

body.page-photo-series .photoSeriesSubtitle {
  margin: 0.52rem 0 0;
  font-family: "Inter", system-ui, sans-serif;
  font-size: clamp(0.72rem, 0.95vw, 0.9rem);
  font-weight: 500;
  letter-spacing: 0.05em;
  color: rgba(255, 255, 255, 0.55);
}

body.page-photo-series .photoSeriesIntro {
  margin: 0.86rem auto 0;
  max-width: 62ch;
  font-family: "Inter", system-ui, sans-serif;
  font-size: clamp(0.74rem, 0.98vw, 0.92rem);
  font-weight: 400;
  letter-spacing: 0.02em;
  line-height: 1.56;
  color: rgba(255, 255, 255, 0.62);
}

body.page-photo-series .photoSeriesHero {
  width: 100vw;
  margin: 0 calc(50% - 50vw) clamp(2.4rem, 5vw, 4rem);
  min-height: 85vh;
  max-height: 100vh;
}

body.page-photo-series .photoSeriesHero img {
  width: 100%;
  height: 100%;
  min-height: inherit;
  max-height: inherit;
  display: block;
  object-fit: contain;
  object-position: center;
  filter: grayscale(100%);
  transition: transform 0.4s ease;
}

body.page-photo-series .sosSection01 {
  width: min(100%, 1400px);
  margin: 0 auto;
  padding: clamp(1rem, 2.1vw, 1.8rem) clamp(1rem, 2.4vw, 2rem) 120px;
  box-sizing: border-box;
}

body.page-photo-series .sosComposition {
  position: relative;
  min-height: clamp(700px, 74vw, 980px);
}

body.page-photo-series .sosImage {
  position: absolute;
  margin: 0;
}

body.page-photo-series .sosImage img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  filter: grayscale(100%);
  transition: transform 300ms ease-out;
  cursor: zoom-in;
}

body.page-photo-series .sosImage:hover img {
  transform: scale(1.02);
}

body.page-photo-series .sosImage--main {
  width: 62%;
  left: 5%;
  top: 8%;
  z-index: 2;
}

body.page-photo-series .sosImage--topRight {
  width: 23%;
  right: 5.5%;
  top: 4%;
  transform: translateY(-24px);
  z-index: 3;
}

body.page-photo-series .sosImage--bottomRight {
  width: 33%;
  right: 3%;
  bottom: 4%;
  z-index: 1;
}

body.page-photo-series .sosImage--main.reveal-on-scroll {
  transition-delay: 0ms;
}

body.page-photo-series .sosImage--bottomRight.reveal-on-scroll {
  transition-delay: 110ms;
}

body.page-photo-series .sosImage--topRight.reveal-on-scroll {
  transition-delay: 190ms;
}

/* Traces of Presence — Section 01 custom four-image composition */
body.page-photo-series-traces .tracesS01 {
  width: min(100%, 1560px);
  margin: 0 auto;
  padding: clamp(1rem, 2.1vw, 1.8rem) clamp(1rem, 2.4vw, 2rem) 160px;
  margin-top: clamp(92px, 10vw, 148px);
  box-sizing: border-box;
}

body.page-photo-series-traces .tracesS01Canvas {
  position: relative;
  width: min(100%, 1440px);
  margin: 0 auto;
  min-height: clamp(1020px, 92vw, 1280px);
}

body.page-photo-series-traces .tracesS01Cluster {
  --traces-hero-width: clamp(620px, 62vw, 900px);
  --traces-hero-height: calc(var(--traces-hero-width) * 0.75);
  position: absolute;
  left: 55%;
  top: clamp(136px, 14.6vw, 210px);
  width: calc(var(--traces-hero-width) * 1.65);
  height: calc(var(--traces-hero-width) * 1.72);
  transform: translateX(-30%);
}

body.page-photo-series-traces .tracesS01Piece {
  position: absolute;
  margin: 0;
}

body.page-photo-series-traces .tracesS01Piece img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  filter: grayscale(100%);
  transition: transform 300ms ease-out;
  cursor: zoom-in;
}

body.page-photo-series-traces .tracesS01Piece:hover img {
  transform: scale(1.02);
}

/* 02 = hero anchor (base = 100%) */
body.page-photo-series-traces .tracesS01Piece--02 {
  width: var(--traces-hero-width);
  left: 0;
  top: 0;
  z-index: 9;
}

/* 01 = secondary (55-60% hero width), +35% W and -38% H from hero */
body.page-photo-series-traces .tracesS01Piece--01 {
  width: calc(var(--traces-hero-width) * 0.54);
  left: calc(var(--traces-hero-width) * 0.74);
  top: calc(var(--traces-hero-height) * -0.52);
  z-index: 6;
}

/* 03 = ghost fragment (28-32% hero width), -28% W and +62% H */
body.page-photo-series-traces .tracesS01Piece--03 {
  width: calc(var(--traces-hero-width) * 0.30);
  left: calc(var(--traces-hero-width) * -0.22);
  top: calc(var(--traces-hero-height) * 0.66);
  z-index: 3;
}

/* 04 = support (48-52% hero width), +5% W and +92% H */
body.page-photo-series-traces .tracesS01Piece--04 {
  width: calc(var(--traces-hero-width) * 0.48);
  left: calc(var(--traces-hero-width) * 0.23);
  top: calc(var(--traces-hero-height) * 1.03);
  z-index: 4;
}

body.page-photo-series-traces .tracesS01Piece--03 img {
  filter: grayscale(100%) brightness(0.86);
}

body.page-photo-series-traces .tracesS01Piece--02.reveal-on-scroll {
  transition-delay: 0ms;
}

body.page-photo-series-traces .tracesS01Piece--01.reveal-on-scroll {
  transition-delay: 90ms;
}

body.page-photo-series-traces .tracesS01Piece--03.reveal-on-scroll {
  transition-delay: 150ms;
}

body.page-photo-series-traces .tracesS01Piece--04.reveal-on-scroll {
  transition-delay: 210ms;
}

/* Traces of Presence — Section 02 (01/02 over 03 hero, 04 bottom) */
body.page-photo-series-traces .tracesS02 {
  width: min(100%, 1500px);
  margin: 0 auto;
  padding: clamp(0.6rem, 1.4vw, 1rem) clamp(1rem, 2.4vw, 2rem) 160px;
  box-sizing: border-box;
  /* whole section nudge right (zig-zag vs S01 / S03); +15 steps (180px) on base clamp */
  transform: translateX(calc(clamp(48px, 5.5vw, 112px) + 180px));
}

body.page-photo-series-traces .tracesS02Canvas {
  position: relative;
  width: min(100%, 1220px);
  margin: 0 auto;
  min-height: clamp(840px, 80vw, 1040px);
}

body.page-photo-series-traces .tracesS02Piece {
  position: absolute;
  margin: 0;
}

body.page-photo-series-traces .tracesS02Piece img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  filter: grayscale(100%);
  transition: transform 300ms ease-out;
  cursor: zoom-in;
}

body.page-photo-series-traces .tracesS02Piece:hover img {
  transform: scale(1.02);
}

/* 03 hero anchor */
body.page-photo-series-traces .tracesS02Piece--03 {
  width: 74%;
  left: 16%;
  top: 42%;
  transform: none;
  z-index: 5;
}

/* 01 top-left */
body.page-photo-series-traces .tracesS02Piece--01 {
  width: 34%;
  left: 16%;
  top: 2%;
  z-index: 6;
}

/* 02 top overlap, shifted right */
body.page-photo-series-traces .tracesS02Piece--02 {
  width: 17%;
  left: 45%;
  top: 24%;
  z-index: 7;
}

/* 04 bottom support */
body.page-photo-series-traces .tracesS02Piece--04 {
  width: 45%;
  left: 49% !important;
  top: 81%;
  transform: translateX(-52%) !important;
  z-index: 4;
}

body.page-photo-series-traces .tracesS02Piece--03.reveal-on-scroll {
  transition-delay: 0ms;
}

body.page-photo-series-traces .tracesS02Piece--01.reveal-on-scroll {
  transition-delay: 80ms;
}

body.page-photo-series-traces .tracesS02Piece--02.reveal-on-scroll {
  transition-delay: 140ms;
}

body.page-photo-series-traces .tracesS02Piece--04.reveal-on-scroll {
  transition-delay: 210ms;
}

/* Traces of Presence — Section 03: tight cluster like ref 221724 (hero anchor, birds over hero BL) */
body.page-photo-series-traces .tracesS03 {
  width: 100%;
  margin: 0 auto;
  padding: clamp(0.6rem, 1.2vw, 1rem) 0 160px;
  box-sizing: border-box;
  background: #000;
  /* whole section nudge left relative to center flow (+3 steps) */
  transform: translateX(calc(clamp(-64px, -5vw, -28px) - 36px));
}

body.page-photo-series-traces .tracesS03Canvas {
  position: relative;
  width: 100%;
  height: 1500px;
  margin: 0;
  background: #000;
  --s03-hero-left: 36%;
  --s03-hero-w: 620px;
  /* matches top spacing 02 (13%) → 06 (26%) */
  --s03-tier-gap: 13%;
  --s03-04-top: 50%;
}

body.page-photo-series-traces .tracesS03Piece {
  position: absolute;
  margin: 0;
  overflow: visible;
  transform: none;
  line-height: 0;
}

body.page-photo-series-traces .tracesS03Piece img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  filter: grayscale(100%);
  transition: transform 300ms ease-out;
  cursor: zoom-in;
}

body.page-photo-series-traces .tracesS03Piece:hover img {
  transform: scale(1.02);
}

/* 01 — shifted left from hero-center (7×12px); slightly smaller */
body.page-photo-series-traces .tracesS03Piece--01 {
  top: 8.5%;
  left: calc(var(--s03-hero-left) + (var(--s03-hero-w) / 2) - 245px - 84px);
  width: 245px;
  z-index: 1;
}

/* 02 — right of 01, slightly lower, a bit narrower than 01 */
body.page-photo-series-traces .tracesS03Piece--02 {
  top: 12.5%;
  left: calc(var(--s03-hero-left) + (var(--s03-hero-w) / 2) + 12px);
  width: 235px;
  z-index: 2;
}

/* 06 = bridge hero — center-right anchor */
body.page-photo-series-traces .tracesS03Piece--06 {
  top: 26%;
  left: var(--s03-hero-left);
  width: var(--s03-hero-w);
  z-index: 3;
}

/* 03 — birds: leftmost; TR overlaps hero BL */
body.page-photo-series-traces .tracesS03Piece--03 {
  top: 47%;
  left: calc(var(--s03-hero-left) - 154px);
  width: 220px;
  z-index: 7;
}

/* 04 — closer to hero; clear bottom by ~2–3% typical */
body.page-photo-series-traces .tracesS03Piece--04 {
  top: var(--s03-04-top);
  left: calc(var(--s03-hero-left) + var(--s03-hero-w) - 430px);
  width: 430px;
  z-index: 5;
}

/* 05 = fog — tier gap below 04 + slight extra nudge */
body.page-photo-series-traces .tracesS03Piece--05 {
  top: calc(var(--s03-04-top) + var(--s03-tier-gap) + 0.5%);
  left: calc(50% - 250px - 204px);
  width: 500px;
  z-index: 6;
}

/* Scroll reveal must not apply translateY to absolutely positioned figures */
body.page-photo-series-traces .tracesS03Piece.reveal-on-scroll {
  opacity: 0;
  transform: none;
  transition: opacity 400ms ease;
}

body.page-photo-series-traces .tracesS03Piece.reveal-on-scroll.is-visible {
  opacity: 1;
  transform: none;
}

body.page-photo-series-traces .tracesS03Piece--06.reveal-on-scroll {
  transition-delay: 0ms;
}

body.page-photo-series-traces .tracesS03Piece--01.reveal-on-scroll {
  transition-delay: 80ms;
}

body.page-photo-series-traces .tracesS03Piece--02.reveal-on-scroll {
  transition-delay: 120ms;
}

body.page-photo-series-traces .tracesS03Piece--03.reveal-on-scroll {
  transition-delay: 160ms;
}

body.page-photo-series-traces .tracesS03Piece--04.reveal-on-scroll {
  transition-delay: 200ms;
}

body.page-photo-series-traces .tracesS03Piece--05.reveal-on-scroll {
  transition-delay: 240ms;
}

body.page-photo-series .photoSequence {
  width: 100%;
  margin: 0 auto;
  padding-inline: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(3rem, 7vw, 7.5rem);
}

body.page-photo-series .photoFilmBlock {
  margin: 0;
  display: flex;
  justify-content: center;
  width: 100%;
}

body.page-photo-series .photoFilmBlock img {
  width: auto;
  max-width: min(100%, 900px);
  max-height: 84vh;
  height: auto;
  display: block;
  object-fit: contain;
  filter: grayscale(100%);
  transition: transform 0.4s ease;
}

body.page-photo-series .photoFilmBlock:hover img {
  transform: scale(1.02);
}

body.page-photo-series .photoFilmBlock--fullbleed {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  justify-content: stretch;
}

body.page-photo-series .photoFilmBlock--fullbleed img {
  width: 100%;
  max-width: none;
  max-height: none;
}

body.page-photo-series .photoFilmBlock--centered img {
  max-width: min(100%, 900px);
}

body.page-photo-series .photoFilmSplit {
  width: min(100%, 1220px);
  margin: 0 auto;
  padding-inline: clamp(1rem, 2.8vw, 2.6rem);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: clamp(0.75rem, 1.6vw, 1.1rem);
}

body.page-photo-series .photoFilmSplitItem {
  margin: 0;
  flex: 1 1 0;
  display: flex;
}

body.page-photo-series .photoFilmSplitItem img {
  width: 100%;
  height: auto;
  max-height: 72vh;
  object-fit: contain;
  filter: grayscale(100%);
  transition: transform 0.4s ease;
}

body.page-photo-series .photoFilmSplit:hover img {
  transform: scale(1.02);
}

body.page-photo-series .photoFilmBlock--vertical-left,
body.page-photo-series .photoFilmBlock--vertical-right {
  justify-content: flex-start;
}

body.page-photo-series .photoFilmBlock--vertical-left img,
body.page-photo-series .photoFilmBlock--vertical-right img {
  max-width: min(100%, 500px);
  max-height: 86vh;
}

body.page-photo-series .photoFilmBlock--vertical-left {
  padding-left: clamp(1rem, 7vw, 10rem);
}

body.page-photo-series .photoFilmBlock--vertical-right {
  justify-content: flex-end;
  padding-right: clamp(1rem, 7vw, 10rem);
}

body.page-photo-series .photoFilmBreak {
  height: clamp(100px, 15vh, 200px);
}

body.page-photo-series .reveal-on-scroll {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 400ms ease, transform 400ms ease;
}

body.page-photo-series .reveal-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

body.page-photo-series .photoSeriesEndNav {
  width: min(100%, 1180px);
  margin: clamp(3rem, 7vw, 6rem) auto 0;
  padding: 0 clamp(1.2rem, 3.4vw, 2.8rem);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  padding-top: clamp(1.1rem, 2.4vw, 1.7rem);
}

body.page-photo-series .photoSeriesEndNav a {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 0.76rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  transition: color 0.2s ease;
}

body.page-photo-series .photoSeriesEndNav a:hover,
body.page-photo-series .photoSeriesEndNav a:focus-visible {
  color: #fff;
}

body.page-photo-series .photoLightbox {
  position: fixed;
  inset: 0;
  z-index: 240;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.94);
}

body.page-photo-series .photoLightbox[hidden] {
  display: none;
}

body.page-photo-series .photoLightboxStage {
  margin: 0;
  width: 100vw;
  height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
}

body.page-photo-series .photoLightboxImage {
  width: 100%;
  height: 100%;
  max-width: 100vw;
  max-height: 100dvh;
  display: block;
  object-fit: contain;
}

body.page-photo-series .photoLightboxClose {
  position: absolute;
  top: clamp(0.9rem, 2vw, 1.4rem);
  right: clamp(1rem, 2.2vw, 1.6rem);
  border: 0;
  background: transparent;
  color: rgba(255, 255, 255, 0.84);
  font-size: clamp(1.5rem, 3vw, 2rem);
  line-height: 1;
  cursor: pointer;
}

body.page-photo-series .photoLightboxClose:hover,
body.page-photo-series .photoLightboxClose:focus-visible {
  color: #fff;
}

body.page-photo-series .photoLightboxNav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: 0;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.86);
  width: clamp(34px, 3vw, 42px);
  height: clamp(54px, 6vw, 64px);
  font-size: clamp(1.2rem, 2.4vw, 1.8rem);
  line-height: 1;
  cursor: pointer;
}

body.page-photo-series .photoLightboxNav:hover,
body.page-photo-series .photoLightboxNav:focus-visible {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
}

body.page-photo-series .photoLightboxNav--prev {
  left: clamp(0.8rem, 1.8vw, 1.5rem);
}

body.page-photo-series .photoLightboxNav--next {
  right: clamp(0.8rem, 1.8vw, 1.5rem);
}

@media (max-width: 900px) {
  body.page-photo-series .photoSeriesTitleBlock {
    padding: clamp(0.78rem, 2.6vw, 1rem) 1rem clamp(1.35rem, 4vw, 1.8rem);
  }

  body.page-photo-series .photoSeriesIntro {
    max-width: 50ch;
  }

  body.page-photo-series .photoSeriesHero {
    min-height: 56vh;
  }

  body.page-photo-series .sosSection01 {
    padding: clamp(0.85rem, 2.6vw, 1.2rem) 1rem 84px;
  }

  body.page-photo-series .sosComposition {
    min-height: clamp(560px, 95vw, 760px);
  }

  body.page-photo-series .sosImage--main {
    width: 64%;
    left: 2%;
    top: 10%;
  }

  body.page-photo-series .sosImage--topRight {
    width: 27%;
    right: 4%;
    top: 6%;
    transform: translateY(-18px);
  }

  body.page-photo-series .sosImage--bottomRight {
    width: 36%;
    right: 0;
    bottom: 8%;
  }

  body.page-photo-series .photoSequence {
    gap: clamp(1.8rem, 6vw, 2.8rem);
  }

  body.page-photo-series .photoFilmBlock img {
    max-width: calc(100% - 2rem);
    max-height: 72vh;
  }

  body.page-photo-series .photoFilmSplit {
    width: 100%;
    padding-inline: 1rem;
    flex-direction: column;
    gap: 0.8rem;
  }

  body.page-photo-series .photoFilmSplitItem img {
    max-height: 68vh;
  }

  body.page-photo-series .photoFilmBlock--vertical-left,
  body.page-photo-series .photoFilmBlock--vertical-right {
    justify-content: center;
    padding-left: 0;
    padding-right: 0;
  }

  body.page-photo-series .photoFilmBlock--vertical-left img,
  body.page-photo-series .photoFilmBlock--vertical-right img {
    max-width: calc(100% - 2rem);
    max-height: 76vh;
  }

  body.page-photo-series .photoFilmBreak {
    height: clamp(72px, 11vh, 120px);
  }

  body.page-photo-series .photoSeriesEndNav {
    padding-inline: 1rem;
  }

  body.page-photo-series .photoLightboxNav {
    width: 32px;
    height: 46px;
  }

  body.page-photo-series-traces .tracesS01 {
    padding: clamp(0.85rem, 2.6vw, 1.2rem) 1rem 112px;
    margin-top: clamp(72px, 9vw, 108px);
  }

  body.page-photo-series-traces .tracesS01Canvas {
    min-height: clamp(860px, 114vw, 1120px);
  }

  body.page-photo-series-traces .tracesS01Cluster {
    --traces-hero-width: clamp(500px, 72vw, 760px);
    --traces-hero-height: calc(var(--traces-hero-width) * 0.75);
    left: 56%;
    top: clamp(160px, 20vw, 230px);
    width: calc(var(--traces-hero-width) * 1.62);
    height: calc(var(--traces-hero-width) * 1.7);
    transform: translateX(-34%);
  }

  body.page-photo-series-traces .tracesS02 {
    padding: clamp(0.6rem, 1.8vw, 0.9rem) 1rem 116px;
  }

  body.page-photo-series-traces .tracesS02Canvas {
    min-height: clamp(860px, 122vw, 1120px);
  }

  body.page-photo-series-traces .tracesS02Piece--03 {
    width: 84%;
    left: 4%;
    top: 45%;
    transform: none;
  }

  body.page-photo-series-traces .tracesS02Piece--01 {
    width: 36%;
    left: 4%;
    top: 6%;
  }

  body.page-photo-series-traces .tracesS02Piece--02 {
    width: 18%;
    left: 43%;
    top: 27%;
  }

  body.page-photo-series-traces .tracesS02Piece--04 {
    width: 54%;
    left: 49% !important;
    top: 85%;
    transform: translateX(-50%) !important;
  }

  body.page-photo-series-traces .tracesS03 {
    padding: clamp(0.7rem, 1.6vw, 1rem) 0 132px;
    overflow-x: auto;
  }

  body.page-photo-series-traces .tracesS03Canvas {
    width: 100%;
    min-width: 960px;
    height: 1500px;
  }
}

@media (max-width: 680px) {
  body.page-photo-series .sosSection01 {
    padding: clamp(0.75rem, 2.4vw, 1rem) 1rem 56px;
  }

  body.page-photo-series .sosComposition {
    position: static;
    min-height: 0;
  }

  body.page-photo-series .sosImage {
    position: static;
    width: 100%;
    transform: none;
  }

  body.page-photo-series .sosImage + .sosImage {
    margin-top: clamp(24px, 7vw, 40px);
  }

  body.page-photo-series .sosImage--main,
  body.page-photo-series .sosImage--bottomRight,
  body.page-photo-series .sosImage--topRight {
    width: 100%;
  }

  body.page-photo-series-traces .tracesS01 {
    padding: clamp(0.75rem, 2.4vw, 1rem) 1rem 64px;
  }

  body.page-photo-series-traces .tracesS01Canvas {
    position: static;
    min-height: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(24px, 7vw, 40px);
  }

  body.page-photo-series-traces .tracesS01Cluster {
    position: static;
    width: 100%;
    height: auto;
    transform: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(24px, 7vw, 40px);
  }

  body.page-photo-series-traces .tracesS01Piece {
    position: static;
    width: 100% !important;
    transform: none !important;
  }

  body.page-photo-series-traces .tracesS01Piece img {
    width: 100%;
  }

  body.page-photo-series-traces .tracesS02 {
    padding: 0.8rem 1rem 72px;
    transform: none;
  }

  body.page-photo-series-traces .tracesS02Canvas {
    position: static;
    min-height: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(24px, 7vw, 40px);
  }

  body.page-photo-series-traces .tracesS02Piece {
    position: static;
    width: 100% !important;
    transform: none !important;
  }

  body.page-photo-series-traces .tracesS02Piece img {
    width: 100%;
  }

  body.page-photo-series-traces .tracesS03 {
    padding: 0.8rem 0 72px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    transform: none;
  }

  body.page-photo-series-traces .tracesS03Canvas {
    position: relative;
    width: 100%;
    min-width: 960px;
    height: 1500px;
  }

  /* Keep absolute collage — no flex/grid stack */
  body.page-photo-series-traces .tracesS03Piece {
    transform: none;
  }
}

/* Structure of Silence — Section 01 interactive composition */
body.page-photo-series-structure .s01Interactive {
  position: relative;
  isolation: isolate;
  width: min(100%, 1200px);
  margin: 168px auto 224px;
  min-height: clamp(760px, 79vw, 1060px);
}

body.page-photo-series-structure .s01Piece {
  margin: 0;
  position: absolute;
}

body.page-photo-series-structure .s01Piece--hero {
  position: relative;
  width: 61%;
  z-index: 6;
  left: 50%;
  top: 82px;
  transform: translateX(-50%);
}

body.page-photo-series-structure .s01Piece--leftOverlap {
  left: 4%;
  top: -18px;
  width: 29%;
  z-index: 4;
}

body.page-photo-series-structure .s01Piece--top {
  top: 126px;
  left: 72%;
  width: 21%;
  z-index: 3;
}

body.page-photo-series-structure .s01Piece--center {
  left: 1%;
  top: 70%;
  width: 23%;
  z-index: 2;
}

body.page-photo-series-structure .s01Piece--bottomRight {
  left: 65%;
  bottom: 72px;
  width: 21%;
  z-index: 1;
}

body.page-photo-series-structure .s01Piece img {
  --piece-opacity: 1;
  --piece-filter: grayscale(100%) contrast(1);
  --piece-scale: 1;
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  opacity: var(--piece-opacity);
  filter: var(--piece-filter);
  transform: scale(var(--piece-scale));
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.17);
  transition: transform 320ms ease, opacity 320ms ease, filter 320ms ease;
  cursor: zoom-in;
  will-change: transform, opacity;
}

body.page-photo-series-structure .s01Piece--hero img {
  --piece-opacity: 1;
  --piece-filter: grayscale(100%) contrast(1.1);
  --piece-scale: 1.03;
}

body.page-photo-series-structure .s01Piece--leftOverlap img {
  --piece-opacity: 0.96;
  --piece-filter: grayscale(100%) contrast(0.95);
  --piece-scale: 0.99;
}

body.page-photo-series-structure .s01Piece--top img {
  --piece-opacity: 0.95;
  --piece-filter: grayscale(100%) brightness(0.98) contrast(0.96);
  --piece-scale: 0.99;
}

body.page-photo-series-structure .s01Piece--center img {
  --piece-opacity: 0.93;
  --piece-filter: grayscale(100%) brightness(0.9) contrast(0.9);
  --piece-scale: 0.98;
}

body.page-photo-series-structure .s01Piece--bottomRight img {
  --piece-opacity: 0.98;
  --piece-filter: grayscale(100%) brightness(1.03) contrast(1.03);
  --piece-scale: 1;
}

body.page-photo-series-structure .s01Interactive:hover .s01Piece img {
  opacity: 0.68;
  filter: grayscale(100%) brightness(0.86) contrast(0.93);
}

body.page-photo-series-structure .s01Piece:hover {
  z-index: 14;
}

body.page-photo-series-structure .s01Piece:hover img {
  opacity: 1;
  filter: var(--piece-filter);
  transform: translateY(-8px) scale(1.04);
}

body.page-photo-series-structure .s01Piece.reveal-on-scroll {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 400ms ease, transform 400ms ease;
}

body.page-photo-series-structure .s01Piece.reveal-on-scroll.is-visible {
  opacity: 1;
}

body.page-photo-series-structure .s01Piece--hero.reveal-on-scroll {
  transform: translate(-50%, 40px);
}

body.page-photo-series-structure .s01Piece--hero.reveal-on-scroll.is-visible {
  transform: translate(-50%, 0);
}

body.page-photo-series-structure .s01Piece--leftOverlap.reveal-on-scroll {
  transform: translateY(40px);
  transition-delay: 70ms;
}

body.page-photo-series-structure .s01Piece--leftOverlap.reveal-on-scroll.is-visible {
  transform: translateY(0);
}

body.page-photo-series-structure .s01Piece--top.reveal-on-scroll {
  transform: translateY(40px);
  transition-delay: 130ms;
}

body.page-photo-series-structure .s01Piece--top.reveal-on-scroll.is-visible {
  transform: translateY(0);
}

body.page-photo-series-structure .s01Piece--center.reveal-on-scroll {
  transform: translateY(40px);
  transition-delay: 180ms;
}

body.page-photo-series-structure .s01Piece--center.reveal-on-scroll.is-visible {
  transform: translateY(0);
}

body.page-photo-series-structure .s01Piece--bottomRight.reveal-on-scroll {
  transform: translateY(40px);
  transition-delay: 240ms;
}

body.page-photo-series-structure .s01Piece--bottomRight.reveal-on-scroll.is-visible {
  transform: translateY(0);
}

@media (max-width: 900px) {
  body.page-photo-series-structure .s01Interactive {
    margin: clamp(104px, 13vw, 156px) auto;
    min-height: clamp(640px, 90vw, 910px);
    width: min(100%, 920px);
    padding: 0 16px;
    box-sizing: border-box;
  }

  body.page-photo-series-structure .s01Piece--hero {
    width: 65%;
    left: 52%;
    top: 64px;
    transform: translateX(-50%);
  }

  body.page-photo-series-structure .s01Piece--leftOverlap {
    left: 3%;
    top: -8px;
    width: 30%;
  }

  body.page-photo-series-structure .s01Piece--top {
    top: 96px;
    left: 73%;
    width: 22%;
  }

  body.page-photo-series-structure .s01Piece--center {
    left: 0;
    top: 68%;
    width: 24%;
  }

  body.page-photo-series-structure .s01Piece--bottomRight {
    left: 63%;
    bottom: 56px;
    width: 22%;
  }

  body.page-photo-series-structure .s01Piece--hero.reveal-on-scroll {
    transform: translate(-50%, 40px);
  }

  body.page-photo-series-structure .s01Piece--hero.reveal-on-scroll.is-visible {
    transform: translate(-50%, 0);
  }
}

@media (max-width: 680px) {
  body.page-photo-series-structure .s01Interactive {
    margin: 92px auto 110px;
    min-height: 0;
    width: calc(100% - 32px);
    padding: 0;
    display: block;
  }

  body.page-photo-series-structure .s01Piece {
    position: static;
    transform: none;
  }

  body.page-photo-series-structure .s01Piece--hero {
    width: 92%;
    margin: 0 auto;
  }

  body.page-photo-series-structure .s01Piece--leftOverlap {
    width: 72%;
    margin-top: 24px;
  }

  body.page-photo-series-structure .s01Piece--top {
    width: 62%;
    margin-top: 24px;
    margin-left: auto;
  }

  body.page-photo-series-structure .s01Piece--center {
    width: 78%;
    margin-top: 24px;
    margin-left: 6%;
  }

  body.page-photo-series-structure .s01Piece--bottomRight {
    width: 64%;
    margin-top: 32px;
    margin-left: auto;
    margin-right: 2%;
  }

  body.page-photo-series-structure .s01Interactive:hover .s01Piece img {
    opacity: var(--piece-opacity);
    filter: var(--piece-filter);
  }

  body.page-photo-series-structure .s01Piece.reveal-on-scroll,
  body.page-photo-series-structure .s01Piece--hero.reveal-on-scroll,
  body.page-photo-series-structure .s01Piece--top.reveal-on-scroll {
    transform: translateY(40px);
  }

  body.page-photo-series-structure .s01Piece.reveal-on-scroll.is-visible,
  body.page-photo-series-structure .s01Piece--hero.reveal-on-scroll.is-visible,
  body.page-photo-series-structure .s01Piece--top.reveal-on-scroll.is-visible {
    transform: translateY(0);
  }
}

/* Structure of Silence — Section 02 layered cinematic composition */
body.page-photo-series-structure .s02Timeline {
  width: min(100%, 1620px);
  margin: 0 auto;
  padding: clamp(92px, 11vw, 150px) clamp(18px, 3vw, 38px)
    clamp(96px, 12vw, 170px);
  box-sizing: border-box;
}

body.page-photo-series-structure .s02Track {
  position: relative;
  width: min(100%, 1460px);
  height: clamp(500px, 52vw, 600px);
  margin: 0 auto;
}

body.page-photo-series-structure .s02Item {
  margin: 0;
  position: absolute;
}

body.page-photo-series-structure .s02Item img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  filter: grayscale(100%);
  box-shadow: 0 3px 12px rgba(0, 0, 0, 0.13);
  transition: transform 400ms ease, box-shadow 400ms ease;
  cursor: zoom-in;
}

/* 01 — curved architecture, bottom-left anchor */
body.page-photo-series-structure .s02Item--01 {
  width: 30%;
  left: 3%;
  bottom: 10px;
  z-index: 4;
}

/* 02 — fog tower, top-center focal */
body.page-photo-series-structure .s02Item--02 {
  width: 25%;
  left: 42%;
  top: 0;
  z-index: 5;
}

/* 03 — cables, lower middle support */
body.page-photo-series-structure .s02Item--03 {
  width: 27%;
  left: 52%;
  top: 416px;
  z-index: 3;
}

/* 04 — light curve, right-side accent */
body.page-photo-series-structure .s02Item--04 {
  width: 27%;
  left: 67%;
  top: 252px;
  z-index: 6;
}

/* 05 — vertical bars, large background field */
body.page-photo-series-structure .s02Item--05 {
  width: 58%;
  left: 20%;
  top: 88px;
  z-index: 1;
}

body.page-photo-series-structure .s02Item:hover {
  z-index: 8;
}

body.page-photo-series-structure .s02Item:hover img {
  transform: scale(1.03);
  box-shadow: 0 6px 16px rgba(255, 255, 255, 0.05), 0 8px 22px rgba(0, 0, 0, 0.18);
}

body.page-photo-series-structure .s02Item.reveal-on-scroll {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 360ms ease, transform 360ms ease;
}

body.page-photo-series-structure .s02Item.reveal-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

body.page-photo-series-structure .s02Item--01.reveal-on-scroll {
  transition-delay: 40ms;
}
body.page-photo-series-structure .s02Item--02.reveal-on-scroll {
  transition-delay: 100ms;
}
body.page-photo-series-structure .s02Item--03.reveal-on-scroll {
  transition-delay: 160ms;
}
body.page-photo-series-structure .s02Item--04.reveal-on-scroll {
  transition-delay: 220ms;
}
body.page-photo-series-structure .s02Item--05.reveal-on-scroll {
  transition-delay: 280ms;
}

@media (max-width: 1100px) {
  body.page-photo-series-structure .s02Timeline {
    padding: clamp(76px, 9.5vw, 110px) 16px clamp(84px, 10.5vw, 120px);
  }

  body.page-photo-series-structure .s02Track {
    height: clamp(500px, 76vw, 650px);
  }

  body.page-photo-series-structure .s02Item--01 {
    width: 34%;
    left: 0;
    bottom: 6px;
  }

  body.page-photo-series-structure .s02Item--02 {
    width: 28%;
    left: 36%;
    top: 0;
  }

  body.page-photo-series-structure .s02Item--03 {
    width: 31%;
    left: 48%;
    top: 390px;
  }

  body.page-photo-series-structure .s02Item--04 {
    width: 30%;
    left: 62%;
    top: 236px;
  }

  body.page-photo-series-structure .s02Item--05 {
    width: 64%;
    left: 16%;
    top: 90px;
  }
}

@media (max-width: 680px) {
  body.page-photo-series-structure .s02Timeline {
    padding: 60px 16px 82px;
  }

  body.page-photo-series-structure .s02Track {
    height: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 18px;
  }

  body.page-photo-series-structure .s02Item {
    position: static;
    width: auto !important;
  }

  body.page-photo-series-structure .s02Item img {
    width: 100%;
    max-width: none;
  }

  /* Mobile order */
  body.page-photo-series-structure .s02Item--01 {
    order: 1;
  }
  body.page-photo-series-structure .s02Item--02 {
    order: 2;
  }
  body.page-photo-series-structure .s02Item--05 {
    order: 3;
  }
  body.page-photo-series-structure .s02Item--04 {
    order: 4;
  }
  body.page-photo-series-structure .s02Item--03 {
    order: 5;
  }
}

/* Structure of Silence — Section 03 quiet gallery wall */
body.page-photo-series-structure .s03QuietWall {
  width: min(100%, 1600px);
  margin: 0 auto;
  padding: clamp(92px, 11vw, 132px) clamp(20px, 3.2vw, 42px)
    clamp(110px, 13vw, 170px);
  box-sizing: border-box;
}

body.page-photo-series-structure .s03Row {
  position: relative;
  width: min(100%, 1420px);
  height: clamp(560px, 66vw, 760px);
  margin: 0 auto;
}

body.page-photo-series-structure .s03Item {
  margin: 0;
  position: absolute;
}

body.page-photo-series-structure .s03Item img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  filter: grayscale(100%);
  transform: scale(1);
  transform-origin: center;
  box-shadow: 0 3px 12px rgba(0, 0, 0, 0.12);
  transition: transform 240ms ease, box-shadow 240ms ease;
  cursor: zoom-in;
}

body.page-photo-series-structure .s03Item--01 {
  width: 42%;
  left: 4%;
  top: 180px;
  z-index: 6;
}

body.page-photo-series-structure .s03Item--02 {
  width: 42%;
  left: 49%;
  top: 38px;
  z-index: 5;
}

body.page-photo-series-structure .s03Item--03 {
  width: 38%;
  left: 47%;
  top: 300px;
  z-index: 7;
}

body.page-photo-series-structure .s03Item--04 {
  width: 17%;
  left: 73%;
  top: 402px;
  z-index: 8;
}

body.page-photo-series-structure .s03Item:hover img {
  transform: scale(1.03);
  box-shadow: 0 5px 16px rgba(255, 255, 255, 0.04), 0 8px 22px rgba(0, 0, 0, 0.18);
}

@media (max-width: 1200px) {
  body.page-photo-series-structure .s03QuietWall {
    padding: clamp(82px, 10vw, 118px) 16px clamp(96px, 12vw, 142px);
  }

  body.page-photo-series-structure .s03Row {
    height: clamp(520px, 72vw, 700px);
  }

  body.page-photo-series-structure .s03Item--01 {
    width: 46%;
    left: 2%;
    top: 188px;
  }

  body.page-photo-series-structure .s03Item--03 {
    width: 42%;
    left: 45%;
    top: 300px;
  }

  body.page-photo-series-structure .s03Item--04 {
    width: 20%;
    left: 72%;
    top: 394px;
  }

  body.page-photo-series-structure .s03Item--02 {
    width: 44%;
    left: 47%;
    top: 46px;
  }
}

@media (max-width: 760px) {
  body.page-photo-series-structure .s03QuietWall {
    padding: 72px 16px 96px;
  }

  body.page-photo-series-structure .s03Row {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: center;
    align-items: start;
    gap: 22px;
    width: 100%;
    height: auto;
  }

  body.page-photo-series-structure .s03Item {
    position: static;
    width: 100% !important;
    z-index: auto;
  }

  body.page-photo-series-structure .s03Item img {
    width: 100%;
    max-width: 100%;
    height: auto;
  }
}

/* Structure of Silence — Section 04 atmospheric triad */
body.page-photo-series-structure .s04QuietStack {
  width: min(100%, 1600px);
  margin: 0 auto;
  padding: clamp(90px, 11vw, 140px) clamp(20px, 3vw, 42px)
    clamp(130px, 14vw, 190px);
  box-sizing: border-box;
}

body.page-photo-series-structure .s04Stage {
  position: relative;
  width: min(100%, 1260px);
  height: clamp(760px, 78vw, 980px);
  margin: 0 auto;
}

body.page-photo-series-structure .s04Item {
  margin: 0;
  position: absolute;
}

body.page-photo-series-structure .s04Item img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  filter: grayscale(100%);
  box-shadow: 0 3px 12px rgba(0, 0, 0, 0.12);
  transform: scale(1);
  transform-origin: center;
  transition: transform 240ms ease, box-shadow 240ms ease;
  cursor: zoom-in;
}

/* 01 — main front image */
body.page-photo-series-structure .s04Item--01 {
  width: 58%;
  left: 21%;
  top: 160px;
  z-index: 7;
}

/* 04 — fog support behind main */
body.page-photo-series-structure .s04Item--04 {
  width: 34%;
  left: 4%;
  top: 708px;
  z-index: 5;
}

/* 02 — top small image */
body.page-photo-series-structure .s04Item--02 {
  width: 24%;
  left: 35%;
  top: 18px;
  z-index: 8;
}

/* 03 — bottom-right support image */
body.page-photo-series-structure .s04Item--03 {
  width: 23%;
  left: 78%;
  top: 760px;
  z-index: 6;
}

body.page-photo-series-structure .s04Item:hover img {
  transform: scale(1.03);
  box-shadow: 0 5px 16px rgba(255, 255, 255, 0.04), 0 8px 22px rgba(0, 0, 0, 0.18);
}

body.page-photo-series-structure .s04Item.reveal-on-scroll {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 360ms ease, transform 360ms ease;
}

body.page-photo-series-structure .s04Item.reveal-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

body.page-photo-series-structure .s04Item--02.reveal-on-scroll {
  transition-delay: 40ms;
}

body.page-photo-series-structure .s04Item--01.reveal-on-scroll {
  transition-delay: 120ms;
}

body.page-photo-series-structure .s04Item--04.reveal-on-scroll {
  transition-delay: 160ms;
}

body.page-photo-series-structure .s04Item--03.reveal-on-scroll {
  transition-delay: 200ms;
}

@media (max-width: 1200px) {
  body.page-photo-series-structure .s04QuietStack {
    padding: clamp(78px, 10vw, 116px) 16px clamp(102px, 12vw, 148px);
  }

  body.page-photo-series-structure .s04Stage {
    height: clamp(700px, 92vw, 920px);
  }

  body.page-photo-series-structure .s04Item--01 {
    width: 64%;
    left: 18%;
    top: 160px;
  }

  body.page-photo-series-structure .s04Item--04 {
    width: 40%;
    left: 2%;
    top: 700px;
  }

  body.page-photo-series-structure .s04Item--03 {
    width: 26%;
    left: 78%;
    top: 760px;
  }

  body.page-photo-series-structure .s04Item--02 {
    width: 28%;
    left: 35%;
    top: 14px;
  }
}

@media (max-width: 760px) {
  body.page-photo-series-structure .s04QuietStack {
    padding: 66px 16px 96px;
  }

  body.page-photo-series-structure .s04Stage {
    height: auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
    width: 100%;
  }

  body.page-photo-series-structure .s04Item {
    position: static;
    width: 100%;
  }

  body.page-photo-series-structure .s04Item--02 {
    width: 72%;
    justify-self: center;
    order: 1;
  }

  body.page-photo-series-structure .s04Item--01 {
    width: 100%;
    order: 2;
  }

  body.page-photo-series-structure .s04Item--04 {
    width: 88%;
    justify-self: start;
    order: 3;
  }

  body.page-photo-series-structure .s04Item--03 {
    width: 82%;
    justify-self: end;
    order: 4;
  }
}

/* Structure of Silence — Section 05 urban cross composition */
body.page-photo-series-structure .s05UrbanCross {
  width: min(100%, 1600px);
  margin: 0 auto;
  padding: clamp(96px, 11vw, 150px) clamp(20px, 3vw, 44px)
    clamp(118px, 13vw, 180px);
  box-sizing: border-box;
}

body.page-photo-series-structure .s05Stage {
  position: relative;
  width: min(100%, 1280px);
  height: clamp(820px, 88vw, 1040px);
  margin: 0 auto;
}

body.page-photo-series-structure .s05Item {
  margin: 0;
  position: absolute;
}

body.page-photo-series-structure .s05Item img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  filter: grayscale(100%);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.16);
  transition: transform 240ms ease, box-shadow 240ms ease;
  cursor: zoom-in;
}

body.page-photo-series-structure .s05Item--01 {
  width: 34%;
  left: 33%;
  top: 0;
  z-index: 6;
}

body.page-photo-series-structure .s05Item--02 {
  width: 24%;
  left: 38%;
  top: 356px;
  z-index: 7;
}

body.page-photo-series-structure .s05Item--03 {
  width: 24%;
  left: 12%;
  top: 700px;
  z-index: 5;
}

body.page-photo-series-structure .s05Item--04 {
  width: 40%;
  left: 48%;
  top: 700px;
  z-index: 4;
}

body.page-photo-series-structure .s05Item:hover img {
  transform: scale(1.03);
  box-shadow: 0 6px 18px rgba(255, 255, 255, 0.04), 0 10px 24px rgba(0, 0, 0, 0.22);
}

/* Structure of Silence — Section 06 statement panorama */
body.page-photo-series-structure .s06StatementBand {
  margin: 0;
  padding: clamp(88px, 11vw, 140px) 0 clamp(124px, 14vw, 188px);
}

body.page-photo-series-structure .s06StatementImage {
  margin: 0;
  width: min(100%, 1720px);
  margin-left: auto;
  margin-right: auto;
}

body.page-photo-series-structure .s06StatementImage img {
  width: 100%;
  height: clamp(220px, 28vw, 430px);
  display: block;
  object-fit: cover;
  object-position: center center;
  filter: grayscale(100%);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.2);
  transform: scale(1);
  transition: transform 260ms ease, box-shadow 260ms ease;
  cursor: zoom-in;
}

body.page-photo-series-structure .s06StatementImage:hover img {
  transform: scale(1.015);
  box-shadow: 0 10px 30px rgba(255, 255, 255, 0.03), 0 12px 30px rgba(0, 0, 0, 0.22);
}

body.page-photo-series-structure .s06StatementImage.reveal-on-scroll {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 360ms ease, transform 360ms ease;
}

body.page-photo-series-structure .s06StatementImage.reveal-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 900px) {
  body.page-photo-series-structure .s05Stage {
    height: clamp(840px, 128vw, 1100px);
  }

  body.page-photo-series-structure .s05Item--01 {
    width: 42%;
    left: 29%;
  }

  body.page-photo-series-structure .s05Item--02 {
    width: 30%;
    left: 35%;
    top: 390px;
  }

  body.page-photo-series-structure .s05Item--03 {
    width: 27%;
    left: 10%;
    top: 790px;
  }

  body.page-photo-series-structure .s05Item--04 {
    width: 44%;
    left: 46%;
    top: 790px;
  }
}

@media (max-width: 760px) {
  body.page-photo-series-structure .s05UrbanCross {
    padding: 72px 16px 102px;
  }

  body.page-photo-series-structure .s05Stage {
    height: auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
    width: 100%;
  }

  body.page-photo-series-structure .s05Item {
    position: static;
    width: 100% !important;
  }

  body.page-photo-series-structure .s06StatementBand {
    padding: 70px 0 102px;
  }

  body.page-photo-series-structure .s06StatementImage img {
    height: clamp(150px, 36vw, 220px);
  }
}

/* Nature Without Time — Section 01 cinematic restrained sequence */
body.page-photo-series-nature .sosSection01 {
  width: min(100%, 1400px) !important;
  margin: 0 auto !important;
  padding: clamp(1rem, 2vw, 1.5rem) clamp(0.7rem, 1.6vw, 1.4rem)
    clamp(130px, 15vw, 200px) !important;
  box-sizing: border-box;
}

body.page-photo-series-nature .sosComposition {
  position: static !important;
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: clamp(120px, 12vw, 160px) !important;
}

body.page-photo-series-nature .sosImage {
  position: static !important;
  margin: 0 !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  bottom: auto !important;
  transform: none !important;
}

/* Cinematic width rhythm: 70% -> 86% -> 74% */
body.page-photo-series-nature .sosImage--main {
  order: 1;
  width: min(100%, 70%) !important;
}
body.page-photo-series-nature .sosImage--topRight {
  order: 2;
  width: min(100%, 86%) !important;
}
body.page-photo-series-nature .sosImage--bottomRight {
  order: 3;
  width: min(100%, 74%) !important;
}

/* No card feeling: no hover lift, no framed styling */
body.page-photo-series-nature .sosImage img {
  box-shadow: none !important;
  border: 0 !important;
  background: transparent !important;
}

body.page-photo-series-nature .sosImage:hover img {
  transform: none !important;
}

/* Soft, understated reveal motion */
body.page-photo-series-nature .sosImage.reveal-on-scroll {
  opacity: 0;
  transform: translateY(16px) !important;
  transition: opacity 900ms ease, transform 900ms ease;
}
body.page-photo-series-nature .sosImage.reveal-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0) !important;
}

@media (max-width: 900px) {
  body.page-photo-series-nature .sosComposition {
    gap: clamp(82px, 10vw, 118px) !important;
  }
  body.page-photo-series-nature .sosImage--main {
    width: min(100%, 78%) !important;
  }
  body.page-photo-series-nature .sosImage--topRight {
    width: min(100%, 90%) !important;
  }
  body.page-photo-series-nature .sosImage--bottomRight {
    width: min(100%, 82%) !important;
  }
}

@media (max-width: 680px) {
  body.page-photo-series-nature .sosComposition {
    gap: clamp(64px, 9vw, 90px) !important;
  }
}
