/* hybrid: jetbrains mono for metadata + eb garamond for body. */

:root {
  --fg: #1a1a1a;
  --muted: #8a8a86;
  --bg: #fcfcfa;
  --rule: #e8e8e4;
  --serif: "EB Garamond", Georgia, "Times New Roman", serif;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }

/* persistent site header — sticky band, logo mark + bold serif caps nav. */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--bg);
  /* extend the bg full-width even though body has horizontal padding */
  margin: 0 -1.25rem 3rem;
  padding: 0 1.25rem;
  border-bottom: 1px solid var(--rule);
}
.site-header-inner {
  max-width: 46rem;
  margin: 0 auto;
  padding: 0.9rem 0;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1rem 2.5rem;
}
.site-header .logo {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  color: var(--fg);
  line-height: 1;
  flex-shrink: 0;
}
.site-header .logo:hover {
  background: transparent;
  color: var(--fg);
  box-shadow: none;
  text-decoration: none;
  opacity: 0.7;
}
.site-header .logo svg {
  display: block;
  width: 38px;
  height: 38px;
}
.site-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1.5rem;
}
.site-nav a {
  font-family: var(--serif);
  font-style: normal;
  font-weight: 700;
  font-size: 1.5rem;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  text-decoration: none;
  color: var(--fg);
  line-height: 1;
}
/* when one tab is the current page, mute the inactive ones (but never the hovered one) */
.site-nav:has(a[aria-current="page"]) a:not([aria-current="page"]):not(:hover) {
  color: var(--muted);
}
.site-nav a:hover {
  background: var(--fg);
  color: var(--bg);
  text-decoration: none;
  box-shadow: 0.15em 0 0 var(--fg), -0.15em 0 0 var(--fg);
}

body {
  font-family: var(--serif);
  font-size: 25px;
  line-height: 1.5;
  color: var(--fg);
  background: var(--bg);
  margin: 0;
  padding: 0 1.25rem 5rem;
}

main, article {
  max-width: 46rem;
  margin: 0 auto;
}

h1 {
  font-family: var(--serif);
  font-size: 2.75rem;
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.015em;
  margin: 0 0 0.75rem;
}

h2 {
  font-family: var(--serif);
  font-size: 1.6rem;
  font-weight: 700;
  text-transform: none;
  letter-spacing: -0.01em;
  color: var(--fg);
  margin: 3rem 0 1.25rem;
  padding-bottom: 0.4rem;
  border-bottom: 2px solid var(--fg);
}

p {
  margin: 0.5rem 0 0.9rem;
}

a {
  color: var(--fg);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
a:hover {
  background: var(--fg);
  color: var(--bg);
  text-decoration: none;
  box-shadow: 0.15em 0 0 var(--fg), -0.15em 0 0 var(--fg);
}
/* unfinished links: hidden until wired up. remove the attribute to publish. */
a[data-todo] { display: none; }

.bio,
.reading-intro,
.writing-intro,
.projects-intro {
  font-family: var(--mono);
  font-size: 0.78rem;
  color: var(--muted);
  margin: 0 0 2rem;
  max-width: 36rem;
}

.contact {
  font-family: var(--mono);
  font-size: 0.78rem;
  color: var(--muted);
  margin: -1.4rem 0 2rem;
}

/* "currently" block — scannable metadata strip on the home page. mono
   throughout, label muted, value at full color for contrast. */
dl.now {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 0.4rem 1.5rem;
  font-family: var(--mono);
  font-size: 0.78rem;
  margin: 0 0 2.5rem;
  max-width: 36rem;
}
dl.now dt { color: var(--muted); }
dl.now dd { margin: 0; color: var(--fg); }
dl.now a { color: var(--fg); }

nav.links {
  font-family: var(--mono);
  font-size: 0.82rem;
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  margin: 1.5rem 0 0;
}

hr.section-rule {
  border: 0;
  border-top: 2px solid var(--fg);
  margin: 3rem 0 1.25rem;
}

ul.project-list,
ul.post-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

ul.project-list li,
ul.post-list li {
  display: grid;
  grid-template-columns: 5.5rem minmax(0, 1.35fr) minmax(0, 1fr);
  align-items: baseline;
  gap: 0.4rem 1.5rem;
  padding: 0.7rem 0;
}

.title-block {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0 0.6rem;
  min-width: 0;
}

/* titles in lists — slightly larger serif at regular weight, with link underline. */
ul.project-list li a:not(.tag),
ul.post-list li a:not(.tag),
ul.home-list li a {
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.25;
}

.date, .year {
  font-family: var(--mono);
  font-size: 0.78rem;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}

.desc {
  display: block;
  color: var(--muted);
  font-size: 0.95rem;
  margin: 0;
}

.more {
  font-family: var(--mono);
  font-size: 0.82rem;
  margin-top: 1rem;
}

/* tag — small mono caps, no chrome. clickable to filter. */
a.tag {
  font-family: var(--mono);
  font-size: 0.7rem;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  text-decoration: none;
  margin-left: 0.6rem;
  white-space: nowrap;
  vertical-align: 0.08em;
}
a.tag:hover {
  color: var(--fg);
  background: transparent;
  box-shadow: none;
}

/* filter row at top of archive — styled like an h2 section header. */
nav.tag-filter {
  font-family: var(--serif);
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  margin: 3rem 0 1.25rem;
  padding-bottom: 0.4rem;
  border-bottom: 2px solid var(--fg);
}
nav.tag-filter a {
  color: var(--muted);
  text-decoration: none;
  font-weight: 700;
}
nav.tag-filter a.active {
  color: var(--fg);
}
nav.tag-filter a:hover {
  color: var(--fg);
  background: transparent;
  box-shadow: none;
  text-decoration: none;
}

.tag-note {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1rem;
  color: var(--muted);
  margin: -0.5rem 0 1.5rem;
}

.back {
  font-family: var(--mono);
  font-size: 0.78rem;
  display: inline-block;
  margin-bottom: 2.5rem;
  color: var(--muted);
}

/* ---- home page ---- */

/* hero: name + serif lead bio + contact strip. the portrait that opens the site. */
.home .hero {
  margin: 0.5rem 0 3.5rem;
}
.home .hero h1 {
  margin: 0 0 1.25rem;
}
.home .lead {
  font-family: var(--serif);
  font-size: 1.25rem;
  line-height: 1.45;
  color: var(--fg);
  margin: 0 0 1.5rem;
  max-width: 36rem;
}
.home .links {
  font-family: var(--mono);
  font-size: 0.78rem;
  color: var(--muted);
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.2rem 0.55rem;
}
.home .links a { color: var(--fg); }
.home .links .sep { color: var(--muted); }

/* teaser: quiet mono label + thin rule + "all →" anchored right.
   intentionally lighter than the h2+thick-rule treatment used on archive pages. */
.home-teaser { margin: 0 0 2.75rem; }
.home-teaser-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: 0.55rem;
  border-bottom: 1px solid var(--rule);
  margin: 0 0 0.4rem;
}
.home-label {
  font-family: var(--mono);
  font-size: 0.78rem;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin: 0;
  padding: 0;
  border: 0;
}
.home-all {
  font-family: var(--mono);
  font-size: 0.78rem;
  color: var(--muted);
  text-decoration: none;
  white-space: nowrap;
}
.home-all:hover {
  color: var(--fg);
  background: transparent;
  box-shadow: none;
  text-decoration: none;
}

ul.home-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
ul.home-list li {
  display: grid;
  grid-template-columns: 5.5rem 1fr;
  align-items: baseline;
  gap: 0.4rem 1.5rem;
  padding: 0.55rem 0;
}

h1.label {
  font-family: var(--serif);
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.015em;
  text-transform: none;
  color: var(--fg);
  margin: 0 0 1.5rem;
  padding-bottom: 0.5rem;
  border-bottom: 3px solid var(--fg);
}

/* ---- individual post pages ---- */

article > header {
  margin: 1rem 0 3.5rem;
}

article > header h1 {
  font-family: var(--serif);
  font-size: 2.85rem;
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--fg);
  margin: 0 0 0.9rem;
  text-transform: none;
}

article > header .dek {
  font-family: var(--serif);
  font-size: 1.15rem;
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  color: var(--fg);
  margin: 0 0 1.25rem;
  opacity: 0.7;
}

article > header .date {
  display: block;
  min-width: 0;
  font-family: var(--mono);
  font-size: 0.78rem;
  color: var(--muted);
  margin: 0;
}

article p, article li {
  font-size: 1.2rem;
  line-height: 1.6;
  hyphens: auto;
  font-feature-settings: "onum" 1;
}

/* drop cap — the only opener device. fires on the first paragraph after the
   first h2, or on any paragraph with class="lede". */
article > h2:first-of-type + p::first-letter,
article p.lede::first-letter {
  font-family: var(--serif);
  font-size: 3.4em;
  font-weight: 400;
  float: left;
  line-height: 0.86;
  padding: 0.05em 0.1em 0 0;
}

/* section-break italic line: centered standalone phrase between paragraphs */
article p.break {
  text-align: center;
  font-style: italic;
  margin: 3rem 1.5rem;
  color: var(--fg);
}

/* short centered hr used as a subtle divider between sections */
article hr {
  border: 0;
  height: 3px;
  background: var(--fg);
  width: 3rem;
  margin: 2.75rem auto;
}

/* parallel paragraphs: two equal columns, collapses to one on narrow screens */
article .two-column {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin: 0.5rem 0 0.9rem;
}
article .two-column p { margin: 0; }
@media (max-width: 520px) {
  article .two-column { grid-template-columns: 1fr; }
}

article .refs {
  font-size: 0.9rem;
  line-height: 1.5;
}
article .refs p {
  font-size: 0.9rem;
  line-height: 1.5;
  margin: 0.4rem 0;
  text-indent: -1.5rem;
  padding-left: 1.5rem;
}

article ul, article ol {
  padding-left: 1.5rem;
  margin: 1rem 0;
}
article ul li, article ol li {
  margin: 0.5rem 0;
  padding-left: 0.25rem;
}
article ul { list-style: none; }
article ul li::before {
  content: '\2014';
  color: var(--muted);
  margin-left: -1.25rem;
  margin-right: 0.5rem;
}

/* section headings — big serif with a hard rule underneath. */
article h2 {
  font-family: var(--serif);
  font-size: 1.6rem;
  font-weight: 700;
  text-transform: none;
  letter-spacing: -0.01em;
  color: var(--fg);
  margin: 3.25rem 0 1.5rem;
  padding-bottom: 0.4rem;
  border-bottom: 3px solid var(--fg);
}

/* blockquote: upright body, thick left rule, right-aligned mono citation. */
article blockquote {
  margin: 1.75rem 0;
  padding: 0.15rem 0 0.15rem 1.5rem;
  border-left: 4px solid var(--fg);
  color: var(--fg);
  font-size: 1.02rem;
}

article blockquote p { margin: 0.5rem 0; }

article blockquote cite {
  display: block;
  font-family: var(--mono);
  font-size: 0.72rem;
  font-style: normal;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
  text-align: right;
  margin-top: 0.75rem;
}

/* ---- reading page ---- */

ul.book-grid {
  list-style: none;
  padding: 0;
  margin: 0 0 3rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2.25rem 1.75rem;
}

ul.book-grid li {
  display: flex;
  flex-direction: column;
}

ul.book-grid .cover {
  display: block;
  width: 100%;
  aspect-ratio: 2 / 3;
  object-fit: cover;
  background: var(--rule);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06),
              0 10px 22px rgba(0, 0, 0, 0.12);
  margin-bottom: 0.85rem;
}

ul.book-grid .book-title {
  font-family: var(--serif);
  font-size: 1.05rem;
  font-weight: 600;
  line-height: 1.25;
}

ul.book-grid .book-author {
  display: block;
  font-size: 0.9rem;
  color: var(--muted);
  margin-top: 0.15rem;
}

ul.book-grid .desc {
  display: block;
  margin-top: 0.5rem;
  font-size: 0.9rem;
  color: var(--muted);
  line-height: 1.45;
}

ul.book-grid .desc:empty {
  display: none;
}

ul.book-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

ul.book-list li {
  display: grid;
  grid-template-columns: 5.5rem minmax(0, 1.35fr) minmax(0, 1fr);
  align-items: baseline;
  gap: 0.4rem 1.5rem;
  padding: 0.7rem 0;
}

ul.book-list .book-title {
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.25;
}

ul.book-list .book-author {
  font-size: 1rem;
  color: var(--muted);
}

section.book-quotes {
  margin: 0 0 2.5rem;
}

section.book-quotes h3 {
  font-family: var(--serif);
  font-size: 1.3rem;
  font-weight: 700;
  margin: 2.5rem 0 1rem;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid var(--rule);
}

section.book-quotes h3 .byline {
  font-weight: 400;
  font-style: italic;
  color: var(--muted);
  font-size: 1rem;
}

section.book-quotes blockquote {
  margin: 1.25rem 0;
  padding: 0.15rem 0 0.15rem 1.5rem;
  border-left: 4px solid var(--fg);
  color: var(--fg);
}

section.book-quotes blockquote p {
  margin: 0.4rem 0;
  font-size: 1.05rem;
  line-height: 1.55;
}

section.book-quotes blockquote cite {
  display: block;
  font-family: var(--mono);
  font-size: 0.72rem;
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
  text-align: right;
  margin-top: 0.5rem;
}

/* ---- quotes page ---- */

.quotes-intro {
  font-family: var(--mono);
  font-size: 0.78rem;
  color: var(--muted);
  margin: 0 0 2rem;
  max-width: 36rem;
}

/* random surface — three quotes presented like found pages.
   no chrome, generous whitespace, separated by a thin centered rule. */
.quote-surface {
  margin: 0 0 4rem;
}
.quote-surface blockquote {
  border: 0;
  padding: 0;
  margin: 0 0 2.5rem;
  font-family: var(--serif);
}
.quote-surface blockquote p {
  font-size: 1.25rem;
  line-height: 1.55;
  margin: 0 0 0.6rem;
}
.quote-surface blockquote cite {
  display: block;
  font-family: var(--mono);
  font-size: 0.72rem;
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
  margin-top: 0.9rem;
}
.quote-surface blockquote + blockquote {
  padding-top: 2.5rem;
  border-top: 1px solid var(--rule);
}

/* surface heading: styled like h2 ("archive") but it's the clickable
   shuffle action. parallel section header to the archive below. */
.surface-heading {
  display: block;
  width: 100%;
  text-align: left;
  font-family: var(--serif);
  font-size: 1.6rem;
  font-weight: 700;
  text-transform: none;
  letter-spacing: -0.01em;
  color: var(--fg);
  background: transparent;
  border: 0;
  border-bottom: 2px solid var(--fg);
  margin: 0 0 1.25rem;
  padding: 0 0 0.4rem;
  cursor: pointer;
  transition: color 120ms ease;
}
.surface-heading:hover {
  color: var(--muted);
}

.archive-heading {
  /* matches h2 in style — already set globally */
}
.archive-note {
  font-family: var(--mono);
  font-size: 0.78rem;
  color: var(--muted);
  margin: -0.5rem 0 1.5rem;
}

/* archive accordion — one <details> per source, native disclosure. */
.quote-archive {
  margin: 0 0 3rem;
}
.archive-group {
  border-bottom: 1px solid var(--rule);
}
.archive-group > summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1.5rem;
  padding: 0.85rem 0;
  font-family: var(--serif);
}
.archive-group > summary::-webkit-details-marker { display: none; }
.archive-group > summary::before {
  content: '+';
  font-family: var(--mono);
  font-size: 0.9rem;
  color: var(--muted);
  margin-right: 0.6rem;
  width: 0.8em;
  display: inline-block;
}
.archive-group[open] > summary::before { content: '−'; color: var(--fg); }

.archive-group .archive-label {
  font-size: 1.15rem;
  font-weight: 400;
  flex: 1;
  min-width: 0;
}
.archive-group[open] .archive-label { font-weight: 700; }
.archive-group .archive-count {
  font-family: var(--mono);
  font-size: 0.78rem;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}
.archive-group.fragments > summary {
  font-style: italic;
  color: var(--muted);
}
.archive-group.fragments[open] > summary .archive-label { color: var(--fg); }

.archive-quotes {
  padding: 0.5rem 0 1.5rem 1.4rem;
}
.archive-quotes blockquote {
  margin: 1.1rem 0;
  padding: 0.1rem 0 0.1rem 1.1rem;
  border-left: 2px solid var(--rule);
}
.archive-quotes blockquote p {
  font-family: var(--serif);
  font-size: 1.05rem;
  line-height: 1.55;
  margin: 0.4rem 0;
}
.archive-quotes blockquote cite {
  display: block;
  font-family: var(--mono);
  font-size: 0.7rem;
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
  margin-top: 0.6rem;
}

/* section label between archive sub-sections (single lines, fragments) */
.archive-section-label {
  font-family: var(--mono);
  font-size: 0.72rem;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
  border: 0;
  padding: 0;
  margin: 2.5rem 0 1rem;
}

/* singletons — flat list, no click required. each entry: quote + attribution. */
.singletons {
  margin: 0 0 1rem;
}
.single-line {
  padding: 1.1rem 0;
  border-bottom: 1px solid var(--rule);
}
.single-line:last-child { border-bottom: 0; }
.single-line blockquote {
  margin: 0;
  padding: 0;
  border: 0;
}
.single-line blockquote p {
  font-family: var(--serif);
  font-size: 1.05rem;
  line-height: 1.55;
  margin: 0 0 0.55rem;
}
.single-line blockquote cite {
  display: block;
  font-family: var(--mono);
  font-size: 0.7rem;
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
}

@media (max-width: 640px) {
  .quote-surface blockquote p { font-size: 1.1rem; }
  .archive-group .archive-label { font-size: 1.05rem; }
  .archive-quotes { padding-left: 0.8rem; }
  .single-line blockquote p { font-size: 1rem; }
}

/* ---- design archive + case studies ---- */

.design-intro {
  font-family: var(--mono);
  font-size: 0.78rem;
  color: var(--muted);
  margin: 0 0 2rem;
  max-width: 36rem;
}

ul.design-grid {
  list-style: none;
  padding: 0;
  margin: 1.5rem 0 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem 1.25rem;
}
ul.design-grid li { display: block; }
ul.design-grid a {
  display: block;
  text-decoration: none;
  color: var(--fg);
}
ul.design-grid a:hover {
  background: transparent;
  box-shadow: none;
}
ul.design-grid a:hover .thumb {
  opacity: 0.85;
}
ul.design-grid a:hover .title {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
ul.design-grid .thumb {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  margin: 0 0 0.6rem;
  transition: opacity 120ms ease;
}
ul.design-grid .title {
  display: block;
  font-family: var(--serif);
  font-size: 1.1rem;
  line-height: 1.2;
  font-weight: 400;
  margin: 0.2rem 0 0.15rem;
}
ul.design-grid .meta {
  display: block;
  font-family: var(--mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

/* case study body: borrow article styling, add image figures. */
article .client {
  font-family: var(--mono);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
  display: block;
  margin: 0 0 0.4rem;
}

article figure.case {
  margin: 2.25rem 0;
}
article figure.case img,
article figure.case video {
  display: block;
  width: 100%;
  height: auto;
}
article figure.case figcaption {
  font-family: var(--mono);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin: 0.6rem 0 0;
}
article figure.case.two {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}
article figure.case.two figcaption {
  grid-column: 1 / -1;
}
article figure.case.three {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0.75rem;
}
article figure.case.three figcaption {
  grid-column: 1 / -1;
}

/* tall image (e.g. instagram story 9:16) — center and constrain width
   so it doesn't render as a screen-tall block. */
article figure.case.tall {
  max-width: 20rem;
  margin-left: auto;
  margin-right: auto;
}

/* stack: multiple images in one figure, vertical, with a small gap.
   use for wide artifacts (e.g. flyer front/back) that don't fit two-up. */
article figure.case.stack {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

/* narrow screens: shrink mono metadata column, let nav wrap. */
@media (max-width: 640px) {
  body { font-size: 20px; padding: 2rem 1rem 4rem; }
  h1 { font-size: 1.85rem; }
  h2 { font-size: 1.3rem; }
  .tagline { font-size: 0.82rem; word-break: break-word; }
  ul.project-list li,
  ul.post-list li,
  ul.book-list li,
  ul.home-list li {
    grid-template-columns: 4.5rem 1fr;
    gap: 0.3rem 1rem;
  }
  ul.book-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem 1.25rem;
  }
  .home .lead { font-size: 1.05rem; }
  .home .hero { margin-bottom: 2.5rem; }
  ul.project-list li .desc,
  ul.post-list li .desc,
  ul.book-list li .desc {
    grid-column: 2;
    text-align: left;
  }
  .date, .year { font-size: 0.72rem; }
  article > header h1 { font-size: 1.95rem; }
  article p, article li { font-size: 1.05rem; }

  .site-header { margin: 0 -1rem 2.25rem; padding: 0 1rem; }
  .site-header-inner { padding: 0.7rem 0; gap: 0.75rem 1.25rem; }
  .site-header .logo svg { width: 32px; height: 32px; }
  .site-nav { gap: 1rem 1.1rem; }
  .site-nav a { font-size: 1.15rem; letter-spacing: 0.02em; }

  ul.design-grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem 1rem; }
  article figure.case.two,
  article figure.case.three { grid-template-columns: 1fr; }
}
