.article-header { border-bottom: 0; }
.article-main { width: min(100% - 40px, 1120px); margin: auto; }
.article-hero { padding: 100px 0 80px; border-bottom: 1px solid var(--line); }
.article-hero .post-meta { margin-bottom: 30px; }
.article-hero h1 {
  max-width: 920px; margin: 0 0 45px; font-family: var(--serif);
  font-size: clamp(48px, 7vw, 92px); font-weight: 400; line-height: 1.18; letter-spacing: -.055em;
}
.article-deck { max-width: 680px; color: var(--muted); font-family: var(--serif); font-size: 22px; line-height: 1.75; }
.article-layout { display: grid; grid-template-columns: 180px minmax(0, 680px); justify-content: center; gap: 70px; padding: 90px 0 130px; }
.article-aside { font-size: 11px; color: var(--muted); line-height: 1.8; }
.article-aside > div { position: sticky; top: 40px; }
.article-aside strong { display: block; color: var(--ink); margin-bottom: 12px; letter-spacing: .1em; }
.article-body { font-family: var(--serif); font-size: 18px; line-height: 2; }
.article-body > p:first-child::first-letter {
  float: left; color: var(--accent); font-size: 74px; line-height: .85; padding: 13px 12px 0 0;
}
.article-body h2 { margin: 70px 0 22px; font-size: 34px; font-weight: 400; letter-spacing: -.03em; }
.article-body blockquote { margin: 55px 0; padding: 10px 0 10px 28px; border-left: 2px solid var(--accent); color: var(--moss); font-size: 26px; line-height: 1.6; }
.article-body code { font-family: monospace; font-size: .85em; background: var(--paper-deep); padding: 3px 6px; }
.article-end { border-top: 1px solid var(--line); padding-top: 35px; margin-top: 70px; color: var(--muted); font-family: var(--sans); font-size: 12px; }
.next-article { display: block; color: #f1eee7; background: #263a30; padding: 80px max(20px, calc((100vw - 1120px) / 2)); }
.next-article small { letter-spacing: .15em; }
.next-article strong { display: block; max-width: 850px; margin-top: 20px; font-family: var(--serif); font-size: clamp(36px, 5vw, 64px); font-weight: 400; }
@media (max-width: 760px) {
  .article-hero { padding-top: 65px; }
  .article-layout { grid-template-columns: 1fr; gap: 25px; padding-top: 55px; }
  .article-aside > div { position: static; display: flex; gap: 8px; }
  .article-aside strong { display: inline; }
  .article-body { font-size: 17px; }
}
