/* ============================================================
   PREMIUM LAYER — Muggers of Vadodara
   Coexistence experience · loaded after style.css
   Sections are prefixed px- and used on index/story/field-notes.
   ============================================================ */

/* ------------------------------------------------------------
   SHARED PRIMITIVES
   ------------------------------------------------------------ */
.px-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ochre-deep);
}
.px-eyebrow::before {
  content: "";
  width: 34px;
  height: 1px;
  background: var(--ochre);
}

.px-h2 {
  font-family: var(--f-display);
  font-size: clamp(2.4rem, 5.2vw, 4.4rem);
  line-height: 1.04;
  margin: 0.45em 0 0.35em;
  color: var(--ink);
  font-weight: 400;
}
.px-h2 em {
  font-style: italic;
  color: var(--pond);
}

.px-lead {
  font-size: clamp(1.02rem, 1.5vw, 1.2rem);
  line-height: 1.75;
  color: var(--ink-soft);
  max-width: 58ch;
}

/* Reveal-on-scroll (premium layer uses data-rv) */
[data-rv] {
  opacity: 0;
  transform: translateY(34px);
  transition: opacity 0.9s var(--ease-out), transform 0.9s var(--ease-out);
}
[data-rv].rv-in {
  opacity: 1;
  transform: none;
}

/* ------------------------------------------------------------
   PX-HERO — full-bleed photographic prologue
   ------------------------------------------------------------ */
.px-hero {
  position: relative;
  min-height: 92vh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background: var(--pond-darker);
}
.px-hero__img {
  position: absolute;
  inset: -8% 0;
  width: 100%;
  height: 116%;
  object-fit: cover;
  object-position: center 38%;
  will-change: transform;
  filter: saturate(0.92) contrast(1.04);
}
.px-hero__shade {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(5,28,18,0.55) 0%, rgba(5,28,18,0.05) 34%, rgba(5,28,18,0.16) 58%, rgba(4,18,11,0.92) 100%);
}
.px-hero__inner {
  position: relative;
  z-index: 2;
  width: min(1280px, 92vw);
  margin: 0 auto;
  padding: 0 0 7vh;
  color: var(--cream);
}
.px-hero__kicker {
  display: flex;
  align-items: center;
  gap: 14px;
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.34em;
  text-transform: uppercase;
  color: var(--sun);
  margin-bottom: 18px;
}
.px-hero__kicker::before,
.px-hero__kicker::after {
  content: "";
  height: 1px;
  width: 44px;
  background: rgba(235,200,117,0.55);
}
.px-hero__title {
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(3rem, 8.4vw, 7.6rem);
  line-height: 0.98;
  margin: 0;
  letter-spacing: -0.01em;
  text-wrap: balance;
  text-shadow: 0 4px 60px rgba(2,12,7,0.65);
}
.px-hero__title em {
  font-style: italic;
  color: var(--sun);
}
.px-hero__row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 28px;
  margin-top: 34px;
  padding-top: 26px;
  border-top: 1px solid rgba(245,236,210,0.22);
}
.px-hero__sub {
  max-width: 52ch;
  font-size: clamp(1rem, 1.4vw, 1.18rem);
  line-height: 1.7;
  color: rgba(245,236,210,0.88);
  margin: 0;
}
.px-hero__coords {
  font-family: var(--f-mono);
  font-size: 12.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(235,200,117,0.85);
  text-align: right;
  line-height: 2;
  white-space: nowrap;
}
.px-hero__credit {
  position: absolute;
  right: 18px;
  bottom: 12px;
  z-index: 3;
  font-size: 10.5px;
  letter-spacing: 0.12em;
  color: rgba(245,236,210,0.4);
}

/* ------------------------------------------------------------
   PX-BELT — double marquee band
   ------------------------------------------------------------ */
.px-belt {
  background: var(--pond-deep);
  color: var(--cream);
  overflow: hidden;
  border-top: 1px solid rgba(235,200,117,0.25);
  border-bottom: 1px solid rgba(235,200,117,0.25);
}
.px-belt__row {
  display: flex;
  width: max-content;
  gap: 0;
  padding: 14px 0;
  animation: pxBelt 36s linear infinite;
}
.px-belt__row--rev {
  animation-direction: reverse;
  border-top: 1px dashed rgba(245,236,210,0.16);
  color: var(--sun);
}
.px-belt__row span {
  font-family: var(--f-mono);
  font-size: 13px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  padding: 0 26px;
  white-space: nowrap;
}
.px-belt__row span::after {
  content: "✦";
  margin-left: 52px;
  color: var(--ochre);
  font-size: 11px;
}
@keyframes pxBelt {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ------------------------------------------------------------
   PX-CENSUS — animated counters band
   ------------------------------------------------------------ */
.px-census {
  background: var(--cream);
  padding: clamp(64px, 9vw, 110px) 0 clamp(48px, 7vw, 84px);
}
.px-census__inner {
  width: min(1280px, 92vw);
  margin: 0 auto;
}
.px-census__head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: clamp(36px, 5vw, 64px);
}
.px-census__note {
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.px-census__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1.5px solid var(--ink);
}
.px-census__cell {
  padding: 30px 26px 34px 0;
  border-bottom: 1px solid rgba(14,31,19,0.16);
}
.px-census__cell + .px-census__cell {
  border-left: 1px solid rgba(14,31,19,0.14);
  padding-left: 26px;
}
.px-census__num {
  font-family: var(--f-display);
  font-size: clamp(2.6rem, 5.4vw, 4.6rem);
  line-height: 1;
  color: var(--pond-deep);
}
.px-census__num sup {
  font-size: 0.45em;
  color: var(--ochre-deep);
  margin-left: 2px;
}
.px-census__label {
  margin-top: 12px;
  font-family: var(--f-mono);
  font-size: 12.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.px-census__hint {
  margin-top: 7px;
  font-size: 13.5px;
  color: var(--ink-faint);
  line-height: 1.55;
}

/* ------------------------------------------------------------
   PX-PACT — the coexistence editorial
   ------------------------------------------------------------ */
.px-pact {
  background:
    linear-gradient(180deg, var(--cream) 0%, var(--cream-deep) 100%);
  padding: clamp(60px, 9vw, 120px) 0;
}
.px-pact__inner {
  width: min(1280px, 92vw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(36px, 6vw, 90px);
  align-items: center;
}
.px-pact__photo-wrap {
  position: relative;
}
.px-pact__photo {
  width: 100%;
  aspect-ratio: 4 / 4.6;
  object-fit: cover;
  border-radius: 4px;
  box-shadow: 28px 28px 0 -6px var(--pond-deep), 0 30px 60px rgba(5,28,18,0.25);
}
.px-pact__stamp {
  position: absolute;
  top: -34px;
  right: -26px;
  width: 118px;
  height: 118px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: var(--ochre);
  color: var(--pond-darker);
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-align: center;
  line-height: 1.5;
  transform: rotate(8deg);
  box-shadow: 0 14px 30px rgba(110,75,42,0.35);
  animation: pxStampFloat 5.5s ease-in-out infinite;
}
@keyframes pxStampFloat {
  0%, 100% { transform: rotate(8deg) translateY(0); }
  50%      { transform: rotate(5deg) translateY(-9px); }
}
.px-pact__caption {
  margin-top: 16px;
  font-size: 12.5px;
  letter-spacing: 0.06em;
  color: var(--ink-faint);
}
.px-pact__body p {
  font-size: clamp(1rem, 1.35vw, 1.16rem);
  line-height: 1.85;
  color: var(--ink-soft);
  margin: 0 0 1.2em;
}
.px-pact__body p strong {
  color: var(--pond-deep);
}
.px-pact__sign {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-top: 30px;
  padding-top: 22px;
  border-top: 1px dashed rgba(14,31,19,0.25);
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

/* ------------------------------------------------------------
   PX-RIVER — interactive Vishwamitri map
   ------------------------------------------------------------ */
.px-river {
  background: var(--pond-darker);
  color: var(--cream);
  padding: clamp(70px, 10vw, 130px) 0;
  position: relative;
  overflow: hidden;
}
.px-river__inner {
  width: min(1280px, 92vw);
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.px-river .px-eyebrow { color: var(--sun); }
.px-river .px-eyebrow::before { background: var(--sun); }
.px-river .px-h2 { color: var(--t-title); }
.px-river .px-h2 em { color: var(--sun); }
.px-river__lead { color: rgba(245,236,210,0.78); }

.px-river__stage {
  margin-top: clamp(36px, 5vw, 60px);
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(28px, 4vw, 60px);
  align-items: center;
}
.px-river__map {
  width: 100%;
  height: auto;
  overflow: visible;
}
.px-river__path {
  fill: none;
  stroke: rgba(136,163,122,0.65);
  stroke-width: 10;
  stroke-linecap: round;
  filter: drop-shadow(0 0 18px rgba(77,125,89,0.45));
}
.px-river__path--glow {
  stroke: rgba(235,200,117,0.18);
  stroke-width: 26;
}
.px-river__spot {
  cursor: pointer;
}
.px-river__spot circle.dot {
  fill: var(--sun);
  stroke: var(--pond-darker);
  stroke-width: 3;
  transition: r 0.25s var(--ease), fill 0.25s var(--ease);
}
.px-river__spot circle.halo {
  fill: none;
  stroke: rgba(235,200,117,0.5);
  animation: pxHalo 2.6s ease-out infinite;
}
@keyframes pxHalo {
  0%   { r: 10; opacity: 0.85; }
  100% { r: 30; opacity: 0; }
}
.px-river__spot text {
  fill: rgba(245,236,210,0.78);
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.px-river__spot.is-active circle.dot {
  fill: var(--cream);
}
.px-river__spot.is-active text {
  fill: var(--sun);
}

.px-river__panel {
  background: rgba(245,236,210,0.05);
  border: 1px solid rgba(235,200,117,0.28);
  border-radius: 6px;
  padding: clamp(24px, 3vw, 40px);
  min-height: 320px;
  backdrop-filter: blur(4px);
}
.px-river__panel-tag {
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--sun);
}
.px-river__panel-title {
  font-family: var(--f-display);
  font-size: clamp(1.7rem, 2.6vw, 2.4rem);
  margin: 12px 0 14px;
  color: var(--t-title);
  line-height: 1.1;
}
.px-river__panel-body {
  font-size: 15.5px;
  line-height: 1.8;
  color: rgba(245,236,210,0.82);
}
.px-river__panel-meta {
  display: flex;
  gap: 22px;
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px dashed rgba(235,200,117,0.25);
}
.px-river__panel-meta div span {
  display: block;
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(245,236,210,0.5);
  margin-bottom: 5px;
}
.px-river__panel-meta div strong {
  font-family: var(--f-display);
  font-size: 1.35rem;
  color: var(--sun);
  font-weight: 400;
}

/* ------------------------------------------------------------
   PX-DECK — horizontal fact dossier
   ------------------------------------------------------------ */
.px-deck {
  background: var(--cream);
  padding: clamp(70px, 9vw, 120px) 0;
  overflow: hidden;
}
.px-deck__head {
  width: min(1280px, 92vw);
  margin: 0 auto clamp(30px, 4vw, 52px);
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
}
.px-deck__hint {
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
  display: flex;
  align-items: center;
  gap: 10px;
}
.px-deck__hint::after {
  content: "⟶";
  font-size: 16px;
  color: var(--ochre-deep);
  animation: pxNudge 1.8s ease-in-out infinite;
}
@keyframes pxNudge {
  0%, 100% { transform: translateX(0); }
  50%      { transform: translateX(7px); }
}
.px-deck__rail {
  display: flex;
  gap: 22px;
  overflow-x: auto;
  padding: 6px max(calc((100vw - 1280px) / 2), 4vw) 26px;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  cursor: grab;
}
.px-deck__rail::-webkit-scrollbar { display: none; }
.px-deck__rail.is-dragging { cursor: grabbing; scroll-snap-type: none; }

.px-card {
  flex: 0 0 min(340px, 78vw);
  scroll-snap-align: start;
  background: var(--ivory);
  border: 1.5px solid var(--ink);
  border-radius: 6px;
  padding: 26px 26px 30px;
  position: relative;
  box-shadow: 7px 7px 0 var(--pond-deep);
  transition: transform 0.35s var(--ease), box-shadow 0.35s var(--ease);
  user-select: none;
}
.px-card:hover {
  transform: translateY(-8px) rotate(-0.5deg);
  box-shadow: 11px 13px 0 var(--ochre);
}
.px-card--photo {
  padding: 0;
  overflow: hidden;
  background: var(--pond-darker);
}
.px-card--photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.92;
  pointer-events: none;
}
.px-card__no {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.3em;
  color: var(--ochre-deep);
  text-transform: uppercase;
}
.px-card__big {
  font-family: var(--f-display);
  font-size: clamp(2.6rem, 4vw, 3.6rem);
  line-height: 1;
  color: var(--pond-deep);
  margin: 14px 0 10px;
}
.px-card__big span {
  font-size: 0.5em;
  color: var(--ochre-deep);
}
.px-card__txt {
  font-size: 14.5px;
  line-height: 1.7;
  color: var(--ink-soft);
}
.px-card__foot {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px dashed rgba(14,31,19,0.25);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

/* ------------------------------------------------------------
   PX-MONSOON — dark chapter, the city makes way
   ------------------------------------------------------------ */
.px-monsoon {
  position: relative;
  background: var(--pond-darker);
  color: var(--cream);
  padding: clamp(80px, 11vw, 150px) 0;
  overflow: hidden;
}
.px-monsoon__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.22;
  filter: saturate(0.7);
}
.px-monsoon__veil {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, var(--pond-darker) 0%, rgba(5,28,18,0.35) 30%, rgba(5,28,18,0.45) 70%, var(--pond-darker) 100%);
}
.px-monsoon__inner {
  position: relative;
  z-index: 2;
  width: min(1180px, 92vw);
  margin: 0 auto;
}
.px-monsoon .px-eyebrow { color: var(--sun); }
.px-monsoon .px-eyebrow::before { background: var(--sun); }
.px-monsoon__title {
  font-family: var(--f-display);
  font-size: clamp(2.6rem, 6vw, 5.2rem);
  line-height: 1.02;
  margin: 0.4em 0 0.4em;
  color: var(--t-title);
  max-width: 18ch;
}
.px-monsoon__title em { font-style: italic; color: var(--sun); }
.px-monsoon__lead {
  max-width: 56ch;
  font-size: clamp(1rem, 1.4vw, 1.18rem);
  line-height: 1.8;
  color: rgba(245,236,210,0.85);
}
.px-monsoon__timeline {
  margin-top: clamp(44px, 6vw, 80px);
  border-left: 1.5px solid rgba(235,200,117,0.4);
  padding-left: clamp(24px, 4vw, 48px);
  display: grid;
  gap: clamp(30px, 4vw, 46px);
}
.px-mt {
  position: relative;
  max-width: 680px;
}
.px-mt::before {
  content: "";
  position: absolute;
  left: calc(-1 * clamp(24px, 4vw, 48px) - 7px);
  top: 8px;
  width: 13px;
  height: 13px;
  border-radius: 50%;
  background: var(--sun);
  box-shadow: 0 0 0 5px rgba(235,200,117,0.18);
}
.px-mt__year {
  font-family: var(--f-mono);
  font-size: 12.5px;
  letter-spacing: 0.3em;
  color: var(--sun);
  text-transform: uppercase;
}
.px-mt__title {
  font-family: var(--f-display);
  font-size: clamp(1.4rem, 2.2vw, 1.9rem);
  margin: 8px 0 8px;
  color: var(--t-title);
}
.px-mt__txt {
  font-size: 15px;
  line-height: 1.75;
  color: rgba(245,236,210,0.78);
}
.px-monsoon__counter {
  margin-top: clamp(48px, 6vw, 80px);
  display: flex;
  flex-wrap: wrap;
  gap: clamp(28px, 5vw, 70px);
  border-top: 1px dashed rgba(235,200,117,0.3);
  padding-top: clamp(28px, 4vw, 44px);
}
.px-monsoon__counter div strong {
  display: block;
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(2.4rem, 4.6vw, 3.8rem);
  color: var(--sun);
  line-height: 1;
}
.px-monsoon__counter div span {
  display: block;
  margin-top: 10px;
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: rgba(245,236,210,0.6);
}

/* ------------------------------------------------------------
   PX-MAKARA — myth & culture
   ------------------------------------------------------------ */
.px-makara {
  background: linear-gradient(180deg, var(--cream-deep) 0%, var(--cream) 55%);
  padding: clamp(70px, 10vw, 130px) 0;
}
.px-makara__inner {
  width: min(1280px, 92vw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: clamp(36px, 6vw, 90px);
  align-items: center;
}
.px-makara__art {
  position: relative;
}
.px-makara__photo {
  width: 100%;
  aspect-ratio: 4 / 4.8;
  object-fit: cover;
  border-radius: 200px 200px 6px 6px;
  border: 1.5px solid var(--ink);
  box-shadow: -22px 24px 0 -6px var(--ochre);
  filter: sepia(0.24) contrast(1.02);
}
.px-makara__mascot {
  position: absolute;
  bottom: -28px;
  right: -22px;
  width: clamp(110px, 13vw, 160px);
  filter: drop-shadow(0 16px 24px rgba(5,28,18,0.3));
  mix-blend-mode: multiply;
  animation: pxStampFloat 6s ease-in-out infinite;
}
.px-makara__caption {
  margin-top: 36px;
  font-size: 12.5px;
  color: var(--ink-faint);
  letter-spacing: 0.06em;
}
.px-makara__body p {
  font-size: clamp(1rem, 1.35vw, 1.16rem);
  line-height: 1.85;
  color: var(--ink-soft);
  margin: 0 0 1.2em;
}
.px-makara__glyphs {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}
.px-makara__glyphs span {
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border: 1px solid rgba(14,31,19,0.35);
  border-radius: 100px;
  padding: 9px 18px;
  color: var(--ink-muted);
  background: var(--ivory);
}

/* ------------------------------------------------------------
   PX-RESIDENTS — known individuals (rebuilt)
   ------------------------------------------------------------ */
.px-res {
  background: var(--cream);
  padding: clamp(70px, 9vw, 120px) 0;
}
.px-res__inner {
  width: min(1280px, 92vw);
  margin: 0 auto;
}
.px-res__grid {
  margin-top: clamp(36px, 5vw, 60px);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 2.6vw, 34px);
}
.px-res-card {
  background: var(--ivory);
  border: 1.5px solid var(--ink);
  border-radius: 8px;
  overflow: hidden;
  transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease);
}
.px-res-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 26px 50px rgba(14,31,19,0.18), 8px 10px 0 var(--pond-deep);
}
.px-res-card__art {
  position: relative;
  aspect-ratio: 4 / 3.1;
  overflow: hidden;
  background: var(--pond-darker);
}
.px-res-card__art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s var(--ease);
}
.px-res-card:hover .px-res-card__art img {
  transform: scale(1.06);
}
.px-res-card__id {
  position: absolute;
  top: 14px;
  left: 14px;
  background: var(--pond-darker);
  color: var(--sun);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  padding: 7px 12px;
  border-radius: 3px;
  border: 1px solid rgba(235,200,117,0.5);
}
.px-res-card__body {
  padding: 24px 24px 28px;
}
.px-res-card__name {
  font-family: var(--f-display);
  font-size: 1.65rem;
  margin: 0 0 10px;
  color: var(--pond-deep);
  font-weight: 400;
}
.px-res-card__txt {
  font-size: 14.5px;
  line-height: 1.7;
  color: var(--ink-soft);
  margin: 0 0 16px;
}
.px-res-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.px-res-card__tags span {
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  background: var(--cream-deep);
  border: 1px solid rgba(14,31,19,0.2);
  padding: 5px 11px;
  border-radius: 100px;
  color: var(--ink-muted);
}

/* ------------------------------------------------------------
   PX-GALLERY — river archive + lightbox
   ------------------------------------------------------------ */
.px-gallery {
  background: var(--pond-deep);
  padding: clamp(70px, 9vw, 120px) 0;
  color: var(--cream);
}
.px-gallery__inner {
  width: min(1280px, 92vw);
  margin: 0 auto;
}
.px-gallery .px-eyebrow { color: var(--sun); }
.px-gallery .px-eyebrow::before { background: var(--sun); }
.px-gallery .px-h2 { color: var(--t-title); }
.px-gallery .px-h2 em { color: var(--sun); }
.px-gallery__grid {
  margin-top: clamp(34px, 5vw, 56px);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 200px;
  gap: 14px;
}
.px-gal {
  position: relative;
  border-radius: 5px;
  overflow: hidden;
  cursor: zoom-in;
  border: 1px solid rgba(235,200,117,0.2);
}
.px-gal img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.7s var(--ease), filter 0.7s var(--ease);
  filter: saturate(0.9);
}
.px-gal:hover img {
  transform: scale(1.07);
  filter: saturate(1.05);
}
.px-gal figcaption {
  position: absolute;
  inset: auto 0 0;
  padding: 26px 16px 12px;
  background: linear-gradient(180deg, transparent, rgba(4,18,11,0.85));
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(245,236,210,0.85);
  opacity: 0;
  transform: translateY(8px);
  transition: 0.45s var(--ease);
}
.px-gal:hover figcaption {
  opacity: 1;
  transform: none;
}
.px-gal--w2 { grid-column: span 2; }
.px-gal--h2 { grid-row: span 2; }

/* Lightbox */
.px-lightbox {
  position: fixed;
  inset: 0;
  z-index: 999;
  background: rgba(2,12,7,0.93);
  display: grid;
  place-items: center;
  padding: 4vmin;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s var(--ease);
}
.px-lightbox.is-open {
  opacity: 1;
  pointer-events: auto;
}
.px-lightbox img {
  max-width: 92vw;
  max-height: 84vh;
  border-radius: 6px;
  box-shadow: 0 40px 120px rgba(0,0,0,0.6);
}
.px-lightbox figcaption {
  margin-top: 16px;
  text-align: center;
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(245,236,210,0.75);
}
.px-lightbox__close {
  position: absolute;
  top: 22px;
  right: 26px;
  background: none;
  border: 1px solid rgba(245,236,210,0.4);
  color: var(--cream);
  width: 46px;
  height: 46px;
  border-radius: 50%;
  font-size: 19px;
  transition: 0.3s;
}
.px-lightbox__close:hover {
  background: var(--cream);
  color: var(--pond-darker);
}

/* ------------------------------------------------------------
   PX-CODE — the riverbank code (do / don't)
   ------------------------------------------------------------ */
.px-code {
  background: var(--cream);
  padding: clamp(70px, 9vw, 120px) 0;
}
.px-code__inner {
  width: min(1180px, 92vw);
  margin: 0 auto;
}
.px-code__cols {
  margin-top: clamp(34px, 5vw, 56px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(22px, 3vw, 40px);
}
.px-code__col {
  border: 1.5px solid var(--ink);
  border-radius: 8px;
  overflow: hidden;
  background: var(--ivory);
}
.px-code__col-head {
  padding: 18px 26px;
  font-family: var(--f-mono);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.px-code__col--do .px-code__col-head {
  background: var(--pond-deep);
  color: var(--reed);
}
.px-code__col--dont .px-code__col-head {
  background: var(--terracotta);
  color: var(--ivory);
}
.px-code__list {
  list-style: none;
  margin: 0;
  padding: 10px 0;
}
.px-code__list li {
  display: flex;
  gap: 16px;
  padding: 16px 26px;
  font-size: 15px;
  line-height: 1.65;
  color: var(--ink-soft);
}
.px-code__list li + li {
  border-top: 1px dashed rgba(14,31,19,0.18);
}
.px-code__list li::before {
  flex: 0 0 auto;
  font-family: var(--f-mono);
  font-size: 13px;
  margin-top: 2px;
}
.px-code__col--do .px-code__list li::before {
  content: "✓";
  color: var(--pond);
}
.px-code__col--dont .px-code__list li::before {
  content: "✕";
  color: var(--terracotta);
}

/* ------------------------------------------------------------
   PX-VISIT — closing CTA
   ------------------------------------------------------------ */
.px-visit {
  background: var(--cream);
  padding: 0 0 clamp(80px, 10vw, 130px);
}
.px-visit__card {
  width: min(1280px, 92vw);
  margin: 0 auto;
  background: var(--pond-darker);
  border-radius: 12px;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  color: var(--cream);
  box-shadow: 0 40px 80px rgba(5,28,18,0.35);
}
.px-visit__copy {
  padding: clamp(36px, 5vw, 72px);
}
.px-visit .px-eyebrow { color: var(--sun); }
.px-visit .px-eyebrow::before { background: var(--sun); }
.px-visit__title {
  font-family: var(--f-display);
  font-size: clamp(2rem, 3.8vw, 3.3rem);
  line-height: 1.06;
  margin: 0.4em 0 0.45em;
  color: var(--t-title);
}
.px-visit__title em { color: var(--sun); font-style: italic; }
.px-visit__txt {
  font-size: 15.5px;
  line-height: 1.8;
  color: rgba(245,236,210,0.82);
  max-width: 46ch;
}
.px-visit__list {
  list-style: none;
  margin: 26px 0 30px;
  padding: 0;
  display: grid;
  gap: 12px;
}
.px-visit__list li {
  display: flex;
  gap: 14px;
  font-size: 14.5px;
  color: rgba(245,236,210,0.85);
  border-bottom: 1px dashed rgba(235,200,117,0.22);
  padding-bottom: 12px;
}
.px-visit__list li span {
  flex: 0 0 92px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--sun);
  padding-top: 3px;
}
.px-visit__art {
  position: relative;
  min-height: 420px;
}
.px-visit__art img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.px-visit__art::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, var(--pond-darker) 0%, transparent 26%);
}

/* ------------------------------------------------------------
   PX-FOOT — grand footer
   ------------------------------------------------------------ */
.px-foot {
  background: var(--pond-darker);
  color: var(--cream);
  padding: clamp(60px, 8vw, 100px) 0 34px;
  border-top: 1px solid rgba(235,200,117,0.2);
}
.px-foot__inner {
  width: min(1280px, 92vw);
  margin: 0 auto;
}
.px-foot__word {
  font-family: var(--f-display);
  font-size: clamp(2.6rem, 7.5vw, 6.4rem);
  line-height: 1;
  color: var(--t-title);
  border-bottom: 1px solid rgba(235,200,117,0.25);
  padding-bottom: clamp(26px, 4vw, 44px);
  margin-bottom: clamp(26px, 4vw, 44px);
  text-wrap: balance;
}
.px-foot__word em { color: var(--sun); font-style: italic; }
.px-foot__grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr 1fr;
  gap: clamp(26px, 4vw, 60px);
}
.px-foot__tag {
  font-size: 14.5px;
  line-height: 1.75;
  color: rgba(245,236,210,0.7);
  max-width: 34ch;
}
.px-foot__col h4 {
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--sun);
  margin: 0 0 16px;
}
.px-foot__col a {
  display: block;
  font-size: 14.5px;
  color: rgba(245,236,210,0.78);
  padding: 5px 0;
  transition: 0.25s;
}
.px-foot__col a:hover {
  color: var(--sun);
  transform: translateX(5px);
}
.px-foot__bottom {
  margin-top: clamp(40px, 5vw, 64px);
  padding-top: 22px;
  border-top: 1px dashed rgba(245,236,210,0.18);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 12px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(245,236,210,0.45);
}

/* ============================================================
   STORY PAGE — chaptered long read
   ============================================================ */
.px-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  width: 0%;
  background: linear-gradient(90deg, var(--ochre), var(--sun));
  z-index: 1001;
}
.st-hero {
  position: relative;
  min-height: 86vh;
  display: flex;
  align-items: flex-end;
  background: var(--pond-darker);
  overflow: hidden;
}
.st-hero__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.5;
  filter: saturate(0.85);
}
.st-hero__shade {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(5,28,18,0.4), rgba(4,18,11,0.95));
}
.st-hero__inner {
  position: relative;
  z-index: 2;
  width: min(900px, 92vw);
  margin: 0 auto;
  padding-bottom: 9vh;
  text-align: center;
  color: var(--cream);
}
.st-hero__kicker {
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.36em;
  text-transform: uppercase;
  color: var(--sun);
}
.st-hero__title {
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(3rem, 8vw, 6.8rem);
  line-height: 1;
  margin: 0.3em 0;
  color: var(--t-title);
}
.st-hero__title em { color: var(--sun); font-style: italic; }
.st-hero__dek {
  font-size: clamp(1rem, 1.5vw, 1.2rem);
  line-height: 1.75;
  color: rgba(245,236,210,0.85);
  max-width: 56ch;
  margin: 0 auto;
}
.st-hero__meta {
  margin-top: 30px;
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: rgba(245,236,210,0.55);
}

.st-chapter {
  background: var(--cream);
  padding: clamp(76px, 10vw, 130px) 0 clamp(40px, 6vw, 70px);
}
.st-chapter--dark {
  background: var(--pond-darker);
  color: var(--cream);
}
.st-chapter__inner {
  width: min(760px, 92vw);
  margin: 0 auto;
}
.st-chapter__no {
  display: flex;
  align-items: center;
  gap: 18px;
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.34em;
  text-transform: uppercase;
  color: var(--ochre-deep);
}
.st-chapter--dark .st-chapter__no { color: var(--sun); }
.st-chapter__no::after {
  content: "";
  flex: 1;
  height: 1px;
  background: currentColor;
  opacity: 0.4;
}
.st-chapter__title {
  font-family: var(--f-display);
  font-size: clamp(2.3rem, 5vw, 4rem);
  line-height: 1.05;
  margin: 0.5em 0 0.6em;
  color: var(--pond-deep);
  font-weight: 400;
}
.st-chapter--dark .st-chapter__title { color: var(--t-title); }
.st-chapter__title em { font-style: italic; color: var(--ochre-deep); }
.st-chapter--dark .st-chapter__title em { color: var(--sun); }
.st-body p {
  font-size: clamp(1.05rem, 1.45vw, 1.2rem);
  line-height: 1.95;
  color: var(--ink-soft);
  margin: 0 0 1.4em;
}
.st-chapter--dark .st-body p { color: rgba(245,236,210,0.84); }
.st-body p:first-of-type::first-letter {
  font-family: var(--f-display);
  font-size: 4.2em;
  float: left;
  line-height: 0.8;
  padding: 8px 14px 0 0;
  color: var(--ochre-deep);
}
.st-chapter--dark .st-body p:first-of-type::first-letter { color: var(--sun); }

.st-figure {
  width: min(1080px, 94vw);
  margin: clamp(40px, 6vw, 70px) auto;
}
.st-figure img {
  width: 100%;
  max-height: 72vh;
  object-fit: cover;
  border-radius: 6px;
  box-shadow: 0 30px 70px rgba(5,28,18,0.3);
}
.st-figure figcaption {
  margin-top: 14px;
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-faint);
  display: flex;
  gap: 12px;
  align-items: center;
}
.st-figure figcaption::before {
  content: "";
  width: 26px;
  height: 1px;
  background: var(--ochre);
}
.st-quote {
  width: min(860px, 92vw);
  margin: clamp(46px, 7vw, 80px) auto;
  text-align: center;
}
.st-quote blockquote {
  font-family: var(--f-display);
  font-size: clamp(1.6rem, 3.4vw, 2.7rem);
  line-height: 1.3;
  font-style: italic;
  color: var(--pond-deep);
  margin: 0 0 18px;
}
.st-quote cite {
  font-family: var(--f-mono);
  font-style: normal;
  font-size: 11.5px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.st-note {
  border: 1.5px dashed var(--ochre);
  background: var(--ivory);
  border-radius: 8px;
  padding: 22px 26px;
  margin: 30px 0;
  font-size: 14.5px;
  line-height: 1.75;
  color: var(--ink-soft);
}
.st-note strong {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--ochre-deep);
  display: block;
  margin-bottom: 8px;
}
.st-next {
  background: var(--cream);
  padding: clamp(60px, 9vw, 110px) 0;
}
.st-next__card {
  width: min(860px, 92vw);
  margin: 0 auto;
  display: block;
  text-align: center;
  border: 1.5px solid var(--ink);
  border-radius: 10px;
  background: var(--ivory);
  padding: clamp(36px, 5vw, 60px);
  box-shadow: 8px 9px 0 var(--pond-deep);
  transition: 0.35s var(--ease);
}
.st-next__card:hover {
  transform: translateY(-7px);
  box-shadow: 12px 14px 0 var(--ochre);
}
.st-next__eyebrow {
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ochre-deep);
}
.st-next__title {
  font-family: var(--f-display);
  font-size: clamp(1.8rem, 3.6vw, 2.9rem);
  color: var(--pond-deep);
  margin: 14px 0 8px;
}
.st-next__sub {
  color: var(--ink-muted);
  font-size: 15px;
}

/* ============================================================
   FIELD NOTES — the dossier
   ============================================================ */
.fn-hero {
  background: var(--pond-darker);
  color: var(--cream);
  padding: clamp(120px, 16vh, 180px) 0 clamp(56px, 8vw, 90px);
  position: relative;
  overflow: hidden;
}
.fn-hero__inner {
  width: min(1280px, 92vw);
  margin: 0 auto;
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(32px, 5vw, 70px);
  align-items: center;
}
.fn-hero .px-eyebrow { color: var(--sun); }
.fn-hero .px-eyebrow::before { background: var(--sun); }
.fn-hero__title {
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(2.8rem, 6.4vw, 5.6rem);
  line-height: 1;
  margin: 0.35em 0;
  color: var(--t-title);
}
.fn-hero__title em { color: var(--sun); font-style: italic; }
.fn-hero__sub {
  font-size: clamp(1rem, 1.4vw, 1.15rem);
  line-height: 1.8;
  color: rgba(245,236,210,0.82);
  max-width: 50ch;
}
.fn-hero__plate {
  position: relative;
  border: 1px solid rgba(235,200,117,0.4);
  border-radius: 8px;
  padding: 14px;
  background: rgba(245,236,210,0.04);
}
.fn-hero__plate img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: 4px;
}
.fn-hero__plate-tag {
  position: absolute;
  top: -13px;
  left: 22px;
  background: var(--ochre);
  color: var(--pond-darker);
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 3px;
}
.fn-hero__taxo {
  margin: 18px 4px 4px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 18px;
  font-size: 12.5px;
}
.fn-hero__taxo div span {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(245,236,210,0.5);
  display: block;
}
.fn-hero__taxo div em {
  font-style: italic;
  color: var(--sun);
}

.fn-vitals {
  background: var(--cream);
  padding: clamp(60px, 8vw, 100px) 0;
}
.fn-vitals__inner {
  width: min(1280px, 92vw);
  margin: 0 auto;
}
.fn-vitals__grid {
  margin-top: clamp(30px, 4vw, 50px);
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 16px;
}
.fn-vital {
  border: 1.5px solid var(--ink);
  border-radius: 8px;
  background: var(--ivory);
  padding: 22px 18px 24px;
  text-align: center;
  transition: 0.3s var(--ease);
}
.fn-vital:hover {
  background: var(--pond-deep);
  transform: translateY(-6px);
}
.fn-vital:hover .fn-vital__num { color: var(--sun); }
.fn-vital:hover .fn-vital__label { color: rgba(245,236,210,0.7); }
.fn-vital__num {
  font-family: var(--f-display);
  font-size: clamp(1.7rem, 2.6vw, 2.4rem);
  color: var(--pond-deep);
  line-height: 1.05;
  transition: 0.3s;
}
.fn-vital__num span { font-size: 0.55em; color: var(--ochre-deep); }
.fn-vital__label {
  margin-top: 10px;
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
  transition: 0.3s;
}

/* Anatomy plate with hotspot pins */
.fn-anatomy {
  background: var(--pond-deep);
  color: var(--cream);
  padding: clamp(70px, 9vw, 120px) 0;
}
.fn-anatomy__inner {
  width: min(1180px, 92vw);
  margin: 0 auto;
}
.fn-anatomy .px-eyebrow { color: var(--sun); }
.fn-anatomy .px-eyebrow::before { background: var(--sun); }
.fn-anatomy .px-h2 { color: var(--t-title); }
.fn-anatomy .px-h2 em { color: var(--sun); }
.fn-anatomy__stage {
  position: relative;
  margin-top: clamp(34px, 5vw, 54px);
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid rgba(235,200,117,0.35);
}
.fn-anatomy__stage > img {
  width: 100%;
  display: block;
}
.fn-pin {
  position: absolute;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: none;
  background: var(--sun);
  color: var(--pond-darker);
  font-family: var(--f-mono);
  font-size: 13px;
  font-weight: 700;
  display: grid;
  place-items: center;
  cursor: pointer;
  box-shadow: 0 0 0 6px rgba(235,200,117,0.25);
  transition: 0.3s var(--ease);
}
.fn-pin:hover, .fn-pin.is-on {
  transform: scale(1.18);
  background: var(--cream);
}
.fn-pin__tip {
  position: absolute;
  bottom: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%) translateY(6px);
  width: 240px;
  background: var(--cream);
  color: var(--ink);
  border-radius: 6px;
  padding: 14px 16px;
  font-size: 13px;
  line-height: 1.6;
  text-align: left;
  opacity: 0;
  pointer-events: none;
  transition: 0.3s var(--ease);
  box-shadow: 0 18px 40px rgba(0,0,0,0.35);
  z-index: 5;
}
.fn-pin__tip strong {
  display: block;
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ochre-deep);
  margin-bottom: 6px;
}
.fn-pin.is-on .fn-pin__tip {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* Numbered fact grid */
.fn-facts {
  background: var(--cream);
  padding: clamp(70px, 9vw, 120px) 0;
}
.fn-facts__inner {
  width: min(1280px, 92vw);
  margin: 0 auto;
}
.fn-facts__grid {
  margin-top: clamp(34px, 5vw, 56px);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1.5px solid var(--ink);
  border-left: 1.5px solid var(--ink);
}
.fn-fact {
  border-right: 1.5px solid var(--ink);
  border-bottom: 1.5px solid var(--ink);
  padding: clamp(22px, 3vw, 34px);
  background: var(--ivory);
  transition: background 0.3s;
  position: relative;
}
.fn-fact:hover {
  background: var(--reed);
}
.fn-fact__no {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.26em;
  color: var(--ochre-deep);
}
.fn-fact__title {
  font-family: var(--f-display);
  font-size: 1.4rem;
  margin: 12px 0 10px;
  color: var(--pond-deep);
  line-height: 1.15;
}
.fn-fact__txt {
  font-size: 14px;
  line-height: 1.7;
  color: var(--ink-soft);
}

/* Myth vs fact */
.fn-myth {
  background: var(--cream-deep);
  padding: clamp(70px, 9vw, 120px) 0;
}
.fn-myth__inner {
  width: min(960px, 92vw);
  margin: 0 auto;
}
.fn-myth__list {
  margin-top: clamp(30px, 4vw, 48px);
  display: grid;
  gap: 16px;
}
.fn-myth__item {
  border: 1.5px solid var(--ink);
  border-radius: 8px;
  background: var(--ivory);
  overflow: hidden;
}
.fn-myth__q {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 16px;
  text-align: left;
  background: none;
  border: none;
  padding: 20px 24px;
  font-family: var(--f-body);
  font-size: clamp(1rem, 1.5vw, 1.15rem);
  color: var(--ink);
}
.fn-myth__q .tag {
  flex: 0 0 auto;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  background: var(--terracotta);
  color: var(--ivory);
  padding: 6px 12px;
  border-radius: 100px;
}
.fn-myth__q .arrow {
  margin-left: auto;
  transition: transform 0.35s var(--ease);
  color: var(--ochre-deep);
}
.fn-myth__item.is-open .arrow {
  transform: rotate(180deg);
}
.fn-myth__a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.5s var(--ease);
}
.fn-myth__a-inner {
  padding: 0 24px 24px;
  display: flex;
  gap: 16px;
  font-size: 15px;
  line-height: 1.75;
  color: var(--ink-soft);
}
.fn-myth__a-inner .tag {
  flex: 0 0 auto;
  align-self: flex-start;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  background: var(--pond-deep);
  color: var(--reed);
  padding: 6px 12px;
  border-radius: 100px;
}

/* Quiz */
.fn-quiz {
  background: var(--pond-darker);
  color: var(--cream);
  padding: clamp(70px, 9vw, 120px) 0;
}
.fn-quiz__inner {
  width: min(820px, 92vw);
  margin: 0 auto;
  text-align: center;
}
.fn-quiz .px-eyebrow { color: var(--sun); justify-content: center; }
.fn-quiz .px-eyebrow::before { background: var(--sun); }
.fn-quiz .px-h2 { color: var(--t-title); }
.fn-quiz .px-h2 em { color: var(--sun); }
.fn-quiz__card {
  margin-top: clamp(30px, 4vw, 48px);
  border: 1px solid rgba(235,200,117,0.35);
  border-radius: 10px;
  background: rgba(245,236,210,0.05);
  padding: clamp(28px, 4vw, 48px);
}
.fn-quiz__progress {
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--sun);
  margin-bottom: 18px;
}
.fn-quiz__q {
  font-family: var(--f-display);
  font-size: clamp(1.5rem, 2.8vw, 2.2rem);
  line-height: 1.25;
  color: var(--t-title);
  margin: 0 0 28px;
}
.fn-quiz__opts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.fn-quiz__opt {
  border: 1px solid rgba(245,236,210,0.4);
  background: none;
  color: var(--cream);
  border-radius: 8px;
  padding: 16px 18px;
  font-size: 15px;
  text-align: left;
  transition: 0.25s var(--ease);
}
.fn-quiz__opt:hover {
  background: rgba(245,236,210,0.1);
  border-color: var(--sun);
}
.fn-quiz__opt.is-right {
  background: var(--pond);
  border-color: var(--reed);
  color: var(--reed);
}
.fn-quiz__opt.is-wrong {
  background: rgba(176,104,70,0.35);
  border-color: var(--terracotta);
  color: rgba(245,236,210,0.7);
}
.fn-quiz__note {
  margin-top: 20px;
  font-size: 14px;
  line-height: 1.7;
  color: rgba(245,236,210,0.8);
  min-height: 44px;
}
.fn-quiz__next {
  margin-top: 10px;
  background: var(--ochre);
  border: none;
  color: var(--pond-darker);
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  padding: 14px 30px;
  border-radius: 100px;
  transition: 0.25s;
}
.fn-quiz__next:hover { background: var(--sun); }
.fn-quiz__score {
  font-family: var(--f-display);
  font-size: clamp(2.4rem, 5vw, 4rem);
  color: var(--sun);
  margin: 10px 0 14px;
}

/* ============================================================
   RESPONSIVE — premium layer
   ============================================================ */
@media (max-width: 1020px) {
  .px-census__grid { grid-template-columns: 1fr 1fr; }
  .px-census__cell:nth-child(odd) { border-left: none; padding-left: 0; }
  .px-census__cell:nth-child(even) { border-left: 1px solid rgba(14,31,19,0.14); padding-left: 26px; }
  .px-gallery__grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 190px; }
  .px-res__grid { grid-template-columns: 1fr 1fr; }
  .fn-vitals__grid { grid-template-columns: repeat(3, 1fr); }
  .fn-facts__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 880px) {
  .px-pact__inner,
  .px-makara__inner,
  .px-river__stage,
  .px-visit__card,
  .fn-hero__inner { grid-template-columns: 1fr; }
  .px-pact__photo { aspect-ratio: 4/3.4; }
  .px-pact__stamp { top: auto; bottom: -30px; right: 10px; width: 100px; height: 100px; }
  .px-makara__photo { aspect-ratio: 4/3.6; }
  .px-visit__art { min-height: 300px; }
  .px-visit__art::after { background: linear-gradient(180deg, var(--pond-darker), transparent 30%); }
  .px-foot__grid { grid-template-columns: 1fr 1fr; }
  .px-code__cols { grid-template-columns: 1fr; }
  .px-res__grid { grid-template-columns: 1fr; }
  .px-hero__coords { text-align: left; }
}
@media (max-width: 560px) {
  .px-gallery__grid { grid-template-columns: 1fr; grid-auto-rows: 230px; }
  .px-gal--w2 { grid-column: span 1; }
  .px-gal--h2 { grid-row: span 1; }
  .fn-vitals__grid { grid-template-columns: 1fr 1fr; }
  .fn-facts__grid { grid-template-columns: 1fr; }
  .fn-quiz__opts { grid-template-columns: 1fr; }
  .px-foot__grid { grid-template-columns: 1fr; }
  .px-census__grid { grid-template-columns: 1fr; }
  .px-census__cell { padding-left: 0 !important; border-left: none !important; }
  .fn-hero__taxo { grid-template-columns: 1fr; }
}

/* ============================================================
   V2 — NEW CINEMATIC INTRO (replaces the 3D stage)
   Pure CSS/JS. No Three.js, no garba.
   ============================================================ */
.intro {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: var(--bg-base);
  isolation: isolate;
}
.intro__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 42%;
  opacity: 0.5;
  filter: saturate(0.85) contrast(1.06);
  transform: scale(1.12);
  animation: introZoom 22s ease-in-out infinite alternate;
  z-index: -3;
}
@keyframes introZoom {
  from { transform: scale(1.12) translateY(0); }
  to   { transform: scale(1.22) translateY(-2%); }
}
.intro__veil {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(120% 90% at 50% 18%, rgba(4,18,11,0.15) 0%, rgba(2,12,7,0.72) 62%, var(--bg-base) 100%),
    linear-gradient(180deg, rgba(2,12,7,0.7) 0%, rgba(2,12,7,0.1) 38%, rgba(2,12,7,0.55) 78%, var(--bg-base) 100%);
}
.intro__caustics {
  position: absolute;
  inset: -20%;
  z-index: -1;
  background:
    radial-gradient(40% 22% at 30% 40%, rgba(120,170,120,0.10), transparent 70%),
    radial-gradient(34% 18% at 70% 55%, rgba(235,200,117,0.08), transparent 70%),
    radial-gradient(28% 16% at 52% 30%, rgba(120,170,120,0.08), transparent 70%);
  mix-blend-mode: screen;
  animation: introCaustics 16s ease-in-out infinite alternate;
}
@keyframes introCaustics {
  from { transform: translate3d(-2%, -1%, 0) scale(1); opacity: 0.7; }
  to   { transform: translate3d(3%, 2%, 0) scale(1.08); opacity: 1; }
}
.intro__inner {
  position: relative;
  z-index: 2;
  width: min(1080px, 92vw);
  text-align: center;
  color: var(--cream);
  padding: 8vh 0;
}
.intro__eyebrow {
  font-family: var(--f-mono);
  font-size: clamp(10px, 1.1vw, 12.5px);
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--sun);
  opacity: 0;
  animation: introUp 1s var(--ease-out) 0.2s forwards;
}
.intro__waterline {
  width: min(560px, 80vw);
  height: 2px;
  margin: 26px auto 30px;
  border-radius: 2px;
  background: linear-gradient(90deg, transparent, var(--sun) 18%, var(--cream) 50%, var(--sun) 82%, transparent);
  box-shadow: 0 0 28px rgba(235,200,117,0.6);
  transform: scaleX(0);
  transform-origin: center;
  animation: introLine 1.5s var(--ease-out) 0.45s forwards;
}
@keyframes introLine {
  from { transform: scaleX(0); opacity: 0; }
  to   { transform: scaleX(1); opacity: 1; }
}
.intro__title {
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(3.2rem, 10vw, 9rem);
  line-height: 0.94;
  margin: 0;
  letter-spacing: -0.015em;
  text-shadow: 0 6px 70px rgba(2,12,7,0.7);
}
.intro__title .w {
  display: inline-block;
  opacity: 0;
  transform: translateY(46px) rotate(2deg);
  animation: introWord 1.1s var(--ease-out) forwards;
}
.intro__title .w:nth-child(1) { animation-delay: 0.55s; }
.intro__title .w:nth-child(2) { animation-delay: 0.72s; color: var(--sun); font-style: italic; }
.intro__title .w:nth-child(3) { animation-delay: 0.89s; }
@keyframes introWord {
  to { opacity: 1; transform: none; }
}
.intro__sub {
  max-width: 42ch;
  margin: 26px auto 0;
  font-size: clamp(1rem, 1.6vw, 1.32rem);
  line-height: 1.7;
  color: rgba(245,236,210,0.9);
  opacity: 0;
  animation: introUp 1.1s var(--ease-out) 1.15s forwards;
}
@keyframes introUp {
  from { opacity: 0; transform: translateY(26px); }
  to   { opacity: 1; transform: none; }
}
.intro__ripples {
  position: absolute;
  left: 50%;
  bottom: 12vh;
  width: 10px;
  height: 10px;
  transform: translateX(-50%);
  z-index: 1;
}
.intro__ripples span {
  position: absolute;
  inset: 0;
  margin: auto;
  width: 120px;
  height: 120px;
  margin-left: -60px;
  margin-top: -60px;
  border: 1px solid rgba(235,200,117,0.45);
  border-radius: 50%;
  opacity: 0;
  animation: introRipple 4.5s ease-out infinite;
}
.intro__ripples span:nth-child(2) { animation-delay: 1.5s; }
.intro__ripples span:nth-child(3) { animation-delay: 3s; }
@keyframes introRipple {
  0%   { transform: scale(0.2); opacity: 0.6; }
  100% { transform: scale(2.2); opacity: 0; }
}
.intro__cue {
  position: absolute;
  left: 50%;
  bottom: 4vh;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgba(245,236,210,0.72);
  opacity: 0;
  animation: introUp 1s var(--ease-out) 1.6s forwards;
}
.intro__cue-arrow {
  font-size: 17px;
  color: var(--sun);
  animation: introBounce 1.8s ease-in-out infinite;
}
@keyframes introBounce {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(7px); }
}

/* ---- HOME nav: transparent over the dark intro, solid on scroll ---- */
body.home .nav.is-visible {
  background: transparent !important;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-bottom-color: transparent;
  box-shadow: none;
}
body.home .nav.is-visible .nav__brand-text { color: var(--cream); }
body.home .nav.is-visible .nav__brand-sub  { color: rgba(245,236,210,0.62); }
body.home .nav.is-visible .nav__link       { color: rgba(245,236,210,0.86); }
body.home .nav.is-visible .nav__link:hover { color: var(--sun); }
body.home .nav.is-visible .nav__brand      { color: var(--cream); }
body.home .nav.is-visible .nav__bag        { color: var(--cream); }
body.home .nav.is-visible .nav__brand-mark { background: rgba(235,200,117,0.85); color: var(--pond-darker); }

body.home .nav.is-visible.is-solid {
  background: rgba(244,236,216,0.9) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom-color: rgba(27,90,58,0.1);
}
body.home .nav.is-visible.is-solid .nav__brand-text { color: var(--pond-deep); }
body.home .nav.is-visible.is-solid .nav__brand-sub  { color: var(--ink-muted); }
body.home .nav.is-visible.is-solid .nav__link       { color: var(--ink-soft); }
body.home .nav.is-visible.is-solid .nav__link:hover { color: var(--pond); }
body.home .nav.is-visible.is-solid .nav__brand      { color: var(--pond); }
body.home .nav.is-visible.is-solid .nav__bag        { color: var(--ink); }
body.home .nav.is-visible.is-solid .nav__brand-mark { background: var(--reed); color: var(--pond); }

body.home .page { padding-top: 0; }
body.home .page::before { display: none; }

/* ============================================================
   PX-CLOCK — A day on the river (informational, 4 phases)
   ============================================================ */
.px-clock {
  background: var(--pond-darker);
  color: var(--cream);
  padding: clamp(70px, 9vw, 120px) 0;
  position: relative;
  overflow: hidden;
}
.px-clock__inner {
  width: min(1280px, 92vw);
  margin: 0 auto;
}
.px-clock .px-eyebrow { color: var(--sun); }
.px-clock .px-eyebrow::before { background: var(--sun); }
.px-clock .px-h2 { color: var(--t-title); }
.px-clock .px-h2 em { color: var(--sun); }
.px-clock__lead { color: rgba(245,236,210,0.78); }
.px-clock__strip {
  height: 8px;
  border-radius: 8px;
  margin: clamp(32px, 4vw, 50px) 0 4px;
  background: linear-gradient(90deg, #20364a 0%, #c98a4a 26%, #ebc875 50%, #b06846 74%, #0c1a2a 100%);
  box-shadow: 0 0 30px rgba(235,200,117,0.25);
}
.px-clock__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-left: 1px dashed rgba(235,200,117,0.28);
}
.px-clock__cell {
  padding: 26px clamp(16px, 2vw, 28px) 8px;
  border-right: 1px dashed rgba(235,200,117,0.28);
  transition: background 0.4s var(--ease);
}
.px-clock__cell:hover { background: rgba(245,236,210,0.05); }
.px-clock__time {
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--sun);
}
.px-clock__phase {
  font-family: var(--f-display);
  font-size: clamp(1.4rem, 2.4vw, 2rem);
  margin: 10px 0 12px;
  color: var(--t-title);
  line-height: 1.1;
}
.px-clock__txt {
  font-size: 14.5px;
  line-height: 1.72;
  color: rgba(245,236,210,0.78);
}

/* ============================================================
   PX-CLOSE — closing statement (replaces the old Visit CTA)
   ============================================================ */
.px-close {
  position: relative;
  min-height: 86vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  background: var(--pond-darker);
}
.px-close__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.4;
  filter: saturate(0.85);
}
.px-close__veil {
  position: absolute;
  inset: 0;
  background: radial-gradient(120% 100% at 50% 50%, rgba(2,12,7,0.45), rgba(2,12,7,0.9));
}
.px-close__inner {
  position: relative;
  z-index: 2;
  width: min(960px, 92vw);
  color: var(--cream);
  padding: 10vh 0;
}
.px-close__mark {
  font-family: var(--f-display);
  font-size: 4rem;
  line-height: 0;
  color: var(--sun);
  opacity: 0.7;
}
.px-close__title {
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(2.2rem, 5.4vw, 4.6rem);
  line-height: 1.1;
  margin: 0.3em 0 0.5em;
  color: var(--t-title);
  text-wrap: balance;
}
.px-close__title em { font-style: italic; color: var(--sun); }
.px-close__line {
  font-size: clamp(1rem, 1.5vw, 1.22rem);
  line-height: 1.8;
  color: rgba(245,236,210,0.85);
  max-width: 52ch;
  margin: 0 auto;
}
.px-close__sign {
  margin-top: 34px;
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: rgba(235,200,117,0.8);
}

@media (max-width: 880px) {
  .px-clock__grid { grid-template-columns: 1fr 1fr; }
  .px-clock__cell:nth-child(n+3) { border-top: 1px dashed rgba(235,200,117,0.28); }
}
@media (max-width: 560px) {
  .px-clock__grid { grid-template-columns: 1fr; }
}

/* ============================================================
   HERO CAROUSEL — 6 auto-sliding intro slides (homepage)
   ============================================================ */
.hero-cx {
  position: relative;
  height: 100vh;
  min-height: 600px;
  overflow: hidden;
  background: var(--pond-darker);
}
.hero-cx__track {
  display: flex;
  height: 100%;
  width: 100%;
  transition: transform 0.9s cubic-bezier(0.76, 0, 0.24, 1);
  will-change: transform;
}
.hero-cx__slide {
  position: relative;
  flex: 0 0 100%;
  height: 100%;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
}
.hero-cx__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 40%;
  transform: scale(1.04);
  filter: saturate(0.95) contrast(1.04);
}
.hero-cx__slide.is-active .hero-cx__img {
  animation: heroKen 8s ease-out forwards;
}
@keyframes heroKen {
  from { transform: scale(1.04); }
  to   { transform: scale(1.13); }
}
.hero-cx__veil {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(5,28,18,0.50) 0%, rgba(5,28,18,0.06) 32%, rgba(4,18,11,0.30) 58%, rgba(3,14,8,0.93) 100%);
}

.hero-cx__inner {
  position: relative;
  z-index: 2;
  width: min(1280px, 92vw);
  margin: 0 auto;
  padding: 0 0 13vh;
  color: var(--cream);
}
.hero-cx__eyebrow {
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.34em;
  text-transform: uppercase;
  color: var(--sun);
  margin: 0 0 18px;
}
.hero-cx__title {
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(2.6rem, 6.6vw, 6rem);
  line-height: 0.99;
  letter-spacing: -0.01em;
  margin: 0;
  max-width: 16ch;
  text-wrap: balance;
  text-shadow: 0 4px 60px rgba(2,12,7,0.6);
}
.hero-cx__slide--brand .hero-cx__title {
  font-size: clamp(3.2rem, 9vw, 8rem);
  max-width: none;
}
.hero-cx__title em { font-style: italic; color: var(--sun); }
.hero-cx__sub {
  max-width: 48ch;
  margin: 22px 0 0;
  font-size: clamp(1rem, 1.5vw, 1.22rem);
  line-height: 1.65;
  color: rgba(245,236,210,0.9);
}
.hero-cx__cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 30px;
  padding: 14px 28px;
  border-radius: 100px;
  background: var(--sun);
  color: var(--pond-darker);
  font-family: var(--f-mono);
  font-size: 12.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background 0.3s var(--ease-out), transform 0.3s var(--ease-out);
}
.hero-cx__cta:hover { background: var(--ochre); transform: translateY(-2px); }
.hero-cx__cta--ghost {
  background: transparent;
  color: var(--cream);
  border: 1px solid rgba(245,236,210,0.5);
}
.hero-cx__cta--ghost:hover { background: rgba(245,236,210,0.12); border-color: var(--cream); }

/* entrance animation for active slide content */
.hero-cx__inner > * {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out);
}
.hero-cx__slide.is-active .hero-cx__eyebrow { opacity: 1; transform: none; transition-delay: 0.15s; }
.hero-cx__slide.is-active .hero-cx__title  { opacity: 1; transform: none; transition-delay: 0.28s; }
.hero-cx__slide.is-active .hero-cx__sub    { opacity: 1; transform: none; transition-delay: 0.42s; }
.hero-cx__slide.is-active .hero-cx__cta    { opacity: 1; transform: none; transition-delay: 0.56s; }

/* arrows */
.hero-cx__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 6;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 1px solid rgba(245,236,210,0.4);
  background: rgba(5,28,18,0.28);
  backdrop-filter: blur(6px);
  color: var(--cream);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background 0.3s, transform 0.3s, border-color 0.3s;
}
.hero-cx__nav:hover { background: rgba(5,28,18,0.55); border-color: var(--cream); transform: translateY(-50%) scale(1.08); }
.hero-cx__nav--prev { left: clamp(14px, 3vw, 40px); }
.hero-cx__nav--next { right: clamp(14px, 3vw, 40px); }

/* dots + progress */
.hero-cx__dots {
  position: absolute;
  left: 0; right: 0;
  bottom: clamp(20px, 4vh, 40px);
  z-index: 6;
  display: flex;
  gap: 12px;
  justify-content: center;
}
.hero-cx__dot {
  position: relative;
  width: 38px;
  height: 4px;
  border: none;
  padding: 0;
  border-radius: 100px;
  background: rgba(245,236,210,0.32);
  cursor: pointer;
  overflow: hidden;
  transition: background 0.3s;
}
.hero-cx__dot::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 0;
  background: var(--sun);
  border-radius: 100px;
}
.hero-cx__dot.is-active { background: rgba(245,236,210,0.5); }
.hero-cx__dot.is-active::after { width: 100%; transition: width var(--hero-fill, 3800ms) linear; }

@media (max-width: 640px) {
  .hero-cx__nav { width: 44px; height: 44px; font-size: 18px; }
  .hero-cx__inner { padding-bottom: 16vh; }
  .hero-cx__sub { font-size: 0.98rem; }
}

/* Touch: keep the slim progress-bar look but enlarge the tap target */
@media (hover: none), (pointer: coarse) {
  .hero-cx__dots { gap: 16px; }
  .hero-cx__dot {
    width: 30px;
    height: 28px;
    background: transparent;
    display: flex;
    align-items: center;
  }
  .hero-cx__dot::before {
    content: "";
    position: absolute;
    left: 0; right: 0; top: 50%;
    transform: translateY(-50%);
    height: 4px;
    border-radius: 100px;
    background: rgba(245, 236, 210, 0.32);
  }
  .hero-cx__dot.is-active::before { background: rgba(245, 236, 210, 0.5); }
  .hero-cx__dot::after {
    top: 50%;
    bottom: auto;
    height: 4px;
    transform: translateY(-50%);
  }
}
@media (prefers-reduced-motion: reduce) {
  .hero-cx__slide.is-active .hero-cx__img { animation: none; }
  .hero-cx__inner > * { opacity: 1; transform: none; transition: none; }
  .hero-cx__dot.is-active::after { transition: none; }
}
