:root {
  --paper: #f3eee5;
  --paper-deep: #e6dccd;
  --ink: #151413;
  --soft-ink: #3f3a35;
  --muted: #756c62;
  --charcoal: #121214;
  --ivory: #f8f3eb;
  --line: rgba(21, 20, 19, 0.16);
  --line-dark: rgba(248, 243, 235, 0.22);
  --accent: #9a4a35;
  --ochre: #b68a35;
  --blue: #536978;
  --sage: #6d7e73;
  --card: rgba(255,255,255,0.54);
  --shadow: 0 28px 80px rgba(18,18,20,.18);
  --max: 1180px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: var(--paper);
  color: var(--ink);
  line-height: 1.6;
}
a { color: inherit; }
.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  backdrop-filter: blur(18px);
  background: rgba(243,238,229,0.88);
  border-bottom: 1px solid var(--line);
}
.nav {
  max-width: var(--max);
  margin: 0 auto;
  padding: 16px 22px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
}
.brand { text-decoration: none; letter-spacing: .1em; text-transform: uppercase; font-weight: 850; }
.nav-links { display: flex; flex-wrap: wrap; gap: 16px; font-size: .94rem; }
.nav-links a { text-decoration: none; color: var(--muted); }
.nav-links a:hover, .nav-links a[aria-current="page"] { color: var(--ink); }
main { min-height: 70vh; }
.eyebrow { letter-spacing: .14em; text-transform: uppercase; color: var(--accent); font-size: .78rem; font-weight: 850; }
h1 { font-size: clamp(3.1rem, 8vw, 7.4rem); line-height: .88; margin: 14px 0 22px; letter-spacing: -.07em; }
h2 { font-size: clamp(2.15rem, 4.4vw, 4rem); line-height: .96; letter-spacing: -.055em; margin: 0 0 18px; }
h3 { margin: 0 0 8px; font-size: 1.12rem; }
p { margin-top: 0; }
.lede { font-size: clamp(1.08rem, 2vw, 1.38rem); color: var(--soft-ink); max-width: 64ch; }
.hero {
  max-width: var(--max);
  margin: 0 auto;
  padding: 74px 22px 54px;
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, .98fr);
  gap: 46px;
  align-items: center;
}
.hero-image { margin: 0; border: 1px solid var(--line); background: #ddd; box-shadow: var(--shadow); }
.hero-image img { display: block; width: 100%; height: min(62vh, 620px); object-fit: cover; filter: saturate(.9) contrast(1.04); }
.hero-image figcaption { padding: 10px 14px; color: var(--muted); font-size: .86rem; }

/* About image reel */
.about-reel .reel-stage { position: relative; width: 100%; height: min(62vh, 620px); overflow: hidden; background: #1c1a17; }
.about-reel .reel-slide { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transition: opacity 1.1s ease; filter: saturate(.9) contrast(1.04); }
.about-reel .reel-slide.is-active { opacity: 1; }
.about-reel .reel-caption { padding: 10px 14px; color: var(--muted); font-size: .86rem; min-height: 1.2em; }
.about-reel .reel-dots { display: flex; gap: 9px; padding: 0 14px 10px; }
.about-reel .reel-dot { width: 12px; height: 12px; padding: 0; border-radius: 50%; border: 2px solid var(--ink); background: var(--paper); cursor: pointer; }
.about-reel .reel-dot.is-active { background: var(--ink); box-shadow: 0 0 0 2px var(--paper), 0 0 0 4px var(--ink); }
.about-reel .reel-note { padding: 0 14px 12px; color: var(--muted); font-size: .78rem; font-style: italic; }
@media (prefers-reduced-motion: reduce) { .about-reel .reel-slide { transition: none; } }
.button-row { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 26px; }
.button { display: inline-block; padding: 11px 16px; border: 1px solid currentColor; text-decoration: none; font-weight: 850; }
.button.primary { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.button.journey-cta { background: var(--accent, #9a4a35); color: var(--paper); border-color: var(--accent, #9a4a35); box-shadow: 0 2px 0 var(--ink); }
.button.journey-cta:hover { transform: translateY(-1px); }

.journey-signpost { padding: 0; }
.journey-signpost-inner {
  display: flex; align-items: center; justify-content: space-between; gap: 28px;
  flex-wrap: wrap;
  margin: 0 clamp(22px, 6vw, 90px);
  padding: 26px clamp(20px, 4vw, 40px);
  background: var(--accent, #9a4a35); color: var(--paper);
  border: 2px solid var(--ink);
}
.journey-signpost-text { max-width: 640px; }
.journey-signpost-text .eyebrow { color: var(--paper); opacity: .9; }
.journey-signpost-text h2 { margin: 6px 0 8px; color: var(--paper); }
.journey-signpost-text p { margin: 0; color: var(--paper); opacity: .94; }
.journey-signpost-btn { background: var(--paper); color: var(--ink); border-color: var(--paper); white-space: nowrap; }
.journey-signpost-btn:hover { transform: translateY(-1px); }
.section { max-width: var(--max); margin: 0 auto; padding: 58px 22px; }
.section-intro { max-width: 760px; }
.grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.card { background: var(--card); border: 1px solid var(--line); padding: 24px; min-height: 190px; }
.card p { color: var(--muted); margin-bottom: 0; }
.card a { color: var(--accent); font-weight: 850; text-decoration-thickness: 1px; text-underline-offset: 4px; }
.panel { background: var(--charcoal); color: var(--ivory); padding: 42px; border-radius: 2px; }
.panel p { color: #d7cdbf; }
.note { border-left: 4px solid var(--accent); padding: 16px 20px; background: rgba(154,74,53,.08); color: #3b332d; }
.archive-strip { display: grid; grid-template-columns: .8fr 1.2fr; gap: 22px; align-items: center; }
.archive-strip img { width: 100%; display: block; border: 1px solid var(--line); }

/* Horizontal museum prototype — stacked layout */
.museum-hero {
  min-height: auto;
  display: block;
  border-bottom: 1px solid var(--line);
}
.museum-intro {
  max-width: var(--max);
  margin: 0 auto;
  padding: clamp(48px, 7vw, 92px) 28px clamp(36px, 5vw, 64px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  background:
    radial-gradient(circle at 12% 20%, rgba(182,138,53,.17), transparent 32%),
    linear-gradient(135deg, var(--paper), var(--paper-deep));
}
.museum-intro .lede { max-width: 56ch; }
.scroll-cue {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 28px;
  color: var(--muted);
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: .78rem;
}
.scroll-cue::after { content: "→"; font-size: 1.5rem; color: var(--accent); }
.gallery-rail {
  display: flex;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  min-height: 78vh;
  background: var(--charcoal);
  color: var(--ivory);
  scrollbar-color: var(--accent) rgba(255,255,255,.08);
  padding-bottom: 18px;
}
.gallery-rail::-webkit-scrollbar { height: 12px; }
.gallery-rail::-webkit-scrollbar-track { background: rgba(255,255,255,.08); }
.gallery-rail::-webkit-scrollbar-thumb { background: var(--accent); border-radius: 999px; }
.museum-card {
  position: relative;
  flex: 0 0 clamp(260px, 34vw, 480px);
  min-height: 78vh;
  scroll-snap-align: start;
  display: flex;
  align-items: flex-end;
  border-left: 1px solid var(--line-dark);
  overflow: hidden;
  text-decoration: none;
}
.museum-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(.08) saturate(.82) contrast(1.06) brightness(.78);
  transform: scale(1.02);
  transition: transform .7s ease, filter .7s ease;
}
.museum-card:hover img { transform: scale(1.065); filter: grayscale(0) saturate(.98) contrast(1.08) brightness(.86); }
.museum-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(18,18,20,.04), rgba(18,18,20,.28) 36%, rgba(18,18,20,.86));
}
.card-copy {
  position: relative;
  z-index: 1;
  padding: clamp(24px, 4vw, 42px);
  max-width: 520px;
}
.room-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: .74rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 850;
  color: #ead5af;
}
.room-label::before {
  content: "";
  width: 22px;
  height: 2px;
  background: currentColor;
}
.museum-card h2 { color: var(--ivory); font-size: clamp(2.1rem, 4.2vw, 4.4rem); margin-top: 12px; }
.museum-card p { color: #e5dbcf; max-width: 38ch; }
.museum-card .enter { color: #f3d493; font-weight: 850; margin-top: 18px; }
.museum-card.placeholder img { filter: grayscale(.25) saturate(.65) contrast(1.02) brightness(.62); }
.museum-card.placeholder .room-label { color: #d8d1c8; }
.orientation-band {
  background: var(--ivory);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.orientation-grid {
  max-width: var(--max);
  margin: 0 auto;
  padding: 34px 22px;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 20px;
}
.orientation-item {
  border-left: 3px solid var(--accent);
  padding-left: 16px;
}
.orientation-item:nth-child(2) { border-color: var(--blue); }
.orientation-item:nth-child(3) { border-color: var(--sage); }
.orientation-item strong { display: block; }
.orientation-item span { color: var(--muted); }
.photo-inbox {
  background: rgba(83,105,120,.09);
  border: 1px solid rgba(83,105,120,.28);
  padding: 24px;
}
.footer { max-width: var(--max); margin: 0 auto; padding: 40px 22px 70px; color: var(--muted); border-top: 1px solid var(--line); }
.footer a { color: var(--ink); }
@media (max-width: 920px) {
  .museum-intro { padding: 44px 22px; }
  .gallery-rail { min-height: 72vh; }
  .museum-card { flex-basis: 82vw; min-height: 72vh; }
  .hero, .archive-strip { grid-template-columns: 1fr; padding-top: 44px; }
  .grid, .orientation-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .nav { align-items: flex-start; flex-direction: column; }
  .museum-card { flex-basis: 88vw; }
  .panel { padding: 28px; }
}

/* ============================================================
   Full-site warm-museum extensions — 2026-06-03 (Opus build)
   New rooms: nav dropdown, sub-hero, method steps, journey road,
   timeline rows, archive list, bibliography, colophon. Reuses
   existing tokens (paper/ink/ochre/accent/charcoal) for unity.
   ============================================================ */

/* Wider nav for full site */
.nav-links a.cta { color: var(--accent); }

/* Compact page hero (non-museum pages) */
.page-hero {
  max-width: var(--max);
  margin: 0 auto;
  padding: clamp(48px,7vw,86px) clamp(22px,6vw,90px) clamp(24px,4vw,40px);
}
.page-hero h1 { max-width: 18ch; }
.page-hero .lede { max-width: 60ch; }
/* Match generous inset on single-column content sections of inner pages */
.page-hero + .section,
.page-hero ~ .section { padding-left: clamp(22px,6vw,90px); padding-right: clamp(22px,6vw,90px); }
.breadcrumb { font-size:.82rem; color:var(--muted); letter-spacing:.04em; margin-bottom:18px; }
.breadcrumb a { color:var(--muted); text-decoration:none; }
.breadcrumb a:hover { color:var(--ink); }

/* Section lead band on charcoal */
.band-dark {
  background: var(--charcoal);
  color: var(--ivory);
  border-top:1px solid var(--line-dark);
  border-bottom:1px solid var(--line-dark);
}
.band-dark .band-inner { max-width:var(--max); margin:0 auto; padding:clamp(40px,6vw,72px) 22px; }
.band-dark h2 { color: var(--ivory); }
.band-dark p { color:#d7cdbf; max-width:64ch; }
.band-dark .eyebrow { color: var(--ochre); }

/* Method steps — cabinetmaker process */
.steps { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:14px; }
.step {
  border:1px solid var(--line);
  background:var(--card);
  padding:22px;
  position:relative;
}
.step .num {
  font-size:.78rem; font-weight:850; letter-spacing:.14em; text-transform:uppercase;
  color:var(--accent);
}
.step h3 { margin-top:8px; font-size:1.18rem; }
.step p { color:var(--muted); margin-bottom:0; }

/* Two-column prose layout */
.prose { max-width:760px; margin:0 auto; }
.prose p { color:var(--soft-ink); }
.prose h2 { margin-top:42px; }
.prose ul { color:var(--soft-ink); padding-left:1.2em; }
.prose li { margin-bottom:8px; }

/* Journey road — horizontal museum-road hybrid */
.journey-road {
  background:var(--charcoal);
  color:var(--ivory);
  padding:clamp(32px,5vw,56px) 0;
  border-top:1px solid var(--line-dark);
}
.road-track {
  display:flex;
  gap:0;
  overflow-x:auto;
  scroll-snap-type:x proximity;
  padding:14px 22px 26px;
  max-width:100%;
}
.road-stage {
  flex:0 0 clamp(240px,26vw,320px);
  scroll-snap-align:start;
  border-left:2px solid rgba(182,138,53,.45);
  padding:0 22px;
  position:relative;
}
.road-stage::before {
  content:"";
  position:absolute; left:-7px; top:4px;
  width:12px; height:12px; border-radius:50%;
  background:var(--ochre);
  box-shadow:0 0 0 4px rgba(182,138,53,.18);
}
.road-stage .stage-no { font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ochre); font-weight:850; }
.road-stage h3 { color:var(--ivory); margin:8px 0 6px; font-size:1.3rem; }
.road-stage p { color:#cfc6ba; font-size:.94rem; }

/* Timeline rows (incorporated archive) */
.tl-wrap { max-width:var(--max); margin:0 auto; padding:40px 22px 60px; }
.tl-controls { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:24px; align-items:center; }
.tl-search {
  flex:1 1 260px;
  padding:11px 14px;
  border:1px solid var(--line);
  background:var(--ivory);
  font:inherit; color:var(--ink);
}
.tl-count { color:var(--muted); font-size:.88rem; }
.tl-list { display:flex; flex-direction:column; gap:0; border-left:2px solid var(--line); }
.tl-entry {
  position:relative;
  padding:18px 0 18px 28px;
  border-bottom:1px solid var(--line);
}
.tl-entry::before {
  content:""; position:absolute; left:-7px; top:24px;
  width:11px; height:11px; border-radius:50%;
  background:var(--accent);
}
.tl-entry .tl-date { font-size:.8rem; letter-spacing:.06em; text-transform:uppercase; color:var(--accent); font-weight:850; }
.tl-entry h3 { margin:4px 0 6px; font-size:1.14rem; }
.tl-entry p { color:var(--muted); margin-bottom:8px; }
.tl-tags { display:flex; flex-wrap:wrap; gap:6px; }
.tl-tag {
  font-size:.72rem; padding:2px 9px; border-radius:999px;
  background:rgba(154,74,53,.1); color:var(--accent);
  border:1px solid rgba(154,74,53,.22);
}
.tl-tag.area { background:rgba(83,105,120,.12); color:var(--blue); border-color:rgba(83,105,120,.28); }

/* Archive list (rants / journal extracts) */
.archive-list { max-width:860px; margin:0 auto; display:flex; flex-direction:column; gap:14px; }
.archive-item {
  border:1px solid var(--line);
  background:var(--card);
  padding:22px 24px;
  display:flex; flex-direction:column; gap:8px;
}
.archive-item .a-date { font-size:.78rem; text-transform:uppercase; letter-spacing:.1em; color:var(--muted); font-weight:800; }
.archive-item h3 { font-size:1.22rem; }
.archive-item p { color:var(--soft-ink); margin-bottom:0; }
.archive-item .a-link { color:var(--accent); font-weight:850; text-decoration:none; }
.archive-item .a-link:hover { text-decoration:underline; text-underline-offset:4px; }

/* Bibliography */
.biblio { max-width:820px; margin:0 auto; }
.biblio-item { padding:16px 0; border-bottom:1px solid var(--line); color:var(--soft-ink); font-size:.98rem; }
.biblio-item .b-title { font-weight:800; color:var(--ink); }
.biblio-item a { color:var(--accent); }

/* Colophon */
.colophon-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:22px; max-width:860px; margin:0 auto; }
.colophon-grid .card { min-height:auto; }

/* Lock badge for private routes */
.lock { display:inline-flex; align-items:center; gap:7px; font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; font-weight:850; color:var(--muted); border:1px solid var(--line); padding:4px 10px; border-radius:999px; }
.lock::before { content:"🔒"; }

@media (max-width:920px){
  .steps { grid-template-columns:1fr 1fr; }
  .colophon-grid { grid-template-columns:1fr; }
}
@media (max-width:640px){
  .steps { grid-template-columns:1fr; }
}
