/* ============================================================
   WILD LIGHT — Mara Venn, Nature Photographer
   Spiral + Index views · click-open lightbox · overlay pages
   ============================================================ */

:root {
  --bg: #0b0f0c;
  --bg-soft: #10150f;
  --ink: #e9e4d8;
  --ink-dim: rgba(233, 228, 216, 0.55);
  --ink-faint: rgba(233, 228, 216, 0.28);
  --moss: #a8b892;
  --amber: #c9a36b;
  --serif: "Fraunces", Georgia, serif;
  --sans: "Space Grotesk", system-ui, sans-serif;
  --ease: cubic-bezier(0.65, 0, 0.35, 1);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html, body { height: 100%; overflow: hidden; }

body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-weight: 300;
  cursor: none;
  -webkit-font-smoothing: antialiased;
}

button { font: inherit; color: inherit; background: none; border: none; cursor: none; }
a { color: inherit; text-decoration: none; cursor: none; }
::selection { background: var(--moss); color: var(--bg); }
svg { fill: none; stroke: currentColor; stroke-width: 1.4; stroke-linecap: round; stroke-linejoin: round; }

html { scrollbar-width: none; }
::-webkit-scrollbar { width: 0; height: 0; }

/* ---------- WebGL canvas ---------- */
#webgl {
  position: fixed; inset: 0; width: 100%; height: 100%;
  z-index: 0; display: block;
}

/* gallery gestures own the touch — no page scroll / pull-to-refresh / zoom fighting them */
#webgl, .stage, .view { touch-action: none; }
.page__scroll { touch-action: pan-y; }

.veil {
  position: fixed; left: 0; right: 0; height: 24vh;
  z-index: 1; pointer-events: none;
  transition: opacity 0.6s ease;
}
.veil--top    { top: 0;    background: linear-gradient(var(--bg), transparent); }
.veil--bottom { bottom: 0; background: linear-gradient(transparent, var(--bg)); }
body.list-mode .veil { opacity: 0; }

.grain {
  position: fixed; inset: -100%; z-index: 41; pointer-events: none;
  opacity: 0.07;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation: grain 0.9s steps(6) infinite;
}
@keyframes grain {
  0%{transform:translate(0,0)} 20%{transform:translate(-6%,4%)} 40%{transform:translate(4%,-6%)}
  60%{transform:translate(-4%,-4%)} 80%{transform:translate(6%,6%)} 100%{transform:translate(0,0)}
}

/* ---------- Preloader ---------- */
.preloader {
  position: fixed; inset: 0; z-index: 100; background: var(--bg);
  display: flex; align-items: center; justify-content: center;
}
.preloader__inner { text-align: center; }
.preloader__label {
  font-size: 11px; letter-spacing: 0.35em; text-transform: uppercase;
  color: var(--ink-dim); margin-bottom: 2rem;
}
.preloader__counter {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(4rem, 12vw, 9rem); line-height: 1;
  font-variant-numeric: tabular-nums;
}
.preloader__counter::after { content: "%"; font-size: 0.35em; color: var(--moss); }
.preloader__bar {
  width: min(340px, 60vw); height: 1px; margin: 2.2rem auto 0;
  background: rgba(233, 228, 216, 0.12); overflow: hidden;
}
.preloader__bar span { display: block; height: 100%; width: 0%; background: var(--moss); }

/* ---------- Cursor (camera) ---------- */
.cursor { position: fixed; top: 0; left: 0; z-index: 95; pointer-events: none; }
.cursor__ring {
  position: absolute; width: 46px; height: 46px; margin: -23px; border-radius: 50%;
  border: 1px solid rgba(233, 228, 216, 0.18);
  transition: width .35s var(--ease), height .35s var(--ease), margin .35s var(--ease), border-color .35s var(--ease), background-color .35s var(--ease);
}
.cursor.is-hover .cursor__ring {
  width: 78px; height: 78px; margin: -39px;
  border-color: rgba(168, 184, 146, 0.85); background: rgba(168, 184, 146, 0.07);
}
.cursor.is-open .cursor__ring { width: 94px; height: 94px; margin: -47px; border-color: var(--amber); }
.cursor__cam {
  position: absolute; width: 26px; height: 26px; margin: -13px; color: var(--ink);
  transition: color .3s ease;
}
.cursor__cam svg { width: 100%; height: 100%; }
.cursor__cam svg path, .cursor__cam svg circle { stroke: currentColor; stroke-width: 1; fill: none; }
.cursor.is-hover .cursor__cam { color: var(--moss); }
.cursor.is-open .cursor__cam { color: var(--amber); }
.cursor__label {
  position: absolute; top: 26px; left: 26px; font-size: 10px; letter-spacing: 0.25em;
  text-transform: uppercase; white-space: nowrap; color: var(--moss); opacity: 0;
  transition: opacity .3s ease;
}
.cursor.has-label .cursor__label { opacity: 1; }
@media (hover: none) { .cursor { display: none; } body, a, button { cursor: auto; } }

/* ---------- Shutter flash ---------- */
.shutter {
  position: fixed; inset: 0; z-index: 200; pointer-events: none; opacity: 0;
  background: radial-gradient(ellipse at center, #fff 0%, #f4f2ea 45%, rgba(255,255,255,0) 75%);
}

/* ---------- Nav ---------- */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 60;
  display: flex; justify-content: space-between; align-items: center;
  padding: 1.5rem clamp(1.2rem, 4vw, 3rem);
}
.nav__logo {
  font-family: var(--serif); font-size: 1.15rem; letter-spacing: 0.02em;
  display: inline-flex; align-items: center; gap: 0.6rem; mix-blend-mode: difference;
}
.nav__mark { width: 18px; height: 18px; color: var(--moss); }

.nav__center {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.45rem 0.6rem; border: 1px solid rgba(233, 228, 216, 0.12); border-radius: 100px;
  backdrop-filter: blur(6px); background: rgba(11, 15, 12, 0.25);
}
.viewtab {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--ink-dim); padding: 0.35rem 0.7rem; border-radius: 100px;
  transition: color .4s ease, background-color .4s ease;
}
.viewtab svg { width: 15px; height: 15px; }
.viewtab.is-active { color: var(--bg); background: var(--moss); }
.viewtab__sep { width: 1px; height: 14px; background: rgba(233, 228, 216, 0.15); }

.nav__links { display: flex; gap: 2rem; mix-blend-mode: difference; }
.nav__links button {
  font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; position: relative;
}
.nav__links button::after {
  content: ""; position: absolute; left: 0; bottom: -5px; width: 100%; height: 1px;
  background: currentColor; transform: scaleX(0); transform-origin: right; transition: transform .45s var(--ease);
}
.nav__links button:hover::after { transform: scaleX(1); transform-origin: left; }

/* ---------- Time-of-day switch ---------- */
.timeswitch {
  position: fixed; left: clamp(1.2rem, 4vw, 3rem); top: 50%; transform: translateY(-50%);
  z-index: 55; display: flex; flex-direction: column; gap: 0.5rem;
  padding: 0.5rem 0.4rem; border: 1px solid rgba(233,228,216,0.12); border-radius: 100px;
  background: rgba(11,15,12,0.28); backdrop-filter: blur(6px);
}
.timebtn {
  width: 34px; height: 34px; display: grid; place-items: center; border-radius: 50%;
  color: var(--ink-dim); transition: color .4s ease, background-color .4s ease;
}
.timebtn svg { width: 18px; height: 18px; }
.timebtn:hover { color: var(--ink); }
.timebtn.is-active { color: var(--bg); background: var(--moss); }

/* ---------- Stage / views ---------- */
.stage { position: fixed; inset: 0; z-index: 2; }
.view {
  position: absolute; inset: 0;
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.7s ease, visibility 0.7s ease;
}
.view.is-active { opacity: 1; visibility: visible; pointer-events: auto; }

/* ---------- Spiral view HUD ---------- */
.view--spiral { pointer-events: none; }
.view--spiral.is-active { pointer-events: auto; }

.hero__titles {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  text-align: center; pointer-events: none; width: min(92vw, 1100px);
}
.hero__titles::before {
  content: ""; position: absolute; inset: -30% -20%;
  background: radial-gradient(ellipse 55% 52% at 50% 50%, rgba(11,15,12,0.72), transparent 70%);
  z-index: -1;
}
.hero__eyebrow { font-size: 11px; letter-spacing: 0.4em; text-transform: uppercase; color: var(--ink-dim); margin-bottom: 1.4rem; }
.hero__h1 { font-family: var(--serif); font-weight: 300; font-size: clamp(4.5rem, 17vw, 15rem); line-height: 0.86; letter-spacing: -0.02em; text-transform: uppercase; }
.hero__word { display: block; overflow: hidden; padding: 0.05em 0; }
.hero__word--italic { font-style: italic; text-transform: lowercase; color: var(--moss); margin-top: -0.04em; }
.hero__letters { display: inline-block; }
.hero__letters .ltr { display: inline-block; will-change: transform; }
.hero__sub { margin-top: 1.8rem; font-size: clamp(0.8rem, 1.4vw, 1rem); color: var(--ink-dim); letter-spacing: 0.06em; }
.reveal-line { overflow: hidden; }
.reveal-line > span { display: inline-block; }

/* spiral decorative frame (awwwards flourish) */
.deco { position: absolute; inset: 0; pointer-events: none; z-index: 2; opacity: 0; }
.view--spiral.is-active .deco { opacity: 1; transition: opacity 1s ease 0.6s; }
.deco__corner { position: absolute; width: 26px; height: 26px; border: 1px solid rgba(233,228,216,0.28); }
.deco__corner--tl { top: clamp(5.5rem,10vh,7rem); left: clamp(1.2rem,4vw,3rem); border-right: 0; border-bottom: 0; }
.deco__corner--tr { top: clamp(5.5rem,10vh,7rem); right: clamp(1.2rem,4vw,3rem); border-left: 0; border-bottom: 0; }
.deco__corner--bl { bottom: clamp(5.5rem,10vh,7rem); left: clamp(1.2rem,4vw,3rem); border-right: 0; border-top: 0; }
.deco__corner--br { bottom: clamp(5.5rem,10vh,7rem); right: clamp(1.2rem,4vw,3rem); border-left: 0; border-top: 0; }
.deco__reticle {
  position: absolute; top: 50%; left: 50%; width: 30px; height: 30px; margin: -15px;
  border: 1px solid rgba(168,184,146,0.35); border-radius: 50%;
}
.deco__reticle::before, .deco__reticle::after { content: ""; position: absolute; background: rgba(168,184,146,0.45); }
.deco__reticle::before { top: 50%; left: -8px; right: -8px; height: 1px; }
.deco__reticle::after { left: 50%; top: -8px; bottom: -8px; width: 1px; }
.deco__coord { position: absolute; top: 50%; transform: translateY(-50%); font-size: 9px; letter-spacing: 0.3em; color: var(--ink-faint); }
.deco__coord--l { left: clamp(1.2rem,4vw,3rem); }
.deco__coord--r { right: clamp(1.2rem,4vw,3rem); writing-mode: horizontal-tb; }

.hud { position: absolute; z-index: 3; opacity: 0; }
.hud--chapter { left: clamp(1.2rem, 4vw, 3rem); bottom: 2.6rem; }
.chapter__index { font-size: 11px; letter-spacing: 0.3em; color: var(--amber); margin-bottom: 0.4rem; }
.chapter__name { font-family: var(--serif); font-style: italic; font-size: clamp(1.6rem, 3vw, 2.6rem); overflow: hidden; }
.chapter__name span { display: inline-block; }

.hud--count {
  right: clamp(1.2rem, 4vw, 3rem); top: 50%; transform: translateY(-50%);
  writing-mode: vertical-rl; font-size: 11px; letter-spacing: 0.3em; color: var(--ink-dim);
  display: flex; align-items: center; gap: 0.6rem;
}
.count__slash { color: var(--ink-faint); }
#countNow { color: var(--ink); }

.hud--cue {
  left: 50%; bottom: 2.2rem; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
  font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ink-dim);
}
.hud--cue svg { width: 20px; height: 20px; color: var(--moss); animation: bob 1.8s var(--ease) infinite; }
@keyframes bob { 0%,100%{transform:translateY(-3px)} 50%{transform:translateY(3px)} }

/* ---------- List / Index view ---------- */
.view--list { background: var(--bg); }
.list__rail {
  position: absolute; top: 50%; left: 0; transform: translateY(-50%);
  width: 100%; height: 46vh; overflow: visible;
  perspective: 1400px;
}
.list__track { position: absolute; top: 0; left: 0; height: 100%; display: flex; align-items: center; will-change: transform; transform-style: preserve-3d; }
.list__item {
  position: relative; flex: 0 0 auto; height: 100%;
  width: clamp(148px, 15vw, 244px); margin: 0 clamp(0.6rem, 1.4vw, 1.5rem);
  display: flex; flex-direction: column; justify-content: center;
  transform: scale(0.88); transition: transform .7s var(--ease);
  transform-style: preserve-3d;
}
.list__item.is-focus { transform: scale(1); }
.list__frame {
  position: relative; height: 76%; overflow: hidden; border-radius: 2px;
  filter: brightness(0.68) saturate(0.85) blur(0px);
  transition: filter .35s var(--ease);
  transform-style: preserve-3d; backface-visibility: hidden; will-change: transform, filter;
}
.list__frame img { width: 100%; height: 100%; object-fit: cover; display: block; }
.list__item.is-focus .list__frame { filter: brightness(1) saturate(1.05) blur(0px); }
/* hover-focus: hovered tile stays crisp, all others blur out fast */
.list__rail.has-hover .list__item:not(.is-hovered) .list__frame { filter: brightness(0.5) saturate(0.7) blur(6px); }
.list__rail.has-hover .list__item.is-hovered .list__frame { filter: brightness(1.05) saturate(1.1) blur(0px); }
.list__rail.has-hover .list__item:not(.is-hovered) { opacity: 0.7; }
.list__cap { display: flex; justify-content: space-between; align-items: baseline; gap: 0.6rem; margin-top: 0.9rem; opacity: 0.5; transition: opacity .5s ease; }
.list__item.is-focus .list__cap { opacity: 1; }
.list__cap b { font-family: var(--serif); font-style: italic; font-weight: 400; font-size: 0.9rem; white-space: nowrap; }
.list__cap span { font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-faint); white-space: nowrap; }
/* cute, alive index number in the frame corner */
.list__idx {
  position: absolute; top: 0.35rem; left: 0.5rem; z-index: 3; pointer-events: none;
  font-family: "Gochi Hand", cursive; font-size: 1.5rem; line-height: 1; color: var(--ink);
  text-shadow: 0 2px 10px rgba(0,0,0,0.6); transform-origin: 50% 100%;
  animation: idxbob 2.6s ease-in-out infinite;
}
.list__item.is-focus .list__idx { color: var(--amber); }
@keyframes idxbob {
  0%,100% { transform: translateY(0) rotate(-4deg); }
  50%     { transform: translateY(-4px) rotate(3deg); }
}

.list__readout {
  position: absolute; bottom: clamp(2rem, 8vh, 5rem); left: clamp(1.2rem, 4vw, 3rem);
  pointer-events: none;
}
.list__num { font-size: 11px; letter-spacing: 0.3em; color: var(--ink-dim); margin-bottom: 0.5rem; }
.list__num i { color: var(--ink-faint); font-style: normal; }
.list__title { font-family: var(--serif); font-style: italic; font-size: clamp(2rem, 5vw, 3.4rem); }
.hud--cue-h { flex-direction: row; bottom: clamp(2rem, 8vh, 5rem); left: auto; right: clamp(1.2rem, 4vw, 3rem); transform: none; opacity: 1; }
.hud--cue-h svg { animation: bobx 1.8s var(--ease) infinite; }
@keyframes bobx { 0%,100%{transform:translateX(-3px)} 50%{transform:translateX(3px)} }

/* ---------- Overlay pages ---------- */
.page {
  position: fixed; inset: 0; z-index: 70; background: var(--bg-soft);
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity .6s ease, visibility .6s ease;
}
.page.is-open { opacity: 1; visibility: visible; pointer-events: auto; }
.page__scroll { position: absolute; inset: 0; overflow-y: auto; padding: 16vh clamp(1.4rem, 6vw, 6rem) 12vh; }
.page__scroll--center { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; }
.page__close {
  position: fixed; top: 1.5rem; right: clamp(1.2rem, 4vw, 3rem); z-index: 2;
  width: 46px; height: 46px; border: 1px solid rgba(233,228,216,0.2); border-radius: 50%;
  display: grid; place-items: center; transition: transform .5s var(--ease), border-color .4s ease;
}
.page__close svg { width: 18px; height: 18px; }
.page__close:hover { transform: rotate(90deg); border-color: var(--moss); }

.page__kicker {
  display: inline-flex; align-items: center; gap: 0.6rem;
  font-size: 11px; letter-spacing: 0.35em; text-transform: uppercase; color: var(--amber); margin-bottom: 1.6rem;
}
.page__kicker svg { width: 16px; height: 16px; }
.page__title { font-family: var(--serif); font-weight: 300; font-size: clamp(3.5rem, 11vw, 10rem); line-height: 0.9; text-transform: uppercase; }
.page__title .i { font-style: italic; text-transform: lowercase; color: var(--moss); }
.page__title span { display: inline-block; }

.about2 { max-width: 1200px; }
.about2__lead {
  font-family: var(--serif); font-weight: 300; font-size: clamp(1.8rem, 4.4vw, 3.6rem);
  line-height: 1.2; margin: 6vh 0 10vh; max-width: 20ch;
}
.about2__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.5rem, 4vw, 4rem); }
.about2__col h3 { font-family: var(--serif); font-style: italic; font-size: 1.4rem; margin: 1rem 0 0.7rem; }
.about2__col p { color: var(--ink-dim); line-height: 1.7; font-size: 0.95rem; }
.about2__ico { display: inline-grid; place-items: center; width: 46px; height: 46px; border: 1px solid rgba(233,228,216,0.15); border-radius: 50%; color: var(--moss); }
.about2__ico svg { width: 22px; height: 22px; }
.about2__stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; margin-top: 12vh; border-top: 1px solid rgba(233,228,216,0.1); padding-top: 4vh; }
.about2__stats b { display: block; font-family: var(--serif); font-weight: 300; font-size: clamp(2.4rem, 5vw, 4rem); }
.about2__stats span { font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--ink-faint); }

.contact2__mail {
  font-family: var(--serif); font-weight: 300; font-style: italic;
  font-size: clamp(2rem, 8vw, 6.5rem); border-bottom: 1px solid rgba(233,228,216,0.25);
  padding-bottom: 0.08em; margin: 1.5rem 0 4vh; transition: color .5s ease, border-color .5s ease;
}
.contact2__mail:hover { color: var(--moss); border-color: var(--moss); }
.contact2__row { display: flex; gap: clamp(1.5rem, 5vw, 4rem); flex-wrap: wrap; justify-content: center; margin-bottom: 8vh; }
.contact2__link { display: inline-flex; align-items: center; gap: 0.6rem; font-size: 11px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--ink-dim); transition: color .4s ease; }
.contact2__link:hover { color: var(--ink); }
.contact2__link span { display: inline-grid; place-items: center; width: 34px; height: 34px; border: 1px solid rgba(233,228,216,0.15); border-radius: 50%; color: var(--moss); }
.contact2__link svg { width: 16px; height: 16px; }

.marquee { width: 100vw; border-top: 1px solid rgba(233,228,216,0.08); border-bottom: 1px solid rgba(233,228,216,0.08); padding: 1rem 0; overflow: hidden; white-space: nowrap; }
.marquee__track { display: inline-flex; will-change: transform; }
.marquee__track span { font-size: 12px; letter-spacing: 0.45em; text-transform: uppercase; color: var(--ink-dim); padding-right: 2rem; }

/* pop-up text prep (JS splits + animates) */
.word-mask { display: inline-block; overflow: hidden; vertical-align: top; }
.word-mask > span { display: inline-block; }

/* float-on-hover for About / Contact text */
.float-word { display: inline-block; transition: transform 0.4s var(--ease), color 0.35s ease, text-shadow 0.35s ease; }
.float-word:hover { transform: translateY(-9px); color: var(--amber); text-shadow: 0 10px 24px rgba(0,0,0,0.4); }
.page__title span { transition: transform 0.45s var(--ease), color 0.35s ease; }
.page__title span:hover { transform: translateY(-12px); color: var(--amber); }
.about2__col, .about2__stats > div, .contact2__link, .contact2__mail {
  transition: transform 0.45s var(--ease), color 0.4s ease, border-color 0.4s ease;
}
.about2__col:hover, .about2__stats > div:hover { transform: translateY(-10px); }
.about2__col:hover h3 { color: var(--amber); }
.about2__stats > div:hover b { color: var(--moss); }
.contact2__link:hover { transform: translateY(-7px); }
.contact2__mail:hover { transform: translateY(-6px); }

/* ---------- Lightbox ---------- */
.lightbox { position: fixed; inset: 0; z-index: 85; pointer-events: none; visibility: hidden; }
.lightbox.is-open { pointer-events: auto; visibility: visible; }
.lightbox__bg { position: absolute; inset: 0; background: rgba(7, 10, 8, 0.92); backdrop-filter: blur(4px); opacity: 0; }
.lightbox__media { position: fixed; overflow: hidden; will-change: transform, width, height; border-radius: 2px; }
.lightbox__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.lightbox__caption { position: absolute; left: 50%; bottom: clamp(2rem, 6vh, 4rem); transform: translateX(-50%); text-align: center; width: min(90vw, 640px); }
.lb__index { font-size: 11px; letter-spacing: 0.35em; color: var(--amber); margin-bottom: 0.7rem; }
.lb__title { font-family: var(--serif); font-weight: 300; font-size: clamp(2rem, 5vw, 3.6rem); line-height: 1; }
.lb__line { font-family: var(--serif); font-style: italic; font-size: clamp(1rem, 1.8vw, 1.35rem); color: var(--moss); margin-top: 1rem; line-height: 1.5; }

/* photographer credit header */
.lb__cred { position: absolute; top: clamp(1.6rem, 7vh, 3.4rem); left: clamp(1.4rem, 5vw, 4rem); max-width: min(40vw, 440px); z-index: 4; }
.lb__cred-k { display: inline-flex; align-items: center; gap: 0.5rem; font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--amber); margin-bottom: 1rem; }
.lb__cred-k svg { width: 15px; height: 15px; }
.lb__cred-name { font-family: var(--serif); font-weight: 300; font-size: clamp(1.9rem, 3.6vw, 3.1rem); line-height: 1; margin-bottom: 0.8rem; text-shadow: 0 2px 18px rgba(0,0,0,0.55); }
.lb__cred-role { font-size: clamp(0.85rem, 1.1vw, 1rem); color: var(--ink-dim); line-height: 1.55; margin-bottom: 0.7rem; max-width: 32ch; text-shadow: 0 2px 14px rgba(0,0,0,0.6); }
.lb__cred-loc { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-faint); text-shadow: 0 2px 14px rgba(0,0,0,0.6); }
.lb__title, .lb__line { text-shadow: 0 2px 18px rgba(0,0,0,0.5); }

/* hover-highlight words (camera cursor over the letters → orange + green glow) */
.lb-word { display: inline-block; transition: color 0.3s ease, text-shadow 0.35s ease, transform 0.3s var(--ease); }
.lb-word:hover { color: var(--amber); text-shadow: 0 0 22px rgba(168, 184, 146, 0.65), 0 0 7px rgba(201, 163, 107, 0.55); transform: translateY(-2px); }
.lightbox__close {
  position: absolute; top: 1.6rem; right: clamp(1.2rem, 4vw, 3rem); z-index: 3;
  width: 46px; height: 46px; border: 1px solid rgba(233,228,216,0.25); border-radius: 50%;
  display: grid; place-items: center; opacity: 0; transition: transform .5s var(--ease), border-color .4s ease;
}
.lightbox__close svg { width: 18px; height: 18px; }
.lightbox__close:hover { transform: rotate(90deg); border-color: var(--amber); }
.lightbox__nav { position: absolute; inset: 0; display: flex; justify-content: space-between; align-items: center; padding: 0 clamp(0.8rem, 3vw, 2.4rem); pointer-events: none; }
.lightbox__nav button { pointer-events: auto; width: 54px; height: 54px; border: 1px solid rgba(233,228,216,0.18); border-radius: 50%; display: grid; place-items: center; color: var(--ink-dim); opacity: 0; transition: color .4s ease, border-color .4s ease, background-color .4s ease; }
.lightbox__nav button:hover { color: var(--bg); background: var(--moss); border-color: var(--moss); }
.lightbox__nav svg { width: 20px; height: 20px; }

/* ---------- Responsive ---------- */
@media (max-width: 820px) {
  .nav__center { position: fixed; left: 50%; bottom: 1.4rem; top: auto; transform: translateX(-50%); }
  .about2__cols { grid-template-columns: 1fr; gap: 3rem; }
  .about2__stats { grid-template-columns: repeat(2, 1fr); gap: 2rem 1rem; }
  .list__item { width: 64vw; }
  .list__rail { height: 52vh; }
  .list__idx { font-size: 1.3rem; }
  .hud--count { display: none; }
  .hud--cue { bottom: 6.6rem; }
  .list__readout { bottom: 6.6rem; }
  .hud--cue-h { display: none; }              /* touch drag is obvious → declutter */
  .list__title { font-size: clamp(1.6rem, 7vw, 2.4rem); }
  .timeswitch { flex-direction: row; top: 4.4rem; left: 50%; bottom: auto; transform: translateX(-50%); }
  .deco__coord--l { display: none; }
  .lb__cred { top: 4.4rem; left: 50%; transform: translateX(-50%); max-width: 92vw; text-align: center; }
  .lb__cred-k { justify-content: center; }
  .lb__cred-role { max-width: 40ch; margin-left: auto; margin-right: auto; }
}
@media (prefers-reduced-motion: reduce) {
  .grain, .hud--cue svg, .hud--cue-h svg { animation: none; }
}
