:root {
  color-scheme: light;
  --ink: #1f2422;
  --muted: #6f746e;
  --paper: #f6f1e8;
  --panel: #fffaf2;
  --line: #dbd1bf;
  --accent: #9b3527;
  --deep: #24372f;
  --shadow: 0 18px 50px rgba(31, 36, 34, 0.12);
}
* { 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.55; }
img { display: block; max-width: 100%; }
a { color: inherit; }
.site-header { position: sticky; top: 0; z-index: 10; display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 16px clamp(18px, 4vw, 54px); background: rgba(246, 241, 232, 0.94); border-bottom: 1px solid var(--line); backdrop-filter: blur(14px); }
.wordmark { font-family: Georgia, "Times New Roman", serif; font-size: 20px; text-decoration: none; letter-spacing: 0; }
nav { display: flex; gap: clamp(14px, 3vw, 30px); font-size: 14px; }
nav a { text-decoration: none; color: var(--muted); }
nav a:hover { color: var(--ink); }
.hero { min-height: 86vh; display: grid; grid-template-columns: minmax(0, 0.95fr) minmax(420px, 1.05fr); align-items: stretch; border-bottom: 1px solid var(--line); background: #ece5d8; }
.hero-copy { display: flex; flex-direction: column; justify-content: flex-end; padding: clamp(72px, 9vw, 130px) clamp(24px, 5vw, 74px); }
.hero-copy p, .section-heading p, .gallery-hero p { margin: 0 0 10px; color: var(--accent); font-size: 13px; font-weight: 760; text-transform: uppercase; letter-spacing: 0.08em; }
h1, h2, h3 { font-family: Georgia, "Times New Roman", serif; font-weight: 500; line-height: 1.06; }
h1 { margin: 0 0 18px; font-size: clamp(48px, 7vw, 104px); max-width: 760px; }
.hero-copy span { display: block; max-width: 530px; font-size: clamp(18px, 2vw, 25px); color: #4a504a; }
.hero-art { min-height: 620px; padding: clamp(20px, 4vw, 52px); display: flex; align-items: center; justify-content: center; background: #ded7ca; border-left: 1px solid var(--line); }
.hero-art img { width: min(100%, 820px); max-height: 78vh; object-fit: contain; box-shadow: var(--shadow); background: #ddd5c8; }
.intro-band, .section, .site-footer { padding: clamp(54px, 8vw, 104px) clamp(20px, 5vw, 72px); }
.intro-band { display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.8fr); gap: clamp(34px, 7vw, 90px); align-items: start; background: var(--panel); border-bottom: 1px solid var(--line); }
.intro-text p, .life-copy p, .archive-copy p, .source-note { margin: 0; max-width: 820px; font-size: clamp(18px, 2vw, 23px); color: #343a36; }
.facts { margin: 0; display: grid; gap: 14px; }
.facts div { padding: 18px 0; border-top: 1px solid var(--line); }
.facts dt { color: var(--muted); font-size: 13px; text-transform: uppercase; letter-spacing: 0.08em; }
.facts dd { margin: 4px 0 0; font-size: 20px; }
.section-heading { max-width: 840px; margin-bottom: clamp(28px, 5vw, 56px); }
.section-heading h2 { margin: 0; font-size: clamp(34px, 5vw, 66px); }
.work-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; }
.work-card { background: var(--panel); border: 1px solid var(--line); box-shadow: var(--shadow); }
.work-card.wide { grid-column: 1 / -1; display: grid; grid-template-columns: minmax(0, 1.16fr) minmax(320px, 0.84fr); }
.work-card img { width: 100%; height: 410px; object-fit: cover; background: #ddd5c8; }
.work-card.wide img { height: 600px; object-position: center; }
.work-card div { padding: clamp(22px, 4vw, 40px); }
.work-card h3, .memory-grid h3 { margin: 0 0 12px; font-size: 31px; }
.work-card p, .memory-grid p { margin: 0; color: #4c514d; font-size: 17px; }
.gallery-hero { padding: clamp(78px, 10vw, 142px) clamp(20px, 5vw, 72px) clamp(48px, 7vw, 86px); background: #ece5d8; border-bottom: 1px solid var(--line); }
.gallery-hero h1 { margin: 0 0 18px; font-size: clamp(46px, 7vw, 92px); max-width: 900px; }
.gallery-hero span { display: block; max-width: 680px; font-size: clamp(18px, 2vw, 24px); color: #4a504a; }
.gallery-section { background: var(--panel); border-top: 1px solid var(--line); }
.gallery-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.gallery-page-section { padding-top: clamp(28px, 4vw, 54px); }
.gallery-count { margin: 0 0 34px; color: var(--muted); font-size: 15px; }
.gallery-category + .gallery-category { margin-top: clamp(46px, 7vw, 82px); padding-top: clamp(34px, 5vw, 58px); border-top: 1px solid var(--line); }
.gallery-category-heading { max-width: 720px; margin-bottom: 22px; }
.gallery-category-heading p { margin: 0 0 8px; color: var(--accent); font-size: 12px; font-weight: 760; text-transform: uppercase; letter-spacing: 0.08em; }
.gallery-category-heading h2 { margin: 0 0 8px; font-size: clamp(30px, 4vw, 50px); }
.gallery-category-heading span { color: #4a504a; font-size: 17px; }
.gallery-link { margin: 24px 0 0; }
.gallery-link a { color: var(--accent); font-weight: 700; text-decoration-thickness: 1px; text-underline-offset: 5px; }
.gallery-item { position: relative; overflow: hidden; background: #e2d8c9; border: 1px solid var(--line); }
.gallery-item.feature { grid-column: span 2; grid-row: span 2; }
.gallery-item a { display: block; text-decoration: none; }
.gallery-item img { width: 100%; height: 360px; object-fit: contain; transition: transform 220ms ease; background: #e2d8c9; }
.gallery-item.feature img { height: 738px; }
.gallery-grid-page { display: block; column-count: 3; column-gap: 18px; }
.gallery-grid-page .gallery-item { display: inline-block; width: 100%; margin: 0 0 18px; break-inside: avoid; }
.gallery-grid-page .gallery-item.feature { grid-column: auto; grid-row: auto; }
.gallery-grid-page .gallery-item img, .gallery-grid-page .gallery-item.feature img { height: auto; padding: 0; object-fit: initial; }
.gallery-item a:hover img { transform: scale(1.025); }
.gallery-item figcaption { margin: 0; padding: 13px 14px; min-height: 48px; background: rgba(255, 250, 242, 0.94); color: #3a403b; font-size: 14px; border-top: 1px solid var(--line); }
.life-section { background: #e9e2d6; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.life-copy { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: clamp(26px, 6vw, 76px); }
.archive-layout { display: grid; grid-template-columns: minmax(0, 1fr) minmax(300px, 0.72fr); gap: clamp(26px, 5vw, 64px); align-items: start; }
figure { margin: 0; }
figure img { width: 100%; border: 1px solid var(--line); box-shadow: var(--shadow); }
figcaption { margin-top: 12px; color: var(--muted); font-size: 14px; }
.archive-copy ul { margin: 28px 0 0; padding-left: 20px; color: #434842; font-size: 18px; }
.archive-copy li + li { margin-top: 8px; }
.memory-section { background: var(--deep); color: #f7f3ec; }
.memory-section .section-heading p { color: #ddb58a; }
.memory-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.memory-grid article { padding: 26px; border: 1px solid rgba(247, 243, 236, 0.22); background: rgba(255, 250, 242, 0.06); }
.memory-grid h3 { color: #fffaf2; }
.memory-grid p, .source-note { color: #d8d0c3; }
.source-note { margin-top: 28px; font-size: 17px; }
.site-footer { display: flex; justify-content: space-between; gap: 24px; border-top: 1px solid var(--line); color: var(--muted); font-size: 14px; }
.site-footer p { margin: 0; }
.site-footer a { text-decoration: none; color: var(--accent); }
@media (max-width: 920px) {
  .site-header { align-items: flex-start; flex-direction: column; gap: 10px; }
  nav { width: 100%; justify-content: space-between; }
  .hero, .intro-band, .work-card.wide, .life-copy, .archive-layout, .memory-grid { grid-template-columns: 1fr; }
  .gallery-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .gallery-grid-page { column-count: 2; }
  .gallery-item.feature { grid-column: 1 / -1; grid-row: auto; }
  .gallery-item img, .gallery-item.feature img { height: 360px; }
  .gallery-grid-page .gallery-item img, .gallery-grid-page .gallery-item.feature img { height: auto; }
  .hero { min-height: auto; }
  .hero-copy { order: 2; padding-top: 42px; }
  .hero-art { min-height: 0; border-left: 0; border-bottom: 1px solid var(--line); }
  .hero-art img { max-height: 58vh; }
  .work-grid { grid-template-columns: 1fr; }
  .work-card img, .work-card.wide img { height: 360px; }
  .site-footer { flex-direction: column; }
}
@media (max-width: 520px) {
  nav { gap: 10px; font-size: 13px; }
  .hero-art { padding: 18px; }
  .hero-art img { max-height: 48vh; }
  .work-card img, .work-card.wide img, .gallery-item img, .gallery-item.feature img { height: 280px; }
  .gallery-grid { grid-template-columns: 1fr; }
  .gallery-grid-page { column-count: 1; }
  .gallery-grid-page .gallery-item img, .gallery-grid-page .gallery-item.feature img { height: auto; }
  .intro-text p, .life-copy p, .archive-copy p { font-size: 18px; }
}
