/* ============================================================
   UN.COMMON.ICON — An Index of Uncommon Things
   Faithful static recreation of the Claude Design prototype.
   ============================================================ */

/* ---- Design tokens ---- */
:root {
  --bg:        #120F0B;   /* page (warmed) */
  --bg-dark:   #0D0B08;   /* alternating sections / marquee */
  --frame:     #16110C;   /* image frame fill */
  --cream:     #ECE6DA;   /* primary text */
  --serif:     #C9C0B0;   /* body serif */
  --muted:     #9A9082;   /* secondary */
  --taupe:     #847B6E;   /* mono labels */
  --faint:     #5A534A;   /* faint dividers / glyphs */
  --signal:    #D8FF47;   /* accent (electric) */
  --pen:       #FF3D8B;   /* accent (handwritten) */
  --glow:      #B57BFF;   /* accent (uv violet) */

  --maxw: 1640px;
  --pad: clamp(18px, 5vw, 72px);

  --font-display: 'Syne', system-ui, sans-serif;
  --font-serif:   'Bodoni Moda', Georgia, serif;
  --font-hand:    'Caveat', cursive;
  --font-mono:    'Space Mono', ui-monospace, monospace;
}

/* ---- Reset / base ---- */
* { box-sizing: border-box; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--cream);
  font-family: var(--font-display);
  min-height: 100vh;
  overflow-x: hidden;
  position: relative;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; }
input { font-family: inherit; }
input::placeholder { color: #6F675B; }
::selection { background: var(--signal); color: var(--bg); }
::-webkit-scrollbar { width: 11px; height: 11px; }
::-webkit-scrollbar-track { background: var(--bg-dark); }
::-webkit-scrollbar-thumb { background: #29231C; }
::-webkit-scrollbar-thumb:hover { background: #3A3127; }

/* ---- Keyframes ---- */
@keyframes uci-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes uci-pulse   { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: .2; transform: scale(.72); } }
@keyframes uci-cue     { 0% { transform: translateY(0); opacity: .35; } 50% { opacity: 1; } 100% { transform: translateY(11px); opacity: .35; } }
@keyframes uci-grain   { 0% { transform: translate(0,0); } 25% { transform: translate(-7px,4px); } 50% { transform: translate(5px,-6px); } 75% { transform: translate(-4px,-3px); } 100% { transform: translate(0,0); } }

/* ---- Scroll reveal ---- */
[data-reveal] { opacity: 0; transform: translateY(28px); transition: transform .9s cubic-bezier(.2,.7,.2,1), opacity .9s cubic-bezier(.2,.7,.2,1); }
[data-reveal][data-shown] { opacity: 1; transform: none; }

/* ---- Shared layout helpers ---- */
.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding-left: var(--pad); padding-right: var(--pad); }

.section { padding-top: clamp(74px,11vh,150px); padding-bottom: clamp(74px,11vh,150px); scroll-margin-top: 90px; }
.section--dark { background: var(--bg-dark); border-top: 1px solid rgba(236,230,218,0.10); }

/* Section header label row (e.g. "Signals — What We're Watching   01") */
.section-head {
  display: flex; align-items: baseline; justify-content: space-between; gap: 24px;
  border-top: 1px solid rgba(236,230,218,0.22); padding-top: 18px;
}
.section-head .label {
  font-family: var(--font-mono); font-size: clamp(10px,1vw,12px);
  letter-spacing: .28em; text-transform: uppercase; color: var(--taupe);
}
.section-head .num {
  font-family: var(--font-mono); font-size: clamp(10px,1vw,12px);
  letter-spacing: .28em; color: var(--signal);
}

.lede {
  margin: 0; font-family: var(--font-display); font-weight: 500;
  line-height: 1.3; color: var(--cream);
}

/* ---- Grain overlay ---- */
.grain {
  position: fixed; inset: -40px; z-index: 82; pointer-events: none;
  opacity: .055; mix-blend-mode: overlay;
  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='0.82' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  background-size: 240px 240px;
  animation: uci-grain 9s steps(5) infinite;
}

/* ---- Custom cursor disc ---- */
.cursor-disc {
  position: fixed; left: 0; top: 0; width: 78px; height: 78px; border-radius: 50%;
  border: 1px solid var(--signal); color: var(--signal);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono); font-size: 9px; letter-spacing: .24em;
  pointer-events: none; z-index: 95; opacity: 0;
  transform: translate(-300px,-300px);
  transition: opacity .3s ease, width .3s ease, height .3s ease;
}

/* ============================================================
   HEADER
   ============================================================ */
.header {
  position: sticky; top: 0; z-index: 70;
  background: rgba(14,11,9,0);
  border-bottom: 1px solid rgba(236,230,218,0);
  transition: background .45s ease, border-color .45s ease, backdrop-filter .45s ease;
}
.header.scrolled {
  background: rgba(14,11,9,0.86);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom-color: rgba(236,230,218,0.12);
}
.topbar-border { border-bottom: 1px solid rgba(236,230,218,0.07); }
.topbar {
  display: flex; align-items: center; justify-content: space-between; gap: 14px; height: 34px;
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .2em; text-transform: uppercase;
  color: var(--taupe); white-space: nowrap; overflow: hidden;
}
.topbar .group { display: flex; align-items: center; gap: 14px; min-width: 0; }
.topbar .group:last-child { flex-shrink: 0; }
.topbar .live { display: inline-flex; align-items: center; gap: 7px; color: var(--cream); flex-shrink: 0; }
.dot { width: 6px; height: 6px; border-radius: 50%; background: var(--signal); display: inline-block; }
.dot--pulse { animation: uci-pulse 2.6s ease-in-out infinite; }
.topbar .sep { opacity: .45; flex-shrink: 0; }
.topbar .ellip { overflow: hidden; text-overflow: ellipsis; }
.topbar .strong { color: var(--cream); }

.navrow {
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  height: clamp(62px,8vh,78px);
}
.logo {
  font-family: var(--font-display); font-weight: 700; font-size: clamp(15px,1.6vw,19px);
  letter-spacing: .01em; color: var(--cream); display: inline-flex; align-items: center; flex-shrink: 0;
}
.logo .d { color: var(--taupe); margin: 0 1px; }

.nav { display: flex; align-items: center; gap: clamp(16px,2.3vw,38px); }
.nav-link {
  font-family: var(--font-mono); font-size: 12px; letter-spacing: .16em; text-transform: uppercase;
  color: var(--muted); padding: 6px 0;
  background-image: linear-gradient(var(--signal), var(--signal));
  background-size: 0% 1px; background-position: 0 100%; background-repeat: no-repeat;
  transition: background-size .35s ease, color .35s ease;
}
.nav-link:hover { color: var(--cream); background-size: 100% 1px; }

.btn-outline {
  font-family: var(--font-mono); font-size: 12px; letter-spacing: .16em; text-transform: uppercase;
  color: var(--cream); border: 1px solid rgba(236,230,218,0.3); padding: 13px 20px;
  transition: background .35s ease, color .35s ease, border-color .35s ease;
}
.btn-outline:hover { background: var(--cream); color: var(--bg); border-color: var(--cream); }

.burger {
  appearance: none; background: none; border: none; cursor: pointer;
  display: none; flex-direction: column; gap: 6px; padding: 8px 0;
}
.burger span { width: 28px; height: 1.5px; background: var(--cream); display: block; }
.burger span:last-child { width: 18px; }

/* ---- Mobile overlay ---- */
.overlay {
  position: fixed; inset: 0; z-index: 90; background: var(--bg-dark);
  transform: translateY(-101%); opacity: 0; pointer-events: none;
  transition: transform .6s cubic-bezier(.72,0,.18,1), opacity .45s ease;
  display: flex; flex-direction: column; padding: clamp(18px,6vw,40px);
}
.overlay.open { transform: translateY(0); opacity: 1; pointer-events: auto; }
.overlay-top {
  display: flex; align-items: center; justify-content: space-between;
  border-bottom: 1px solid rgba(236,230,218,0.14); padding-bottom: 18px;
}
.overlay-logo { font-family: var(--font-display); font-weight: 700; font-size: 16px; color: var(--cream); }
.overlay-logo .d { color: var(--taupe); }
.overlay-close {
  appearance: none; background: none; border: none; color: var(--cream);
  font-size: 28px; line-height: 1; cursor: pointer; font-family: var(--font-mono);
}
.overlay-nav { flex: 1; display: flex; flex-direction: column; justify-content: center; gap: 6px; }
.overlay-nav a {
  font-family: var(--font-display); font-weight: 700; text-transform: uppercase;
  font-size: clamp(34px,11vw,64px); line-height: 1.04; letter-spacing: -0.02em; color: var(--cream); padding: 6px 0;
}
.overlay-foot { border-top: 1px solid rgba(236,230,218,0.14); padding-top: 20px; display: flex; flex-direction: column; gap: 16px; }
.overlay-cta {
  display: inline-flex; align-items: center; justify-content: center; gap: 12px;
  background: var(--cream); color: var(--bg);
  font-family: var(--font-mono); font-size: 13px; letter-spacing: .16em; text-transform: uppercase; padding: 18px;
}
.overlay-meta {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--taupe);
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative; padding-top: clamp(44px,7vh,96px); padding-bottom: clamp(36px,5vh,64px);
  min-height: 88vh; display: flex; flex-direction: column; justify-content: center; scroll-margin-top: 90px;
}
.hero-eyebrow {
  display: flex; align-items: baseline; justify-content: space-between; gap: 18px; flex-wrap: wrap;
  font-family: var(--font-mono); font-size: clamp(10px,1vw,12px); letter-spacing: .26em; text-transform: uppercase; color: var(--taupe);
}
.hero-eyebrow .strong { color: var(--cream); }

.hero-h1 {
  margin: clamp(22px,3.4vh,44px) 0 0; font-family: var(--font-display); font-weight: 800; text-transform: uppercase;
  font-size: clamp(45px,9.1vw,152px); line-height: 0.93; letter-spacing: -0.022em; color: var(--cream);
}
.hero-h1 span { display: block; }
.scribble {
  position: relative; display: inline-block; font-family: var(--font-serif); font-weight: 500;
  font-style: italic; text-transform: lowercase; letter-spacing: 0; padding: 0 .06em;
}
.scribble svg { position: absolute; left: -0.22em; top: -0.2em; width: 5.3em; height: 1.4em; overflow: visible; pointer-events: none; }

.hero-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr));
  gap: clamp(28px,4vw,72px); align-items: end; margin-top: clamp(34px,5vh,68px);
}
.hero-copy p {
  margin: 0; max-width: 42ch; font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(18px,1.7vw,25px); line-height: 1.5; color: var(--serif);
}
.hero-ctas { display: flex; flex-wrap: wrap; gap: 14px; margin-top: clamp(26px,3.4vh,40px); }

.btn-solid {
  display: inline-flex; align-items: center; gap: 14px; background: var(--cream); color: var(--bg);
  font-family: var(--font-mono); font-size: 13px; letter-spacing: .15em; text-transform: uppercase;
  padding: 20px 30px; border: 1px solid var(--cream);
  transition: background .4s ease, border-color .4s ease, letter-spacing .4s ease;
}
.btn-solid:hover { background: var(--signal); border-color: var(--signal); letter-spacing: .19em; }

.btn-underline {
  display: inline-flex; align-items: center; gap: 10px; color: var(--cream);
  font-family: var(--font-mono); font-size: 13px; letter-spacing: .15em; text-transform: uppercase; padding: 20px 4px;
  background-image: linear-gradient(var(--signal), var(--signal));
  background-size: 0% 1px; background-position: 0 100%; background-repeat: no-repeat;
  transition: background-size .4s ease;
}
.btn-underline:hover { background-size: 100% 1px; }

.hero-figure { margin: 0; position: relative; }
.tape {
  position: absolute; z-index: 4; background: rgba(217,210,197,0.16);
  border: 1px dashed rgba(236,230,218,0.25); pointer-events: none;
}
.hero-figure .tape { right: 18px; top: -12px; width: 88px; height: 26px; transform: rotate(4deg); }
.frame {
  position: relative; overflow: hidden; border: 1px solid rgba(236,230,218,0.16);
  background: var(--frame);
}
.frame img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.figcap {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 14px; margin-top: 14px;
}
.figcap .hand {
  font-family: var(--font-hand); font-size: clamp(20px,2vw,26px); line-height: 1; color: var(--pen);
}
.bars { display: flex; align-items: flex-end; gap: 1.5px; height: 20px; flex-shrink: 0; }
.bars span { display: block; width: 1.5px; background: var(--taupe); }
.bars--faint span { background: var(--faint); }

.hero-foot {
  display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap;
  margin-top: clamp(30px,5vh,60px); padding-top: 18px; border-top: 1px solid rgba(236,230,218,0.14);
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--taupe);
}
.hero-foot .scroll { display: inline-flex; align-items: center; gap: 10px; color: var(--cream); }
.hero-foot .scroll .cue { display: inline-block; animation: uci-cue 1.7s ease-in-out infinite; }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee {
  border-top: 1px solid rgba(236,230,218,0.14); border-bottom: 1px solid rgba(236,230,218,0.14);
  background: var(--bg-dark); overflow: hidden; padding: clamp(14px,2vh,22px) 0;
}
.marquee-track { display: flex; width: max-content; animation: uci-marquee 36s linear infinite; }
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee-row {
  display: flex; align-items: center; flex-shrink: 0;
  font-family: var(--font-display); font-weight: 600; text-transform: uppercase;
  font-size: clamp(20px,3vw,40px); letter-spacing: 0.01em; color: var(--cream);
}
.marquee-row .item { padding: 0 clamp(20px,3vw,44px); }
.marquee-row .slash { color: var(--faint); }

/* ============================================================
   01 · SIGNALS
   ============================================================ */
.signals-lede { margin: 0 0 clamp(40px,5vw,72px); max-width: 30ch; font-size: clamp(20px,2.3vw,32px); line-height: 1.28; }

.signal-feature {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(320px,1fr));
  gap: clamp(28px,4vw,60px); align-items: center; margin-bottom: clamp(44px,5vw,80px);
}
.signal-feature figure { margin: 0; position: relative; }

.eyebrow-row {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .24em; text-transform: uppercase;
  color: var(--signal); margin-bottom: 18px; display: flex; gap: 14px; align-items: center;
}
.eyebrow-row .strong { color: var(--cream); }
.eyebrow-row .mid { color: var(--faint); }
.eyebrow-row .meta { color: var(--taupe); }

.signal-title { margin: 0; font-family: var(--font-display); font-weight: 700; font-size: clamp(28px,3.6vw,54px); line-height: 1.02; letter-spacing: -0.018em; color: var(--cream); }
.signal-dek { margin: 22px 0 0; max-width: 40ch; font-family: var(--font-serif); font-size: clamp(17px,1.5vw,22px); line-height: 1.5; color: var(--serif); }

.link-mono {
  display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 12px;
  letter-spacing: .16em; text-transform: uppercase; color: var(--cream); padding-bottom: 4px;
  background-image: linear-gradient(var(--signal), var(--signal));
  background-size: 0% 1px; background-position: 0 100%; background-repeat: no-repeat;
  transition: background-size .4s ease;
}
.link-mono:hover { background-size: 100% 1px; }
.signal-feature .link-mono { margin-top: 28px; }

.signal-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(232px,1fr)); gap: clamp(22px,2.4vw,38px); }
.signal-card { display: flex; flex-direction: column; gap: 16px; color: var(--cream); transition: transform .4s ease; }
.signal-card:hover { transform: translateY(-5px); }
.signal-card figure { margin: 0; position: relative; }
.signal-card .cat {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .2em; text-transform: uppercase;
  color: var(--taupe); display: flex; gap: 10px;
}
.signal-card .cat .strong { color: var(--cream); }
.signal-card .cat .mid { color: var(--faint); }
.signal-card h4 { margin: -4px 0 0; font-family: var(--font-display); font-weight: 600; font-size: clamp(19px,1.7vw,25px); line-height: 1.1; letter-spacing: -0.01em; color: var(--cream); }
.signal-card p { margin: 0; font-family: var(--font-serif); font-size: 15px; line-height: 1.5; color: var(--muted); }

/* ============================================================
   02 · MANIFESTO
   ============================================================ */
.manifesto-quote { margin: 0 0 clamp(44px,5vw,80px); max-width: 24ch; }
.manifesto-quote p {
  margin: 0; font-family: var(--font-serif); font-weight: 500;
  font-size: clamp(28px,5.1vw,76px); line-height: 1.07; letter-spacing: -0.01em; color: var(--cream);
}
.manifesto-quote .ink { font-style: italic; color: var(--pen); }
.manifesto-quote em { font-style: italic; }

.split { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr)); gap: clamp(36px,4vw,72px); align-items: center; }
.hand-head { font-family: var(--font-hand); font-size: clamp(26px,2.6vw,40px); color: var(--pen); line-height: 1; margin-bottom: clamp(22px,2.6vw,30px); }

.beliefs { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: clamp(16px,2vw,24px); }
.beliefs li { display: flex; gap: 16px; align-items: baseline; }
.beliefs .star { color: var(--pen); font-size: 17px; flex-shrink: 0; line-height: 1.4; }
.beliefs li span:last-child { font-family: var(--font-display); font-weight: 500; font-size: clamp(18px,1.7vw,24px); line-height: 1.34; color: var(--cream); }

.sign-row { display: flex; align-items: baseline; flex-wrap: wrap; gap: clamp(16px,2vw,26px); margin-top: clamp(28px,3vw,42px); }
.sign-row .sig { font-family: var(--font-hand); font-size: clamp(34px,3.6vw,52px); color: var(--cream); line-height: 1; }
.sign-row .aside { font-family: var(--font-hand); font-size: clamp(20px,2vw,27px); color: var(--pen); }

.poster {
  margin: 0; position: relative; width: 100%; justify-self: center;
}
.poster--scared { max-width: 430px; transform: rotate(-1.4deg); }
.poster--about  { max-width: 450px; transform: rotate(1.5deg); }
.poster .frame { box-shadow: 0 34px 80px -24px rgba(0,0,0,0.75); }
.poster--scared .tape { left: 50%; top: -14px; transform: translateX(-50%) rotate(2deg); width: 124px; height: 30px; border-color: rgba(236,230,218,0.22); }
.poster--about .tape.a { right: 26px; top: -13px; transform: rotate(5deg); width: 108px; height: 28px; border-color: rgba(236,230,218,0.22); }
.poster--about .tape.b { left: 20px; bottom: -12px; transform: rotate(-4deg); width: 92px; height: 26px; background: rgba(217,210,197,0.14); border-color: rgba(236,230,218,0.2); }

.rules {
  margin-top: clamp(48px,6vw,84px); border-top: 1px solid rgba(236,230,218,0.16); padding-top: clamp(22px,3vw,34px);
  display: flex; flex-wrap: wrap; align-items: center; gap: clamp(14px,2.2vw,30px);
}
.rules .head { font-family: var(--font-mono); font-size: 11px; letter-spacing: .24em; text-transform: uppercase; color: var(--taupe); }
.rules .rule {
  display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .04em; text-transform: uppercase; color: var(--serif);
}
.rules .rule .star { color: var(--signal); }

/* ============================================================
   03 · ABOUT
   ============================================================ */
.about-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr)); gap: clamp(36px,4vw,76px); align-items: center; }
.about-copy { order: 1; }
.about-hello { font-family: var(--font-hand); font-size: clamp(40px,5.4vw,76px); line-height: 0.9; color: var(--pen); }
.about-h2 { margin: 16px 0 0; font-family: var(--font-display); font-weight: 700; text-transform: uppercase; font-size: clamp(26px,3.4vw,50px); line-height: 1.0; letter-spacing: -0.02em; color: var(--cream); }
.about-body { margin: 24px 0 0; max-width: 46ch; font-family: var(--font-serif); font-size: clamp(17px,1.5vw,21px); line-height: 1.6; color: var(--serif); }
.about-list { list-style: none; margin: 26px 0 0; padding: 0; display: flex; flex-direction: column; gap: 13px; }
.about-list li { display: flex; gap: 14px; align-items: baseline; font-family: var(--font-display); font-weight: 500; font-size: clamp(16px,1.4vw,20px); line-height: 1.3; color: var(--cream); }
.about-list .star { color: var(--pen); flex-shrink: 0; }
.about-q { font-family: var(--font-hand); font-size: clamp(28px,3.2vw,44px); color: var(--pen); margin-top: clamp(26px,3vw,38px); line-height: 1; }
.about-q .heart { color: var(--cream); }
.about-figure { order: 2; }

/* ============================================================
   04 · IN MOTION
   ============================================================ */
.motion-lede { margin: 0 0 clamp(28px,3vw,44px); max-width: 34ch; font-size: clamp(19px,2vw,28px); }
.row-list .end-rule { border-top: 1px solid rgba(236,230,218,0.16); }

.project-row {
  display: flex; flex-direction: column; gap: 12px; padding: clamp(22px,2.6vw,34px) 0;
  border-top: 1px solid rgba(236,230,218,0.16); transition: padding-left .4s ease;
}
.project-row:hover { padding-left: 14px; }
.project-row .top { display: flex; align-items: baseline; justify-content: space-between; gap: 18px; flex-wrap: wrap; }
.project-row .id-title { display: flex; align-items: baseline; gap: clamp(16px,2vw,32px); min-width: 0; }
.project-row .no { font-family: var(--font-mono); font-size: 12px; color: var(--taupe); flex-shrink: 0; }
.project-row .title { font-family: var(--font-display); font-weight: 600; font-size: clamp(24px,3vw,46px); line-height: 1.02; letter-spacing: -0.018em; color: var(--cream); }
.project-row .status { display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--cream); flex-shrink: 0; }
.project-row .meta { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--taupe); padding-left: clamp(28px,3.4vw,52px); }
.project-row .meta .mid { opacity: .4; }

/* ============================================================
   05 · ROOMS
   ============================================================ */
.room-feature {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(320px,1fr));
  gap: clamp(28px,4vw,60px); align-items: center; margin-bottom: clamp(44px,5vw,76px);
}
.room-feature figure { margin: 0; position: relative; order: 2; }
.room-feature .copy { order: 1; }
.room-up { display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-mono); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--cream); margin-bottom: 22px; }
.room-title { margin: 0; font-family: var(--font-display); font-weight: 700; text-transform: uppercase; font-size: clamp(30px,4vw,60px); line-height: 0.98; letter-spacing: -0.02em; color: var(--cream); }
.room-facts { display: flex; flex-wrap: wrap; gap: clamp(20px,3vw,44px); margin-top: 26px; font-family: var(--font-mono); font-size: 12px; letter-spacing: .16em; text-transform: uppercase; color: var(--taupe); }
.room-facts .k { color: var(--faint); display: block; margin-bottom: 6px; }
.room-facts .v { color: var(--cream); }
.room-lineup { margin-top: 22px; max-width: 48ch; font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .12em; text-transform: uppercase; line-height: 1.7; color: var(--muted); }
.room-feature .btn-solid { margin-top: 30px; padding: 18px 28px; font-size: 12.5px; }

.archive-head { font-family: var(--font-mono); font-size: 11px; letter-spacing: .24em; text-transform: uppercase; color: var(--taupe); margin-bottom: 8px; }
.archive-row {
  display: flex; align-items: baseline; justify-content: space-between; gap: 18px; flex-wrap: wrap;
  padding: clamp(18px,2.2vw,28px) 0; border-top: 1px solid rgba(236,230,218,0.16);
}
.archive-row .id-title { display: flex; align-items: baseline; gap: clamp(16px,2vw,30px); min-width: 0; }
.archive-row .no { font-family: var(--font-mono); font-size: 12px; color: var(--taupe); flex-shrink: 0; }
.archive-row .title { font-family: var(--font-display); font-weight: 600; font-size: clamp(20px,2.3vw,34px); line-height: 1.04; letter-spacing: -0.015em; color: var(--cream); }
.archive-row .meta { display: flex; align-items: baseline; gap: clamp(14px,2vw,30px); font-family: var(--font-mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--taupe); flex-shrink: 0; }
.archive-row .meta .mid { opacity: .4; }
.archive-row .meta .tag { color: var(--cream); }

/* ============================================================
   06 · JOURNAL
   ============================================================ */
.journal-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px,1fr)); gap: clamp(30px,4vw,64px); align-items: start; }
.journal-feature { display: block; color: var(--cream); }
.journal-feature figure { margin: 0 0 24px; position: relative; }
.journal-meta { font-family: var(--font-mono); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--taupe); display: flex; gap: 12px; margin-bottom: 16px; }
.journal-meta .cat { color: var(--signal); }
.journal-meta .mid { color: var(--faint); }
.journal-meta .dim { opacity: .4; }
.journal-feature h3 { margin: 0; font-family: var(--font-display); font-weight: 700; font-size: clamp(26px,3.2vw,46px); line-height: 1.04; letter-spacing: -0.018em; color: var(--cream); }
.journal-feature p { margin: 20px 0 0; max-width: 46ch; font-family: var(--font-serif); font-size: clamp(17px,1.5vw,21px); line-height: 1.55; color: var(--serif); }

.journal-row { display: block; padding: clamp(22px,2.4vw,30px) 0; border-top: 1px solid rgba(236,230,218,0.16); transition: padding-left .4s ease; }
.journal-row:hover { padding-left: 12px; }
.journal-row .meta { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .2em; text-transform: uppercase; color: var(--taupe); display: flex; gap: 12px; margin-bottom: 14px; }
.journal-row .meta .strong { color: var(--cream); }
.journal-row .meta .dim { opacity: .4; }
.journal-row h4 { margin: 0; font-family: var(--font-display); font-weight: 600; font-size: clamp(20px,2vw,30px); line-height: 1.1; letter-spacing: -0.012em; color: var(--cream); }
.journal-row--feat { display: flex; align-items: center; gap: clamp(16px,2.4vw,28px); }
.jr-thumb { width: clamp(112px,18vw,150px); flex-shrink: 0; aspect-ratio: 3/4; object-fit: cover; border: 1px solid rgba(236,230,218,0.16); box-shadow: 0 14px 34px -16px rgba(0,0,0,0.7); }
.jr-body { min-width: 0; }
.journal-more { border-top: 1px solid rgba(236,230,218,0.16); padding-top: 26px; }

/* ============================================================
   07 · COLLABORATE
   ============================================================ */
.collab-lede { margin: 0 0 clamp(28px,3vw,48px); max-width: 38ch; font-size: clamp(19px,2vw,28px); }
.collab-credit { color: var(--signal); white-space: nowrap; background-image: linear-gradient(var(--signal),var(--signal)); background-size: 0% 1px; background-position: 0 100%; background-repeat: no-repeat; transition: background-size .35s ease; }
.collab-credit:hover { background-size: 100% 1px; }
.collab-row {
  display: grid; grid-template-columns: auto 1fr auto; gap: clamp(16px,3vw,44px); align-items: center;
  padding: clamp(22px,2.6vw,34px) 0; border-top: 1px solid rgba(236,230,218,0.16); transition: padding-left .4s ease;
}
.collab-row:hover { padding-left: 14px; }
.collab-row .no { font-family: var(--font-mono); font-size: 12px; color: var(--taupe); }
.collab-row h4 { margin: 0; font-family: var(--font-display); font-weight: 600; font-size: clamp(22px,2.6vw,40px); line-height: 1.02; letter-spacing: -0.018em; color: var(--cream); }
.collab-row p { margin: 8px 0 0; max-width: 52ch; font-family: var(--font-serif); font-size: clamp(15px,1.3vw,18px); line-height: 1.45; color: var(--muted); }
.collab-row .arrow { font-family: var(--font-mono); font-size: 20px; color: var(--taupe); transition: color .4s ease, transform .4s ease; }
.collab-row:hover .arrow { color: var(--signal); transform: translateX(6px); }
.collab-cta { border-top: 1px solid rgba(236,230,218,0.16); padding-top: clamp(34px,4vw,56px); }
.collab-cta .btn-solid { padding: 21px 32px; }

/* ============================================================
   NEWSLETTER
   ============================================================ */
.newsletter { padding-top: clamp(80px,13vh,170px); padding-bottom: clamp(80px,13vh,170px); }
.newsletter .wrap { max-width: 980px; text-align: center; }
.nl-eyebrow { font-family: var(--font-mono); font-size: clamp(10px,1vw,12px); letter-spacing: .28em; text-transform: uppercase; color: var(--taupe); margin-bottom: clamp(22px,3vw,34px); }
.nl-h2 { margin: 0; font-family: var(--font-display); font-weight: 800; text-transform: uppercase; font-size: clamp(40px,7vw,108px); line-height: 0.94; letter-spacing: -0.022em; color: var(--cream); }
.nl-h2--pink { color: var(--pen); }
.nl-coolmetoo { margin: clamp(14px,2vw,20px) 0 0; font-family: var(--font-display); font-weight: 800; text-transform: uppercase; font-size: clamp(16px,2.2vw,26px); letter-spacing: .03em; color: var(--cream); }
.nl-body { margin: clamp(24px,3vw,36px) auto 0; max-width: 54ch; font-family: var(--font-serif); font-size: clamp(17px,1.6vw,22px); line-height: 1.55; color: var(--serif); }
.nl-proof { margin: clamp(14px,2vw,20px) auto 0; max-width: 54ch; font-family: var(--font-mono); font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--signal); }
.nl-form { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; align-items: stretch; margin-top: clamp(34px,4vw,52px); }
.nl-ctas { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; align-items: center; margin-top: clamp(34px,4vw,52px); }

/* Contact form (events / collaboration) */
.contact-form { max-width: 600px; margin: clamp(30px,4vw,44px) auto 0; display: flex; flex-direction: column; gap: 12px; text-align: left; }
.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.cf-input { width: 100%; background: rgba(236,230,218,0.03); border: 1px solid rgba(236,230,218,0.2); color: var(--cream); font-family: var(--font-mono); font-size: 14px; letter-spacing: .02em; padding: 15px 16px; outline: none; transition: border-color .3s ease; box-sizing: border-box; }
.cf-input::placeholder { color: #6F675B; }
.cf-input:focus { border-color: var(--signal); }
.cf-select { appearance: none; -webkit-appearance: none; cursor: pointer; padding-right: 40px; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23ECE6DA' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>"); background-repeat: no-repeat; background-position: right 16px center; }
.cf-select option { background: var(--bg-dark); color: var(--cream); }
.cf-textarea { resize: vertical; min-height: 92px; font-family: var(--font-display); font-size: 15px; line-height: 1.55; }
.cf-submit { align-self: flex-start; background: var(--cream); color: var(--bg); border: 1px solid var(--cream); font-family: var(--font-mono); font-size: 13px; letter-spacing: .15em; text-transform: uppercase; padding: 16px 28px; cursor: pointer; display: inline-flex; align-items: center; gap: 10px; transition: background .4s ease, border-color .4s ease, letter-spacing .4s ease; }
.cf-submit:hover { background: var(--signal); border-color: var(--signal); letter-spacing: .19em; }
.cf-submit[aria-busy="true"] { opacity: .6; cursor: progress; }
@media (max-width: 560px) { .cf-row { grid-template-columns: 1fr; } }
.nl-input {
  flex: 1; min-width: 240px; max-width: 420px; background: transparent; border: none;
  border-bottom: 1px solid rgba(236,230,218,0.3); color: var(--cream);
  font-family: var(--font-mono); font-size: 14px; letter-spacing: .04em; padding: 18px 4px; outline: none;
  transition: border-color .4s ease;
}
.nl-input:focus { border-bottom-color: var(--signal); }
.nl-submit {
  background: var(--cream); color: var(--bg); border: 1px solid var(--cream);
  font-family: var(--font-mono); font-size: 13px; letter-spacing: .15em; text-transform: uppercase;
  padding: 18px 30px; cursor: pointer; transition: background .4s ease, border-color .4s ease, letter-spacing .4s ease;
}
.nl-submit:hover { background: var(--signal); border-color: var(--signal); letter-spacing: .19em; }
.nl-success {
  display: inline-flex; align-items: center; gap: 12px; margin-top: clamp(34px,4vw,52px);
  font-family: var(--font-mono); font-size: 14px; letter-spacing: .14em; text-transform: uppercase; color: var(--cream);
  border: 1px solid rgba(236,230,218,0.3); padding: 18px 28px;
}
.nl-success .dot { width: 8px; height: 8px; }
.nl-sign { font-family: var(--font-hand); font-size: clamp(30px,3.4vw,48px); color: var(--pen); margin-top: clamp(22px,2.6vw,32px); line-height: 1; }
.nl-fine { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--faint); margin-top: 18px; }
.hidden { display: none !important; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { padding-top: clamp(64px,9vh,116px); padding-bottom: 36px; background: var(--bg); border-top: 1px solid rgba(236,230,218,0.14); }
.footer-word { display: block; font-family: var(--font-display); font-weight: 800; text-transform: uppercase; font-size: clamp(16px,5.6vw,92px); line-height: 0.9; letter-spacing: -0.03em; color: var(--cream); white-space: nowrap; }
.footer-hand { font-family: var(--font-hand); font-size: clamp(24px,2.8vw,40px); color: var(--pen); margin-top: clamp(8px,1.2vw,16px); }
.footer-words { font-family: var(--font-mono); font-size: clamp(10px,1.1vw,13px); letter-spacing: .2em; text-transform: uppercase; color: var(--taupe); margin-top: clamp(18px,2.4vw,30px); padding-bottom: clamp(40px,5vw,64px); border-bottom: 1px solid rgba(236,230,218,0.14); }

.footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); gap: clamp(28px,4vw,48px); padding: clamp(40px,5vw,64px) 0; border-bottom: 1px solid rgba(236,230,218,0.14); }
.footer-col .head { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .24em; text-transform: uppercase; color: var(--faint); margin-bottom: 22px; }
.footer-col .links { display: flex; flex-direction: column; gap: 13px; font-family: var(--font-display); font-size: 16px; color: var(--serif); }
.footer-col .links a { transition: color .3s ease; }
.footer-col .links a:hover { color: var(--cream); }
.footer-col .links span { color: var(--serif); }
.footer-col .links span.dim { color: var(--taupe); }
.footer-social {
  display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 600;
  font-size: clamp(20px,2vw,28px); color: var(--cream); padding-bottom: 4px;
  background-image: linear-gradient(var(--signal), var(--signal));
  background-size: 0% 1px; background-position: 0 100%; background-repeat: no-repeat; transition: background-size .4s ease;
}
.footer-social:hover { background-size: 100% 1px; }
.footer-socials { display: flex; gap: 18px; margin-top: 18px; font-family: var(--font-mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--taupe); }
.footer-socials a { transition: color .3s ease; }
.footer-socials a:hover { color: var(--cream); }

.footer-bottom { display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; padding-top: 28px; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--faint); }
.footer-bottom .bars { height: 22px; }
.footer-bottom .copy { text-align: center; flex: 1; min-width: 200px; }
.footer-bottom .top-link { display: inline-flex; align-items: center; gap: 9px; color: var(--taupe); transition: color .3s ease; }
.footer-bottom .top-link:hover { color: var(--cream); }

/* ============================================================
   SELECTED PRODUCTIONS / CREDITS BAND
   ============================================================ */
.credits { background: var(--bg-dark); border-top: 1px solid rgba(236,230,218,0.10); border-bottom: 1px solid rgba(236,230,218,0.10); padding: clamp(34px,5vw,60px) 0; }
.credits-row { display: flex; flex-wrap: wrap; align-items: baseline; gap: 12px clamp(16px,2.4vw,30px); }
.credits-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: .24em; text-transform: uppercase; color: var(--taupe); flex-shrink: 0; }
.credits-list { display: flex; flex-wrap: wrap; align-items: baseline; gap: 10px clamp(12px,1.6vw,22px); font-family: var(--font-display); font-weight: 600; font-size: clamp(17px,1.9vw,24px); letter-spacing: -0.01em; color: var(--cream); }
.credits-list .mid { color: var(--faint); font-weight: 400; }
.credits-list a { transition: color .3s ease; }
.credits-list a:hover { color: var(--signal); }
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: clamp(18px,3vw,40px); margin-top: clamp(28px,3.5vw,48px); }
.stat { display: flex; flex-direction: column; gap: 8px; border-top: 1px solid rgba(236,230,218,0.14); padding-top: 18px; }
.stat-n { font-family: var(--font-display); font-weight: 800; font-size: clamp(38px,5vw,64px); line-height: 0.95; letter-spacing: -0.02em; color: var(--signal); }
.stat-l { font-family: var(--font-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--taupe); }

/* ============================================================
   IMAGE-SLOT PLACEHOLDERS
   On-brand stand-ins for the prototype's drop-zones: a duotone
   editorial wash + grain, the FIG/ROOM label, and a faint caption.
   Desaturated by default; recovers colour + lifts on hover, mirroring
   the prototype's grayscale -> colour image treatment.
   ============================================================ */
.slot {
  position: relative; overflow: hidden; border: 1px solid rgba(236,230,218,0.16);
  background: var(--frame); display: block; cursor: pointer;
}
.slot--thin { border-color: rgba(236,230,218,0.14); }
.slot .wash {
  position: absolute; inset: 0;
  filter: saturate(1.15) brightness(1.02);
  transition: filter .7s ease, transform .7s ease;
}
.slot::after {
  content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .5; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  background-size: 160px 160px;
}
.slot:hover .wash { filter: saturate(1.45) brightness(1.14); transform: scale(1.04); }

/* Real photo dropped into a slot: <a class="slot has-photo ..."><img class="slot-photo" ...><span class="tag">…</span></a> */
.slot-photo { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(1.05) brightness(.98); transition: filter .7s ease, transform .7s ease; }
.slot:hover .slot-photo { filter: saturate(1.25) brightness(1.08); transform: scale(1.04); }
.slot.has-photo .wash, .slot.has-photo .caption { display: none; }
.slot .tag {
  position: absolute; left: 14px; top: 14px; z-index: 3; pointer-events: none;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .2em; color: var(--cream); mix-blend-mode: difference;
}
.slot--sm .tag { left: 12px; top: 12px; font-size: 9.5px; }
.slot .caption {
  position: absolute; inset: 0; z-index: 2; pointer-events: none;
  display: flex; align-items: center; justify-content: center; text-align: center; padding: 24px;
  font-family: var(--font-mono); font-size: clamp(11px,1vw,13px); letter-spacing: .22em; text-transform: uppercase;
  color: rgba(236,230,218,0.62); text-shadow: 0 2px 18px rgba(0,0,0,0.6);
}

/* Duotone washes — distinct hue per slot, all dark + editorial */
.wash-1 { background:
  radial-gradient(120% 90% at 20% 15%, rgba(216,255,71,0.10), transparent 55%),
  radial-gradient(120% 120% at 85% 90%, rgba(255,61,139,0.16), transparent 60%),
  linear-gradient(150deg, #1c1712, #0c0a08 70%); }
.wash-2 { background:
  radial-gradient(120% 100% at 80% 10%, rgba(255,61,139,0.14), transparent 55%),
  linear-gradient(200deg, #211a14, #0b0908 72%); }
.wash-3 { background:
  radial-gradient(100% 120% at 15% 85%, rgba(120,150,255,0.12), transparent 55%),
  linear-gradient(135deg, #161821, #0a0a0c 75%); }
.wash-4 { background:
  radial-gradient(120% 110% at 90% 20%, rgba(216,255,71,0.12), transparent 55%),
  linear-gradient(165deg, #1b1d14, #0b0b08 72%); }
.wash-5 { background:
  radial-gradient(110% 120% at 30% 20%, rgba(220,180,150,0.14), transparent 55%),
  linear-gradient(150deg, #221a16, #0c0a08 74%); }
.wash-6 { background:
  radial-gradient(120% 100% at 70% 80%, rgba(255,61,139,0.12), transparent 55%),
  radial-gradient(120% 100% at 10% 10%, rgba(216,255,71,0.08), transparent 55%),
  linear-gradient(180deg, #1a1410, #0a0807 72%); }

/* Aspect-ratio helpers for slots */
.ar-5-6  { aspect-ratio: 5/6; }
.ar-4-5  { aspect-ratio: 4/5; }
.ar-4-3  { aspect-ratio: 4/3; }
.ar-16-11{ aspect-ratio: 16/11; }
.ar-3-4  { aspect-ratio: 3/4; }

/* ============================================================
   RESPONSIVE — mobile < 880px
   ============================================================ */
.desktop-only { display: inline; }

@media (max-width: 879px) {
  .nav, .btn-outline.nav-cta { display: none; }
  .burger { display: flex; }
  .topbar .desktop-only { display: none; }
}

@media (min-width: 880px) {
  .burger { display: none; }
}

/* ============================================================
   ACCESSIBILITY & FORM PLUMBING
   ============================================================ */
/* Skip link — hidden until keyboard-focused */
.skip-link {
  position: fixed; top: 10px; left: 10px; z-index: 200;
  background: var(--signal); color: var(--bg);
  font-family: var(--font-mono); font-size: 12px; letter-spacing: .14em; text-transform: uppercase;
  padding: 12px 18px; transform: translateY(-180%); transition: transform .2s ease;
}
.skip-link:focus { transform: none; outline: none; }

/* Visible focus ring for keyboard users only (mouse users keep the clean look) */
:focus-visible { outline: 2px solid var(--signal); outline-offset: 3px; }
.nl-input:focus-visible { outline: none; }   /* input already shows a focus underline */

/* Newsletter submit + status states */
.nl-submit[aria-busy="true"] { opacity: .6; cursor: progress; }
.nl-status {
  margin: 16px auto 0; max-width: 54ch;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--pen);
}
.nl-status:empty { margin: 0; }

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
  html { scroll-behavior: auto; }
  [data-reveal] { opacity: 1 !important; transform: none !important; }
}
