/* ─────────────────────────────────────────────────────────────────────
   Biennale.com — Shared editorial page stylesheet
   Used by all biennale series pages (sydney, venice, documenta, etc.)
   Each page declares its accent color via :root override in <style>.
   ───────────────────────────────────────────────────────────────────── */

:root {
  color-scheme: light;
  --paper: #f7f6f3;
  --paper-deep: #efeae2;
  --card: #f2ede5;
  --ink: #2a2622;
  --ink-soft: #5a544c;
  --ink-faint: #8a8378;
  --rule: rgba(42, 38, 34, .16);
  --rule-soft: rgba(42, 38, 34, .07);

  /* Default accents — overridden per page */
  --accent: #3498db;
  --accent-deep: #1f6ea3;
  --accent-tint: rgba(52, 152, 219, .08);
  --accent-tint-strong: rgba(52, 152, 219, .15);

  /* Editorial wraparound — desaturated portal purple. Identical across all pages. */
  --editorial: #6b4f8f;
  --editorial-soft: rgba(107, 79, 143, .32);

  /* Type */
  --serif: "Cormorant Garamond", "Adobe Caslon Pro", Georgia, serif;
  --sans:  "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  /* Layout tokens */
  --measure: 38rem;
  --measure-wide: 56rem;
  --radius: 1rem;
  --radius-sm: .5rem;
}

* { box-sizing: border-box; }
html {
  -webkit-text-size-adjust: 100%;
  background: #f7f6f3;
  color: #2a2622;
  color-scheme: light;
  forced-color-adjust: none;
  scroll-behavior: smooth;
}
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  forced-color-adjust: none;
}
img { max-width: 100%; height: auto; display: block; }
a {
  color: var(--ink);
  text-decoration: underline;
  text-decoration-thickness: .5px;
  text-underline-offset: 3px;
  text-decoration-color: var(--rule);
  transition: color .15s, text-decoration-color .15s;
}
a:hover { color: var(--accent); text-decoration-color: var(--accent); }
section[id] { scroll-margin-top: 24px; }

/* Page frame */
.wrap  { max-width: 80rem; margin: 0 auto; padding: 0 clamp(20px, 4vw, 56px); }
.spine { max-width: var(--measure); margin: 0 auto; }
.spine-wide { max-width: var(--measure-wide); margin: 0 auto; }

/* Sponsorship band */
.sponsor-band {
  border-top: .5px solid var(--rule);
  border-bottom: .5px solid var(--rule);
  text-align: center;
  padding: 22px 16px;
  margin: 48px 0 0;
  font: 500 10.5px/1.6 var(--sans);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--editorial);
}
.sponsor-band strong { color: var(--ink); font-weight: 600; }

/* Masthead */
.masthead {
  padding: 48px 0 32px;
  border-bottom: .5px solid var(--rule);
  position: relative;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  color: inherit;
  transition: opacity .15s;
}
.brand:hover { opacity: .85; color: inherit; }
.brand-mark { width: 40px; height: 40px; flex-shrink: 0; display: block; }
.brand-word {
  font: italic 500 clamp(28px, 3.4vw, 34px)/1 var(--serif);
  letter-spacing: -.01em;
  color: #272040;
}
.masthead-top {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  padding-bottom: 24px;
  margin-bottom: 44px;
  border-bottom: .5px solid var(--rule);
}
.masthead h1 {
  font: 400 clamp(56px, 11vw, 132px)/.92 var(--serif);
  letter-spacing: -.025em;
  margin: 0 0 22px;
  color: var(--ink);
}
.masthead h1 em { font-style: italic; font-weight: 300; color: var(--accent-deep); }
.masthead .essence {
  font: italic 300 clamp(20px, 2.4vw, 26px)/1.4 var(--serif);
  max-width: 44rem;
  color: var(--ink-soft);
  margin: 0 0 32px;
}
.years-strip {
  display: flex;
  align-items: baseline;
  gap: 14px;
  margin-bottom: 44px;
  font: 500 11px/1 var(--sans);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--editorial);
}
.years-strip .span {
  font: italic 300 clamp(28px, 4vw, 40px)/1 var(--serif);
  letter-spacing: -.01em;
  color: var(--accent);
  text-transform: none;
}

/* Section nav rail */
nav.rail {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding-top: 28px;
  border-top: .5px solid var(--rule);
}
nav.rail a {
  text-decoration: none;
  font: 500 11px/1 var(--sans);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink);
  padding: 9px 16px;
  border: .5px solid var(--rule);
  border-radius: 9999px;
  transition: all .15s;
}
nav.rail a:hover { background: var(--accent); color: #fff; border-color: var(--accent); }
nav.rail a[aria-current="page"] { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* In-page jump strip */
nav.page-jump { border-bottom: .5px solid var(--rule); }
nav.page-jump ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px 24px;
}
nav.page-jump a {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 16px 0;
  font: 500 11px/1 var(--sans);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink);
  text-decoration: none;
  white-space: nowrap;
}
nav.page-jump a::before {
  content: "↓";
  font-weight: 600;
  font-size: 12px;
  color: var(--accent);
  transition: transform .15s;
}
nav.page-jump a:hover { color: var(--accent); }
nav.page-jump a:hover::before { transform: translateY(2px); }

/* Hero */
figure.hero { margin: 48px 0 0; }
figure.hero img {
  width: 100%;
  aspect-ratio: 3/2;
  object-fit: cover;
  filter: contrast(1.02) saturate(.96);
  border-radius: var(--radius);
}
figure.hero figcaption,
figure.inline figcaption {
  font: 11px/1.55 var(--sans);
  letter-spacing: .02em;
  color: var(--ink-faint);
  padding-top: 16px;
  border-top: .5px solid var(--rule-soft);
}
figure figcaption .label {
  color: var(--editorial);
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  font-size: 10px;
  margin-right: 8px;
}
figure figcaption a { color: var(--ink-soft); text-decoration-color: var(--rule); }
figure figcaption a:hover { color: var(--accent); }

/* Lead essay */
section.essay { padding: 104px 0 96px; position: relative; overflow: hidden; }
.essay-backdrop {
  position: absolute;
  top: 40px;
  left: 50%;
  transform: translateX(-50%);
  font: italic 300 clamp(120px, 18vw, 260px)/.85 var(--serif);
  color: var(--accent);
  opacity: .055;
  letter-spacing: -.04em;
  pointer-events: none;
  user-select: none;
  white-space: nowrap;
  z-index: 0;
}
section.essay > .wrap { position: relative; z-index: 1; }

.kicker {
  font: 600 11px/1 var(--sans);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--editorial);
  margin: 0 0 28px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.kicker::before {
  content: "";
  width: 28px;
  height: 1.5px;
  background: var(--editorial);
  flex-shrink: 0;
}
.kicker .dot {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--ink-faint);
  display: inline-block;
}
.kicker.center { justify-content: center; }
.kicker.center::after {
  content: "";
  width: 28px;
  height: 1.5px;
  background: var(--editorial);
  flex-shrink: 0;
}

h2.headline {
  font: 400 clamp(38px, 5.8vw, 68px)/1.02 var(--serif);
  letter-spacing: -.022em;
  margin: 0 0 22px;
  color: var(--ink);
}
h2.headline em { font-style: italic; color: var(--accent-deep); }
.dek {
  font: italic 300 clamp(20px, 2.4vw, 27px)/1.4 var(--serif);
  color: var(--ink-soft);
  margin: 0 0 40px;
}
.byline {
  font: 500 11px/1 var(--sans);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin: 0 0 56px;
  padding-bottom: 24px;
  border-bottom: .5px solid var(--rule);
}
.byline strong { color: var(--ink); font-weight: 600; }

/* Fact callout */
.fact-callout {
  margin: 32px 0 40px;
  padding: 24px 26px;
  background: var(--accent-tint);
  border-left: 3px solid var(--accent);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}
.fact-callout .label {
  font: 600 10px/1 var(--sans);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--accent-deep);
  margin: 0 0 14px;
}
.fact-callout dl {
  margin: 0;
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 8px 18px;
}
.fact-callout dt {
  font: 600 10.5px/1 var(--sans);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--editorial);
  align-self: center;
}
.fact-callout dd {
  margin: 0;
  font: 400 17px/1.3 var(--serif);
  color: var(--ink);
}
.fact-callout dd em { font-style: italic; color: var(--accent-deep); }

/* Essay body */
.essay-body { font: 400 19px/1.65 var(--serif); color: var(--ink); }
.essay-body > p { margin: 0 0 1.3em; }
.essay-body > p:first-of-type::first-letter {
  font: italic 500 5.6em/.86 var(--serif);
  float: left;
  padding: .05em .1em 0 0;
  margin-top: .04em;
  color: var(--accent);
}
.essay-body h3 {
  font: italic 400 1.4em/1.25 var(--serif);
  margin: 2em 0 .6em;
  color: var(--ink);
}

/* Pull quote */
blockquote.pull {
  margin: 64px -2rem;
  padding: 0 0 0 2rem;
  border-left: 3px solid var(--accent);
  font: italic 300 clamp(24px, 3.2vw, 34px)/1.22 var(--serif);
  color: var(--ink);
}
blockquote.pull cite {
  display: block;
  font: 500 10.5px/1 var(--sans);
  font-style: normal;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-top: 22px;
}

/* Inline image */
figure.inline { margin: 64px 0; }
figure.inline img {
  aspect-ratio: 3/2;
  object-fit: cover;
  width: 100%;
  filter: contrast(1.02) saturate(.96);
  border-radius: var(--radius);
}

/* Second voice */
section.counter {
  padding: 96px 0;
  background: var(--accent-tint);
  border-top: .5px solid var(--rule);
  border-bottom: .5px solid var(--rule);
}
section.counter h2.headline { font-size: clamp(32px, 4.8vw, 54px); }
section.counter .essay-body > p:first-of-type::first-letter {
  float: none;
  font-size: 1em;
  padding: 0;
  margin: 0;
  color: inherit;
  font-style: normal;
  font-weight: 400;
}

/* Current Coverage */
section.current-coverage {
  padding: 56px 0 88px;
  border-top: .5px solid var(--rule);
  background: var(--paper);
}
.current-coverage-head { margin: 0 auto 32px; max-width: 60rem; }
.current-coverage-head .kicker { margin: 0 0 14px; }
.current-coverage-head h2 {
  font: italic 400 clamp(24px, 3vw, 32px)/1.05 var(--serif);
  margin: 0 0 8px;
  color: var(--ink);
}
.current-coverage-head h2 em { font-style: italic; color: var(--accent-deep); }
.current-coverage-head .lede {
  font: italic 400 16px/1.5 var(--serif);
  color: var(--ink-soft);
  margin: 0;
}
.coverage-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  max-width: 64rem;
  margin: 0 auto;
}
.cov-card {
  padding: 18px 20px;
  border-radius: var(--radius-sm);
  background: var(--card);
  border: .5px solid var(--rule);
  text-decoration: none;
  color: var(--ink);
  display: block;
  transition: border-color .15s, transform .15s;
}
.cov-card:hover { border-color: var(--accent); transform: translateY(-1px); color: var(--ink); }
.cov-meta {
  font: 600 9.5px/1 var(--sans);
  letter-spacing: .16em;
  text-transform: uppercase;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 10px;
}
.cov-meta .outlet { color: var(--accent); }
.cov-meta .date { color: var(--ink-faint); font-weight: 500; }
.cov-title {
  font: 500 16px/1.32 var(--serif);
  margin: 0 0 6px;
  color: var(--ink);
}
.cov-title em { font-style: italic; font-weight: 400; }
.cov-note { font: 10.5px/1.45 var(--sans); color: var(--ink-faint); margin: 0; }

/* Defining moments */
section.moments { padding: 112px 0 80px; border-top: .5px solid var(--rule); }
.moments-head {
  text-align: center;
  margin-bottom: 72px;
  max-width: 36rem;
  margin-left: auto;
  margin-right: auto;
}
.moments-head h2 {
  font: italic 400 clamp(36px, 5.2vw, 56px)/1.05 var(--serif);
  margin: 0 0 16px;
  color: var(--ink);
}
.moments-head p { font: italic 400 18px/1.55 var(--serif); color: var(--ink-soft); }
.moments-grid { display: grid; max-width: 60rem; margin: 0 auto; }
.moment {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 40px;
  padding: 44px 0;
  border-top: .5px solid var(--rule);
}
.moment:last-child { border-bottom: .5px solid var(--rule); }
.moment .year {
  font: 300 64px/.95 var(--serif);
  color: var(--accent);
  letter-spacing: -.02em;
}
.moment .year .ed {
  display: block;
  font: 500 10px/1 var(--sans);
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--editorial);
  margin-top: 16px;
}
.moment h3 {
  font: 500 26px/1.22 var(--serif);
  margin: 0 0 14px;
  letter-spacing: -.012em;
  color: var(--ink);
}
.moment h3 em { font-style: italic; font-weight: 400; }
.moment p {
  margin: 0 0 .8em;
  font: 400 17px/1.55 var(--serif);
  color: var(--ink-soft);
}
.moment p:last-child { margin-bottom: 0; }
.moment .src {
  font: 500 10px/1 var(--sans);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-top: 18px;
}

/* People */
section.people { padding: 96px 0 80px; border-top: .5px solid var(--rule); }
.people-head {
  text-align: center;
  margin-bottom: 56px;
  max-width: 40rem;
  margin-left: auto;
  margin-right: auto;
}
.people-head h2 {
  font: italic 400 clamp(34px, 5vw, 52px)/1.05 var(--serif);
  margin: 0;
  color: var(--ink);
}
.people-head h2 em { color: var(--accent-deep); }
.people-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
  max-width: 68rem;
  margin: 0 auto;
}
.person {
  padding: 32px;
  border-radius: var(--radius);
  background: var(--card);
  border: .5px solid var(--rule);
}
.person:hover { border-color: var(--accent); }
.person-photo {
  margin: 0 0 22px;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: var(--radius-sm);
  background: var(--paper);
  border: .5px solid var(--rule-soft);
}
.person-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 25%;
  filter: contrast(1.02) saturate(.96);
}
.person-photo-credit {
  font: 9.5px/1.5 var(--sans);
  letter-spacing: .04em;
  color: var(--ink-faint);
  margin: -12px 0 16px;
}
.person-role {
  font: 600 10px/1 var(--sans);
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--editorial);
  margin: 0 0 10px;
}
.person-name {
  font: 500 26px/1.1 var(--serif);
  letter-spacing: -.015em;
  margin: 0 0 14px;
  color: var(--ink);
}
.person-name em { font-style: italic; font-weight: 400; }
.person-bio { font: 400 16px/1.55 var(--serif); color: var(--ink-soft); margin: 0; }
.person-bio em { font-style: italic; color: var(--ink); }
.person-source {
  font: 500 10px/1 var(--sans);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin: 14px 0 0;
  padding-top: 14px;
  border-top: .5px solid var(--rule-soft);
}

/* Founding facts */
section.facts {
  padding: 56px 0;
  border-top: .5px solid var(--rule);
  border-bottom: .5px solid var(--rule);
  background: var(--paper-deep);
}
.facts-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 32px;
  max-width: 72rem;
  margin: 0 auto;
}
.fact .label {
  font: 600 10px/1 var(--sans);
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--editorial);
  margin-bottom: 10px;
  display: block;
}
.fact .value {
  font: 400 22px/1.2 var(--serif);
  letter-spacing: -.01em;
  color: var(--ink);
}
.fact .value em { font-style: italic; font-weight: 300; color: var(--accent-deep); }

/* Map & venues */
section.geo { padding: 88px 0; }
.geo-head { margin: 0 auto 32px; max-width: 60rem; }
.geo-head h2 {
  font: italic 400 clamp(30px, 4.2vw, 44px)/1.05 var(--serif);
  margin: 0;
  color: var(--ink);
}
.map-frame {
  border-radius: var(--radius);
  overflow: hidden;
  border: .5px solid var(--rule);
  aspect-ratio: 16/8;
  max-width: 60rem;
  margin: 0 auto;
  background: var(--paper-deep);
}
.map-frame iframe { width: 100%; height: 100%; border: 0; filter: saturate(.85); }
.venues { margin: 40px auto 0; max-width: 60rem; }
.venues h3 {
  font: 600 10px/1 var(--sans);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--editorial);
  margin: 0 0 24px;
  padding-bottom: 14px;
  border-bottom: .5px solid var(--rule);
}
.venue {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 28px;
  padding: 20px 0;
  border-bottom: .5px solid var(--rule-soft);
}
.venue:last-child { border-bottom: 0; }
.venue .name {
  font: 500 19px/1.3 var(--serif);
  margin: 0 0 4px;
}
.venue .name em { font-style: italic; font-weight: 400; }
.venue .sub {
  font: 500 11px/1 var(--sans);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--editorial);
}
.venue .addr { font: 13px/1.5 var(--sans); color: var(--ink-soft); }

/* Directory rail */
section.directory { padding: 88px 0; border-top: .5px solid var(--rule); }
.directory-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 36px;
  flex-wrap: wrap;
  gap: 16px;
}
.directory-head h2 {
  font: italic 400 clamp(28px, 3.8vw, 40px)/1.05 var(--serif);
  margin: 0;
  color: var(--ink);
}
.directory-head .more {
  font: 600 10.5px/1 var(--sans);
  letter-spacing: .16em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--accent);
  padding: 10px 18px;
  border: .5px solid var(--accent);
  border-radius: 9999px;
  white-space: nowrap;
}
.directory-head .more:hover { background: var(--accent); color: #fff; }
.directory-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.dir-card {
  padding: 28px 26px;
  border-radius: var(--radius);
  background: var(--card);
  border: .5px solid var(--rule);
  text-decoration: none;
  color: var(--ink);
  transition: all .2s;
}
.dir-card:hover { background: var(--paper); border-color: var(--accent); transform: translateY(-2px); }
.dir-card .city {
  font: 600 10px/1 var(--sans);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--editorial);
  margin-bottom: 14px;
}
.dir-card .name {
  font: 500 24px/1.15 var(--serif);
  letter-spacing: -.01em;
  margin-bottom: 12px;
  color: var(--ink);
}
.dir-card .name em { font-style: italic; font-weight: 400; }
.dir-card .note { font: italic 15px/1.5 var(--serif); color: var(--ink-soft); }

/* Essential reading */
section.reading { padding: 88px 0; border-top: .5px solid var(--rule); }
.reading-head { margin-bottom: 48px; }
.reading-head h2 {
  font: italic 400 clamp(28px, 3.8vw, 40px)/1.05 var(--serif);
  margin: 0;
  color: var(--ink);
}
.reading-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.book {
  padding: 28px;
  border-radius: var(--radius);
  background: var(--card);
  border: .5px solid var(--rule);
}
.book:hover { border-color: var(--accent); }
.book .title {
  font: 500 20px/1.3 var(--serif);
  margin: 0 0 8px;
  color: var(--ink);
}
.book .title em { font-style: italic; font-weight: 400; }
.book .author {
  font: 500 10.5px/1 var(--sans);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--editorial);
  margin-bottom: 14px;
}
.book .note {
  font: italic 15px/1.55 var(--serif);
  color: var(--ink-soft);
  margin: 0;
}

/* Related editorial */
section.related {
  padding: 64px 0;
  border-top: .5px solid var(--rule);
  background: var(--paper-deep);
}
.related-head {
  margin-bottom: 28px;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 12px;
}
.related-head h2 {
  font: italic 400 clamp(24px, 3vw, 32px)/1.05 var(--serif);
  margin: 0;
  color: var(--ink);
}
details.related-wrap > summary {
  list-style: none;
  cursor: pointer;
  font: 600 11px/1 var(--sans);
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--accent);
  padding: 12px 0;
  margin-bottom: 12px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
details.related-wrap > summary::-webkit-details-marker { display: none; }
details.related-wrap > summary::after {
  content: "+";
  font: 14px/1 var(--sans);
}
details.related-wrap[open] > summary::after { content: "−"; }
.related-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.rel-card {
  padding: 20px 22px;
  border-radius: var(--radius-sm);
  background: var(--paper);
  border: .5px solid var(--rule);
  text-decoration: none;
  color: var(--ink);
  display: block;
}
.rel-card:hover { border-color: var(--accent); transform: translateY(-1px); }
.rel-card .rel-meta {
  font: 600 9.5px/1 var(--sans);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--editorial);
  margin-bottom: 10px;
}
.rel-card .rel-title {
  font: 500 16px/1.32 var(--serif);
  margin: 0 0 8px;
  color: var(--ink);
}
.rel-card .rel-title em { font-style: italic; font-weight: 400; }
.rel-card .rel-byline { font: 11px/1.4 var(--sans); color: var(--ink-faint); }

/* Rights notice */
.rights-notice {
  padding: 56px 0;
  background: var(--paper);
  border-top: .5px solid var(--rule);
}
.rights-notice .inner { max-width: 60rem; margin: 0 auto; }
.rights-notice h4 {
  font: 600 10px/1 var(--sans);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--editorial);
  margin: 0 0 22px;
  padding-bottom: 14px;
  border-bottom: .5px solid var(--rule);
}
.rights-notice p {
  font: 15px/1.6 var(--serif);
  color: var(--ink-soft);
  margin: 0 0 14px;
}
.rights-notice a { color: var(--ink); text-decoration-color: var(--accent); }

/* Footer */
footer {
  background: var(--ink);
  color: #c8c0b5;
  padding: 88px 0 40px;
  font: 14px/1.55 var(--sans);
}
footer a { color: #e5dfd2; text-decoration-color: rgba(229, 223, 210, .3); }
footer a:hover { color: #fff; }
.bookshelf-promo {
  padding: 0 0 56px;
  margin-bottom: 56px;
  border-bottom: .5px solid rgba(255, 255, 255, .1);
}
.bookshelf-promo h3 {
  font: italic 400 clamp(24px, 3vw, 32px)/1.05 var(--serif);
  margin: 0 0 28px;
  color: #fff;
}
.bookshelf-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-bottom: 22px;
}
.bookshelf-item h4 {
  font: 500 17px/1.3 var(--serif);
  margin: 0 0 8px;
  color: #fff;
}
.bookshelf-item h4 em { font-style: italic; font-weight: 400; }
.bookshelf-item p {
  font: italic 14px/1.5 var(--serif);
  color: rgba(232, 223, 210, .65);
  margin: 0 0 12px;
}
.bookshelf-item a {
  font: 600 10.5px/1 var(--sans);
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--accent);
  text-decoration: none;
}
.bookshelf-item a:hover { color: #fff; }
.affiliate-note {
  font: 11px/1.7 var(--sans);
  color: rgba(232, 223, 210, .45);
  margin: 0;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 56px;
  padding-bottom: 56px;
  border-bottom: .5px solid rgba(255, 255, 255, .1);
}
footer h5 {
  font: 600 10px/1 var(--sans);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: #c8c0b5;
  opacity: .7;
  margin: 0 0 18px;
}
footer ul { list-style: none; padding: 0; margin: 0; }
footer li { margin-bottom: 10px; }
.brand.brand-footer .brand-word { color: #fff; }
.brand.brand-footer .brand-mark rect[stroke] { stroke: var(--accent); }
.brand.brand-footer .brand-mark rect[fill]:not([fill="none"]) { fill: var(--accent); }
.colophon {
  font: italic 14px/1.5 var(--serif);
  color: #a89e8a;
  max-width: 22rem;
}
.copyright-block {
  padding-top: 36px;
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 40px;
  font: 11px/1.7 var(--sans);
  color: #a89e8a;
}
.copyright-block .right { text-align: right; }

/* Responsive */
@media (max-width: 900px) {
  body { font-size: 16px; }
  .essay-body { font-size: 18px; }
  .facts-grid, .directory-grid { grid-template-columns: repeat(2, 1fr); }
  .related-list, .bookshelf-grid, .footer-grid { grid-template-columns: 1fr 1fr; }
  .reading-list { grid-template-columns: 1fr; }
  .footer-grid { gap: 40px; }
  .copyright-block { grid-template-columns: 1fr; }
  .copyright-block .right { text-align: left; }
  blockquote.pull { margin: 40px 0; padding: 0 0 0 1.5rem; }
  .essay-backdrop { font-size: 26vw; }
  .venue, .people-grid { grid-template-columns: 1fr; }
  .fact-callout dl { grid-template-columns: 1fr; }
  .fact-callout dt { margin-top: 8px; }
  nav.page-jump ul {
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
    justify-content: flex-start;
    gap: 24px;
  }
  nav.page-jump ul::-webkit-scrollbar { display: none; }
  .coverage-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .moment { grid-template-columns: 1fr; gap: 14px; }
  .moment .year { font-size: 48px; }
  .footer-grid { grid-template-columns: 1fr; }
  .brand-mark { width: 32px; height: 32px; }
  .brand-word { font-size: 24px; }
  .related-list { grid-template-columns: 1fr; }
  .essay-body > p:first-of-type::first-letter { font-size: 4.6em; }
  nav.rail a { font-size: 10px; padding: 7px 12px; letter-spacing: .1em; }
}
@media print {
  body { background: #fff; color: #000; font-size: 11pt; }
  .sponsor-band, nav.rail, nav.page-jump, section.directory,
  section.widgets, section.geo, footer, .essay-backdrop { display: none; }
}
