  :root {
    --paper:      #eee6d3;
    --paper-2:    #e4dbc4;
    --ink:        #0b0b0b;
    --ink-soft:   #2b2b2b;
    --ink-faint:  #6b6558;
    --rule:       #0b0b0b;
    --rule-soft:  #b8ad93;
    --accent:     #d4ff3e;
    --accent-ink: #0b0b0b;
    --caution:    #e84a1e;
    --display:    "Fraunces", ui-serif, Georgia, serif;
    --sans:       "IBM Plex Sans", ui-sans-serif, system-ui, sans-serif;
    --mono:       "IBM Plex Mono", ui-monospace, "Menlo", monospace;
  }

  *, *::before, *::after { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; }

  body {
    font-family: var(--sans);
    font-weight: 400;
    background: var(--paper);
    color: var(--ink);
    line-height: 1.5;
    font-size: 15px;
    background-image:
      radial-gradient(ellipse 800px 400px at 20% 0%, rgba(212,255,62,0.05), transparent 60%),
      radial-gradient(ellipse 600px 300px at 90% 100%, rgba(232,74,30,0.03), transparent 70%),
      repeating-linear-gradient(90deg, rgba(11,11,11,0.015) 0 1px, transparent 1px 3px);
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
  }
  ::selection { background: var(--accent); color: var(--accent-ink); }

  .container { max-width: 1080px; margin: 0 auto; padding: 0 32px; overflow-x: hidden; }
  @media (max-width: 720px) { .container { padding: 0 18px; } }

  /* ======== MASTHEAD ======== */
  .masthead { padding: 32px 0 0; border-bottom: 3px solid var(--rule); }
  .masthead .logo {
    display: flex; justify-content: space-between; align-items: flex-end;
    gap: 24px; flex-wrap: wrap;
    padding: 22px 0 26px;
  }
  .masthead .logo a.wordmark { color: inherit; text-decoration: none; display: block; }
  .masthead .logo h1 {
    margin: 0;
    font-family: var(--display);
    font-weight: 400;
    font-size: clamp(36px, 6.2vw, 76px);
    line-height: 0.95;
    letter-spacing: -0.035em;
    font-variation-settings: "opsz" 144, "SOFT" 25;
  }
  .masthead nav.primary {
    display: flex; gap: 28px; align-items: baseline;
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em;
    text-transform: uppercase;
    padding-bottom: 12px;
  }
  .masthead nav.primary a {
    color: var(--ink-faint); text-decoration: none;
    padding: 4px 0; border-bottom: 1px solid transparent;
  }
  .masthead nav.primary a:hover { color: var(--ink); }
  .masthead nav.primary a.current {
    color: var(--ink); border-bottom-color: var(--ink);
  }

  .masthead .stats {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
    border-top: 1px solid var(--rule);
  }
  .masthead .stats .stat {
    padding: 12px 14px; border-right: 1px solid var(--rule-soft);
    display: flex; flex-direction: column; gap: 2px;
  }
  .masthead .stats .stat:last-child { border-right: 0; }
  .masthead .stats .stat .num {
    font-family: var(--display); font-weight: 400; font-size: 28px;
    letter-spacing: -0.02em; line-height: 1; font-feature-settings: "tnum";
  }
  .masthead .stats .stat .lbl {
    font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.16em;
    text-transform: uppercase; color: var(--ink-faint); margin-top: 4px;
  }
  @media (max-width: 720px) {
    .masthead .stats { grid-template-columns: repeat(2, 1fr); }
    .masthead .stats .stat:nth-child(2) { border-right: 0; }
    .masthead .stats .stat:nth-child(1), .masthead .stats .stat:nth-child(2) {
      border-bottom: 1px solid var(--rule-soft);
    }
  }

  /* ======== SEARCH ======== */
  .search-bar { border-bottom: 3px solid var(--rule); padding: 22px 0 18px; }
  .search-bar .lbl {
    font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em;
    text-transform: uppercase; color: var(--ink-faint); margin-bottom: 10px;
  }
  form.search {
    display: flex; gap: 0; margin: 0;
    border: 2px solid var(--rule); background: #fdfaf0;
    transition: border-color 0.12s ease;
  }
  form.search:focus-within { border-color: var(--caution); }
  form.search input[type=text] {
    flex: 1; padding: 14px 18px; font-size: 15px; font-family: var(--sans);
    font-weight: 400; font-style: normal;
    border: 0; background: transparent; color: var(--ink); outline: none;
  }
  form.search input[type=text]::placeholder {
    color: var(--ink-faint); font-style: normal;
  }
  form.search button {
    padding: 0 28px; font-size: 11px; font-family: var(--mono);
    font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase;
    border: 0; border-left: 2px solid var(--rule);
    background: var(--ink); color: var(--accent); cursor: pointer;
  }
  form.search button:hover { background: var(--accent); color: var(--ink); }

  /* ======== ADVANCED ======== */
  details.adv { margin: 14px 0 0; font-size: 14px; }
  details.adv summary {
    list-style: none; cursor: pointer;
    font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.16em;
    text-transform: uppercase; color: var(--ink-soft); padding: 6px 0;
    display: inline-block;
  }
  details.adv summary::-webkit-details-marker { display: none; }
  details.adv summary::before { content: "[ + ] "; color: var(--ink-faint); }
  details.adv[open] summary::before { content: "[ − ] "; color: var(--ink); }
  details.adv .grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 14px 18px;
    margin-top: 12px; padding: 20px;
    background: var(--paper-2);
    border: 2px solid var(--rule);
    border-radius: 0;
  }
  details.adv label { display: flex; flex-direction: column; gap: 6px;
    font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--ink-soft); }
  details.adv input {
    padding: 8px 10px; border: 1px solid var(--rule); font-size: 14px;
    font-family: var(--sans); background: #fdfaf0; color: var(--ink);
    letter-spacing: normal; text-transform: none;
  }
  details.adv input:focus { outline: 2px solid var(--accent); outline-offset: -2px; }
  details.adv .row { display: flex; gap: 10px; align-items: center;
    margin-top: 6px; grid-column: 1 / -1; }
  details.adv .row button {
    padding: 10px 22px; border: 2px solid var(--rule);
    background: var(--ink); color: var(--accent); cursor: pointer;
    font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em;
    text-transform: uppercase; font-weight: 500;
  }
  details.adv .row button:hover { background: var(--accent); color: var(--ink); }
  details.adv .row a {
    padding: 10px 12px; font-family: var(--mono); font-size: 10.5px;
    letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-faint);
    text-decoration: none; border-bottom: 1px solid transparent;
  }
  details.adv .row a:hover { color: var(--ink); border-bottom-color: var(--ink); }

  /* ======== YEAR NAV ======== */
  nav.years {
    border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
    padding: 10px 0; margin: 24px 0 18px;
    font-family: var(--mono); font-size: 12px;
    letter-spacing: 0.04em;
    display: flex; align-items: center; gap: 14px;
    overflow-x: auto; overflow-y: hidden;
    white-space: nowrap;
    /* slim custom scrollbar */
    scrollbar-width: thin;
    scrollbar-color: var(--ink-faint) transparent;
  }
  nav.years::-webkit-scrollbar { height: 4px; }
  nav.years::-webkit-scrollbar-track { background: transparent; }
  nav.years::-webkit-scrollbar-thumb { background: var(--ink-faint); border-radius: 2px; }
  nav.years::-webkit-scrollbar-thumb:hover { background: var(--ink); }

  nav.years .idx-label {
    font-weight: 700; letter-spacing: 0.18em; font-size: 10.5px;
    padding: 3px 8px; background: var(--ink); color: var(--accent);
    text-transform: uppercase; flex-shrink: 0;
  }
  nav.years a {
    color: var(--ink); text-decoration: none;
    display: inline-flex; align-items: baseline; gap: 5px;
    padding: 2px 6px;
    white-space: nowrap; flex-shrink: 0;
  }
  nav.years a .cnt { color: var(--ink-faint); font-size: 10.5px; }
  nav.years a .cnt::before { content: "("; }
  nav.years a .cnt::after  { content: ")"; }
  nav.years a:hover { background: var(--accent); }
  nav.years a:hover .cnt { color: var(--ink); }
  nav.years a.current { background: var(--ink); color: var(--accent); }
  nav.years a.current .cnt { color: var(--accent); opacity: 0.75; }

  /* ======== SECTION SUMMARY ======== */
  .summary-line {
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em;
    text-transform: uppercase; color: var(--ink-faint);
    margin: 18px 0 14px; display: flex; align-items: baseline; gap: 10px;
  }
  .summary-line b { color: var(--ink); font-weight: 500; }
  .summary-line::before {
    content: ""; flex: 0 0 22px; height: 1px; background: var(--ink);
    align-self: center;
  }

  /* ======== LISTING TABLE ======== */
  /* Columns size to content; the per-cell wrap rules keep any pathological
     long strings from widening the table past its container. */
  table.msgs {
    border-collapse: collapse; width: 100%; margin: 0 0 24px;
  }
  table.msgs thead { display: none; }
  table.msgs tr {
    border-bottom: 1px solid var(--rule-soft);
    transition: background 0.08s ease;
  }
  table.msgs tr:hover { background: rgba(212, 255, 62, 0.25); }
  table.msgs td {
    padding: 12px 14px; vertical-align: top; text-align: left;
    overflow-wrap: anywhere; word-break: break-word;
  }
  table.msgs td.date {
    white-space: nowrap; font-family: var(--mono); font-size: 11.5px;
    color: var(--ink-soft); letter-spacing: 0.04em;
  }
  table.msgs td.date .d { display: inline; }
  table.msgs td.date .t { display: inline; color: var(--ink-faint); margin-left: 4px; }
  table.msgs td.from {
    font-family: var(--sans); font-size: 13px;
    color: var(--ink-soft);
    max-width: 260px;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  }
  /* Stack name over email so a long address wraps cleanly instead of
     squeezing against the next column. */
  table.msgs td.from a {
    color: var(--ink); text-decoration: none; display: block;
    overflow: hidden; text-overflow: ellipsis;
    border-bottom: 1px solid transparent;
  }
  table.msgs td.from a:hover { color: var(--ink); background: var(--accent); }
  table.msgs td.from .email {
    color: var(--ink-faint); font-family: var(--mono); font-size: 10.5px;
    margin-left: 0; margin-top: 2px;
  }
  table.msgs td.subj a {
    font-family: var(--display); font-weight: 400; font-size: 17px;
    font-variation-settings: "opsz" 32, "SOFT" 30;
    color: var(--ink); text-decoration: none;
    letter-spacing: -0.005em; line-height: 1.3;
  }
  table.msgs td.subj a:hover { text-decoration: underline;
    text-decoration-thickness: 2px; text-underline-offset: 3px; }
  @media (max-width: 720px) {
    table.msgs td { padding: 10px 8px; }
    table.msgs td.from { max-width: 160px; }
    table.msgs td.subj a { font-size: 15px; }
  }
  .snippet {
    color: var(--ink-faint); font-family: var(--sans); font-size: 13px;
    margin-top: 4px; line-height: 1.4;
    overflow-wrap: anywhere; word-break: break-word;
  }
  .snippet b {
    background: var(--accent); color: var(--accent-ink);
    font-weight: 500; padding: 0 2px;
  }

  /* ======== PAGER ======== */
  .pager { margin: 28px 0; text-align: center;
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em;
    text-transform: uppercase; }
  .pager a, .pager span { margin: 0 6px; padding: 4px 8px; color: var(--ink-soft);
    text-decoration: none; }
  .pager a:hover { background: var(--ink); color: var(--accent); }
  .pager .cur { background: var(--ink); color: var(--accent); font-weight: 500; }

  /* ======== CRUMBS ======== */
  .crumbs {
    font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--ink-faint);
    margin: 16px 0 14px;
  }
  .crumbs a { color: var(--ink); text-decoration: none;
    border-bottom: 1px solid var(--ink); padding-bottom: 1px; }
  .crumbs a:hover { background: var(--accent); }

  /* ======== MESSAGE META (single-msg view) ======== */
  .msg-meta {
    background: var(--paper-2); padding: 18px 22px;
    border: 2px solid var(--rule);
    margin: 16px 0 24px; font-size: 14px;
    display: grid; grid-template-columns: max-content 1fr; gap: 6px 18px;
  }
  .msg-meta dt {
    font-family: var(--mono); font-weight: 500; color: var(--ink);
    text-align: right; margin: 0; font-size: 10.5px;
    letter-spacing: 0.14em; text-transform: uppercase; padding-top: 3px;
  }
  .msg-meta dd { margin: 0; word-break: break-word; overflow-wrap: anywhere;
    font-family: var(--sans); color: var(--ink-soft); }
  .msg-meta dd a { color: var(--ink); text-decoration: none;
    border-bottom: 1px solid var(--rule-soft); }
  .msg-meta dd a:hover { background: var(--accent); border-bottom-color: var(--ink); }
  .msg-meta dd code, .msg-meta dd .email {
    font-family: var(--mono); font-size: 11.5px; color: var(--ink-faint);
    background: none; border: none; padding: 0;
  }
  .msg-meta dd code {
    background: var(--paper); padding: 1px 5px;
    border: 1px dashed var(--rule-soft);
    /* Long Message-IDs can exceed a grid cell — let the cell clip & the code
       scroll horizontally rather than pushing the whole layout wide. */
    display: inline-block; max-width: 100%;
    overflow-x: auto; vertical-align: middle;
    white-space: nowrap;
  }
  .msg-meta dd { min-width: 0; }  /* lets inline-block children honor max-width */

  /* ======== MESSAGE BODY ======== */
  .msg-body {
    white-space: pre-wrap; word-wrap: break-word;
    font-family: var(--mono); font-size: 13.5px; line-height: 1.65;
    background: #fdfaf0; padding: 22px 24px;
    border: 2px solid var(--rule);
    color: var(--ink); overflow-wrap: anywhere;
  }
  .msg-body.body-empty {
    color: var(--ink-faint); font-style: italic;
    border-style: dashed;
  }
  .msg-body a { color: var(--ink); text-decoration: underline;
    text-decoration-color: var(--accent); text-decoration-thickness: 2px;
    text-underline-offset: 2px; }
  .msg-body a:hover { background: var(--accent); }

  .msg-body-html {
    background: #fdfaf0; padding: 22px 26px;
    border: 2px solid var(--rule);
    font-family: var(--sans); font-size: 15px; line-height: 1.6;
    overflow-wrap: anywhere; color: var(--ink);
  }
  .msg-body-html img { max-width: 100%; height: auto; border: 1px solid var(--rule-soft); }
  .msg-body-html a { color: var(--ink); text-decoration: underline;
    text-decoration-color: var(--accent); text-decoration-thickness: 2px; }
  .msg-body-html a:hover { background: var(--accent); }
  .msg-body-html blockquote {
    border-left: 3px solid var(--ink); margin: 0.6em 0;
    padding: 0.3em 1em; color: var(--ink-soft); background: var(--paper);
  }
  .msg-body-html pre {
    white-space: pre-wrap; background: var(--paper); padding: 10px 14px;
    border-left: 3px solid var(--ink); overflow-x: auto;
    font-family: var(--mono); font-size: 13px;
  }
  .msg-body-html table { border-collapse: collapse; }
  .msg-body-html h1, .msg-body-html h2, .msg-body-html h3 { font-family: var(--display); }

  /* ======== QUOTE COLLAPSIBLES ======== */
  details.quote { display: block; margin: 6px 0; }
  details.quote > summary {
    cursor: pointer; color: var(--ink-faint);
    font-family: var(--mono); font-size: 11px;
    letter-spacing: 0.08em; text-transform: uppercase;
    padding: 4px 0 4px 4px; list-style: none;
    border-left: 3px solid var(--rule-soft);
    padding-left: 10px;
  }
  details.quote > summary:hover { color: var(--ink); border-left-color: var(--ink); }
  details.quote > summary::-webkit-details-marker { display: none; }
  details.quote > summary::before { content: "▸  "; font-size: 11px; color: var(--ink); }
  details.quote[open] > summary::before { content: "▾  "; }
  details.quote > summary .qp {
    color: var(--ink-soft); font-family: var(--mono); font-weight: 400;
    letter-spacing: 0; text-transform: none; font-style: italic;
    margin-left: 6px;
  }
  details.quote > .quote-body {
    display: block; color: var(--ink-faint);
    border-left: 3px solid var(--ink); padding-left: 14px;
    margin: 6px 0 6px 0;
  }
  .msg-body-html details.quote > .quote-body { white-space: normal; }

  /* ======== BODY MODE BANNER ======== */
  .body-mode {
    font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--ink-faint);
    margin: 0 0 10px;
  }
  .body-mode a { color: var(--ink); text-decoration: none;
    border-bottom: 1px solid var(--ink); margin-left: 8px; padding-bottom: 1px; }

  /* ======== THREAD PAGE ======== */
  .thread-title {
    font-family: var(--display); font-weight: 300;
    font-variation-settings: "opsz" 144, "SOFT" 40;
    font-size: clamp(28px, 5vw, 44px); line-height: 1.05;
    letter-spacing: -0.02em;
    margin: 18px 0 6px 0; color: var(--ink);
  }
  .thread-title em { font-style: italic; color: var(--ink-soft); }
  .thread-meta {
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em;
    text-transform: uppercase; color: var(--ink-faint);
    margin: 4px 0 14px;
  }
  .thread-meta a { color: var(--ink); text-decoration: none;
    border-bottom: 1px solid var(--ink); }
  .thread-meta a:hover { background: var(--accent); }
  .thread-meta.merged { color: var(--caution); letter-spacing: 0.08em; }
  .thread-meta.merged span { text-transform: none; letter-spacing: 0; font-style: italic; }

  .thread-controls {
    font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em;
    text-transform: uppercase; margin: 14px 0 10px; color: var(--ink-faint);
    display: flex; gap: 18px; align-items: baseline; flex-wrap: wrap;
  }
  .thread-controls a {
    color: var(--ink); text-decoration: none; padding: 2px 6px;
    border-bottom: 1px solid transparent;
  }
  .thread-controls a:hover { background: var(--accent); }
  .thread-controls a.current {
    background: var(--ink); color: var(--accent);
  }
  .thread-controls .hint {
    margin-left: auto; color: var(--ink-faint); font-style: italic;
    text-transform: none; letter-spacing: 0; font-size: 11px;
  }

  .thread-toc {
    margin: 14px 0 26px; padding: 14px 18px;
    background: var(--paper-2);
    border: 2px solid var(--rule);
    font-size: 13px; max-height: 300px; overflow-y: auto;
  }
  .thread-toc::before {
    display: block; content: "CONTENTS"; font-family: var(--mono);
    font-size: 10px; letter-spacing: 0.18em; font-weight: 500;
    color: var(--ink-faint); margin-bottom: 8px;
    padding-bottom: 6px; border-bottom: 1px solid var(--rule-soft);
  }
  .thread-toc .entry {
    padding: 3px 0; display: flex; gap: 10px; align-items: baseline;
  }
  .thread-toc .entry:hover { background: rgba(212,255,62,0.3); }
  .thread-toc .entry .tee {
    color: var(--ink-faint); font-family: var(--mono);
    white-space: pre; user-select: none; font-size: 12px;
  }
  .thread-toc .entry .date {
    font-family: var(--mono); color: var(--ink-faint);
    font-size: 11px; white-space: nowrap; flex-shrink: 0;
  }
  .thread-toc .entry .from {
    color: var(--ink-soft); font-size: 12.5px; max-width: 200px;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    flex-shrink: 0;
  }
  .thread-toc .entry a.goto {
    color: var(--ink); text-decoration: none;
    font-family: var(--display); font-size: 13.5px;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1;
  }
  .thread-toc .entry a.goto:hover { text-decoration: underline; }
  .thread-toc .entry.active a.goto {
    font-weight: 600; color: var(--ink);
  }
  .thread-toc .entry.active::before {
    content: "▶"; color: var(--caution); margin-right: 4px;
  }

  /* ======== THREAD MESSAGES — numbered correspondence folios ======== */
  .thread-msgs { margin: 20px 0 40px; counter-reset: folio; }
  details.thread-msg {
    counter-increment: folio;
    margin: 0 0 22px; background: #fdfaf0;
    border: 2px solid var(--rule);
    position: relative; scroll-margin-top: 20px;
  }
  details.thread-msg.active {
    border-color: var(--caution);
    outline: 1px solid var(--caution);
    outline-offset: 1px;
  }
  details.thread-msg::before {
    content: "№ " counter(folio);
    position: absolute; top: -1px; right: -1px;
    font-family: var(--mono); font-size: 10.5px; font-weight: 500;
    letter-spacing: 0.14em; padding: 4px 10px;
    background: var(--ink); color: var(--accent);
    z-index: 2;
  }
  details.thread-msg.active::before {
    background: var(--caution); color: var(--paper);
  }
  details.thread-msg > summary {
    list-style: none; cursor: pointer;
    padding: 0; background: transparent;
    border-bottom: 1px solid var(--rule);
    transition: background 0.1s ease;
  }
  details.thread-msg > summary::-webkit-details-marker { display: none; }
  details.thread-msg > summary:hover { background: rgba(212, 255, 62, 0.18); }
  details.thread-msg[open] > summary { border-bottom-style: dashed; border-bottom-color: var(--rule-soft); }
  details.thread-msg > summary .hdr-collapsed {
    padding: 12px 18px 12px 14px; display: flex; gap: 14px;
    align-items: baseline; font-size: 13px;
  }
  details.thread-msg > summary .hdr-collapsed .caret {
    color: var(--ink); font-family: var(--mono); width: 12px;
    flex-shrink: 0; font-size: 10px;
  }
  details.thread-msg > summary .hdr-collapsed .date {
    font-family: var(--mono); color: var(--ink-faint);
    font-size: 11.5px; white-space: nowrap; flex-shrink: 0;
    letter-spacing: 0.02em;
  }
  details.thread-msg > summary .hdr-collapsed .from {
    color: var(--ink); max-width: 240px;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    flex-shrink: 0; font-weight: 500;
  }
  details.thread-msg > summary .hdr-collapsed .sub {
    color: var(--ink-faint); font-family: var(--display); font-style: italic;
    font-size: 14px; font-variation-settings: "opsz" 32;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1;
  }
  details.thread-msg[open] > summary .hdr-collapsed .caret::before { content: "▾"; }
  details.thread-msg:not([open]) > summary .hdr-collapsed .caret::before { content: "▸"; }

  details.thread-msg .hdr {
    padding: 14px 20px 8px; font-size: 13.5px;
    display: grid; grid-template-columns: max-content 1fr; gap: 3px 14px;
    background: var(--paper-2);
  }
  details.thread-msg .hdr dt {
    font-family: var(--mono); font-weight: 500; color: var(--ink);
    text-align: right; margin: 0; font-size: 9.5px;
    letter-spacing: 0.16em; text-transform: uppercase; padding-top: 4px;
  }
  details.thread-msg .hdr dd { margin: 0; word-break: break-word;
    overflow-wrap: anywhere; color: var(--ink-soft);
    font-family: var(--sans); font-size: 13px; }
  details.thread-msg .hdr dd a { color: var(--ink); text-decoration: none;
    border-bottom: 1px solid var(--rule-soft); }
  details.thread-msg .hdr dd a:hover { background: var(--accent); }
  details.thread-msg .hdr dd { min-width: 0; }
  details.thread-msg .hdr dd code,
  details.thread-msg .hdr .tools code.msgid {
    font-family: var(--mono); font-size: 11px; color: var(--ink-faint);
    background: var(--paper); padding: 1px 5px;
    border: 1px dashed var(--rule-soft);
    display: inline-block; max-width: 100%;
    overflow-x: auto; vertical-align: middle;
    white-space: nowrap; letter-spacing: 0;
  }
  details.thread-msg .hdr .tools {
    grid-column: 1 / -1; font-family: var(--mono); font-size: 10px;
    letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-faint);
    margin-top: 6px; padding-top: 8px; border-top: 1px dashed var(--rule-soft);
    min-width: 0; overflow: hidden;
  }
  details.thread-msg .hdr .tools a { color: var(--ink); text-decoration: none;
    border-bottom: 1px solid var(--ink); margin-right: 14px; }
  details.thread-msg .body {
    padding: 18px 22px 22px;
  }
  details.thread-msg .body .msg-body,
  details.thread-msg .body .msg-body-html {
    border: none; box-shadow: none; padding: 0; background: transparent; margin: 0;
  }

  /* ======== ABOUT PAGE ======== */
  .about { margin: 40px 0 60px; }
  .about .about-lede {
    font-family: var(--display); font-weight: 300;
    font-variation-settings: "opsz" 72, "SOFT" 30;
    font-size: clamp(18px, 2.4vw, 24px); line-height: 1.4;
    letter-spacing: -0.005em;
    color: var(--ink-soft); margin: 0 0 40px 0;
    max-width: 65ch;
  }
  .about .about-lede em { font-style: italic; color: var(--ink); }
  .about .about-lede a { color: var(--ink); text-decoration: underline;
    text-decoration-color: var(--accent); text-decoration-thickness: 2px;
    text-underline-offset: 3px; }
  .about .about-grid {
    display: grid; grid-template-columns: 1fr 1fr;
    border-top: 1px solid var(--rule);
    margin-bottom: 20px;
  }
  .about .about-grid > div {
    padding: 22px 0; border-bottom: 1px solid var(--rule-soft);
  }
  .about .about-grid > div:nth-child(odd)  { padding-right: 24px; border-right: 1px solid var(--rule-soft); }
  .about .about-grid > div:nth-child(even) { padding-left: 24px; }
  .about .about-grid h3 {
    margin: 0 0 10px; font-family: var(--mono); font-size: 10.5px;
    letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-faint);
    font-weight: 500;
  }
  .about .about-grid p {
    margin: 0; font-size: 14.5px; line-height: 1.6; color: var(--ink-soft);
    max-width: 48ch;
  }
  .about .about-grid p em { font-family: var(--display); font-style: italic;
    color: var(--ink); font-weight: 400; }
  .about .about-grid p code { font-family: var(--mono); font-size: 12.5px;
    background: var(--paper-2); padding: 1px 5px;
    border: 1px dashed var(--rule-soft); }
  .about .about-grid p a { color: var(--ink); text-decoration: underline;
    text-decoration-color: var(--accent); text-decoration-thickness: 2px;
    text-underline-offset: 2px; }
  @media (max-width: 720px) {
    .about .about-grid { grid-template-columns: 1fr; }
    .about .about-grid > div:nth-child(odd)  { padding-right: 0; border-right: 0; }
    .about .about-grid > div:nth-child(even) { padding-left: 0; }
  }

  /* ======== FOOTER ======== */
  footer {
    margin: 60px 0 0; padding: 22px 0 40px;
    border-top: 3px solid var(--rule);
    font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--ink-faint);
    display: flex; justify-content: space-between; align-items: baseline;
    flex-wrap: wrap; gap: 16px;
  }
  footer a { color: var(--ink); text-decoration: none;
    border-bottom: 1px solid var(--ink); }
  footer a:hover { background: var(--accent); }
  footer .count { color: var(--ink); }
