/* ============================================================
   tylerwince.com — GREAT PRIMER
   Lane: pure-typography.
   Printers once named their type sizes like jewels — pearl,
   brevier, pica, great primer, canon. One typeface (Fraunces)
   climbing that whole ladder. No boxes anywhere: separation by
   space, hairline rules, and type alone. One shot of vermilion.
   Signature: "the ink-in" — display type settles from hairline
   to full weight, staggered, like ink striking paper.
   ============================================================ */

/* ---------- tokens ---------- */

:root {
  --color-bg: #f6f1e5;
  --color-fg: #211b12;
  --color-accent: #c93908;
  --color-muted: #837763;
  --color-border: #ddd2bb;

  --font-display: "Fraunces", "Georgia", serif;
  --font-body: "Fraunces", "Georgia", serif;
  --font-mono: "Courier Prime", "Courier New", monospace;

  --gutter: clamp(1.4rem, 6vw, 6rem);
  --ghost: color-mix(in oklab, var(--color-fg) 8%, transparent);
  --hairline: 1px solid var(--color-border);

  color-scheme: light;
}

@media (prefers-color-scheme: dark) {
  :root {
    --color-bg: #171310;
    --color-fg: #ece2cd;
    --color-accent: #ff7448;
    --color-muted: #9b8e74;
    --color-border: #3a322a;
    --ghost: color-mix(in oklab, var(--color-fg) 10%, transparent);
    color-scheme: dark;
  }
}

/* ---------- reset & base ---------- */

* { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scrollbar-width: thin;
  scrollbar-color: var(--color-muted) var(--color-bg);
}

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--color-bg); }
::-webkit-scrollbar-thumb {
  background: var(--color-muted);
  border: 2px solid var(--color-bg);
}
::-webkit-scrollbar-thumb:hover { background: var(--color-accent); }

::selection {
  background: var(--color-accent);
  color: var(--color-bg);
  text-shadow: none;
}

:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

body {
  background: var(--color-bg);
  color: var(--color-fg);
  font-family: var(--font-body);
  font-optical-sizing: auto;
  font-size: 1.0625rem;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: inherit; }

img { max-width: 100%; }

/* ============================================================
   THE INK-IN (signature interaction)
   Axis lists must match exactly on both sides so browsers
   interpolate instead of stepping. JS adds .ink-anim (motion ok)
   then .is-inked one frame later; no JS or reduced motion =
   final state, no animation.
   ============================================================ */

.site-title-text { font-variation-settings: "wght" 620, "SOFT" 0, "WONK" 0; }
.hero-word { font-variation-settings: "wght" 640, "SOFT" 0, "WONK" 1; }
.hero-word:nth-child(even) { font-variation-settings: "wght" 430, "SOFT" 50, "WONK" 1; }
.section-title { font-variation-settings: "wght" 480, "SOFT" 30, "WONK" 1; }
.article-title { font-variation-settings: "wght" 600, "SOFT" 40, "WONK" 0; }
.archive-today-theme { font-variation-settings: "wght" 540, "SOFT" 0, "WONK" 1; }
.error-code { font-variation-settings: "wght" 900, "SOFT" 0, "WONK" 1; }

html.ink-anim .site-title-text,
html.ink-anim .hero-word,
html.ink-anim .section-title,
html.ink-anim .article-title,
html.ink-anim .archive-today-theme,
html.ink-anim .error-code {
  transition:
    font-variation-settings 1.1s cubic-bezier(0.2, 0.55, 0.25, 1),
    opacity 0.9s ease-out;
  transition-delay: calc(90ms * var(--i, 0));
}

html.ink-anim:not(.is-inked) .site-title-text,
html.ink-anim:not(.is-inked) .hero-word,
html.ink-anim:not(.is-inked) .section-title,
html.ink-anim:not(.is-inked) .article-title,
html.ink-anim:not(.is-inked) .archive-today-theme,
html.ink-anim:not(.is-inked) .error-code {
  font-variation-settings: "wght" 100, "SOFT" 100, "WONK" 1;
  opacity: 0.12;
}

.site-title-text { --i: 0; }
.article-title { --i: 1; }
.archive-today-theme { --i: 1; }
.error-code { --i: 1; }
.home-section--apps .section-title { --i: 4; }
.home-section--writing .section-title { --i: 5; }
.home-section--reading .section-title { --i: 6; }

/* ---------- shared furniture: dot leaders ---------- */

.nav-leader,
.post-leader {
  flex: 1 1 1.5rem;
  min-width: 1.5rem;
  align-self: flex-end;
  height: 0.95em;
  background-image: radial-gradient(circle, currentColor 1px, transparent 1.4px);
  background-size: 8px 3px;
  background-repeat: repeat-x;
  background-position: left bottom 0.18em;
  opacity: 0.4;
}

/* ---------- banner ---------- */

.site-banner {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  border-bottom: var(--hairline);
  padding: 0.55rem var(--gutter);
}

.banner-text {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.4rem 1.4rem;
}

.banner-no { color: var(--color-accent); }

.banner-name {
  text-transform: uppercase;
  letter-spacing: 0.22em;
}

.banner-note { color: var(--color-muted); }

.banner-link {
  margin-left: auto;
  color: var(--color-muted);
  text-decoration: none;
}
.banner-link:hover { color: var(--color-accent); }

/* ---------- header: the title page + table of contents ---------- */

.site-header {
  display: grid;
  grid-template-columns: 1fr minmax(15rem, 21rem);
  align-items: end;
  gap: 2rem 4rem;
  padding: clamp(2rem, 5vw, 4rem) var(--gutter) clamp(1.5rem, 3vw, 2.5rem);
}

.site-title {
  text-decoration: none;
  display: block;
}

.site-title-text {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  line-height: 1.05;
  letter-spacing: -0.01em;
}

.site-title-sub {
  display: block;
  font-style: italic;
  color: var(--color-muted);
  font-size: 0.95rem;
  margin-top: 0.3rem;
}

.site-title:hover .site-title-text { color: var(--color-accent); }

.site-nav-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--color-muted);
  border-bottom: var(--hairline);
  padding-bottom: 0.45rem;
  margin-bottom: 0.55rem;
}

.nav-list {
  list-style: none;
  counter-reset: toc 1; /* the title page is № 01 */
}

.nav-item { counter-increment: toc; }

.nav-item a {
  display: flex;
  align-items: baseline;
  gap: 0.6rem;
  padding: 0.28rem 0;
  text-decoration: none;
  font-size: 1.02rem;
}

.nav-text { font-variation-settings: "wght" 460; }

.nav-folio::before {
  content: counter(toc, decimal-leading-zero);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--color-muted);
}

.nav-item a:hover .nav-text { color: var(--color-accent); }
.nav-item a:hover .nav-folio::before { color: var(--color-accent); }
.nav-item a:hover .nav-leader { opacity: 0.9; color: var(--color-accent); }

.nav-item a.active .nav-text {
  font-style: italic;
  color: var(--color-accent);
  font-variation-settings: "wght" 560;
}
.nav-item a.active .nav-folio::before { color: var(--color-accent); }

/* ---------- main shell ---------- */

.site-main { display: block; }

.content-area {
  max-width: 74rem;
  margin-inline: auto;
  padding: 0 var(--gutter) clamp(3rem, 7vw, 5rem);
}

/* ---------- homepage: the specimen ladder ---------- */

.home { counter-reset: folio; }

.hero { padding: clamp(2.5rem, 7vw, 6rem) 0 clamp(3rem, 7vw, 6rem); }

.hero-eyebrow {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  text-transform: lowercase;
  letter-spacing: 0.18em;
  color: var(--color-muted);
}

.hero-title {
  font-family: var(--font-display);
  font-size: clamp(3.2rem, 14vw, 12.5rem);
  line-height: 0.94;
  letter-spacing: -0.02em;
  margin: 1.2rem 0 2.2rem;
  text-wrap: balance;
}

.hero-word {
  display: inline-block;
  margin-right: 0.22em; /* word space — spans carry their own spacing */
}
.hero-word:last-child { margin-right: 0; }

.hero-word:nth-child(even) {
  font-style: italic;
  color: var(--color-accent);
}

.hero-meta {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0.4rem 1rem;
  font-family: var(--font-mono);
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--color-muted);
}

.hero-meta span + span::before {
  content: "·";
  margin-right: 1rem;
  color: var(--color-border);
}

/* numbered specimen sections with ghost folios */

.home-section {
  position: relative;
  counter-increment: folio;
  border-top: var(--hairline);
  padding: clamp(2.8rem, 6vw, 5rem) 0 clamp(3rem, 6vw, 5rem);
}

.home-section::before {
  content: counter(folio, decimal-leading-zero);
  position: absolute;
  top: 0.5rem;
  right: 0;
  z-index: 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(6rem, 18vw, 14rem);
  line-height: 1;
  font-variation-settings: "wght" 160;
  color: var(--ghost);
  pointer-events: none;
}

.home-section > * { position: relative; z-index: 1; }

.section-header {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0.4rem 1.4rem;
  margin-bottom: clamp(1.6rem, 4vw, 2.6rem);
}

.section-label {
  width: 100%;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: lowercase;
  color: var(--color-muted);
}

.section-title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(2.4rem, 6vw, 4.4rem);
  line-height: 1;
  letter-spacing: -0.01em;
}

.view-all {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  color: var(--color-muted);
  text-decoration: none;
}
.view-all:hover {
  color: var(--color-accent);
  font-style: italic;
}

/* apps — dictionary headword entries with a true hanging indent */

.app-list { list-style: none; }

.app-entry + .app-entry { margin-top: clamp(1.6rem, 4vw, 2.6rem); }

.app-card {
  display: block;
  text-decoration: none;
  padding-left: clamp(2.6rem, 6vw, 4.2rem);
  text-indent: calc(-1 * clamp(2.6rem, 6vw, 4.2rem));
}

.app-info { display: inline; }

.app-icon {
  display: inline-block;
  width: clamp(26px, 3vw, 38px);
  height: auto;
  vertical-align: -0.25em;
  margin-right: 0.9rem;
  filter: grayscale(1) contrast(1.05);
  transition: filter 0.25s ease;
}

.app-card:hover .app-icon { filter: none; }

.app-icon--glyph {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  color: var(--color-accent);
  width: auto;
}

.app-name {
  font-family: var(--font-display);
  font-size: clamp(2.1rem, 5.5vw, 3.9rem);
  font-variation-settings: "wght" 600, "SOFT" 0, "WONK" 1;
  line-height: 1.05;
  letter-spacing: -0.015em;
}

.app-comma {
  font-family: var(--font-display);
  font-size: clamp(2.1rem, 5.5vw, 3.9rem);
  color: var(--color-muted);
}

.app-desc {
  font-size: clamp(1.1rem, 2.4vw, 1.55rem);
  color: var(--color-muted);
  margin-left: 0.6rem;
}

.app-card:hover .app-name {
  color: var(--color-accent);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 0.18em;
}

/* writing — a contents index with dot leaders */

.post-list { max-width: 56rem; }

.post-row {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  padding: 0.7rem 0;
  text-decoration: none;
}

.post-title {
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 3vw, 1.85rem);
  font-variation-settings: "wght" 500;
  line-height: 1.25;
}

.post-date {
  font-family: var(--font-mono);
  font-size: 0.76rem;
  color: var(--color-muted);
  white-space: nowrap;
}

.post-row:hover .post-title { color: var(--color-accent); }
.post-row:hover .post-leader { opacity: 0.9; color: var(--color-accent); }
.post-row:hover .post-date { color: var(--color-fg); }

/* reading — covers standing on a typographic baseline shelf */

.book-grid {
  list-style: none;
  position: relative;
  display: flex;
  align-items: stretch;
  gap: clamp(1.1rem, 2.6vw, 2.2rem);
  padding-top: 1rem;
  overflow-x: auto;
  scrollbar-width: thin;
  --plate: 6.1rem; /* caption block below the shelf rule */
}

.book-grid::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: var(--plate);
  height: 1px;
  background: var(--color-border);
}

.book-spine { flex: 0 0 auto; display: flex; }

.book-card {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  width: clamp(86px, 9vw, 118px);
  text-decoration: none;
}

.book-card-cover {
  display: block;
  width: 100%;
  height: auto;
  outline: 1px solid color-mix(in oklab, var(--color-fg) 18%, transparent);
  filter: grayscale(1) contrast(1.02);
  transition: filter 0.25s ease;
}

.book-card:hover .book-card-cover { filter: none; }

.book-card-cover--blank {
  aspect-ratio: 2 / 3;
  width: 84%;
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 2rem;
  color: var(--color-muted);
}

.book-card-plate {
  display: block;
  height: var(--plate);
  overflow: hidden;
  padding-top: 0.7rem;
}

.book-card-title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-variation-settings: "wght" 560;
  line-height: 1.25;
}

.book-card-author {
  display: block;
  font-style: italic;
  font-size: 0.74rem;
  color: var(--color-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: 0.15rem;
}

.book-card-status {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  color: var(--color-muted);
  margin-top: 0.25rem;
}

.book-card:hover .book-card-title { color: var(--color-accent); }

/* ---------- footer: the colophon ---------- */

.site-footer {
  border-top: var(--hairline);
  margin-top: clamp(2rem, 5vw, 4rem);
  padding: clamp(2.5rem, 5vw, 4rem) var(--gutter) clamp(3rem, 6vw, 5rem);
  text-align: center;
}

.footer-ornament {
  display: block;
  color: var(--color-accent);
  font-size: 1.4rem;
  margin-bottom: clamp(1.6rem, 4vw, 2.5rem);
}

.footer-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-start;
  gap: 2.5rem clamp(3rem, 7vw, 6rem);
  max-width: 62rem;
  margin-inline: auto;
}

.footer-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.3rem;
}

.footer-col-title {
  font-family: var(--font-mono);
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--color-muted);
  margin-bottom: 0.5rem;
}

.footer-col a {
  text-decoration: none;
  padding: 0.1rem 0;
}
.footer-col a:hover {
  color: var(--color-accent);
  font-style: italic;
}

.social-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.footer-monogram {
  width: 2.1rem;
  height: 2.1rem;
  display: inline-block;
  background: currentColor;
  -webkit-mask: url("/assets/images/monogram.svg") center / contain no-repeat;
  mask: url("/assets/images/monogram.svg") center / contain no-repeat;
  margin-bottom: 0.4rem;
}

.footer-note {
  font-style: italic;
  font-size: 0.92rem;
  color: var(--color-muted);
  max-width: 24rem;
  line-height: 1.6;
}

/* ---------- articles (post / page / book / app layouts) ---------- */

.article {
  max-width: 46rem;
  margin-inline: auto;
  padding-top: clamp(1.5rem, 4vw, 3rem);
}

.ticket-rip { display: block; margin-bottom: 1.2rem; }
.ticket-rip::before {
  content: "⁂";
  color: var(--color-accent);
  font-size: 1.2rem;
}

.article-header {
  border-bottom: var(--hairline);
  padding-bottom: clamp(1.4rem, 3vw, 2rem);
  margin-bottom: clamp(1.8rem, 4vw, 2.8rem);
}

.article-kicker {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--color-muted);
}

.article-title {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 7vw, 4.6rem);
  line-height: 1.02;
  letter-spacing: -0.015em;
  margin: 0.9rem 0 1rem;
  text-wrap: balance;
}

.article-description {
  font-style: italic;
  font-size: 1.2rem;
  color: var(--color-muted);
  max-width: 36rem;
  line-height: 1.5;
}

.article-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.3rem 0.9rem;
  margin-top: 1.1rem;
  font-family: var(--font-mono);
  font-size: 0.74rem;
  color: var(--color-muted);
}

.meta-item + .meta-item::before {
  content: "·";
  margin-right: 0.9rem;
  color: var(--color-border);
}

.article-body {
  font-size: 1.0625rem;
  line-height: 1.72;
}

.article-body > * + * { margin-top: 1.2em; }

.article-body > p:first-of-type::first-letter {
  font-family: var(--font-display);
  font-size: 3.4em;
  font-variation-settings: "wght" 600;
  float: left;
  line-height: 0.78;
  padding: 0.08em 0.12em 0 0;
}

/* prose headings only — contract components style their own */
.article-body h2:not([class]),
.article-body h3:not([class]),
.article-body h4:not([class]) {
  font-family: var(--font-display);
  font-style: italic;
  line-height: 1.15;
  margin-top: 2em;
}

.article-body h2:not([class]) { font-size: 1.8rem; }
.article-body h3:not([class]) { font-size: 1.4rem; }
.article-body h4:not([class]) { font-size: 1.15rem; }

/* prose links only — component anchors (index rows, cards) carry classes */
.article-body a:not([class]) {
  color: var(--color-accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.22em;
}
.article-body a:not([class]):hover { text-decoration-thickness: 2px; }

.article-body ul,
.article-body ol { padding-left: 1.4em; }

.article-body li + li { margin-top: 0.4em; }

.article-body strong { font-variation-settings: "wght" 640; }

/* ---------- content elements ---------- */

blockquote {
  position: relative;
  font-style: italic;
  padding-left: 1.8em;
  margin: 1.6em 0;
}

blockquote::before {
  content: "“";
  position: absolute;
  left: 0;
  top: -0.12em;
  font-family: var(--font-display);
  font-size: 2.6em;
  line-height: 1;
  color: var(--color-accent);
}

.pull-quote {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.4rem, 3vw, 1.9rem);
  line-height: 1.35;
  padding-left: 0;
  margin: 2.2rem 0;
}

.pull-quote::before { content: none; }

.pull-quote-mark {
  font-size: 1.9em;
  line-height: 0;
  vertical-align: -0.32em;
  color: var(--color-accent);
  margin-right: 0.05em;
}

pre {
  font-family: var(--font-mono);
  font-size: 0.84rem;
  line-height: 1.6;
  overflow-x: auto;
  padding: 1.2rem 0;
  border-top: var(--hairline);
  border-bottom: var(--hairline);
}

code { font-family: var(--font-mono); font-size: 0.92em; }

pre code { font-size: inherit; }

hr {
  border: none;
  margin: 2.6rem 0;
  text-align: center;
}

hr::before {
  content: "⁂";
  color: var(--color-muted);
  font-size: 1.05rem;
}

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

.reading-stats {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 1.4rem 3.2rem;
  padding: 0.6rem 0 1.8rem;
  border-bottom: var(--hairline);
}

.stat-item {
  display: flex;
  align-items: baseline;
  gap: 0.55rem;
}

.stat-value {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  font-variation-settings: "wght" 560;
  line-height: 1;
}

.stat-item[data-stat="favorites"] .stat-value { color: var(--color-accent); }

.stat-label {
  font-style: italic;
  font-size: 0.95rem;
  color: var(--color-muted);
}

.sort-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.5rem 1.3rem;
  margin: 1.7rem 0 0.6rem;
  font-family: var(--font-mono);
  font-size: 0.78rem;
}

.sort-controls > span {
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-size: 0.66rem;
  color: var(--color-muted);
}

.sort-link {
  color: var(--color-muted);
  text-decoration: none;
}
.sort-link:hover { color: var(--color-accent); }
.sort-link.active {
  color: var(--color-accent);
  text-decoration: underline;
  text-decoration-style: dotted;
  text-underline-offset: 0.35em;
}

.year-section { margin-top: 2.6rem; }

.year-heading {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(2.1rem, 5vw, 3.2rem);
  font-variation-settings: "wght" 240;
  line-height: 1;
  border-bottom: var(--hairline);
  padding-bottom: 0.6rem;
}

.book-list { margin-top: 0.6rem; }

/* catalogue rows with a hanging vermilion star for five-star reads */

.book-line {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.75rem 0 0.75rem 1.3rem;
  text-decoration: none;
}

.book-line-flag {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  line-height: 1;
}

.book-line[data-rating="5"] .book-line-flag::before {
  content: "✱";
  color: var(--color-accent);
  font-size: 0.85rem;
}

.book-line-cover {
  flex: 0 0 2.1rem;
  width: 2.1rem;
}

.book-line-cover img {
  display: block;
  width: 100%;
  height: auto;
  outline: 1px solid color-mix(in oklab, var(--color-fg) 18%, transparent);
  filter: grayscale(1);
  transition: filter 0.25s ease;
}

.book-line:hover .book-line-cover img { filter: none; }

.book-line-main {
  flex: 1;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.2rem 0.7rem;
  min-width: 0;
}

.book-line-title {
  font-family: var(--font-display);
  font-size: 1.12rem;
  font-variation-settings: "wght" 520;
  line-height: 1.3;
}

.book-line-author {
  font-style: italic;
  font-size: 0.92rem;
  color: var(--color-muted);
}

.book-line-rating {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--color-muted);
  white-space: nowrap;
}

.book-line:hover .book-line-title { color: var(--color-accent); }

/* ---------- writing page ---------- */

.post-index { margin-top: 0.5rem; }

.post-index-header { display: block; }

.post-index-row {
  position: relative;
  display: block;
  padding: 1.5rem 0 1.5rem clamp(3.6rem, 8vw, 5.5rem);
  border-top: var(--hairline);
  text-decoration: none;
}

.post-index-row:last-child { border-bottom: var(--hairline); }

.post-index-row::before {
  content: attr(data-index);
  position: absolute;
  left: 0;
  top: 1.3rem;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.9rem, 4vw, 2.8rem);
  font-variation-settings: "wght" 180;
  line-height: 1;
  color: var(--color-muted);
}

.post-index-date {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  color: var(--color-muted);
}

.post-index-title {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3.4vw, 2.2rem);
  font-variation-settings: "wght" 540;
  line-height: 1.15;
  margin-top: 0.25rem;
}

.post-index-desc {
  display: block;
  font-style: italic;
  color: var(--color-muted);
  margin-top: 0.4rem;
  max-width: 46rem;
  line-height: 1.5;
}

.post-index-meta {
  display: block;
  margin-top: 0.55rem;
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  color: var(--color-muted);
}

.post-index-topic { text-transform: lowercase; }

.post-index-topic + .post-index-topic::before {
  content: "· ";
  color: var(--color-border);
  margin-left: 0.4rem;
}

.post-index-row:hover .post-index-title { color: var(--color-accent); }
.post-index-row:hover::before { color: var(--color-accent); }

/* ---------- apps page ---------- */

.app-showcase { margin-top: 0.5rem; }

.app-showcase-card {
  display: block;
  padding: 1.7rem 0;
  border-top: var(--hairline);
  text-decoration: none;
}

.app-showcase-card:last-child { border-bottom: var(--hairline); }

.app-showcase-name {
  display: inline;
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 6vw, 3.8rem);
  font-variation-settings: "wght" 600, "SOFT" 0, "WONK" 1;
  line-height: 1.05;
  letter-spacing: -0.015em;
  margin-right: 1rem;
}

.app-showcase-detail {
  display: inline;
  font-style: italic;
  font-size: 1.08rem;
  color: var(--color-muted);
}

.app-showcase-card:hover .app-showcase-name {
  color: var(--color-accent);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 0.18em;
}

.philosophy-section { margin-top: clamp(3rem, 6vw, 4.5rem); }

.philosophy-heading {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.9rem, 4vw, 2.7rem);
  line-height: 1.1;
}

.philosophy-list {
  counter-reset: phi;
  margin-top: 1.2rem;
}

.philosophy-item {
  counter-increment: phi;
  position: relative;
  padding: 1.3rem 0 1.3rem clamp(2.8rem, 6vw, 4.2rem);
}

.philosophy-item::before {
  content: counter(phi, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: 1.55rem;
  font-family: var(--font-mono);
  font-size: 0.74rem;
  color: var(--color-accent);
}

.philosophy-title {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-variation-settings: "wght" 560;
}

.philosophy-desc {
  color: var(--color-muted);
  margin-top: 0.3rem;
  max-width: 44rem;
  line-height: 1.6;
}

/* ---------- archive page ---------- */

.archive-today {
  padding: 1.6rem 0 2.2rem;
  border-bottom: var(--hairline);
}

.archive-today-label {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.26em;
  color: var(--color-accent);
}

.archive-today-theme {
  display: block;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(2.7rem, 8vw, 5.8rem);
  line-height: 1;
  letter-spacing: -0.015em;
  margin: 0.7rem 0 0.9rem;
}

.archive-today-manifesto {
  font-style: italic;
  font-size: 1.12rem;
  max-width: 50rem;
  line-height: 1.55;
}

.archive-today-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.6rem 1.6rem;
  margin-top: 1.1rem;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--color-muted);
}

.archive-meta-item { letter-spacing: 0.06em; }

.archive-palette {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.archive-palette i {
  display: inline-block;
  width: 0.78rem;
  height: 0.78rem;
  border-radius: 50%;
  outline: 1px solid color-mix(in oklab, var(--color-fg) 22%, transparent);
}

.archive-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.6rem 1.5rem;
  margin: 1.9rem 0 0.5rem;
}

.archive-count {
  font-family: var(--font-mono);
  font-size: 0.74rem;
  color: var(--color-muted);
}

.archive-surprise {
  font-family: var(--font-mono);
  font-size: 0.82rem;
  background: none;
  border: none;
  padding: 0;
  color: var(--color-accent);
  cursor: pointer;
  text-decoration: underline;
  text-decoration-style: dotted;
  text-underline-offset: 0.35em;
}

.archive-surprise:hover {
  text-decoration-style: solid;
  font-style: italic;
}

/* plates: thumbnails sit in grayscale until hover inks them */

.archive-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 2.8rem 2rem;
  margin-top: 2rem;
}

.archive-card {
  display: block;
  text-decoration: none;
}

.archive-thumb {
  display: block;
  outline: 1px solid var(--color-border);
}

.archive-thumb img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 3 / 2;
  object-fit: cover;
  object-position: top;
  filter: grayscale(1);
  transition: filter 0.25s ease;
}

.archive-card:hover .archive-thumb img { filter: none; }

.archive-thumb-fallback {
  display: grid;
  place-items: center;
  aspect-ratio: 3 / 2;
  padding: 1rem;
  text-align: center;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.1rem;
  color: var(--color-muted);
}

.archive-card-info {
  display: block;
  padding-top: 0.75rem;
}

.archive-date {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.1em;
  color: var(--color-muted);
}

.archive-theme {
  display: block;
  font-family: var(--font-display);
  font-size: 1.22rem;
  font-variation-settings: "wght" 560;
  line-height: 1.2;
  margin-top: 0.2rem;
}

.archive-card:hover .archive-theme { color: var(--color-accent); }

.archive-desc {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  font-style: italic;
  font-size: 0.84rem;
  color: var(--color-muted);
  line-height: 1.5;
  margin-top: 0.3rem;
}

.archive-card--lost { opacity: 0.6; }

/* ---------- app layout features ---------- */

.feature-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.8rem 2.4rem;
  margin: 2rem 0;
}

.feature h3 {
  font-family: var(--font-display);
  font-style: normal;
  font-size: 1.2rem;
  font-variation-settings: "wght" 560;
  margin: 0 0 0.3rem;
}

.stack-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0 2rem;
  margin: 2rem 0;
}

.stack-card {
  display: block;
  padding: 1rem 0;
  border-top: var(--hairline);
  text-decoration: none;
}

.stack-card-title {
  display: block;
  font-family: var(--font-display);
  font-size: 1.12rem;
  font-variation-settings: "wght" 560;
}

.stack-card:hover .stack-card-title { color: var(--color-accent); }

.stack-card-count {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--color-muted);
  margin-top: 0.2rem;
}

/* ---------- now page ---------- */

.currently-reading { margin: 1.4rem 0; }

.reading-card {
  position: relative;
  padding: 0.55rem 0 0.55rem 1.5rem;
}

.reading-card::before {
  content: "—";
  position: absolute;
  left: 0;
  color: var(--color-accent);
}

.reading-card-title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.25rem;
}

.reading-card-author {
  font-size: 0.95rem;
  color: var(--color-muted);
  margin-left: 0.5rem;
}

.page-footer-note {
  font-family: var(--font-mono);
  font-size: 0.74rem;
  color: var(--color-muted);
  line-height: 1.8;
  margin-top: 2.4rem;
}

/* ---------- 404 ---------- */

.error-page { padding: clamp(2rem, 6vw, 5rem) 0; }

.error-code {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(7rem, 28vw, 21rem);
  line-height: 0.85;
  letter-spacing: -0.04em;
}

.error-page h2 {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  margin-top: 1.4rem;
}

.error-message {
  font-style: italic;
  color: var(--color-muted);
  max-width: 38rem;
  margin-top: 0.7rem;
}

.error-page a {
  display: inline-block;
  margin-top: 1.6rem;
  font-family: var(--font-mono);
  font-size: 0.85rem;
  color: var(--color-accent);
  text-decoration: underline;
  text-decoration-style: dotted;
  text-underline-offset: 0.35em;
}

.error-page a:hover { text-decoration-style: solid; }

/* ---------- mobile: the pocket edition ---------- */

@media (max-width: 760px) {
  .site-header {
    grid-template-columns: 1fr;
    align-items: start;
    gap: 1.8rem;
  }

  /* the nav becomes a full-width contents page */
  .nav-item a {
    font-size: 1.12rem;
    padding: 0.5rem 0;
  }

  .banner-note { display: none; }

  .home-section::before {
    font-size: clamp(5rem, 26vw, 8rem);
    top: 1rem;
  }

  .post-row { gap: 0.7rem; }

  .book-grid {
    padding-bottom: 0.5rem;
    margin-inline: calc(-1 * var(--gutter));
    padding-inline: var(--gutter);
  }

  .book-grid::after {
    left: var(--gutter);
    right: var(--gutter);
  }

  .book-card { width: 92px; }

  .book-line-rating { display: none; }

  .footer-grid {
    flex-direction: column;
    align-items: center;
  }
}

/* ---------- print: it is, after all, typography ---------- */

@media print {
  .site-banner, .site-nav, .site-footer { display: none; }
}
