  /* ── story view ────────────────────────────── */
  #view-story {
    padding: 180px 40px 160px 40px;
    max-width: 820px;
    margin: 0 auto;
    width: 100%;
  }
  .story-period {
    font-style: normal;
    font-weight: 600;
    color: var(--ink);
  }
  .story-head {
    text-align: center;
    margin-bottom: 80px;
    padding-bottom: 32px;
    border-bottom: 1px solid var(--line);
  }
  .story-eyebrow {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin-bottom: 16px;
  }
  .story-title {
    font-family: var(--serif);
    font-weight: 500;
    font-size: 56px;
    line-height: 1.02;
    letter-spacing: -.02em;
    margin: 0 0 18px 0;
  }
  .story-title em {
    color: var(--accent);
    font-weight: 500;
    font-style: normal;
  }
  .story-sub {
    font-family: var(--serif);
    font-size: 17px;
    line-height: 1.5;
    color: var(--ink-soft);
    max-width: 540px;
    margin: 0 auto;
  }
  .story-para {
    font-family: var(--serif);
    font-size: 22px;
    line-height: 1.55;
    letter-spacing: -.005em;
    color: var(--ink);
    margin: 0 0 36px 0;
    text-wrap: pretty;
  }
  .story-para:first-of-type::first-letter {
    font-family: var(--serif);
    font-size: 64px;
    font-weight: 500;
    line-height: .85;
    float: left;
    padding: 8px 12px 0 0;
    color: var(--accent);
  }
  .story-project {
    color: var(--ink);
    text-decoration: underline;
    text-decoration-color: var(--accent);
    text-decoration-thickness: 1.5px;
    text-underline-offset: 4px;
    cursor: pointer;
    font-weight: 500;
    transition: color .2s;
  }
  .story-project:hover,
  .story-project:focus-visible {
    color: var(--accent);
    outline: none;
  }
  .chapter { margin-bottom: 88px; }
  .chapter-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 24px;
    padding-bottom: 14px;
    margin-bottom: 28px;
    border-bottom: 1px solid var(--line);
  }
  .chapter-mark {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin-bottom: 6px;
  }
  .chapter-title {
    font-family: var(--serif);
    font-weight: 500;
    font-size: 32px;
    line-height: 1.05;
    letter-spacing: -.01em;
    margin: 0;
  }
  .chapter-years {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--ink-mute);
    white-space: nowrap;
  }
  .chapter-intro {
    font-family: var(--serif);
    font-size: 21px;
    line-height: 1.5;
    letter-spacing: -.005em;
    color: var(--ink);
    margin: 0 0 36px 0;
    text-wrap: pretty;
  }
  .chapter:first-of-type .chapter-intro::first-letter {
    font-family: var(--serif);
    font-size: 62px;
    font-weight: 500;
    line-height: .85;
    float: left;
    padding: 8px 12px 0 0;
    color: var(--accent);
  }
  .chapter-project {
    display: grid;
    grid-template-columns: 72px 1fr auto;
    gap: 24px;
    padding: 20px 0;
    border-top: 1px solid var(--line);
    cursor: pointer;
    transition: padding-left .25s, background .25s;
    align-items: baseline;
  }
  .chapter-project:hover {
    padding-left: 12px;
  }
  .chapter-projects .chapter-project:last-child {
    border-bottom: 1px solid var(--line);
  }
  .chapter-project-year {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: .12em;
    color: var(--ink-mute);
  }
  .chapter-project-body { min-width: 0; }
  .chapter-project-title {
    font-family: var(--serif);
    font-size: 22px;
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: -.005em;
    color: var(--ink);
    margin-bottom: 6px;
    transition: color .2s;
  }
  .chapter-project:hover .chapter-project-title { color: var(--accent); }
  .chapter-project-summary {
    font-family: var(--serif);
    font-size: 15px;
    line-height: 1.55;
    color: var(--ink-soft);
    text-wrap: pretty;
  }
  .chapter-project-kind {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--ink-mute);
    white-space: nowrap;
    padding-top: 4px;
  }
  .story-end {
    margin-top: 32px;
    padding: 40px 0 0 0;
    border-top: 1px solid var(--line);
    text-align: center;
    font-family: var(--serif);
    font-size: 22px;
    line-height: 1.45;
    color: var(--ink);
    letter-spacing: -.005em;
  }
  .story-end::before {
    content: "§";
    display: block;
    font-family: var(--serif);
    font-size: 18px;
    color: var(--accent);
    margin-bottom: 14px;
  }

  @media (max-width: 820px) {
    .stack-grid { grid-template-columns: 1fr; gap: 48px; }
    .stack-title { font-size: 34px; }
    .story-title { font-size: 40px; }
    .chapter-title { font-size: 26px; }
    .chapter-project { grid-template-columns: 56px 1fr; }
    .chapter-project-kind { display: none; }
    .folders-grid { grid-template-columns: repeat(2, 1fr); gap: 40px 24px; }
    .folder-files-list { grid-template-columns: repeat(2, 1fr); gap: 28px 18px; }
    /* Open folder header on mobile: drop the "Folders" label so back is just
       a chevron, and let the title-block sit centered between the back and
       next/prev nav. */
    .folder-files-back { padding: 6px; gap: 0; }
    .folder-files-back span { display: none; }
    .folder-files-head { gap: 8px; }
  }
  @media (max-width: 540px) {
    .folders-grid { grid-template-columns: 1fr; gap: 36px; }
  }

