/* =====================================================================
   Reading view (post/essay) — iA Writer preview spirit
   ===================================================================== */
.read-wrap { max-width: var(--read); margin-inline: auto; }
.article { padding: 72px 0 40px; }

.backlink {
  font-family: var(--sans);
  font-size: 13px;
  color: var(--faint);
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 8px;
  margin-bottom: 40px;
}
.backlink:hover { color: var(--accent); }
.backlink .arr { transition: transform 0.18s ease; }
.backlink:hover .arr { transform: translateX(-3px); }

.article .a-date {
  font-family: var(--mono);
  font-size: 12.5px;
  letter-spacing: 0.02em;
  color: var(--faint);
}
.article h1 {
  font-family: var(--serif);
  font-size: 32px;
  line-height: 1.16;
  font-weight: 600;
  letter-spacing: -0.018em;
  color: var(--ink);
  margin: 12px 0 0;
  text-wrap: pretty;
}
.article .a-date.below { margin-top: 16px; }

/* prose */
.prose { margin-top: 40px; }
.prose { font-size: 19.5px; line-height: 1.68; color: var(--ink); }
.prose > :first-child { margin-top: 0; }
.prose p { margin: 0 0 1.3em; text-wrap: pretty; }
.prose h2 {
  font-family: var(--serif);
  font-size: 25px; font-weight: 600; line-height: 1.25;
  letter-spacing: -0.01em;
  margin: 2em 0 0.6em;
}
.prose h3 {
  font-family: var(--serif);
  font-size: 21px; font-weight: 600;
  margin: 1.7em 0 0.5em;
}
.prose a {
  color: var(--ink);
  text-decoration: underline;
  text-decoration-color: var(--rule-2);
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
}
.prose a:hover { color: var(--accent); text-decoration-color: var(--accent); }
.prose strong { font-weight: 600; }
.prose em { font-style: italic; }

.prose blockquote {
  margin: 1.6em 0;
  padding-left: 22px;
  border-left: 2px solid var(--rule-2);
  color: var(--muted);
  font-style: italic;
}
.prose blockquote p:last-child { margin-bottom: 0; }

.prose ul, .prose ol { margin: 0 0 1.3em; padding-left: 1.3em; }
.prose li { margin: 0.3em 0; padding-left: 0.2em; }
.prose li::marker { color: var(--faint); }

.prose hr {
  border: none; height: 0;
  border-top: 1px solid var(--rule);
  margin: 2.4em auto;
  width: 40%;
}

.prose code {
  font-family: var(--mono);
  font-size: 0.82em;
  background: var(--field);
  padding: 0.12em 0.4em;
  border-radius: 4px;
}
.prose pre {
  font-family: var(--mono);
  font-size: 14px; line-height: 1.55;
  background: var(--field);
  padding: 18px 20px;
  border-radius: 8px;
  overflow-x: auto;
  margin: 1.5em 0;
}
.prose pre code { background: none; padding: 0; font-size: inherit; }

/* ---- images & image stacks ---- */
.prose figure { margin: 2em 0; }
.prose figure img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 3px;
}
.prose figcaption {
  font-family: var(--sans);
  font-size: 12.5px;
  color: var(--faint);
  margin-top: 10px;
  text-align: left;
}
/* a "stack": several images in sequence, set tight together */
.prose figure.stack { display: flex; flex-direction: column; gap: 10px; }
.prose figure.stack img { border-radius: 3px; }
/* full-bleed-ish: let images breathe slightly past the text column */
@media (min-width: 760px) {
  .prose figure.wide { margin-inline: -40px; }
}

/* ---- prev / next navigation between pieces ---- */
.postnav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  margin-top: 76px;
  padding-top: 30px;
  border-top: 1px solid var(--rule);
}
.pn-col.right { text-align: right; }
.pn {
  display: inline-flex;
  flex-direction: column;
  gap: 7px;
  max-width: 100%;
  text-decoration: none;
}
.pn-col.right .pn { align-items: flex-end; margin-left: auto; }
.pn-dir {
  font-family: var(--sans);
  font-size: 14px;
  letter-spacing: 0.01em;
  color: var(--accent);
}
.pn .arr { display: inline-block; transition: transform 0.18s ease; }
.pn:hover .pn-dir { color: var(--accent-hover); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
.pn-col.left .pn:hover .arr { transform: translateX(-3px); }
.pn-col.right .pn:hover .arr { transform: translateX(3px); }
.pn-d { font-family: var(--mono); font-size: 11.5px; color: var(--faint); }

@media (max-width: 640px) {
  .article { padding: 40px 0 30px; }
  .article h1 { font-size: 30px; }
  .prose { font-size: 18.5px; }
  @media (max-width: 760px) {
    .prose figure.wide { margin-inline: 0; }
  }

}
