:root {
  color-scheme: dark;
  --bg: #1a1a1a;
  --ink: #f4f1ea;
  --muted: #b9b3aa;
  --rule: #3c3a36;
  --quote: #ddd7cd;
}

* {
  box-sizing: border-box;
}

html {
  min-height: 100%;
  background: var(--bg);
}

body {
  min-height: 100%;
  margin: 0;
  color: var(--ink);
  background: var(--bg);
  font-family: Georgia, "Times New Roman", serif;
  line-height: 1.65;
}

a {
  color: inherit;
  text-underline-offset: 0.18em;
}

.page {
  width: min(100% - 32px, 760px);
  margin: 0 auto;
  padding: 64px 0 32px;
}

.audio-section {
  margin-bottom: 54px;
}

.eyebrow {
  margin: 0 0 12px;
  color: var(--muted);
  font-family: Arial, Helvetica, sans-serif;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-transform: uppercase;
}

h1,
h2,
p,
blockquote {
  overflow-wrap: anywhere;
}

h1 {
  margin: 0 0 24px;
  font-size: clamp(2.3rem, 8vw, 5rem);
  line-height: 0.96;
  letter-spacing: 0;
}

audio {
  display: block;
  width: 100%;
  max-width: 520px;
}

.essay {
  font-size: clamp(1.05rem, 2vw, 1.2rem);
}

.essay p {
  margin: 0 0 1.15em;
}

.essay strong {
  font-family: Arial, Helvetica, sans-serif;
  font-size: 0.95em;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.essay h2 {
  margin: 2.35em 0 0.65em;
  font-family: Arial, Helvetica, sans-serif;
  font-size: clamp(1.25rem, 3vw, 1.75rem);
  line-height: 1.15;
  letter-spacing: 0;
}

blockquote {
  margin: 1.6em 0;
  padding-left: 18px;
  border-left: 2px solid var(--ink);
  color: var(--quote);
  font-style: italic;
}

blockquote p:last-child {
  margin-bottom: 0;
}

hr {
  margin: 2.4em 0 1.4em;
  border: 0;
  border-top: 1px solid var(--rule);
}

.source {
  width: min(100% - 32px, 760px);
  margin: 0 auto;
  padding: 0 0 48px;
  color: var(--muted);
  font-family: Arial, Helvetica, sans-serif;
  font-size: 0.88rem;
  line-height: 1.4;
}

.source p {
  margin: 0;
  padding-top: 22px;
  border-top: 1px solid var(--rule);
}

@media (max-width: 520px) {
  .page {
    width: min(100% - 24px, 760px);
    padding-top: 42px;
  }

  .audio-section {
    margin-bottom: 42px;
  }

  .source {
    width: min(100% - 24px, 760px);
    padding-bottom: 34px;
  }
}
