/* ============================================================
   Dark Shadow VFX — site styles
   Imports tokens from colors_and_type.css
   ============================================================ */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--void); color: var(--bone); }
body { font-family: var(--font-sans); }

.site { min-height: 100vh; }

/* ---------- NAV --------------------------------------------- */
.site-nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 100;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(20px) saturate(1.2);
  -webkit-backdrop-filter: blur(20px) saturate(1.2);
  border-bottom: var(--hairline-soft);
  transition: opacity var(--dur-slow) var(--ease-glide),
              transform var(--dur-slow) var(--ease-glide);
}
.site-nav--hidden { opacity: 0; transform: translateY(-10px); pointer-events: none; }
.site-nav__inner {
  max-width: var(--max-w); margin: 0 auto;
  padding: 20px var(--gutter);
  display: grid; grid-template-columns: 220px 1fr auto; align-items: center; gap: 32px;
}
.wordmark { background: transparent; border: 0; padding: 0; cursor: pointer; }
.wordmark__bc {
  display: inline-block;
  font-family: var(--font-barcode);
  font-size: 28px; line-height: 1;
  color: var(--bone);
  letter-spacing: 0;
  transition: color var(--dur-base) var(--ease-glide), opacity var(--dur-base) var(--ease-glide);
  opacity: 0.92;
}
.wordmark:hover .wordmark__bc { opacity: 1; }
.nav-links {
  list-style: none; padding: 0; margin: 0;
  display: flex; gap: 36px; justify-content: center;
}
.nav-link {
  display: inline-flex; align-items: baseline; gap: 8px;
  font-family: var(--font-sans);
  font-size: var(--t-12); font-weight: var(--w-medium);
  letter-spacing: var(--track-widest);
  text-transform: uppercase;
  color: var(--fog);
  transition: color var(--dur-base) var(--ease-glide);
  padding: 4px 0;
}
.nav-link__num { color: var(--mist); font-variant-numeric: tabular-nums; }
.nav-link:hover { color: var(--bone); }
.nav-link:hover .nav-link__num { color: var(--smoke); }
.nav-link--current { color: var(--bone); }
.nav-link--current .nav-link__num { color: var(--ember); }
.nav-side {
  display: flex; gap: 18px; justify-self: end;
}
.nav-side .overline { font-size: 10px; }

/* ---------- HERO -------------------------------------------- */
.hero {
  min-height: 100vh;
  padding: 0 var(--gutter);
  display: grid; grid-template-rows: 1fr auto;
  transition: padding var(--dur-glacial) var(--ease-glide);
  overflow: hidden;
}
.hero__stage {
  display: flex; align-items: center; justify-content: center;
  padding-top: 88px; padding-bottom: 48px;
  position: relative;
}

/* ============================================================
   BarcodeReveal — animation
   ============================================================ */
.br {
  position: relative;
  display: inline-block;
  padding: clamp(40px, 6vw, 80px) clamp(20px, 3vw, 48px);
  font-family: var(--font-barcode);
  font-size: clamp(40px, 8.4vw, 142px);
  line-height: 1;
  color: var(--bone);
  white-space: nowrap;
  letter-spacing: 0;
  text-align: center;
  isolation: isolate;
  transition: transform var(--dur-glacial) var(--ease-rack), filter var(--dur-glacial) var(--ease-rack);
}
.br--p2 { /* settled, slight settle */ }
.br__text {
  position: relative; z-index: 2;
  display: inline-block;
}
.br__c {
  display: inline-block;
  opacity: 0;
  filter: blur(36px) brightness(0.05);
  transform: translateY(18px) scaleY(0.55);
  transform-origin: 50% 100%;
  transition: opacity 2s var(--ease-rack),
              filter 2.6s var(--ease-rack),
              transform 2.4s var(--ease-rack);
  will-change: opacity, filter, transform;
}
.br--p1 .br__c, .br--p2 .br__c {
  opacity: 1;
  filter: blur(0) brightness(1);
  transform: translateY(0) scaleY(1);
}
/* Sentinel asterisks visible-but-quieter (they ARE part of the brand) */
.br__c--sent { color: var(--smoke); }

/* Tungsten halo behind text — pulses up during reveal */
.br__halo {
  position: absolute; inset: -20% -10%;
  z-index: 0;
  background: radial-gradient(ellipse at 50% 55%,
              rgba(200, 165, 114, 0.32) 0%,
              rgba(200, 165, 114, 0.12) 30%,
              transparent 65%);
  opacity: 0;
  transition: opacity 2.8s var(--ease-glide);
  pointer-events: none;
}
.br--p1 .br__halo, .br--p2 .br__halo { opacity: 1; }
.br--p2 .br__halo { opacity: 0.65; }

/* Light sweep — a vertical column of light moving L→R */
.br__sweep {
  position: absolute; top: 0; bottom: 0; left: -20%;
  width: 26%;
  z-index: 1;
  background: linear-gradient(90deg,
              transparent 0%,
              rgba(255, 248, 230, 0.05) 30%,
              rgba(255, 248, 230, 0.45) 50%,
              rgba(255, 248, 230, 0.05) 70%,
              transparent 100%);
  filter: blur(24px);
  mix-blend-mode: screen;
  opacity: 0;
  pointer-events: none;
}
.br--p1 .br__sweep, .br--p2 .br__sweep {
  animation: br-sweep 2.8s cubic-bezier(0.16, 0.84, 0.24, 1) 0.1s forwards;
}
@keyframes br-sweep {
  0%   { left: -25%; opacity: 0; }
  15%  { opacity: 1; }
  85%  { opacity: 1; }
  100% { left: 105%; opacity: 0; }
}

/* Scanline — a thin horizontal hairline that drops from top to settle
   at the barcode's baseline, suggesting a film projector's slit */
.br__scanline {
  position: absolute; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.85), transparent);
  z-index: 3;
  opacity: 0; top: 0;
  pointer-events: none;
  box-shadow: 0 0 24px rgba(255, 248, 230, 0.6);
}
.br--p1 .br__scanline {
  animation: br-scan 2.4s cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
}
@keyframes br-scan {
  0%   { top: 0%;   opacity: 0; }
  10%  { opacity: 1; }
  80%  { opacity: 1; }
  100% { top: 100%; opacity: 0; }
}

/* Settled state — the whole mark pulls smaller as the page rolls down */
.hero--pulled .br {
  transform: scale(0.86) translateY(-1vh);
  filter: drop-shadow(0 0 60px rgba(200, 165, 114, 0.12));
}

.hero__below {
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px var(--col-gap);
  align-items: end;
  padding-bottom: 80px;
  opacity: 0; transform: translateY(20px);
  transition: opacity 1.4s var(--ease-glide), transform 1.4s var(--ease-glide);
}
.hero--pulled .hero__below { opacity: 1; transform: translateY(0); }
.hero__meta { display: flex; flex-direction: column; gap: 10px; }
.hero__meta .overline { color: var(--smoke); }
.hero__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 400;
  color: var(--bone);
  grid-column: 1 / -1;
  display: grid;
  gap: 8px;
}
.hero__title-mark {
  display: block;
  font-size: clamp(72px, 11vw, 200px);
  line-height: 0.92;
  letter-spacing: -0.045em;
}
.hero__title-sub {
  display: block;
  font-style: italic;
  font-size: clamp(22px, 2.6vw, 42px);
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--fog);
  padding-left: 4px;
}
.hero__title-sub > i {
  display: inline-grid;
  grid-template-columns: auto 1fr;
  align-items: baseline;
  font-style: italic;
}
.slogan__dash {
  grid-column: 1; grid-row: 1;
  color: var(--smoke);
}
.slogan {
  grid-column: 2; grid-row: 1;
  display: block;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 1.4s var(--ease-fade), transform 1.4s var(--ease-glide);
  pointer-events: none;
  white-space: nowrap;
}
.slogan--in {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.hero__cta {
  grid-column: 1 / -1;
  display: flex; gap: 40px; align-items: center; margin-top: 12px;
}

/* ---------- link styles ------------------------------------- */
.link-arrow {
  display: inline-flex; align-items: center; gap: 20px;
  font-family: var(--font-sans);
  font-size: var(--t-12); font-weight: var(--w-medium);
  letter-spacing: var(--track-widest); text-transform: uppercase;
  color: var(--bone);
  cursor: pointer;
}
.link-arrow__rule {
  display: inline-block; width: 60px; height: 1px; background: var(--bone);
  transition: width var(--dur-slow) var(--ease-rack);
}
.link-arrow:hover .link-arrow__rule { width: 110px; }
.link-arrow__glyph {
  font-family: var(--font-display); font-size: 22px;
  transition: transform var(--dur-slow) var(--ease-rack);
}
.link-arrow:hover .link-arrow__glyph { transform: translateX(8px); }
.link-arrow--lg { font-size: var(--t-14); }
.link-arrow--lg .link-arrow__glyph { font-size: 32px; }
.link-arrow--lg .link-arrow__rule { width: 90px; }
.link-arrow--lg:hover .link-arrow__rule { width: 160px; }

.link-text {
  font-family: var(--font-sans); font-size: var(--t-12);
  letter-spacing: var(--track-widest); text-transform: uppercase;
  color: var(--fog);
  transition: color var(--dur-base) var(--ease-glide);
}
.link-text:hover { color: var(--bone); }

/* ---------- GALLERY ----------------------------------------- */
.gallery {
  padding: 160px var(--gutter) 120px;
  max-width: var(--max-w); margin: 0 auto;
}
.gallery__head {
  display: grid; grid-template-columns: 1fr 1.4fr; gap: 32px var(--col-gap);
  align-items: end;
  margin-bottom: 80px;
  border-bottom: var(--hairline);
  padding-bottom: 40px;
}
.gallery__title {
  margin: 0;
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(36px, 4.6vw, 76px);
  line-height: 1.0; letter-spacing: -0.03em;
  grid-column: 1 / 2; grid-row: 2;
  display: grid;
  grid-template-areas: "stack";
  align-items: end;
}
.gallery__title i { color: var(--fog); }
.gtr__phrase {
  grid-area: stack;
  display: block;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 1.4s var(--ease-fade), transform 1.4s var(--ease-glide);
  pointer-events: none;
}
.gtr__phrase--in {
  opacity: 1; transform: translateY(0);
  pointer-events: auto;
}
.gallery__head .overline { grid-column: 1 / 2; grid-row: 1; }
.gallery__lede { grid-column: 2; grid-row: 2; align-self: end; max-width: 44ch; color: var(--fog); }
.gallery__filters {
  grid-column: 2; grid-row: 1; align-self: end; justify-self: end;
  display: flex; gap: 24px;
}
.seg-pill {
  font-family: var(--font-sans); font-size: var(--t-12);
  font-weight: var(--w-medium); letter-spacing: var(--track-widest);
  text-transform: uppercase; color: var(--smoke);
  padding: 6px 0; border-bottom: 1px solid transparent;
  transition: color var(--dur-base) var(--ease-glide), border-color var(--dur-slow) var(--ease-rack);
  cursor: pointer;
}
.seg-pill:hover { color: var(--fog); }
.seg-pill--on { color: var(--bone); border-bottom-color: var(--bone); }
.seg-pill--link { color: var(--bone); display: inline-flex; gap: 10px; align-items: baseline; }
.seg-pill--link .seg-pill__glyph { font-family: var(--font-display); font-size: 16px; transition: transform var(--dur-slow) var(--ease-rack); }
.seg-pill--link:hover { color: var(--ember); border-bottom-color: var(--ember); }
.seg-pill--link:hover .seg-pill__glyph { transform: translateX(6px); }

.gallery__grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 48px var(--col-gap);
}
.gallery__foot {
  margin-top: 96px; padding-top: 32px;
  border-top: var(--hairline);
  display: flex; justify-content: space-between; align-items: center;
}

/* ---------- RACK FOCUS THUMB -------------------------------- */
.rt {
  background: transparent; border: 0; padding: 0;
  color: inherit; text-align: left; cursor: pointer;
  display: flex; flex-direction: column; gap: 18px;
}
.rt__frame {
  position: relative; aspect-ratio: 3/4; overflow: hidden;
  background: #000;
}
.rt__img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  filter: blur(22px) saturate(0.55) brightness(0.7) contrast(1.05);
  transform: scale(1.10);
  transition: filter var(--dur-glacial) var(--ease-rack),
              transform var(--dur-glacial) var(--ease-rack);
}
.rt:hover .rt__img,
.rt:focus-visible .rt__img {
  filter: blur(0) saturate(1.05) brightness(1) contrast(1.05);
  transform: scale(1);
}
.rt__bokeh {
  position: absolute; inset: 0; width: 100%; height: 100%;
  mix-blend-mode: screen; opacity: 0.62;
  transition: opacity var(--dur-glacial) var(--ease-rack);
}
.rt:hover .rt__bokeh, .rt:focus-visible .rt__bokeh { opacity: 0; }
.rt__vignette {
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse at center, transparent 35%, rgba(0,0,0,0.85) 100%);
  transition: opacity var(--dur-glacial) var(--ease-rack);
}
.rt:hover .rt__vignette, .rt:focus-visible .rt__vignette { opacity: 0.35; }
.rt__hairline {
  position: absolute; inset: 0; pointer-events: none;
  border: 1px solid transparent;
  transition: border-color var(--dur-glacial) var(--ease-rack);
}
.rt:hover .rt__hairline, .rt:focus-visible .rt__hairline { border-color: var(--bone); }

.rt__index {
  position: absolute; top: 12px; left: 14px;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: var(--track-widest); color: var(--bone);
  opacity: 0.85; mix-blend-mode: difference;
}
.rt__meta { display: flex; flex-direction: column; gap: 6px; }
.rt__title-row { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; }
.rt__title {
  margin: 0;
  font-family: var(--font-display); font-weight: 400;
  font-size: var(--t-28); line-height: 1; letter-spacing: -0.02em;
  color: var(--bone);
}
.rt__year {
  font-family: var(--font-mono); font-size: var(--t-12);
  color: var(--smoke); letter-spacing: var(--track-wider);
}
.rt__credit {
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center;
  font-family: var(--font-sans); font-size: var(--t-12);
  color: var(--fog); letter-spacing: var(--track-wide);
  text-transform: uppercase;
}
.rt__sep { color: var(--mist); }

/* ---------- CAPABILITIES STRIP ------------------------------ */
.caps {
  max-width: var(--max-w); margin: 0 auto;
  padding: 0 var(--gutter);
}
.caps__list {
  list-style: none; padding: 32px 0; margin: 0;
  display: grid; grid-template-columns: repeat(6, 1fr);
  gap: 0;
  border-top: var(--hairline);
  border-bottom: var(--hairline);
}
.caps__list li {
  display: flex; flex-direction: column; gap: 6px;
  padding: 4px 16px 4px 0;
}
.caps__n {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: var(--track-wider); color: var(--mist);
  font-variant-numeric: tabular-nums;
}
.caps__l {
  font-family: var(--font-sans); font-size: 11px;
  letter-spacing: var(--track-widest); text-transform: uppercase;
  color: var(--bone); font-weight: var(--w-medium);
}

/* ---------- CLIENT WALL ------------------------------------- */
.wall {
  padding: 120px var(--gutter);
  max-width: var(--max-w); margin: 0 auto;
  border-top: var(--hairline);
}
.wall__head {
  display: flex; flex-direction: column; gap: 18px;
  margin-bottom: 80px; max-width: 56ch;
}
.wall__title {
  margin: 0;
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(36px, 4.6vw, 76px);
  line-height: 1.0; letter-spacing: -0.03em;
}
.wall__title i { color: var(--fog); }
.wall__grid {
  display: grid; grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 0;
  border-top: var(--hairline);
  border-bottom: var(--hairline);
}
.wall__cell {
  aspect-ratio: 2 / 1;
  display: flex; align-items: center; justify-content: center;
  padding: 28px;
  border-right: var(--hairline-soft);
  transition: background var(--dur-slow) var(--ease-glide);
}
.wall__cell:last-child { border-right: 0; }
.wall__cell:hover { background: var(--graphite); }
.wall__cell img {
  max-width: 80%; max-height: 56px;
  filter: brightness(0) invert(1);
  opacity: 0.55;
  transition: opacity var(--dur-slow) var(--ease-glide);
}
.wall__cell:hover img { opacity: 1; }
.wall__fallback {
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(13px, 1vw, 16px); line-height: 1.1;
  letter-spacing: -0.01em; text-align: center;
  color: var(--bone); opacity: 0.55;
  transition: opacity var(--dur-slow) var(--ease-glide);
}
.wall__cell:hover .wall__fallback { opacity: 1; }
.wall__cell--stencil img {
  filter: none;
  max-width: 92%; max-height: 80px;
}

/* ---------- ABOUT ------------------------------------------- */
.about {
  padding: 120px var(--gutter);
  max-width: var(--max-w); margin: 0 auto;
  border-top: var(--hairline);
  display: grid; grid-template-columns: 1fr 1.2fr; gap: 64px var(--col-gap);
}
.about__col { display: flex; flex-direction: column; gap: 28px; }
.about__title {
  margin: 0;
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(36px, 4.4vw, 72px);
  line-height: 1.0; letter-spacing: -0.03em;
}
.about__title i { color: var(--fog); }

.about__facts {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  border-top: var(--hairline); margin-top: 24px;
}
.about__facts > div {
  display: grid; grid-template-columns: 120px 1fr;
  padding: 16px 0; border-bottom: var(--hairline-soft);
  align-items: baseline;
}
.about__facts dt {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: var(--track-wider); text-transform: uppercase;
  color: var(--smoke); margin: 0;
}
.about__facts dd { margin: 0; font-family: var(--font-sans); font-size: var(--t-14); color: var(--bone); }

/* ---------- FOOTER ------------------------------------------ */
.foot {
  border-top: var(--hairline);
  padding: 120px var(--gutter) 48px;
  background: var(--void);
}
.foot__cta {
  max-width: var(--max-w); margin: 0 auto 96px;
  display: flex; flex-direction: column; gap: 40px;
}

/* ---------- BEGIN — three doors --------------------------- */
.begin {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: var(--hairline);
  border-bottom: var(--hairline);
}
.begin__door {
  display: flex; flex-direction: column;
  gap: 32px;
  padding: 48px 40px 40px;
  border-right: var(--hairline-soft);
  color: var(--bone);
  cursor: pointer;
  position: relative;
  transition: background var(--dur-slow) var(--ease-glide);
}
.begin__door:last-child { border-right: 0; }
.begin__door:hover { background: var(--graphite); }

.begin__head {
  display: flex; align-items: baseline; gap: 14px;
}
.begin__n {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: var(--track-wider); color: var(--smoke);
  font-variant-numeric: tabular-nums;
}
.begin__label {
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(32px, 3.4vw, 56px);
  line-height: 1; letter-spacing: -0.02em;
  color: var(--bone);
  transition: color var(--dur-base) var(--ease-glide);
}
.begin__door:hover .begin__label { color: var(--bone); }

.begin__body {
  margin: 0;
  font-family: var(--font-sans); font-size: var(--t-14);
  line-height: 1.6; color: var(--fog);
  max-width: 32ch;
  flex: 1;
}

.begin__cta {
  display: flex; align-items: center; gap: 18px;
  font-family: var(--font-sans); font-size: var(--t-12);
  font-weight: var(--w-medium);
  letter-spacing: var(--track-widest); text-transform: uppercase;
  color: var(--bone);
  margin-top: auto;
}
.begin__rule {
  display: inline-block; width: 40px; height: 1px;
  background: var(--bone);
  transition: width var(--dur-slow) var(--ease-rack), background var(--dur-base);
}
.begin__door:hover .begin__rule { width: 96px; background: var(--ember); }
.begin__door:hover .begin__verb { color: var(--ember); }
.begin__glyph {
  font-family: var(--font-display); font-size: 22px;
  margin-left: auto;
  transition: transform var(--dur-slow) var(--ease-rack), color var(--dur-base);
}
.begin__door:hover .begin__glyph { transform: translateX(10px); color: var(--ember); }

@media (max-width: 1100px) {
  .begin { grid-template-columns: 1fr; }
  .begin__door { border-right: 0; border-bottom: var(--hairline-soft); }
  .begin__door:last-child { border-bottom: 0; }
}
/* ============================================================
   FOOTER MARK — two-act animated barcode mark
   Act 1: torch sweeps L→R revealing the text in a ghostly glow.
   Act 2: a lamp at the bottom ignites, casting a tall white
          shadow of the text upward into the dark.
   ============================================================ */
.foot__mark {
  max-width: var(--max-w); margin: 0 auto;
  padding: 320px 0 72px;
  border-top: var(--hairline);
  position: relative;
  overflow: hidden;
  isolation: isolate;
  display: flex; justify-content: center; align-items: flex-end;
}

/* ---- Act 1: travelling torch (behind the text) ------------- */
.foot__mark::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 72px;
  width: 26%;
  height: clamp(80px, 11vw, 180px);
  transform: translate(-100%, 0);
  background: radial-gradient(
    ellipse at center,
    rgba(255, 245, 220, 0.55) 0%,
    rgba(220, 180, 130, 0.18) 35%,
    transparent 70%
  );
  filter: blur(34px);
  z-index: 0;
  pointer-events: none;
  mix-blend-mode: screen;
  opacity: 0;
  animation: foot-torch 12s cubic-bezier(0.16, 0.84, 0.24, 1) infinite;
  will-change: transform, opacity;
}
@keyframes foot-torch {
  0%   { transform: translate(-100%, 0); opacity: 0; }
  4%   { opacity: 1; }
  40%  { transform: translate(400%, 0); opacity: 1; }
  44%  { transform: translate(420%, 0); opacity: 0; }
  100% { transform: translate(-100%, 0); opacity: 0; }
}

/* ---- The barcode text — only visible inside the torch band -- */
.foot__bc {
  display: block;
  font-family: var(--font-barcode);
  font-size: clamp(48px, 8vw, 132px);
  line-height: 1;
  color: var(--bone);
  letter-spacing: 0;
  white-space: nowrap;
  position: relative;
  z-index: 3;
  /* ghostly cool-white halo — only visible inside the masked band */
  text-shadow:
    0 0  6px rgba(255, 252, 245, 0.55),
    0 0 22px rgba(210, 220, 230, 0.32),
    0 0 60px rgba(180, 195, 210, 0.16);
  -webkit-mask-image: linear-gradient(90deg,
    transparent 0%, transparent 46%,
    rgba(0,0,0,0.55) 48%, rgba(0,0,0,1) 50%, rgba(0,0,0,0.55) 52%,
    transparent 54%, transparent 100%);
          mask-image: linear-gradient(90deg,
    transparent 0%, transparent 46%,
    rgba(0,0,0,0.55) 48%, rgba(0,0,0,1) 50%, rgba(0,0,0,0.55) 52%,
    transparent 54%, transparent 100%);
  -webkit-mask-size: 300% 100%;        mask-size: 300% 100%;
  -webkit-mask-repeat: no-repeat;      mask-repeat: no-repeat;
  -webkit-mask-position: 100% 0;       mask-position: 100% 0;
  animation: foot-reveal 12s cubic-bezier(0.16, 0.84, 0.24, 1) infinite;
  will-change: mask-position;
}
@keyframes foot-reveal {
  /*  Sweep L→R from 0-44% of the loop, then dark for the rest. */
  0%   { -webkit-mask-position: 100% 0;       mask-position: 100% 0; }
  44%  { -webkit-mask-position: 0% 0;         mask-position: 0% 0; }
  100% { -webkit-mask-position: 0% 0;         mask-position: 0% 0; }
}

/* ---- Act 2: upward-cast shadow ----------------------------- */
.foot__cast {
  position: absolute;
  left: 50%;
  bottom: 72px;                           /* baseline matches .foot__bc */
  transform: translate(-50%, 0) scaleY(2.4);
  transform-origin: center bottom;
  font-family: var(--font-barcode);
  font-size: clamp(48px, 8vw, 132px);
  line-height: 1;
  color: #ffffff;
  letter-spacing: 0;
  white-space: nowrap;
  filter: blur(10px);
  opacity: 0;
  z-index: 1;                             /* below the solid + .foot__bc */
  pointer-events: none;
  mix-blend-mode: screen;
  /* fade from solid at base of shadow to transparent at top */
  -webkit-mask-image: linear-gradient(180deg,
    transparent 0%, rgba(0,0,0,0.1) 18%, rgba(0,0,0,0.4) 55%, rgba(0,0,0,0.85) 85%, black 100%);
          mask-image: linear-gradient(180deg,
    transparent 0%, rgba(0,0,0,0.1) 18%, rgba(0,0,0,0.4) 55%, rgba(0,0,0,0.85) 85%, black 100%);
  animation: foot-cast 12s cubic-bezier(0.4, 0, 0.2, 1) infinite;
  will-change: transform, opacity, filter;
}
@keyframes foot-cast {
  /*  0-46%   : dark (Act 1 is playing).
      48-55%  : lamp ignites; shadow rises to full height.
      55-78%  : shadow holds, breathing slightly.
      78-92%  : lamp fades; shadow recedes.
      92-100% : dark.                                     */
  0%, 46% { opacity: 0; transform: translate(-50%, 0) scaleY(1.8); filter: blur(14px); }
  55%     { opacity: 0.78; transform: translate(-50%, 0) scaleY(3.6); filter: blur(7px); }
  72%     { opacity: 0.65; transform: translate(-50%, 0) scaleY(3.9); filter: blur(8px); }
  85%     { opacity: 0.32; transform: translate(-50%, 0) scaleY(4.1); filter: blur(10px); }
  92%, 100% { opacity: 0; transform: translate(-50%, 0) scaleY(1.8); filter: blur(14px); }
}

/* ---- The "object" — a slightly out-of-focus black silhouette
       that emerges during Act 2 to motivate the cast shadow.
       Backlit by the lamp from below, so it carries a faint warm
       rim along its lower edge.                                 -- */
.foot__solid {
  position: absolute;
  left: 50%;
  bottom: 72px;                           /* matches .foot__bc baseline */
  transform: translateX(-50%);
  font-family: var(--font-barcode);
  font-size: clamp(48px, 8vw, 132px);
  line-height: 1;
  color: #1A1A1A;                         /* lifted just off pure void */
  letter-spacing: 0;
  white-space: nowrap;
  filter: blur(2.5px);                    /* slightly out of focus */
  opacity: 0;
  z-index: 2;                             /* over the cast, under .foot__bc */
  pointer-events: none;
  /* warm rim from the lamp catching the underside */
  text-shadow:
    0  1px 0  rgba(220, 180, 130, 0.30),
    0  3px 16px rgba(220, 170, 110, 0.18),
    0 -1px 0  rgba(0, 0, 0, 1);
  animation: foot-solid 12s cubic-bezier(0.4, 0, 0.2, 1) infinite;
  will-change: opacity, filter;
}
@keyframes foot-solid {
  /*  Emerges just before the cast peaks, holds through its
      lifetime, fades as the lamp dims.                          */
  0%, 46% { opacity: 0; filter: blur(5px); }
  56%     { opacity: 1; filter: blur(2.5px); }
  78%     { opacity: 1; filter: blur(2.5px); }
  88%     { opacity: 0; filter: blur(4px); }
  100%    { opacity: 0; filter: blur(5px); }
}

/* ---- The lamp at the bottom of the frame ------------------- */
.foot__source {
  position: absolute;
  bottom: -56px; left: 50%;
  width: 56%; height: 140px;
  transform: translateX(-50%);
  background: radial-gradient(ellipse at center top,
    rgba(255, 245, 220, 0.65) 0%,
    rgba(225, 180, 130, 0.28) 30%,
    rgba(200, 165, 114, 0.10) 55%,
    transparent 78%);
  filter: blur(28px);
  opacity: 0;
  z-index: 0;
  pointer-events: none;
  mix-blend-mode: screen;
  animation: foot-source 12s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}
@keyframes foot-source {
  0%, 46% { opacity: 0; }
  52%     { opacity: 0.95; }
  72%     { opacity: 0.75; }
  88%     { opacity: 0; }
  100%    { opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  .foot__mark::before, .foot__bc, .foot__cast, .foot__solid, .foot__source { animation: none; }
  .foot__bc { -webkit-mask-position: 50% 0; mask-position: 50% 0; opacity: 0.85; }
  .foot__cast, .foot__source { opacity: 0; }
  .foot__solid { opacity: 1; }
}

.foot__credits {
  max-width: var(--max-w); margin: 0 auto;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--col-gap);
  padding: 48px 0; border-top: var(--hairline);
  text-align: center;
}
.foot__col { display: flex; flex-direction: column; gap: 12px; align-items: center; }
.foot__col .credit { color: var(--bone); }
.foot__col p {
  margin: 0; font-family: var(--font-sans); font-size: var(--t-14);
  color: var(--fog); line-height: 1.6;
}
.foot__legal {
  max-width: var(--max-w); margin: 24px auto 0;
  display: flex; justify-content: space-between; gap: 24px;
  padding-top: 24px; border-top: var(--hairline-soft);
}

/* ---------- CASE STUDY (project detail) --------------------- */
.case {
  padding: 120px var(--gutter) 0;
  max-width: var(--max-w); margin: 0 auto;
}
.case__chrome {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 40px; border-bottom: var(--hairline);
  margin-bottom: 64px;
}
.case__barcode {
  font-family: var(--font-barcode);
  font-size: 44px; line-height: 1;
  color: var(--bone);
}
.back {
  display: inline-flex; align-items: center; gap: 18px;
  background: transparent; border: 0; cursor: pointer;
  color: var(--bone);
  font-family: var(--font-sans); font-size: var(--t-12);
  font-weight: var(--w-medium);
  letter-spacing: var(--track-widest); text-transform: uppercase;
  padding: 8px 0;
}
.back__glyph { font-family: var(--font-display); font-size: 22px; transition: transform var(--dur-slow) var(--ease-rack); }
.back__rule { display: inline-block; width: 40px; height: 1px; background: var(--bone); transition: width var(--dur-slow) var(--ease-rack); }
.back:hover .back__glyph { transform: translateX(-8px); }
.back:hover .back__rule { width: 80px; }

.case__head { margin-bottom: 48px; max-width: var(--max-w); }
.case__head-meta { margin-bottom: 24px; }
.case__title {
  margin: 0;
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(72px, 11vw, 200px);
  line-height: 0.92; letter-spacing: -0.045em;
}
.case__sub {
  margin: 18px 0 0;
  font-family: var(--font-display); font-style: italic;
  font-size: clamp(22px, 2.4vw, 36px); color: var(--fog);
  max-width: 36ch; line-height: 1.2;
}

.case__plate {
  margin: 64px 0 0; position: relative; overflow: hidden;
  border: 1px solid var(--stroke-soft);
  aspect-ratio: 2.39 / 1;
}
.case__plate img { width: 100%; height: 100%; object-fit: cover; display: block; }
.case__play {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 88px; height: 88px; border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.7);
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(8px);
  color: var(--bone); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: transform var(--dur-slow) var(--ease-rack),
              background var(--dur-slow) var(--ease-glide);
}
.case__play:hover { transform: translate(-50%, -50%) scale(1.04); background: rgba(0,0,0,0.65); }
.case__caption {
  position: absolute; left: 20px; bottom: 16px;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: var(--track-wider); color: var(--fog); text-transform: uppercase;
}

.case__body {
  margin-top: 96px;
  display: grid; grid-template-columns: 340px 1fr; gap: var(--gutter);
  padding-bottom: 120px;
}
.case__sidebar { display: flex; flex-direction: column; gap: 40px; position: sticky; top: 120px; align-self: start; }
.case__facts { display: flex; flex-direction: column; gap: 0; margin: 0; border-top: var(--hairline); }
.case__facts > div { display: grid; grid-template-columns: 110px 1fr; gap: 16px; padding: 14px 0; border-bottom: var(--hairline-soft); align-items: baseline; }
.case__facts dt { margin: 0; font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--track-wider); text-transform: uppercase; color: var(--smoke); }
.case__facts dd { margin: 0; font-family: var(--font-sans); font-size: var(--t-14); color: var(--bone); }
.case__facts .dot { color: var(--mist); }
.case__stats {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  border-top: var(--hairline); border-bottom: var(--hairline);
  padding: 20px 0;
}
.case__stats > div { display: flex; flex-direction: column; gap: 4px; padding-right: 12px; }
.case__stats b { font-family: var(--font-display); font-weight: 400; font-size: 38px; line-height: 1; color: var(--bone); letter-spacing: -0.02em; }
.case__stats b i { font-size: 16px; color: var(--smoke); font-style: normal; letter-spacing: 0.05em; margin-left: 2px; }
.case__stats span { font-family: var(--font-mono); font-size: 9px; letter-spacing: var(--track-wider); text-transform: uppercase; color: var(--smoke); }

.case__prose { max-width: 64ch; display: flex; flex-direction: column; gap: 24px; }
.case__h2 {
  margin: 32px 0 4px;
  font-family: var(--font-display); font-weight: 400;
  font-size: var(--t-36); letter-spacing: -0.02em; line-height: 1.05;
}
.case__h2:first-child { margin-top: 0; }
.case__credits {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  border-top: var(--hairline); margin-top: 8px;
}
.case__credits > div { display: grid; grid-template-columns: 140px 1fr; padding: 12px 0; border-bottom: var(--hairline-soft); align-items: baseline; }
.case__credits dt { margin: 0; font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--track-wider); text-transform: uppercase; color: var(--smoke); }
.case__credits dd { margin: 0; font-family: var(--font-sans); font-size: var(--t-14); color: var(--bone); }

.case__nav {
  display: flex; justify-content: space-between; align-items: center;
  padding: 32px 0; border-top: var(--hairline); border-bottom: var(--hairline);
  margin-bottom: 96px;
}

/* ---------- responsive (gentle) ----------------------------- */
@media (max-width: 1100px) {
  .gallery__grid { grid-template-columns: repeat(2, 1fr); gap: 56px 28px; }
  .wall__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .case__body { grid-template-columns: 1fr; }
  .case__sidebar { position: static; }
  .foot__credits { grid-template-columns: repeat(2, 1fr); row-gap: 32px; }
  .about { grid-template-columns: 1fr; }
  .hero__below { grid-template-columns: 1fr; }
  .nav-links { display: none; }
  .site-nav__inner { grid-template-columns: auto auto; gap: 16px; }
}


/* ============================================================
   REEL PAGE — the screening room
   ============================================================ */
.reel {
  max-width: var(--max-w); margin: 0 auto;
  padding: 120px var(--gutter) 0;
  min-height: 100vh;
  display: flex; flex-direction: column;
}
.reel__chrome {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 32px; border-bottom: var(--hairline);
  margin-bottom: 56px;
}
.reel__head {
  display: flex; flex-direction: column; gap: 14px;
  margin-bottom: 56px; max-width: 60ch;
}
.reel__title {
  margin: 0;
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(72px, 11vw, 200px);
  line-height: 0.92; letter-spacing: -0.045em;
}
.reel__period { color: var(--ember); }
.reel__sub {
  margin: 0; font-family: var(--font-display); font-style: italic;
  font-size: clamp(22px, 2.6vw, 38px); color: var(--fog);
  line-height: 1.2; max-width: 40ch;
}

.reel__theater {
  position: relative;
  padding: 0;
  margin-bottom: 64px;
  isolation: isolate;
}
/* projector light vignette around the screen */
.reel__theater::before {
  content: "";
  position: absolute; inset: -8% -6%;
  background: radial-gradient(ellipse at 50% 50%,
              rgba(200, 165, 114, 0.18) 0%,
              rgba(200, 165, 114, 0.06) 35%,
              transparent 65%);
  z-index: 0;
  pointer-events: none;
  filter: blur(40px);
  animation: reel-flicker 5.2s ease-in-out infinite;
}
@keyframes reel-flicker {
  0%, 100% { opacity: 0.78; }
  47%      { opacity: 1; }
  53%      { opacity: 0.7; }
  57%      { opacity: 0.92; }
}
.reel__rails {
  position: absolute; left: 0; right: 0;
  height: 16px;
  background:
    repeating-linear-gradient(90deg,
      transparent 0 24px,
      rgba(255,255,255,0.06) 24px 28px,
      transparent 28px 52px);
  z-index: 0;
  pointer-events: none;
}
.reel__rails--top { top: -22px; }
.reel__rails--bot { bottom: -22px; }

.reel__screen {
  position: relative;
  aspect-ratio: 2.39 / 1;
  background: #000;
  border: 1px solid var(--stroke);
  overflow: hidden;
  margin: 0;
  z-index: 1;
}
.reel__plate {
  width: 100%; height: 100%; object-fit: cover; display: block;
  filter: brightness(0.45) saturate(0.7) contrast(1.05);
  transition: filter 1.2s var(--ease-rack);
}
.reel__screen--play .reel__plate {
  filter: brightness(0.78) saturate(1.1) contrast(1.1);
}
.reel__scan {
  position: absolute; inset: 0;
  background: linear-gradient(180deg,
    transparent 0%, transparent 49.5%,
    rgba(255,255,255,0.06) 50%,
    transparent 50.5%, transparent 100%);
  background-size: 100% 4px;
  pointer-events: none;
  opacity: 0;
  transition: opacity 1.2s var(--ease-fade);
}
.reel__screen--play .reel__scan { opacity: 0.4; animation: reel-scan 6s linear infinite; }
@keyframes reel-scan { 0% { background-position: 0 0; } 100% { background-position: 0 200px; } }
.reel__grain {
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.1' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.7 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-size: 240px 240px;
  opacity: 0.08;
  mix-blend-mode: overlay;
  pointer-events: none;
}
.reel__screen--play .reel__grain { opacity: 0.18; animation: reel-grain .2s steps(3) infinite; }
@keyframes reel-grain { 0% { background-position: 0 0; } 100% { background-position: 100px 50px; } }

.reel__play {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: transparent; border: 0;
  color: var(--bone);
  cursor: pointer;
  display: flex; flex-direction: column; align-items: center; gap: 16px;
  padding: 24px;
  z-index: 3;
}
.reel__play-ring {
  position: absolute; inset: -32px;
  border: 1px solid rgba(255,255,255,0.6);
  border-radius: 50%;
  transition: transform var(--dur-slow) var(--ease-rack), border-color var(--dur-base);
}
.reel__play:hover .reel__play-ring { transform: scale(1.06); border-color: var(--ember); }
.reel__play svg { transition: transform var(--dur-slow) var(--ease-rack); }
.reel__play:hover svg { transform: translateX(3px); color: var(--ember); }
.reel__play-dur {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: var(--track-wider); color: var(--fog);
  position: absolute; top: calc(100% + 14px);
  white-space: nowrap;
}

.reel__hud {
  position: absolute; left: 16px; right: 16px; bottom: 14px;
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: var(--track-wider); color: var(--fog);
  text-transform: uppercase;
  z-index: 4;
  mix-blend-mode: difference;
}
.reel__hud .rec {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
  background: #FF3B3B; margin-right: 8px;
  animation: reel-rec 1.4s ease-in-out infinite;
}
@keyframes reel-rec { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }
.reel__hud-c { font-variant-numeric: tabular-nums; font-size: 13px; color: var(--bone); }

.reel__stop {
  position: absolute; top: 16px; right: 16px;
  background: rgba(0,0,0,0.55);
  border: 1px solid var(--stroke);
  color: var(--bone);
  font-family: var(--font-sans); font-size: 10px;
  letter-spacing: var(--track-widest); text-transform: uppercase;
  padding: 8px 14px; cursor: pointer;
  display: flex; align-items: center; gap: 10px;
  z-index: 5;
  transition: border-color var(--dur-base), color var(--dur-base);
}
.reel__stop:hover { border-color: var(--ember); color: var(--ember); }
.reel__stop-rule { display: inline-block; width: 14px; height: 1px; background: currentColor; }

.reel__tabs {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-top: var(--hairline); border-bottom: var(--hairline);
  margin-bottom: 64px;
}
.reel__tab {
  background: transparent; border: 0;
  border-right: var(--hairline-soft);
  padding: 28px 24px;
  display: flex; flex-direction: column; gap: 8px;
  cursor: pointer; text-align: left;
  color: var(--fog);
  transition: background var(--dur-slow) var(--ease-glide), color var(--dur-base);
}
.reel__tab:last-child { border-right: 0; }
.reel__tab:hover { background: var(--graphite); color: var(--bone); }
.reel__tab--on { background: var(--graphite); color: var(--bone); }
.reel__tab--on .reel__tab-n { color: var(--ember); }
.reel__tab-n {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: var(--track-wider); color: var(--smoke);
}
.reel__tab-l {
  font-family: var(--font-display); font-size: clamp(20px, 2.2vw, 30px);
  line-height: 1.1; letter-spacing: -0.02em;
}
.reel__tab-d {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: var(--track-wider); color: var(--smoke);
  margin-top: 4px;
}
.reel__foot {
  display: flex; justify-content: space-between; align-items: center;
  padding: 32px 0 64px;
  border-top: var(--hairline);
}

/* ============================================================
   CONTACT PAGE — three doors
   ============================================================ */
.ct {
  max-width: var(--max-w); margin: 0 auto;
  padding: 120px var(--gutter) 64px;
}
.ct__chrome {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 32px; border-bottom: var(--hairline);
  margin-bottom: 64px;
}
.ct__head {
  display: flex; flex-direction: column; gap: 16px;
  margin-bottom: 80px;
  padding-bottom: 48px;
  border-bottom: var(--hairline);
}
.ct__title {
  margin: 0;
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(72px, 12vw, 220px);
  line-height: 0.9; letter-spacing: -0.045em;
}
.ct__period { color: var(--ember); }
.ct__sub {
  font-family: var(--font-display); font-style: italic;
  font-size: clamp(22px, 2.6vw, 42px); color: var(--fog);
  line-height: 1.2;
  display: inline-block;
}
.ct__sub > i {
  display: inline-grid;
  grid-template-columns: auto 1fr;
  align-items: baseline;
  font-style: italic;
}
.ct__lede {
  font-family: var(--font-sans); font-size: var(--t-18);
  color: var(--fog); max-width: 40ch; line-height: 1.5;
  margin: 8px 0 0;
}

.ct__doors {
  display: grid; grid-template-columns: repeat(3, 1fr);
  border-top: var(--hairline);
  border-bottom: var(--hairline);
}
.door {
  display: flex; flex-direction: column; gap: 20px;
  padding: 48px 36px 40px;
  border-right: var(--hairline-soft);
  position: relative;
  isolation: isolate;
  transition: background var(--dur-slow) var(--ease-glide);
}
.door:last-child { border-right: 0; }
.door:hover { background: var(--graphite); }
.door--active { background: var(--graphite); }
.door--active::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--ember); box-shadow: 0 0 16px rgba(200,165,114,0.5);
}
.door__head { display: flex; align-items: baseline; gap: 14px; }
.door__n {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: var(--track-wider); color: var(--smoke);
  font-variant-numeric: tabular-nums;
}
.door__title {
  margin: 0;
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(36px, 3.6vw, 64px);
  line-height: 1; letter-spacing: -0.02em;
}
.door__desc {
  margin: 0;
  font-family: var(--font-sans); font-size: var(--t-14);
  color: var(--fog); line-height: 1.6; max-width: 38ch;
}

.ct-field {
  display: flex; flex-direction: column; gap: 6px;
  margin-top: 4px;
}
.ct-field > span {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: var(--track-wider); text-transform: uppercase;
  color: var(--smoke);
}
.ct-field input, .ct-field textarea, .ct-field select {
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--iron);
  padding: 10px 0;
  color: var(--bone);
  font-family: var(--font-sans);
  font-size: var(--t-15, 15px);
  outline: none;
  transition: border-color var(--dur-base) var(--ease-glide);
  -webkit-appearance: none; appearance: none;
}
.ct-field textarea { resize: vertical; min-height: 96px; line-height: 1.5; }
.ct-field input:focus, .ct-field textarea:focus, .ct-field select:focus { border-bottom-color: var(--ember); }
.ct-field input::placeholder, .ct-field textarea::placeholder { color: var(--mist); }
.ct-field select { color: var(--bone); background-image: linear-gradient(45deg, transparent 50%, var(--fog) 50%), linear-gradient(135deg, var(--fog) 50%, transparent 50%); background-position: calc(100% - 14px) calc(50% - 2px), calc(100% - 8px) calc(50% - 2px); background-size: 6px 6px, 6px 6px; background-repeat: no-repeat; padding-right: 28px; }
.ct-field select option { background: #050505; color: var(--bone); }

.cipher {
  display: flex; align-items: center; gap: 12px;
  margin-top: 8px;
}
.cipher__brackets { font-family: var(--font-display); font-size: 38px; color: var(--smoke); line-height: 1; }
.cipher__input {
  flex: 1;
  background: transparent; border: 0;
  border-bottom: 1px solid var(--iron);
  padding: 12px 0;
  color: var(--bone);
  font-family: var(--font-mono);
  font-size: 18px;
  letter-spacing: 0.32em;
  text-align: center;
  outline: none;
  transition: border-color var(--dur-base) var(--ease-glide);
}
.cipher__input::placeholder { color: var(--mist); letter-spacing: 0.06em; }
.cipher__input:focus { border-bottom-color: var(--ember); }
.cipher__hint {
  margin: 0;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: var(--track-wider); color: var(--smoke);
  text-transform: uppercase;
}

/* large cipher used on clients login */
.cipher--lg { margin: 24px 0 8px; }
.cipher--lg .cipher__brackets { font-size: 56px; }
.cipher--lg .cipher__input { font-size: 28px; padding: 16px 0; }

.drop {
  border: 1px dashed var(--iron);
  padding: 28px 20px;
  display: flex; flex-direction: column; gap: 6px;
  align-items: center; justify-content: center;
  cursor: pointer;
  transition: border-color var(--dur-base), background var(--dur-base);
  text-align: center;
}
.drop:hover, .drop--over { border-color: var(--ember); background: rgba(200,165,114,0.04); }
.drop--has { border-color: var(--bone); }
.drop__title {
  font-family: var(--font-display); font-size: 18px;
  color: var(--bone); line-height: 1.2;
}
.drop__hint {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: var(--track-wider); color: var(--smoke);
  text-transform: uppercase;
}

.ct-submit {
  display: inline-flex; align-items: center; gap: 18px;
  background: transparent; border: 0;
  padding: 16px 0;
  color: var(--bone);
  font-family: var(--font-sans); font-size: var(--t-12);
  font-weight: var(--w-medium);
  letter-spacing: var(--track-widest); text-transform: uppercase;
  cursor: pointer;
  margin-top: auto;
  border-top: var(--hairline-soft);
  transition: color var(--dur-base);
}
.ct-submit .link-arrow__rule { width: 40px; height: 1px; background: currentColor; display: inline-block; transition: width var(--dur-slow) var(--ease-rack); }
.ct-submit .link-arrow__glyph { font-family: var(--font-display); font-size: 22px; margin-left: auto; transition: transform var(--dur-slow) var(--ease-rack); }
.ct-submit:hover { color: var(--ember); }
.ct-submit:hover .link-arrow__rule { width: 80px; }
.ct-submit:hover .link-arrow__glyph { transform: translateX(8px); }

.door__sent {
  display: none;
  border: 1px solid var(--ember);
  padding: 20px;
  background: rgba(200,165,114,0.06);
  margin-top: 4px;
}
.door__sent .overline { display: block; color: var(--ember); margin-bottom: 8px; }
.door__sent p { margin: 0; font-family: var(--font-sans); font-size: var(--t-14); color: var(--fog); line-height: 1.6; }
.door--sent .door__sent { display: block; }
.door--sent .ct-field, .door--sent .ct-submit, .door--sent .drop, .door--sent .cipher, .door--sent .cipher__hint { opacity: 0.32; pointer-events: none; }

.ct__foot {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--col-gap);
  padding: 64px 0 24px;
  border-top: var(--hairline);
  margin-top: 80px;
}
.ct__addr { display: flex; flex-direction: column; gap: 10px; }
.ct__addr .credit { color: var(--bone); }
.ct__addr p { margin: 0; font-family: var(--font-sans); font-size: var(--t-14); color: var(--fog); line-height: 1.5; }

@media (max-width: 1100px) {
  .ct__doors { grid-template-columns: 1fr; }
  .door { border-right: 0; border-bottom: var(--hairline-soft); }
  .door:last-child { border-bottom: 0; }
  .reel__tabs { grid-template-columns: 1fr 1fr; }
  .ct__foot { grid-template-columns: 1fr; }
}

/* ============================================================
   CLIENTS PAGE — login + portal
   ============================================================ */
.cl {
  max-width: var(--max-w); margin: 0 auto;
  padding: 120px var(--gutter) 64px;
  min-height: 100vh;
  display: flex; flex-direction: column;
}
.cl__chrome {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 32px; border-bottom: var(--hairline);
  margin-bottom: 64px;
}

/* ---- LOGIN ---- */
.cl-login {
  flex: 1;
  display: flex; align-items: center; justify-content: center;
  padding: 40px 0;
  transition: opacity var(--dur-glacial) var(--ease-fade);
}
.cl-login--opening { opacity: 0; }
.cl-login__stack {
  display: flex; flex-direction: column; align-items: center; gap: 48px;
  max-width: 560px; width: 100%;
}
.cl-login__title {
  margin: 0; text-align: center;
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(40px, 5.4vw, 88px);
  line-height: 0.95; letter-spacing: -0.04em;
}
.cl-login__period { color: var(--ember); }
.cl-login__sub {
  margin: 12px 0 0; text-align: center;
  font-family: var(--font-display); font-style: italic;
  font-size: clamp(18px, 1.8vw, 26px); color: var(--fog);
}
.cl-login__form {
  display: flex; flex-direction: column; gap: 28px;
  width: 100%; max-width: 480px;
  align-items: center;
}
.cl-login__form .cipher { width: 100%; }
.cl-login__go { margin: 0 auto; }
.cl-login__lost {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: var(--track-wider); color: var(--smoke);
  text-transform: uppercase; text-align: center; line-height: 1.8;
}
.cl-login__lost a { color: var(--bone); border-bottom: 1px solid var(--iron); padding-bottom: 1px; transition: border-color var(--dur-base); }
.cl-login__lost a:hover { border-bottom-color: var(--ember); color: var(--ember); }
.cl-login__err {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: var(--track-wider); color: var(--smoke);
  text-transform: uppercase; text-align: center;
  height: 0; overflow: hidden;
  transition: height var(--dur-base) var(--ease-glide), color var(--dur-base);
}
.cl-login__err--show { height: 18px; color: #C8716E; }
.cl-login__err .overline { color: inherit; }

/* ---- SEAL ---- */
.seal {
  position: relative;
  width: 340px; height: 340px;
  display: flex; align-items: center; justify-content: center;
  isolation: isolate;
}
.seal__ring {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  animation: seal-rot 60s linear infinite;
}
.seal__ring--inner { animation-duration: 38s; animation-direction: reverse; }
.seal__c {
  position: absolute;
  font-family: var(--font-barcode);
  color: var(--bone);
  line-height: 1;
  transform-origin: 50% 50%;
  opacity: 0.78;
}
.seal__ring--inner .seal__c { opacity: 0.55; color: var(--fog); }
@keyframes seal-rot { to { transform: rotate(360deg); } }

.seal__hairline {
  position: absolute; border-radius: 50%;
  border: 1px solid var(--stroke);
  pointer-events: none;
}
.seal__hairline--out { inset: 0; }
.seal__hairline--mid { inset: 40px; }
.seal__hairline--in { inset: 100px; border-color: var(--bone); opacity: 0.18; }

.seal__core {
  font-family: var(--font-barcode);
  font-size: 26px; color: var(--bone);
  letter-spacing: 0;
  z-index: 2;
  opacity: 0.92;
}
.seal__glow {
  position: absolute; inset: -20%;
  background: radial-gradient(ellipse at center,
    rgba(200,165,114,0.22) 0%,
    rgba(200,165,114,0.08) 30%,
    transparent 60%);
  filter: blur(28px);
  z-index: -1; pointer-events: none;
  animation: seal-breathe 9s ease-in-out infinite;
}
@keyframes seal-breathe { 0%, 100% { opacity: 0.5; } 50% { opacity: 1; } }

.seal--rattle { animation: seal-shake 0.6s cubic-bezier(.4,0,.2,1); }
.seal--rattle .seal__hairline--in,
.seal--rattle .seal__hairline--mid { border-color: #C8716E; }
.seal--rattle .seal__core { color: #C8716E; }
@keyframes seal-shake {
  0%,100% { transform: translateX(0); }
  20%     { transform: translateX(-3px); }
  40%     { transform: translateX(3px); }
  60%     { transform: translateX(-2px); }
  80%     { transform: translateX(2px); }
}

/* ---- PORTAL ---- */
.cl-portal {
  display: flex; flex-direction: column; gap: 48px;
}
.cl-portal__bar {
  display: grid; grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 14px 20px;
  border: 1px solid var(--iron);
  background: var(--graphite);
}
.cl-portal__bar > div { display: flex; gap: 14px; align-items: center; }
.cl-portal__bar-c { justify-self: center; }
.cl-portal__bar-r { justify-self: end; gap: 24px; }
.cl-portal__dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--ember); box-shadow: 0 0 12px rgba(200,165,114,0.7);
  animation: cl-dot 2.4s ease-in-out infinite;
}
@keyframes cl-dot { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }
.cl-portal__end {
  background: transparent; border: 0; color: var(--smoke);
  font-family: var(--font-sans); font-size: 10px;
  letter-spacing: var(--track-widest); text-transform: uppercase;
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 12px;
  transition: color var(--dur-base);
}
.cl-portal__end:hover { color: var(--ember); }
.cl-portal__end .link-arrow__rule { display: inline-block; width: 24px; height: 1px; background: currentColor; transition: width var(--dur-base); }
.cl-portal__end:hover .link-arrow__rule { width: 48px; }

.cl-portal__head { display: flex; flex-direction: column; gap: 14px; padding-bottom: 32px; border-bottom: var(--hairline); }
.cl-portal__title { margin: 0; font-family: var(--font-display); font-weight: 400; font-size: clamp(40px, 5vw, 80px); line-height: 1; letter-spacing: -0.035em; }
.cl-portal__title i { color: var(--fog); }
.cl-portal__sub { margin: 0; font-family: var(--font-display); font-style: italic; font-size: clamp(18px, 1.8vw, 26px); color: var(--fog); }

.cl-card {
  border-top: var(--hairline);
  padding: 32px 0;
}
.cl-card > header {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 24px;
}
.cl-card > header .overline { color: var(--bone); }
.cl-card > header .credit { color: var(--smoke); }

/* active deliveries */
.cl-active { list-style: none; padding: 0; margin: 0; }
.cl-active__row {
  display: grid;
  grid-template-columns: 100px 1.6fr 1.2fr 1fr 50px 80px;
  align-items: center;
  gap: 16px;
  padding: 16px 0;
  border-bottom: var(--hairline-soft);
  font-family: var(--font-sans);
}
.cl-active__row:last-child { border-bottom: 0; }
.cl-active__code { font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--track-wider); color: var(--ember); }
.cl-active__title { font-size: var(--t-14); color: var(--bone); }
.cl-active__phase { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--track-wider); color: var(--fog); text-transform: uppercase; }
.cl-active__bar { display: block; height: 1px; background: var(--iron); position: relative; }
.cl-active__bar > span { position: absolute; top: 0; left: 0; height: 1px; background: var(--bone); transition: width var(--dur-slow) var(--ease-rack); }
.cl-active__pct { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--track-wider); color: var(--smoke); font-variant-numeric: tabular-nums; }
.cl-active__due { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--track-wider); color: var(--fog); text-align: right; }

/* vault */
.cl-vault { list-style: none; padding: 0; margin: 0; }
.cl-vault__row {
  display: grid;
  grid-template-columns: 2fr 100px 1fr 220px;
  align-items: center;
  gap: 18px;
  padding: 16px 0;
  border-bottom: var(--hairline-soft);
}
.cl-vault__row:last-child { border-bottom: 0; }
.cl-vault__name { font-family: var(--font-mono); font-size: var(--t-13); color: var(--bone); }
.cl-vault__size { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--track-wider); color: var(--smoke); }
.cl-vault__provider { font-family: var(--font-sans); font-size: 10px; letter-spacing: var(--track-widest); text-transform: uppercase; color: var(--fog); }
.cl-vault__open { display: inline-flex; align-items: center; gap: 14px; font-family: var(--font-sans); font-size: 10px; letter-spacing: var(--track-widest); text-transform: uppercase; color: var(--bone); transition: color var(--dur-base); justify-self: end; }
.cl-vault__open .link-arrow__rule { display: inline-block; width: 32px; height: 1px; background: currentColor; transition: width var(--dur-slow) var(--ease-rack); }
.cl-vault__open .link-arrow__glyph { font-family: var(--font-display); font-size: 18px; transition: transform var(--dur-slow) var(--ease-rack); }
.cl-vault__open:hover { color: var(--ember); }
.cl-vault__open:hover .link-arrow__rule { width: 56px; }
.cl-vault__open:hover .link-arrow__glyph { transform: translateX(6px); }

/* log */
.cl-log { list-style: none; padding: 0; margin: 0; }
.cl-log__row {
  display: grid;
  grid-template-columns: 100px 140px 1fr;
  gap: 18px;
  padding: 14px 0;
  border-bottom: var(--hairline-soft);
}
.cl-log__row:last-child { border-bottom: 0; }
.cl-log__ts { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--track-wider); color: var(--smoke); }
.cl-log__from { font-family: var(--font-sans); font-size: 10px; letter-spacing: var(--track-widest); text-transform: uppercase; color: var(--bone); }
.cl-log__msg { font-family: var(--font-sans); font-size: var(--t-14); color: var(--fog); line-height: 1.55; }

.cl-portal__foot { padding-top: 32px; border-top: var(--hairline); text-align: center; }

@media (max-width: 1100px) {
  .cl-active__row { grid-template-columns: 80px 1.2fr 1fr 1fr; row-gap: 8px; }
  .cl-active__bar, .cl-active__pct, .cl-active__due { grid-column: span 4; }
  .cl-vault__row { grid-template-columns: 1fr; row-gap: 6px; }
  .cl-vault__open { justify-self: start; }
  .cl-log__row { grid-template-columns: 1fr; row-gap: 4px; }
  .cl-portal__bar { grid-template-columns: 1fr; row-gap: 8px; padding: 14px; }
  .cl-portal__bar > div { justify-self: start !important; gap: 12px; }
}


/* Inline "optional" tag in field labels */
.ct-opt {
  font-style: normal;
  margin-left: 8px;
  padding: 2px 6px;
  border: 1px solid var(--iron);
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  color: var(--mist);
  text-transform: lowercase;
  font-weight: 400;
  vertical-align: 1px;
}


/* ============================================================
   APPROACH PAGE — the cryptic placeholder
   ============================================================ */
.ap {
  max-width: var(--max-w); margin: 0 auto;
  padding: 120px var(--gutter) 64px;
  min-height: calc(100vh - 80px);
  display: flex; flex-direction: column;
  position: relative;
  isolation: isolate;
}
.ap__chrome {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 32px; border-bottom: var(--hairline);
  margin-bottom: 56px;
}
/* slow ambient breathe — subtle vignette that pulses */
.ap__pulse {
  position: absolute;
  inset: 80px var(--gutter) 0;
  background: radial-gradient(ellipse 60% 50% at 50% 55%,
    rgba(200, 165, 114, 0.12) 0%,
    rgba(200, 165, 114, 0.04) 35%,
    transparent 65%);
  filter: blur(40px);
  pointer-events: none;
  z-index: 0;
  animation: ap-pulse 11s ease-in-out infinite;
}
@keyframes ap-pulse {
  0%, 100% { opacity: 0.35; }
  50%      { opacity: 1; }
}
/* a single tall hairline that divides the dossier from the stage */
.ap__hairline {
  position: absolute;
  top: 200px; bottom: 200px;
  left: calc(var(--gutter) + 320px);
  width: 1px;
  background: linear-gradient(180deg, transparent, var(--iron) 18%, var(--iron) 82%, transparent);
  z-index: 0;
  pointer-events: none;
}

.ap__main {
  flex: 1;
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 64px;
  align-items: start;
  padding: 64px 0 96px;
  position: relative;
  z-index: 1;
}

/* ---------- Dossier sidebar ---------- */
.dossier {
  display: flex; flex-direction: column;
  gap: 24px;
  padding: 20px;
  border: 1px solid var(--iron);
  background: rgba(12,12,12,0.5);
  position: sticky;
  top: 120px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--track-wider);
  color: var(--fog);
  text-transform: uppercase;
}
.dossier > header,
.dossier > footer {
  display: flex; flex-direction: column; gap: 10px;
}
.dossier > header {
  padding-bottom: 16px; border-bottom: var(--hairline-soft);
  flex-direction: row; justify-content: space-between; align-items: baseline;
}
.dossier__seal {
  color: var(--ember);
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: var(--track-widest);
}
.dossier dl {
  display: flex; flex-direction: column;
  gap: 0; margin: 0;
}
.dossier dl > div {
  display: grid; grid-template-columns: 70px 1fr;
  gap: 14px;
  padding: 10px 0;
  border-bottom: var(--hairline-soft);
  align-items: baseline;
}
.dossier dl > div:last-child { border-bottom: 0; }
.dossier dt { color: var(--smoke); margin: 0; }
.dossier dd { color: var(--bone); margin: 0; font-variant-numeric: tabular-nums; }
.dossier__sep { color: var(--mist); margin: 0 4px; }
.dossier__redact {
  display: inline-block;
  background: var(--mist);
  height: 14px;
  position: relative;
}
.dossier__redact::after {
  content: "";
  position: absolute; inset: 1px;
  border: 1px dashed rgba(0,0,0,0.55);
}
.dossier__redact--sm { width: 90px; }

.dossier__bc {
  font-family: var(--font-barcode);
  font-size: 22px;
  letter-spacing: 0;
  color: var(--bone);
  line-height: 1;
  display: inline-block;
}
.dossier__clock {
  color: var(--ember);
  font-variant-numeric: tabular-nums;
}

.dossier > footer {
  padding-top: 16px; border-top: var(--hairline-soft);
  gap: 8px;
}
.dossier__bar {
  display: block; height: 1px; background: var(--iron);
  position: relative;
}
.dossier__bar > span {
  position: absolute; top: 0; left: 0; height: 1px;
  width: 67%;
  background: var(--ember);
  box-shadow: 0 0 8px rgba(200,165,114,0.4);
  animation: ap-bar 4.8s ease-in-out infinite;
}
@keyframes ap-bar {
  0%, 100% { width: 64%; }
  50%      { width: 70%; }
}

/* ---------- Main stage ---------- */
.ap-stage {
  display: flex; flex-direction: column;
  gap: 32px;
  padding-top: 32px;
}
.ap-stage__brow {
  color: var(--smoke);
  display: inline-block;
  position: relative;
}
.ap-stage__brow::before {
  content: ""; position: absolute;
  left: -16px; top: 50%;
  width: 6px; height: 6px;
  background: var(--ember);
  border-radius: 50%;
  box-shadow: 0 0 12px rgba(200,165,114,0.7);
  transform: translateY(-50%);
  animation: ap-dot 1.8s ease-in-out infinite;
}
@keyframes ap-dot {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.35; }
}

.ap-stage__h1 {
  margin: 0;
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(56px, 9vw, 180px);
  line-height: 0.92; letter-spacing: -0.045em;
  display: grid;
  grid-template-areas: "stack";
  min-height: 1.05em;
}
.ap-stage__lead {
  grid-area: stack;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 1.6s var(--ease-fade), transform 1.6s var(--ease-glide);
  white-space: nowrap;
  pointer-events: none;
}
.ap-stage__lead--in {
  opacity: 1; transform: translateY(0);
  pointer-events: auto;
}

.ap-stage__sub {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(20px, 2.2vw, 34px);
  line-height: 1.2; color: var(--fog);
  display: grid;
  grid-template-areas: "stack";
  min-height: 1.3em;
}
.ap-stage__subln {
  grid-area: stack;
  font-style: italic;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 1.6s var(--ease-fade) 0.2s, transform 1.6s var(--ease-glide) 0.2s;
  pointer-events: none;
  white-space: nowrap;
}
.ap-stage__subln--in {
  opacity: 1; transform: translateY(0);
  pointer-events: auto;
}

/* ---------- Redacted prose + progress ---------- */
.ap-foot {
  position: relative;
  z-index: 1;
  border-top: var(--hairline);
  padding: 40px 0 0;
  display: grid; grid-template-columns: 1.4fr 1fr;
  gap: 48px;
  align-items: end;
}
.ap-foot__prose {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(18px, 1.8vw, 28px);
  line-height: 1.45;
  color: var(--fog);
  max-width: 56ch;
  text-wrap: pretty;
}
.redact {
  display: inline-block;
  background: var(--mist);
  height: 0.85em;
  vertical-align: -0.05em;
  margin: 0 6px;
  position: relative;
}
.redact::after {
  content: "";
  position: absolute; inset: 1px;
  border: 1px dashed rgba(0,0,0,0.45);
}
.redact--md { width: 6.5em; }
.redact--lg { width: 11em; }

.ap-foot__progress {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 18px;
  align-items: center;
  padding: 18px 20px;
  border: 1px solid var(--iron);
  background: rgba(12,12,12,0.5);
}
.ap-foot__lab {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: var(--track-widest); text-transform: uppercase;
  color: var(--smoke);
}
.ap-foot__track {
  display: block; height: 1px; background: var(--iron);
  position: relative;
}
.ap-foot__track > span {
  position: absolute; left: 0; top: 0; height: 1px;
  background: var(--bone);
  box-shadow: 0 0 12px rgba(255,255,255,0.4);
  animation: ap-foot-bar 9s ease-in-out infinite;
}
@keyframes ap-foot-bar {
  0%, 100% { width: 64%; }
  35%      { width: 70%; }
  72%      { width: 66%; }
}
.ap-foot__val {
  font-family: var(--font-display); font-size: 28px;
  color: var(--bone); line-height: 1; letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.ap-foot__val i { font-style: normal; font-size: 14px; color: var(--smoke); margin-left: 2px; }

@media (max-width: 1100px) {
  .ap__main { grid-template-columns: 1fr; }
  .ap__hairline { display: none; }
  .dossier { position: static; }
  .ap-foot { grid-template-columns: 1fr; }
}


/* Approach nav link — replaces label with a re-encoding cipher */
.nav-link__cipher {
  font-family: var(--font-barcode);
  font-size: 20px;
  line-height: 1;
  letter-spacing: 0;
  color: var(--bone);
  display: inline-block;
  min-width: 64px;       /* prevents layout shift on re-encode */
  text-align: left;
  vertical-align: -3px;  /* nudges baseline to align with the "03" prefix */
  transition: color var(--dur-base) var(--ease-glide), opacity var(--dur-base);
  opacity: 0.92;
}
.nav-link:hover .nav-link__cipher { color: var(--ember); opacity: 1; }
.nav-link--current .nav-link__cipher { color: var(--ember); }


/* ============================================================
   CLIENTS HUB — the portal behind the seal
   ============================================================ */
.hub {
  max-width: var(--max-w); margin: 0 auto;
  padding: 120px var(--gutter) 64px;
  min-height: 100vh;
  display: flex; flex-direction: column;
}
.hub__chrome {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 32px; border-bottom: var(--hairline);
  margin-bottom: 56px;
}
.hub__head {
  display: flex; flex-direction: column; gap: 16px;
  padding-bottom: 44px; border-bottom: var(--hairline);
}
.hub__title {
  margin: 0;
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(56px, 8vw, 150px);
  line-height: 0.92; letter-spacing: -0.045em;
}
.hub__period { color: var(--ember); }
.hub__sub {
  margin: 0;
  font-family: var(--font-display); font-style: italic;
  font-size: clamp(20px, 2.2vw, 32px); color: var(--fog);
  line-height: 1.2;
}
.hub__grid {
  display: grid; grid-template-columns: 1fr 1fr;
  border-bottom: var(--hairline);
  flex: 1;
}
.hub__tile {
  display: flex; flex-direction: column; gap: 24px;
  padding: 56px 48px 44px;
  border-right: var(--hairline-soft);
  text-align: left;
  background: transparent; color: var(--bone);
  cursor: pointer;
  position: relative; isolation: isolate;
  min-height: 380px;
  transition: background var(--dur-slow) var(--ease-glide);
}
.hub__tile:last-child { border-right: 0; }
.hub__tile:hover { background: var(--graphite); }
.hub__tile-head { display: flex; align-items: baseline; gap: 16px; }
.hub__n {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: var(--track-wider); color: var(--smoke);
  font-variant-numeric: tabular-nums;
}
.hub__tag {
  margin-left: auto;
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: var(--track-widest); text-transform: uppercase;
  color: var(--ember);
  border: 1px solid var(--iron); padding: 4px 8px;
}
.hub__label {
  margin: 0;
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(36px, 4vw, 68px);
  line-height: 1; letter-spacing: -0.025em;
}
.hub__body {
  margin: 0;
  font-family: var(--font-sans); font-size: var(--t-15, 15px);
  line-height: 1.6; color: var(--fog);
  max-width: 34ch; flex: 1;
}
.hub__cta {
  display: flex; align-items: center; gap: 18px;
  font-family: var(--font-sans); font-size: var(--t-12);
  font-weight: var(--w-medium);
  letter-spacing: var(--track-widest); text-transform: uppercase;
  color: var(--bone);
  margin-top: auto;
}
.hub__rule {
  display: inline-block; width: 44px; height: 1px;
  background: var(--bone);
  transition: width var(--dur-slow) var(--ease-rack), background var(--dur-base);
}
.hub__tile:hover .hub__rule { width: 104px; background: var(--ember); }
.hub__tile:hover .hub__verb { color: var(--ember); }
.hub__glyph {
  font-family: var(--font-display); font-size: 24px;
  margin-left: auto;
  transition: transform var(--dur-slow) var(--ease-rack), color var(--dur-base);
}
.hub__tile:hover .hub__glyph { transform: translateX(10px); color: var(--ember); }
.hub__bc {
  font-family: var(--font-barcode); font-size: 20px;
  color: var(--smoke); margin-left: auto; line-height: 1;
  transition: color var(--dur-base);
}
.hub__tile--locked:hover .hub__bc { color: var(--ember); }
.hub__redact { display: flex; gap: 10px; align-items: center; }
.hub__redact span {
  display: inline-block; height: 12px; background: var(--mist);
  position: relative;
}
.hub__redact span::after { content: ""; position: absolute; inset: 1px; border: 1px dashed rgba(0,0,0,0.5); }
.hub__foot {
  display: flex; justify-content: space-between; align-items: center;
  padding: 28px 0 0;
}
@media (max-width: 1100px) {
  .hub__grid { grid-template-columns: 1fr; }
  .hub__tile { border-right: 0; border-bottom: var(--hairline-soft); min-height: 0; }
  .hub__tile:last-child { border-bottom: 0; }
}


/* ============================================================
   CLIENT REELS — 16:9 screening room (real footage)
   ============================================================ */
.cr {
  max-width: var(--max-w); margin: 0 auto;
  padding: 120px var(--gutter) 0;
  min-height: 100vh; display: flex; flex-direction: column;
}
.cr__chrome {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 32px; border-bottom: var(--hairline);
  margin-bottom: 48px;
}
.cr__head { display: flex; flex-direction: column; gap: 14px; margin-bottom: 40px; max-width: 60ch; }
.cr__title {
  margin: 0; font-family: var(--font-display); font-weight: 400;
  font-size: clamp(64px, 9vw, 168px); line-height: 0.92; letter-spacing: -0.045em;
}
.cr__period { color: var(--ember); }
.cr__sub {
  margin: 0; font-family: var(--font-display); font-style: italic;
  font-size: clamp(20px, 2.2vw, 34px); color: var(--fog); line-height: 1.2; max-width: 44ch;
}
.cr__theater { position: relative; margin-bottom: 56px; isolation: isolate; }
.cr__theater::before {
  content: ""; position: absolute; inset: -7% -5%;
  background: radial-gradient(ellipse at 50% 50%, rgba(200,165,114,0.16) 0%, rgba(200,165,114,0.05) 38%, transparent 66%);
  filter: blur(40px); z-index: 0; pointer-events: none;
  animation: reel-flicker 5.2s ease-in-out infinite;
}
.cr__stage {
  position: relative; aspect-ratio: 16 / 9;
  background: #000; border: 1px solid var(--stroke);
  overflow: hidden; z-index: 1;
}
.cr__video { width: 100%; height: 100%; object-fit: contain; display: block; background: #000; }
.cr__poster {
  position: absolute; inset: 0; z-index: 2;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 36px;
  background: linear-gradient(180deg, rgba(0,0,0,0.2), rgba(0,0,0,0.6));
}
.cr__grain {
  position: absolute; inset: 0; z-index: -1;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.1' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.7 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-size: 240px 240px; opacity: 0.06; mix-blend-mode: overlay; pointer-events: none;
}
.cr__poster-meta { display: flex; flex-direction: column; gap: 10px; }
.cr__poster-title {
  margin: 0; font-family: var(--font-display); font-weight: 400;
  font-size: clamp(28px, 3.4vw, 56px); line-height: 1; letter-spacing: -0.02em; color: var(--bone);
}
.cr__poster-title i { color: var(--fog); font-style: italic; }
.cr__play {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  background: transparent; border: 0; color: var(--bone); cursor: pointer;
  display: flex; flex-direction: column; align-items: center; gap: 16px; padding: 24px; z-index: 3;
}
.cr__play-ring {
  position: absolute; inset: -34px; border: 1px solid rgba(255,255,255,0.6);
  border-radius: 50%; transition: transform var(--dur-slow) var(--ease-rack), border-color var(--dur-base);
}
.cr__play:hover .cr__play-ring { transform: scale(1.06); border-color: var(--ember); }
.cr__play svg { transition: transform var(--dur-slow) var(--ease-rack); }
.cr__play:hover svg { transform: translateX(3px); color: var(--ember); }
.cr__play-dur {
  position: absolute; top: calc(100% + 14px); white-space: nowrap;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--track-wider); color: var(--fog);
}
.cr__pending {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  text-align: center; display: flex; flex-direction: column; gap: 12px; align-items: center;
  border: 1px dashed var(--iron); padding: 28px 36px; background: rgba(0,0,0,0.45); z-index: 3; max-width: 82%;
}
.cr__pending .overline { color: var(--ember); }
.cr__pending p { margin: 0; font-family: var(--font-sans); font-size: var(--t-14); color: var(--fog); line-height: 1.7; }
.cr__pending code {
  font-family: var(--font-mono); font-size: 12px; color: var(--bone);
  background: var(--graphite); padding: 2px 6px; border: 1px solid var(--iron);
}
.cr__tabs { display: grid; grid-template-columns: 1fr 1fr; border-top: var(--hairline); border-bottom: var(--hairline); margin-bottom: 56px; }
.cr__tab {
  background: transparent; border: 0; border-right: var(--hairline-soft);
  padding: 28px; display: flex; flex-direction: column; gap: 10px; cursor: pointer; text-align: left;
  color: var(--fog); transition: background var(--dur-slow) var(--ease-glide), color var(--dur-base);
}
.cr__tab:last-child { border-right: 0; }
.cr__tab:hover { background: var(--graphite); color: var(--bone); }
.cr__tab--on { background: var(--graphite); color: var(--bone); }
.cr__tab--on .cr__tab-n { color: var(--ember); }
.cr__tab-head { display: flex; align-items: baseline; gap: 14px; }
.cr__tab-n { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--track-wider); color: var(--smoke); }
.cr__tab-yr { margin-left: auto; font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--track-wider); color: var(--smoke); }
.cr__tab-l { font-family: var(--font-display); font-size: clamp(24px, 2.6vw, 38px); line-height: 1.05; letter-spacing: -0.02em; }
.cr__tab-d { font-family: var(--font-sans); font-size: var(--t-13, 13px); color: var(--fog); line-height: 1.5; max-width: 36ch; }
.cr__foot { display: flex; justify-content: space-between; align-items: center; padding: 28px 0 64px; border-top: var(--hairline); margin-top: auto; }
@media (max-width: 1100px) {
  .cr__tabs { grid-template-columns: 1fr; }
  .cr__tab { border-right: 0; border-bottom: var(--hairline-soft); }
  .cr__tab:last-child { border-bottom: 0; }
}


/* ============================================================
   CLIENT AREA — restricted, intentionally-empty placeholder
   ============================================================ */
.crarea {
  max-width: var(--max-w); margin: 0 auto;
  padding: 120px var(--gutter) 64px;
  min-height: 100vh; display: flex; flex-direction: column;
  position: relative; isolation: isolate;
}
.crarea__chrome {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 32px; border-bottom: var(--hairline); margin-bottom: 56px;
}
.crarea__pulse {
  position: absolute; inset: 80px var(--gutter) 0;
  background: radial-gradient(ellipse 60% 50% at 50% 55%, rgba(200,165,114,0.10) 0%, rgba(200,165,114,0.03) 40%, transparent 66%);
  filter: blur(40px); pointer-events: none; z-index: 0;
  animation: ap-pulse 11s ease-in-out infinite;
}
.crarea__stack {
  flex: 1; display: flex; flex-direction: column; justify-content: center; align-items: center;
  gap: 26px; text-align: center; position: relative; z-index: 1; padding: 48px 0 96px;
}
.crarea__seal { font-family: var(--font-barcode); font-size: clamp(40px, 6vw, 96px); color: var(--bone); opacity: 0.9; line-height: 1; }
.crarea__title { margin: 0; font-family: var(--font-display); font-weight: 400; font-size: clamp(48px, 7vw, 132px); line-height: 0.95; letter-spacing: -0.04em; }
.crarea__title i { color: var(--fog); }
.crarea__sub { margin: 0; font-family: var(--font-display); font-style: italic; font-size: clamp(18px, 2vw, 28px); color: var(--fog); max-width: 42ch; line-height: 1.3; }
.crarea__lines { display: flex; flex-direction: column; gap: 12px; align-items: center; margin: 8px 0; }
.crarea__lines span { display: flex; gap: 10px; align-items: center; }
.crarea__redact { display: inline-block; height: 13px; background: var(--mist); position: relative; }
.crarea__redact::after { content: ""; position: absolute; inset: 1px; border: 1px dashed rgba(0,0,0,0.5); }
.crarea__note { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--track-wider); text-transform: uppercase; color: var(--smoke); }
