:root {
  --ground: #f6f6f2;
  --card: #ffffff;
  --ink: #21242a;
  --ink-soft: #5b6069;
  --ink-faint: #9aa0a8;
  --line: #e2e2da;
  --trope: #b0416b;
  --scheme: #3a5fc0;
  --syntax: #3d7a4f;
  --shadow: 0 10px 34px rgba(30, 34, 44, .14);
  --serif: 'Charter', 'Iowan Old Style', 'Palatino Linotype', 'Book Antiqua', Georgia, serif;
  --sans: 'Segoe UI', system-ui, -apple-system, 'Helvetica Neue', sans-serif;
}
@media (prefers-color-scheme: dark) {
  :root {
    --ground: #17191d; --card: #1f2227; --ink: #e9e7e1; --ink-soft: #a8adb5;
    --ink-faint: #6d7279; --line: #32363d;
    --trope: #e07a9d; --scheme: #7f9cf0; --syntax: #6cbd82;
    --shadow: 0 12px 38px rgba(0, 0, 0, .5);
  }
}
:root[data-theme="dark"] {
  --ground: #17191d; --card: #1f2227; --ink: #e9e7e1; --ink-soft: #a8adb5;
  --ink-faint: #6d7279; --line: #32363d;
  --trope: #e07a9d; --scheme: #7f9cf0; --syntax: #6cbd82;
  --shadow: 0 12px 38px rgba(0, 0, 0, .5);
}
:root[data-theme="light"] {
  --ground: #f6f6f2; --card: #ffffff; --ink: #21242a; --ink-soft: #5b6069;
  --ink-faint: #9aa0a8; --line: #e2e2da;
  --trope: #b0416b; --scheme: #3a5fc0; --syntax: #3d7a4f;
  --shadow: 0 10px 34px rgba(30, 34, 44, .14);
}

* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--ground);
  color: var(--ink);
  font-family: var(--sans);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
main { max-width: 880px; margin: 0 auto; padding: 1.6rem 1.4rem 5rem; }
a { color: inherit; }

.crumbs {
  max-width: 880px; margin: 0 auto; padding: 1.1rem 1.4rem 0;
  display: flex; justify-content: space-between; align-items: baseline;
  font-size: .82rem; color: var(--ink-soft);
}
.crumbs a { text-decoration: none; }
.crumbs a:hover { text-decoration: underline; }
.crumb-title { font-family: var(--serif); font-style: italic; color: var(--ink-faint); }

.eyebrow {
  font-size: .72rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--ink-faint); margin: 1rem 0 .5rem;
}
h1 {
  font-family: var(--serif); font-size: clamp(1.8rem, 4.2vw, 2.5rem);
  font-weight: 600; letter-spacing: -.01em; margin: 0 0 .35rem; text-wrap: balance;
}
.byline { color: var(--ink-soft); margin: 0 0 1.6rem; font-size: .95rem; }
.lede { color: var(--ink-soft); max-width: 62ch; margin: 0 0 2.2rem; }
.lede b { color: var(--ink); font-weight: 600; }
h2 { font-family: var(--serif); font-size: 1.25rem; font-weight: 600; margin: 2.4rem 0 .4rem; }

/* legend */
.legend { display: flex; flex-wrap: wrap; gap: .5rem; margin: 0 0 1rem; align-items: center; }
.chip {
  display: inline-flex; align-items: center; gap: .45em;
  font: inherit; font-size: .8rem; font-weight: 600; color: var(--ink-soft);
  background: var(--card); border: 1px solid var(--line); border-radius: 999px;
  padding: .3em .85em; cursor: pointer; transition: opacity .15s, border-color .15s;
}
.dot { width: .62em; height: .62em; border-radius: 50%; background: var(--c); flex: none; }
.chip[aria-pressed="false"] { opacity: .38; }
.chip[aria-pressed="false"] .dot { background: var(--ink-faint); }
.chip:hover { border-color: var(--c); }
.chip:focus-visible, .seg:focus-visible, .dev:focus-visible, .entry:focus-visible {
  outline: 2px solid var(--scheme); outline-offset: 2px;
}
.legend-hint { font-size: .76rem; color: var(--ink-faint); }

/* passage */
.passage-card {
  background: var(--card); border: 1px solid var(--line); border-radius: 10px;
  padding: clamp(1.3rem, 3.5vw, 2.3rem) clamp(1.1rem, 4vw, 2.6rem);
}
.passage {
  font-family: var(--serif);
  font-size: clamp(1.15rem, 2.2vw, 1.5rem);
  line-height: 2.3;
  max-width: 62ch;
}
.pline { display: flex; align-items: baseline; }
.ln {
  flex: none; width: 2em; font-size: .62em; color: var(--ink-faint);
  font-family: var(--sans); user-select: none; text-align: right; padding-right: 1.1em;
  font-variant-numeric: tabular-nums;
}
.ltext { flex: 1; min-width: 0; }
.seg {
  -webkit-box-decoration-break: clone; box-decoration-break: clone;
  border-radius: 2px; transition: color .18s, background-color .18s;
}
.seg.tagged { cursor: pointer; }
.passage.dimmed .seg:not(.lit) { color: var(--ink-faint); }
.thesis, .occasion {
  font-size: .84rem; color: var(--ink-soft);
  border-top: 1px solid var(--line); margin-top: 1.4rem; padding-top: .9rem; max-width: 64ch;
}
.thesis b, .occasion b {
  font-size: .66rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--ink-faint); display: block; margin-bottom: .15rem; font-weight: 600;
}
.occasion { border-top: none; margin-top: .9rem; padding-top: 0; display: grid; gap: .7rem; }

/* popover */
#pop {
  position: absolute; z-index: 20; width: min(400px, calc(100vw - 28px));
  background: var(--card); border: 1px solid var(--line); border-radius: 10px;
  box-shadow: var(--shadow); padding: .3rem 0; display: none;
  max-height: min(430px, 60vh); overflow-y: auto;
}
#pop.show { display: block; }
.pop-dev { padding: .8rem 1.05rem .85rem; }
.pop-dev + .pop-dev { border-top: 1px solid var(--line); }
.pop-head { display: flex; align-items: baseline; gap: .5em; flex-wrap: wrap; margin-bottom: .1rem; }
.pop-head .dot { align-self: center; }
.pop-head b { font-size: .98rem; }
.pron { font-size: .73rem; color: var(--ink-faint); }
.fam-tag {
  font-size: .62rem; letter-spacing: .1em; text-transform: uppercase;
  color: var(--c); margin-left: auto; white-space: nowrap;
}
.lines-tag { font-size: .7rem; color: var(--ink-faint); white-space: nowrap; }
.pop-dev p { margin: .35rem 0 0; font-size: .82rem; color: var(--ink-soft); }
.pop-dev p b, .pop-dev p strong { color: var(--ink); font-weight: 600; }
.pop-def { font-style: italic; color: var(--ink); }
.pop-plain { }
.pop-ex {
  border-left: 2px solid var(--c); padding-left: .7em; margin-top: .45rem !important;
  font-family: var(--serif);
}
.pop-dev ul { margin: .35rem 0 0; padding-left: 1.2em; font-size: .82rem; color: var(--ink-soft); }
.pop-pin {
  font-size: .7rem; color: var(--ink-faint); text-align: center;
  padding: .4rem 1rem .5rem; border-top: 1px solid var(--line);
}

/* device index */
.index-hint { font-size: .82rem; color: var(--ink-faint); margin: 0 0 .8rem; }
.fam-head {
  display: flex; align-items: center; gap: .5em;
  font-size: .72rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--ink-soft); margin: 1.3rem 0 .5rem; font-weight: 600;
}
.dev-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(235px, 1fr)); gap: .6rem; }
.dev {
  background: var(--card); border: 1px solid var(--line); border-left: 3px solid var(--c);
  border-radius: 8px; padding: .6rem .8rem; cursor: pointer; transition: border-color .15s;
}
.dev:hover { border-color: var(--c); }
.dev.off { opacity: .35; pointer-events: none; }
.dev b { font-size: .86rem; display: block; }
.dev .pron { display: block; margin: .05rem 0 .2rem; }
.dev p {
  margin: 0; font-size: .76rem; color: var(--ink-soft);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.nospan { font-size: .66rem; color: var(--ink-faint); font-style: italic; }

/* dossier panels */
.panel {
  background: var(--card); border: 1px solid var(--line); border-radius: 8px;
  margin-bottom: .5rem; overflow: hidden;
}
.panel summary {
  cursor: pointer; padding: .65rem .9rem; font-weight: 600; font-size: .88rem;
  display: flex; align-items: center; gap: .7em; list-style: none;
}
.panel summary::-webkit-details-marker { display: none; }
.panel summary::after { content: '+'; margin-left: auto; color: var(--ink-faint); font-weight: 400; }
.panel[open] summary::after { content: '–'; }
.pnum {
  flex: none; width: 1.6em; height: 1.6em; border-radius: 50%;
  border: 1px solid var(--line); color: var(--ink-faint);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: .72rem; font-variant-numeric: tabular-nums;
}
.panel-body { padding: .2rem 1rem 1rem; font-size: .86rem; color: var(--ink-soft); }
.panel-body h4 { color: var(--ink); margin: 1rem 0 .3rem; font-size: .82rem; }
.panel-body p { margin: .5rem 0 0; }
.panel-body b { color: var(--ink); }
.panel-body ul, .panel-body ol { margin: .4rem 0 0; padding-left: 1.3em; }
.panel-body blockquote {
  margin: .5rem 0 0; padding-left: .8em; border-left: 2px solid var(--line);
  font-family: var(--serif); font-style: italic;
}

/* pager */
.pager { display: flex; justify-content: space-between; gap: 1rem; margin-top: 2.6rem; }
.pnav {
  display: flex; gap: .6em; align-items: baseline; text-decoration: none;
  font-size: .82rem; color: var(--ink-soft); max-width: 46%;
}
.pnav:hover { color: var(--ink); }
.pnav.next { text-align: right; margin-left: auto; }
.pnav-dir { color: var(--ink-faint); }

/* ---------- index page ---------- */
.home h1 { font-size: clamp(2rem, 5vw, 3rem); }
.period h2 {
  font-size: .78rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--ink-faint); font-family: var(--sans); font-weight: 600;
  border-bottom: 1px solid var(--line); padding-bottom: .35rem; margin: 2.2rem 0 .6rem;
}
.entry-list { display: flex; flex-direction: column; gap: .4rem; }
.entry {
  display: flex; gap: 1rem; align-items: baseline; text-decoration: none;
  background: var(--card); border: 1px solid var(--line); border-radius: 8px;
  padding: .6rem .9rem; transition: border-color .15s;
}
.entry:hover { border-color: var(--ink-faint); }
.entry-year {
  flex: none; width: 3.2em; font-variant-numeric: tabular-nums;
  color: var(--ink-faint); font-size: .8rem;
}
.entry-main { flex: 1; min-width: 0; font-size: .9rem; }
.entry-main i { color: var(--ink-soft); }
.entry-title { display: block; font-family: var(--serif); color: var(--ink-soft); font-size: .85rem; }
.entry-thesis {
  display: block; color: var(--ink-faint); font-size: .78rem; margin-top: .1rem;
  display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden;
}
.entry-counts { flex: none; display: flex; gap: .3em; }
.count {
  font-size: .68rem; font-variant-numeric: tabular-nums; color: var(--c);
  border: 1px solid color-mix(in srgb, var(--c) 45%, transparent);
  border-radius: 999px; padding: 0 .55em; line-height: 1.5;
}
.foot { margin-top: 3rem; border-top: 1px solid var(--line); padding-top: 1rem;
  font-size: .78rem; color: var(--ink-faint); }

@media (max-width: 560px) {
  .entry { flex-wrap: wrap; gap: .2rem .8rem; }
  .entry-counts { margin-left: auto; }
}
@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; scroll-behavior: auto !important; }
}
